.calendar-container{display:flex;flex-direction:column;height:100vh;background-color:#f8f9fa;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif}.calendar-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;background:#fff;border-bottom:1px solid #e5e7eb;box-shadow:0 1px 3px #0000000d}.header-left{display:flex;align-items:center;gap:1rem}.header-center{flex:1;max-width:400px;margin:0 2rem}.header-right{display:flex;align-items:center;gap:1rem}.navigation-controls{display:flex;gap:.25rem}.date-display{font-size:1.25rem;font-weight:600;color:#1f2937;margin:0}.search-form{position:relative;width:100%}.search-input{width:100%;padding:.5rem .75rem .5rem 2.5rem;border:1px solid #e5e7eb;border-radius:.5rem;font-size:.875rem;transition:all .2s}.search-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.search-icon{position:absolute;left:.75rem;top:50%;transform:translateY(-50%);color:#9ca3af}.view-switcher{display:flex;background:#f3f4f6;border-radius:.5rem;padding:.125rem}.view-btn{padding:.375rem .75rem;background:transparent;border:none;font-size:.875rem;font-weight:500;color:#6b7280;border-radius:.375rem;cursor:pointer;transition:all .2s}.view-btn:hover{color:#374151}.view-btn.active{background:#fff;color:#1f2937;box-shadow:0 1px 3px #0000001a}.header-actions{display:flex;gap:.5rem}.calendar-body{display:flex;flex:1;overflow:hidden}.calendar-sidebar{width:280px;background:#fff;border-right:1px solid #e5e7eb;display:flex;flex-direction:column;overflow-y:auto}.sidebar-header{display:flex;justify-content:space-between;align-items:center;padding:1rem;border-bottom:1px solid #e5e7eb}.sidebar-title{font-size:.875rem;font-weight:600;text-transform:uppercase;color:#6b7280;margin:0}.new-calendar-form{padding:1rem;border-bottom:1px solid #e5e7eb;background:#f9fafb}.calendar-list{flex:1;padding:.5rem}.calendar-item{padding:.75rem;border-radius:.5rem;margin-bottom:.25rem;transition:background-color .2s}.calendar-item:hover{background:#f3f4f6}.calendar-item.hidden{opacity:.5}.calendar-item-main{display:flex;align-items:center;gap:.5rem}.calendar-toggle{background:none;border:none;padding:.25rem;cursor:pointer;color:#6b7280}.calendar-color{width:16px;height:16px;border-radius:4px;flex-shrink:0}.calendar-name{flex:1;font-size:.875rem;font-weight:500;color:#1f2937;cursor:pointer}.badge-default{font-size:.625rem;background:#3b82f6;color:#fff;padding:.125rem .375rem;border-radius:.25rem;margin-left:.5rem}.calendar-actions{display:flex;gap:.25rem}.calendar-description{font-size:.75rem;color:#6b7280;margin:.5rem 0 0 1.75rem}.color-selector{margin:.75rem 0}.color-options{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:.5rem}.color-btn{width:24px;height:24px;border-radius:4px;border:2px solid transparent;cursor:pointer;transition:all .2s}.color-btn:hover{transform:scale(1.1)}.color-btn.selected{border-color:#1f2937}.color-btn.custom{background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;color:#fff}.color-picker-popover{position:absolute;z-index:1000;background:#fff;padding:1rem;border-radius:.5rem;box-shadow:0 10px 40px #00000026;margin-top:.5rem}.sidebar-footer{padding:1rem;border-top:1px solid #e5e7eb}.calendar-stats{display:flex;justify-content:space-around}.stat-item{display:flex;align-items:center;gap:.375rem;font-size:.75rem;color:#6b7280}.calendar-main{flex:1;overflow-y:auto;padding:1rem}.month-view{background:#fff;border-radius:.5rem;box-shadow:0 1px 3px #0000001a;height:100%;display:flex;flex-direction:column}.weekdays{display:grid;grid-template-columns:repeat(7,1fr);border-bottom:1px solid #e5e7eb}.weekday-header{padding:.75rem;text-align:center;font-size:.875rem;font-weight:600;color:#6b7280;text-transform:uppercase}.month-grid{flex:1}.week-row{display:grid;grid-template-columns:repeat(7,1fr);min-height:120px}.day-cell{border-right:1px solid #e5e7eb;border-bottom:1px solid #e5e7eb;padding:.5rem;cursor:pointer;transition:background-color .2s}.day-cell:hover{background:#f9fafb}.day-cell-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.day-number{font-size:.875rem;font-weight:500;color:#374151}.day-other-month .day-number{color:#d1d5db}.day-today{background:#eff6ff}.day-today .day-number{color:#3b82f6;font-weight:600}.today-badge{font-size:.625rem;background:#3b82f6;color:#fff;padding:.125rem .375rem;border-radius:.25rem}.day-drop-target{background:#dbeafe}.day-events{display:flex;flex-direction:column;gap:.25rem}.event-item{padding:.25rem .375rem;border-radius:.25rem;font-size:.75rem;cursor:pointer;transition:transform .2s}.event-item:hover{transform:translate(2px)}.event-time{font-weight:500;margin-right:.25rem}.event-title{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.show-more-btn{background:none;border:none;color:#3b82f6;font-size:.75rem;cursor:pointer;text-align:left;padding:.25rem 0}.week-view{background:#fff;border-radius:.5rem;box-shadow:0 1px 3px #0000001a;height:100%;display:flex;flex-direction:column}.week-header{display:grid;grid-template-columns:80px repeat(7,1fr);border-bottom:2px solid #e5e7eb}.time-gutter{background:#f9fafb;border-right:1px solid #e5e7eb}.week-header-day{text-align:center;padding:1rem .5rem;border-right:1px solid #e5e7eb;cursor:pointer}.week-header-day:hover{background:#f3f4f6}.week-header-day.today{background:#eff6ff}.day-name{font-size:.75rem;font-weight:600;color:#6b7280;text-transform:uppercase;margin-bottom:.25rem}.day-number{font-size:1.25rem;font-weight:500;color:#1f2937}.today-number{color:#3b82f6;font-weight:600}.week-grid{flex:1;display:flex;overflow-y:auto}.time-column{width:80px;flex-shrink:0;background:#f9fafb;border-right:1px solid #e5e7eb}.time-slot-label{height:60px;padding:.25rem .5rem;font-size:.75rem;color:#6b7280;border-bottom:1px solid #f3f4f6}.days-container{flex:1;display:grid;grid-template-columns:repeat(7,1fr)}.day-column{position:relative;border-right:1px solid #e5e7eb}.time-slots{position:absolute;inset:0}.time-slot{height:60px;border-bottom:1px solid #f3f4f6;cursor:pointer}.time-slot:hover{background:#3b82f60d}.day-events{position:absolute;inset:0;pointer-events:none}.week-event{position:absolute;left:4px;right:4px;padding:.25rem .5rem;border-radius:.25rem;cursor:pointer;pointer-events:all;overflow:hidden;font-size:.75rem;transition:transform .2s,box-shadow .2s}.week-event:hover{transform:scale(1.02);box-shadow:0 2px 8px #00000026;z-index:10}.all-day-events{position:sticky;top:0;background:#fff;border-bottom:1px solid #e5e7eb;padding:.25rem;z-index:5}.all-day-event{padding:.25rem .5rem;border-radius:.25rem;font-size:.75rem;margin-bottom:.125rem;cursor:pointer}.day-view{background:#fff;border-radius:.5rem;box-shadow:0 1px 3px #0000001a;height:100%;display:flex;flex-direction:column}.day-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:2px solid #e5e7eb;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.day-header-info{display:flex;align-items:center;gap:1rem}.day-date{font-size:1.5rem;font-weight:600;margin:0}.all-day-section{display:flex;border-bottom:1px solid #e5e7eb;background:#f9fafb}.all-day-label{width:80px;padding:1rem;font-size:.75rem;font-weight:600;color:#6b7280;text-transform:uppercase;border-right:1px solid #e5e7eb}.all-day-events-container{flex:1;padding:.5rem;display:flex;gap:.5rem;flex-wrap:wrap}.all-day-event-item{padding:.5rem 1rem;border-radius:.5rem;display:flex;align-items:center;gap:.5rem;cursor:pointer}.day-timeline{flex:1;display:flex;overflow-y:auto}.time-label{height:80px;padding:.5rem;font-size:.875rem;color:#6b7280;border-bottom:1px solid #f3f4f6}.events-column{flex:1;position:relative}.time-slot-line{position:absolute;top:0;left:0;right:0;height:1px;background:#f3f4f6}.timed-events{position:absolute;inset:0}.timed-event{position:absolute;left:8px;right:8px;padding:.75rem;border-radius:.5rem;cursor:pointer;overflow:hidden;transition:transform .2s,box-shadow .2s}.timed-event:hover{transform:scale(1.02);box-shadow:0 4px 12px #00000026;z-index:10}.event-content{display:flex;flex-direction:column;gap:.375rem}.event-header{display:flex;justify-content:space-between;align-items:center;font-size:.75rem;color:#6b7280}.event-calendar-name{display:flex;align-items:center;gap:.25rem}.event-location{display:flex;align-items:center;gap:.25rem;font-size:.875rem;color:#6b7280}.event-description{font-size:.875rem;color:#4b5563;line-height:1.4}.current-time-indicator{position:absolute;left:0;right:0;z-index:20;pointer-events:none}.time-indicator-ball{position:absolute;left:-6px;width:12px;height:12px;background:#ef4444;border-radius:50%;box-shadow:0 0 0 3px #ef444433}.time-indicator-line{height:2px;background:#ef4444}.day-summary{padding:1rem 1.5rem;background:#f9fafb;border-top:1px solid #e5e7eb}.summary-stats{display:flex;gap:2rem}.stat{display:flex;flex-direction:column}.stat-value{font-size:1.5rem;font-weight:600;color:#1f2937}.stat-label{font-size:.75rem;color:#6b7280;text-transform:uppercase}.year-view{background:#fff;border-radius:.5rem;box-shadow:0 1px 3px #0000001a;padding:1.5rem}.year-header{text-align:center;margin-bottom:2rem}.year-header h2{font-size:2rem;font-weight:600;color:#1f2937;margin:0}.year-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem}.mini-month{background:#f9fafb;border-radius:.5rem;padding:1rem}.mini-month-title{font-size:1rem;font-weight:600;color:#374151;margin:0 0 .75rem;text-align:center}.mini-month-header{display:grid;grid-template-columns:repeat(7,1fr);margin-bottom:.5rem}.mini-day-header{text-align:center;font-size:.625rem;font-weight:600;color:#9ca3af}.mini-month-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}.mini-day{aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;border-radius:.25rem;cursor:pointer;position:relative;transition:all .2s}.mini-day.empty{cursor:default}.mini-day-number{font-size:.75rem;color:#374151}.mini-day-count{position:absolute;bottom:2px;right:2px;font-size:.5rem;background:#3b82f6;color:#fff;padding:0 .125rem;border-radius:.125rem}.mini-day.intensity-0{background:#f3f4f6}.mini-day.intensity-1{background:#c7d2fe}.mini-day.intensity-2{background:#a5b4fc}.mini-day.intensity-3{background:#818cf8}.mini-day.intensity-4{background:#6366f1}.mini-day.today{box-shadow:0 0 0 2px #3b82f6}.mini-day.selected{box-shadow:0 0 0 2px #1f2937}.year-legend{display:flex;align-items:center;justify-content:center;gap:.5rem;margin-top:2rem;font-size:.75rem;color:#6b7280}.legend-boxes{display:flex;gap:.25rem}.legend-box{width:16px;height:16px;border-radius:.25rem}.agenda-view{background:#fff;border-radius:.5rem;box-shadow:0 1px 3px #0000001a}.agenda-header{padding:1rem 1.5rem;border-bottom:1px solid #e5e7eb}.agenda-filters{display:flex;gap:1rem}.filter-select{padding:.5rem .75rem;border:1px solid #e5e7eb;border-radius:.375rem;font-size:.875rem;background:#fff;cursor:pointer}.filter-select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.agenda-list{max-height:calc(100vh - 200px);overflow-y:auto}.agenda-day{border-bottom:1px solid #e5e7eb}.agenda-day.no-events{opacity:.6}.agenda-day.past-day{background:#f9fafb}.agenda-day-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;background:#f9fafb}.day-info{display:flex;align-items:center;gap:.75rem}.day-date{font-size:1.125rem;font-weight:600;color:#1f2937;margin:0}.event-count{font-size:.875rem;background:#e5e7eb;color:#4b5563;padding:.25rem .5rem;border-radius:.375rem}.agenda-events{padding:1rem 1.5rem}.agenda-event{padding:1rem;margin-bottom:.75rem;border-radius:.5rem;background:#f9fafb;cursor:pointer;transition:all .2s}.agenda-event:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.event-main{display:flex;flex-direction:column;gap:.5rem}.event-calendar-badge{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .5rem;border-radius:.375rem;font-size:.75rem;font-weight:500}.event-details{display:flex;flex-wrap:wrap;gap:1rem;font-size:.875rem;color:#6b7280}.event-details span{display:flex;align-items:center;gap:.25rem}.event-all-day{background:#10b981;color:#fff;padding:.125rem .5rem;border-radius:.25rem;font-size:.75rem;font-weight:500}.event-tags{display:flex;flex-wrap:wrap;gap:.375rem;margin-top:.5rem}.tag{font-size:.75rem;background:#e5e7eb;color:#4b5563;padding:.125rem .5rem;border-radius:.25rem}.no-events-message{padding:2rem;text-align:center;color:#9ca3af}.no-events-message p{margin:0 0 .5rem}.btn-primary{display:inline-flex;align-items:center;gap:.375rem;padding:.5rem 1rem;background:#3b82f6;color:#fff;border:none;border-radius:.375rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}.btn-primary:hover{background:#2563eb}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{display:inline-flex;align-items:center;gap:.375rem;padding:.5rem 1rem;background:#e5e7eb;color:#374151;border:none;border-radius:.375rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}.btn-secondary:hover{background:#d1d5db}.btn-danger{display:inline-flex;align-items:center;gap:.375rem;padding:.5rem 1rem;background:#ef4444;color:#fff;border:none;border-radius:.375rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}.btn-danger:hover{background:#dc2626}.btn-ghost{display:inline-flex;align-items:center;gap:.375rem;padding:.5rem 1rem;background:transparent;color:#6b7280;border:1px solid transparent;border-radius:.375rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}.btn-ghost:hover{background:#f3f4f6;border-color:#e5e7eb}.btn-link{background:none;border:none;color:#3b82f6;font-size:.875rem;cursor:pointer;text-decoration:underline}.btn-link:hover{color:#2563eb}.btn-icon{display:inline-flex;align-items:center;justify-content:center;padding:.5rem;background:transparent;border:1px solid #e5e7eb;border-radius:.375rem;cursor:pointer;transition:all .2s}.btn-icon:hover{background:#f3f4f6;border-color:#d1d5db}.btn-icon.btn-sm{padding:.375rem}.btn-icon.btn-xs{padding:.25rem;border:none}.btn-icon.btn-danger:hover{background:#fee2e2;color:#ef4444}.btn-sm{padding:.375rem .75rem;font-size:.75rem}.btn-today{gap:.375rem}.form-input{width:100%;padding:.5rem .75rem;border:1px solid #e5e7eb;border-radius:.375rem;font-size:.875rem;transition:all .2s}.form-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-input-lg{padding:.75rem 1rem;font-size:1rem}.form-input-sm{padding:.375rem .5rem;font-size:.75rem}.form-textarea{width:100%;padding:.5rem .75rem;border:1px solid #e5e7eb;border-radius:.375rem;font-size:.875rem;resize:vertical;transition:all .2s}.form-textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-select{width:100%;padding:.5rem .75rem;border:1px solid #e5e7eb;border-radius:.375rem;font-size:.875rem;background:#fff;cursor:pointer;transition:all .2s}.form-select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-select-sm{padding:.375rem .5rem;font-size:.75rem}.form-group{margin-bottom:1rem}.form-label{display:flex;align-items:center;gap:.375rem;font-size:.875rem;font-weight:500;color:#374151;margin-bottom:.5rem}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.form-actions{display:flex;justify-content:space-between;align-items:center;padding-top:1rem;border-top:1px solid #e5e7eb;margin-top:1.5rem}.actions-left{display:flex;align-items:center;gap:1rem}.actions-right{display:flex;gap:.5rem}.checkbox-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.875rem}.checkbox-label input[type=checkbox]{width:1rem;height:1rem;cursor:pointer}.datetime-inputs{display:flex;gap:.5rem}.recurrence-options{display:flex;align-items:center;gap:.5rem}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:9999}.modal-content{background:#fff;border-radius:.75rem;max-width:90vw;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.event-modal{width:600px}.day-page-modal{width:800px;height:80vh}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #e5e7eb}.modal-title{font-size:1.25rem;font-weight:600;color:#1f2937;margin:0}.modal-title-group{display:flex;align-items:center;gap:1rem}.unsaved-indicator{display:flex;align-items:center;gap:.25rem;font-size:.75rem;color:#f59e0b;background:#fef3c7;padding:.25rem .5rem;border-radius:.375rem}.modal-footer{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-top:1px solid #e5e7eb;background:#f9fafb}.footer-info{font-size:.75rem;color:#6b7280}.footer-actions{display:flex;gap:.5rem}.event-form{padding:1.5rem;overflow-y:auto;max-height:calc(90vh - 140px)}.tags-input-container{display:flex;flex-wrap:wrap;gap:.5rem;padding:.5rem;border:1px solid #e5e7eb;border-radius:.375rem;min-height:42px}.tag-chip{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .5rem;background:#e5e7eb;color:#374151;border-radius:.25rem;font-size:.875rem}.tag-remove{background:none;border:none;color:#6b7280;cursor:pointer;padding:0;margin-left:.25rem;font-size:1rem;line-height:1}.tag-remove:hover{color:#ef4444}.tag-input{flex:1;min-width:120px;border:none;outline:none;font-size:.875rem}.day-page-metadata{padding:1rem 1.5rem;background:#f9fafb;border-bottom:1px solid #e5e7eb}.metadata-row{display:flex;gap:1rem;margin-bottom:1rem}.mood-selector,.weather-selector{flex:1;display:flex;align-items:center;gap:.5rem}.metadata-label{display:flex;align-items:center;gap:.25rem;font-size:.875rem;font-weight:500;color:#374151}.metadata-select{flex:1;padding:.375rem .5rem;border:1px solid #e5e7eb;border-radius:.375rem;font-size:.875rem;background:#fff}.tags-section{display:flex;align-items:center;gap:.5rem}.tags-container{flex:1;display:flex;flex-wrap:wrap;gap:.5rem;padding:.5rem;border:1px solid #e5e7eb;border-radius:.375rem;background:#fff;min-height:36px}.editor-toolbar{display:flex;align-items:center;gap:.25rem;padding:.75rem 1.5rem;border-bottom:1px solid #e5e7eb;background:#f9fafb}.toolbar-btn{padding:.375rem .5rem;background:#fff;border:1px solid #e5e7eb;border-radius:.25rem;font-size:.875rem;cursor:pointer;transition:all .2s;min-width:32px}.toolbar-btn:hover{background:#f3f4f6;border-color:#d1d5db}.toolbar-btn:disabled{opacity:.5;cursor:not-allowed}.toolbar-btn.active{background:#3b82f6;color:#fff;border-color:#3b82f6}.toolbar-separator{width:1px;height:24px;background:#e5e7eb;margin:0 .25rem}.editor-container{flex:1;overflow-y:auto;padding:1.5rem;background:#fff}.calendar-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;gap:1rem}.spinner{width:48px;height:48px;border:4px solid #e5e7eb;border-top-color:#3b82f6;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.calendar-error{display:flex;align-items:center;justify-content:center;height:100vh;background:#fee2e2;color:#dc2626;font-size:1.125rem}@media(max-width:1024px){.calendar-sidebar{width:240px}.year-grid{grid-template-columns:repeat(3,1fr)}}@media(max-width:768px){.calendar-header{flex-direction:column;gap:1rem}.header-left,.header-center,.header-right{width:100%}.calendar-sidebar{position:absolute;left:-280px;z-index:100;transition:left .3s}.calendar-sidebar.open{left:0}.week-grid{font-size:.75rem}.year-grid{grid-template-columns:repeat(2,1fr)}.modal-content{width:95vw;margin:1rem}}@media(max-width:640px){.view-switcher{flex-wrap:wrap}.week-row{min-height:80px}.year-grid,.form-row{grid-template-columns:1fr}}:root{--color-primary: #3B82F6;--color-primary-light: #60A5FA;--color-primary-dark: #2563EB;--color-secondary: #8B5CF6;--color-accent: #14B8A6;--color-success: #10B981;--color-warning: #F59E0B;--color-error: #EF4444;--color-info: #06B6D4;--color-background: #FFFFFF;--color-background-alt: #F9FAFB;--color-surface: #FFFFFF;--color-surface-alt: #F3F4F6;--color-text: #111827;--color-text-secondary: #6B7280;--color-text-disabled: #9CA3AF;--color-border: #E5E7EB;--color-border-light: #F3F4F6;--color-border-dark: #D1D5DB;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--radius-sm: .125rem;--radius-md: .375rem;--radius-lg: .5rem;--radius-xl: .75rem;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1);--transition-fast: .15s ease-in-out;--transition-normal: .25s ease-in-out}*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font-family, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif);background-color:var(--color-background);color:var(--color-text);line-height:1.6;transition:background-color var(--transition-normal),color var(--transition-normal)}button{cursor:pointer;border:none;padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);font-size:.875rem;font-weight:500;transition:all var(--transition-fast);display:inline-flex;align-items:center;gap:var(--spacing-xs)}button:disabled{opacity:.5;cursor:not-allowed}button.primary{background-color:var(--color-primary);color:#fff}button.primary:hover:not(:disabled){background-color:var(--color-primary-dark)}button.secondary{background-color:var(--color-surface-alt);color:var(--color-text);border:1px solid var(--color-border)}button.secondary:hover:not(:disabled){background-color:var(--color-background-alt)}button.danger{background-color:var(--color-error);color:#fff}button.danger:hover:not(:disabled){opacity:.9}button.icon-button{background:transparent;padding:var(--spacing-xs);border-radius:var(--radius-sm)}button.icon-button:hover{background-color:var(--color-surface-alt)}button.text-button{background:transparent;color:var(--color-primary);padding:0}button.text-button:hover{text-decoration:underline}input[type=text],input[type=password],input[type=email],input[type=number],textarea,select{width:100%;padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-surface);color:var(--color-text);font-size:.875rem;transition:border-color var(--transition-fast)}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #3b82f61a}.api-configuration-panel{max-width:1200px;margin:0 auto;padding:var(--spacing-xl)}.api-configuration-panel .header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-xl)}.api-configuration-panel .header h2{font-size:1.5rem;font-weight:600}.api-configuration-panel .header-actions{display:flex;gap:var(--spacing-sm)}.api-configuration-panel.locked{display:flex;align-items:center;justify-content:center;min-height:100vh}.lock-screen{background-color:var(--color-surface);padding:var(--spacing-xl);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);text-align:center;max-width:400px;width:100%}.lock-screen svg{color:var(--color-primary);margin-bottom:var(--spacing-md)}.lock-screen h2{margin-bottom:var(--spacing-sm)}.lock-screen p{color:var(--color-text-secondary);margin-bottom:var(--spacing-lg)}.password-input-group{display:flex;gap:var(--spacing-sm)}.error-message,.success-message{padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);margin-bottom:var(--spacing-md);display:flex;align-items:center;gap:var(--spacing-sm)}.error-message{background-color:#ef44441a;color:var(--color-error);border:1px solid rgba(239,68,68,.2)}.success-message{background-color:#10b9811a;color:var(--color-success);border:1px solid rgba(16,185,129,.2)}.api-configuration-panel .content{display:grid;grid-template-columns:250px 1fr;gap:var(--spacing-xl)}.sidebar{background-color:var(--color-surface);border-radius:var(--radius-lg);padding:var(--spacing-md);height:fit-content}.sidebar h3{font-size:.875rem;font-weight:600;color:var(--color-text-secondary);margin-bottom:var(--spacing-md);text-transform:uppercase;letter-spacing:.05em}.category-group{margin-bottom:var(--spacing-lg)}.category-group h4{font-size:.75rem;font-weight:600;color:var(--color-text-secondary);margin-bottom:var(--spacing-sm);text-transform:uppercase}.provider-button{width:100%;display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-sm) var(--spacing-md);background-color:transparent;border:none;border-left:3px solid transparent;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);text-align:left}.provider-button:hover{background-color:var(--color-surface-alt)}.provider-button.selected{background-color:var(--color-primary);color:#fff}.provider-button .configured-indicator{color:var(--color-success)}.provider-button.selected .configured-indicator{color:#fff}.main-content{background-color:var(--color-surface);border-radius:var(--radius-lg);padding:var(--spacing-xl)}.empty-state{text-align:center;padding:var(--spacing-xl) 0}.empty-state svg{color:var(--color-text-disabled);margin-bottom:var(--spacing-md)}.empty-state h3{margin-bottom:var(--spacing-sm)}.empty-state p{color:var(--color-text-secondary)}.provider-configuration h3{margin-bottom:var(--spacing-lg)}.free-tier-info{background-color:var(--color-info);background-color:#06b6d41a;color:var(--color-info);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);margin-bottom:var(--spacing-lg);display:flex;align-items:center;gap:var(--spacing-sm)}.existing-credentials{margin-bottom:var(--spacing-xl)}.existing-credentials h4{margin-bottom:var(--spacing-md)}.credential-item{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md);background-color:var(--color-surface-alt);border-radius:var(--radius-md);margin-bottom:var(--spacing-sm)}.credential-info{display:flex;align-items:center;gap:var(--spacing-sm)}.default-badge{background-color:var(--color-primary);color:#fff;padding:2px 8px;border-radius:var(--radius-sm);font-size:.75rem;font-weight:500}.credential-actions{display:flex;align-items:center;gap:var(--spacing-sm)}.success-icon{color:var(--color-success)}.error-icon{color:var(--color-error)}.new-credential-form h4,.form-group{margin-bottom:var(--spacing-md)}.form-group label{display:block;margin-bottom:var(--spacing-xs);font-size:.875rem;font-weight:500}.form-actions{display:flex;gap:var(--spacing-md);margin-top:var(--spacing-lg)}.documentation-link,.setup-link{color:var(--color-primary);text-decoration:none;font-size:.875rem;display:inline-flex;align-items:center}.documentation-link:hover,.setup-link:hover{text-decoration:underline}.theme-settings{max-width:1200px;margin:0 auto;padding:var(--spacing-xl)}.themes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--spacing-lg)}.theme-card{background-color:var(--color-surface);border:2px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-md);transition:all var(--transition-fast)}.theme-card:hover{box-shadow:var(--shadow-md)}.theme-card.active{border-color:var(--color-primary)}.theme-preview{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--spacing-xs);margin-bottom:var(--spacing-md)}.color-sample{height:40px;border-radius:var(--radius-sm)}.theme-info h3{font-size:1rem;margin-bottom:var(--spacing-xs)}.theme-info p{font-size:.875rem;color:var(--color-text-secondary);margin-bottom:var(--spacing-md)}.theme-actions{display:flex;gap:var(--spacing-sm);align-items:center}.active-indicator{color:var(--color-success)}.theme-editor-modal{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.theme-editor{background-color:var(--color-surface);border-radius:var(--radius-xl);max-width:800px;width:90%;max-height:90vh;overflow:hidden;display:flex;flex-direction:column}.editor-header{padding:var(--spacing-lg);border-bottom:1px solid var(--color-border);display:flex;justify-content:space-between;align-items:center}.close-button{background:transparent;border:none;font-size:1.5rem;color:var(--color-text-secondary);cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm)}.close-button:hover{background-color:var(--color-surface-alt)}.editor-content{padding:var(--spacing-lg);overflow-y:auto;flex:1}.color-section{margin-bottom:var(--spacing-xl)}.color-section h4{margin-bottom:var(--spacing-md)}.color-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--spacing-md)}.color-picker-group{display:flex;flex-direction:column;gap:var(--spacing-xs)}.color-input-wrapper{display:flex;gap:var(--spacing-xs)}.color-input-wrapper input[type=color]{width:40px;height:38px;border:1px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer}.color-input-wrapper input[type=text]{flex:1}.typography-section{margin-bottom:var(--spacing-xl)}.editor-actions{display:flex;gap:var(--spacing-md);justify-content:flex-end}.setup-wizard{max-width:900px;margin:0 auto;padding:var(--spacing-xl)}.wizard-header{text-align:center;margin-bottom:var(--spacing-xl)}.wizard-header svg{color:var(--color-primary);margin-bottom:var(--spacing-md)}.wizard-header h2{margin-bottom:var(--spacing-sm)}.wizard-header p{color:var(--color-text-secondary)}.progress-bar{height:4px;background-color:var(--color-surface-alt);border-radius:var(--radius-full);margin-bottom:var(--spacing-xl);overflow:hidden}.progress-fill{height:100%;background-color:var(--color-primary);transition:width var(--transition-normal)}.step-indicators{display:flex;justify-content:space-between;margin-bottom:var(--spacing-xl)}.step-indicator{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-xs);color:var(--color-text-disabled);font-size:.75rem}.step-indicator.active{color:var(--color-primary);font-weight:600}.step-indicator.completed{color:var(--color-success)}.wizard-content{background-color:var(--color-surface);border-radius:var(--radius-xl);padding:var(--spacing-xl)}.step-content h3{margin-bottom:var(--spacing-sm)}.step-content p{color:var(--color-text-secondary);margin-bottom:var(--spacing-lg)}.provider-selection{display:flex;flex-direction:column;gap:var(--spacing-md)}.provider-option{border:2px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-md);cursor:pointer;transition:all var(--transition-fast)}.provider-option:hover{border-color:var(--color-primary)}.provider-option.selected{border-color:var(--color-primary);background-color:#3b82f60d}.provider-option.recommended{position:relative}.provider-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-sm)}.recommended-badge{background-color:var(--color-success);color:#fff;padding:2px 8px;border-radius:var(--radius-sm);font-size:.75rem;font-weight:500}.provider-config{margin-top:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid var(--color-border)}.form-field{margin-bottom:var(--spacing-md)}.form-field label{display:block;margin-bottom:var(--spacing-xs);font-size:.875rem;font-weight:500}.provider-actions{display:flex;justify-content:space-between;margin-top:var(--spacing-md)}.help-link{color:var(--color-primary);text-decoration:none;display:flex;align-items:center;gap:var(--spacing-xs);font-size:.875rem}.help-link:hover{text-decoration:underline}.test-button{background-color:var(--color-surface-alt);border:1px solid var(--color-border)}.test-button:hover:not(:disabled){background-color:var(--color-background-alt)}.spinner{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.skip-option{text-align:center;margin-top:var(--spacing-md)}.wizard-navigation{display:flex;justify-content:space-between;margin-top:var(--spacing-xl)}.setup-wizard.locked{display:flex;align-items:center;justify-content:center;min-height:100vh}.unlock-prompt{background-color:var(--color-surface);padding:var(--spacing-xl);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);max-width:400px;width:100%;text-align:center}.setup-wizard.complete{display:flex;align-items:center;justify-content:center;min-height:100vh}.success-message{background-color:var(--color-surface);padding:var(--spacing-xl);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);text-align:center;max-width:500px;width:100%}.success-message svg{color:var(--color-success);margin-bottom:var(--spacing-md)}.configured-summary{text-align:left;margin:var(--spacing-xl) 0}.configured-summary h3{margin-bottom:var(--spacing-md)}.configured-summary ul{list-style:none;padding:0}.configured-summary li{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) 0}.configured-summary .tested{background-color:var(--color-success);color:#fff;padding:2px 8px;border-radius:var(--radius-sm);font-size:.75rem;margin-left:auto}.app{min-height:100vh;background-color:var(--color-background)}.app-nav{background-color:var(--color-surface);border-bottom:1px solid var(--color-border);padding:var(--spacing-md) var(--spacing-xl);display:flex;justify-content:space-between;align-items:center}.nav-brand{display:flex;align-items:center;gap:var(--spacing-md)}.nav-brand h1{font-size:1.25rem;font-weight:600}.nav-tabs{display:flex;gap:var(--spacing-xs)}.nav-tab{background:transparent;border:none;padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);display:flex;align-items:center;gap:var(--spacing-xs);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast)}.nav-tab:hover{background-color:var(--color-surface-alt);color:var(--color-text)}.nav-tab.active{background-color:var(--color-primary);color:#fff}.app-content{padding:var(--spacing-xl)}.home-content{max-width:1200px;margin:0 auto}.home-content h2{font-size:2rem;font-weight:600;margin-bottom:var(--spacing-xl)}.feature-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--spacing-lg);margin-bottom:var(--spacing-xl)}.feature-card{background-color:var(--color-surface);padding:var(--spacing-lg);border-radius:var(--radius-lg);border:1px solid var(--color-border);transition:all var(--transition-fast)}.feature-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.feature-card h3{font-size:1.125rem;margin-bottom:var(--spacing-sm)}.feature-card p{color:var(--color-text-secondary);line-height:1.6}.quick-stats{background-color:var(--color-surface);padding:var(--spacing-xl);border-radius:var(--radius-lg);margin-bottom:var(--spacing-xl)}.quick-stats h3{margin-bottom:var(--spacing-lg)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-md)}.stat-card{background-color:var(--color-surface-alt);padding:var(--spacing-md);border-radius:var(--radius-md);display:flex;flex-direction:column;align-items:center;text-align:center}.stat-label{font-size:.875rem;color:var(--color-text-secondary);margin-bottom:var(--spacing-xs)}.stat-value{font-size:1.25rem;font-weight:600}.welcome-banner{background:linear-gradient(135deg,var(--color-primary),var(--color-primary-dark));color:#fff;padding:var(--spacing-xl);border-radius:var(--radius-lg);text-align:center}.welcome-banner h3{font-size:1.5rem;margin-bottom:var(--spacing-md)}.welcome-banner p{margin-bottom:var(--spacing-lg);opacity:.95}.welcome-banner button{background-color:#fff;color:var(--color-primary);font-weight:600;padding:var(--spacing-sm) var(--spacing-lg)}.welcome-banner button:hover{background-color:var(--color-surface-alt)}@media(max-width:768px){.app-nav{flex-direction:column;gap:var(--spacing-md)}.nav-tabs{width:100%;justify-content:space-around}.nav-tab span{display:none}.feature-grid,.api-configuration-panel .content{grid-template-columns:1fr}.sidebar{display:none}.themes-grid{grid-template-columns:1fr}}.loading{display:flex;align-items:center;justify-content:center;min-height:200px}.loading-spinner{border:3px solid var(--color-surface-alt);border-top-color:var(--color-primary);border-radius:50%;width:40px;height:40px;animation:spin 1s linear infinite}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.mt-1{margin-top:var(--spacing-xs)}.mt-2{margin-top:var(--spacing-sm)}.mt-3{margin-top:var(--spacing-md)}.mt-4{margin-top:var(--spacing-lg)}.mt-5{margin-top:var(--spacing-xl)}.mb-1{margin-bottom:var(--spacing-xs)}.mb-2{margin-bottom:var(--spacing-sm)}.mb-3{margin-bottom:var(--spacing-md)}.mb-4{margin-bottom:var(--spacing-lg)}.mb-5{margin-bottom:var(--spacing-xl)}.p-1{padding:var(--spacing-xs)}.p-2{padding:var(--spacing-sm)}.p-3{padding:var(--spacing-md)}.p-4{padding:var(--spacing-lg)}.p-5{padding:var(--spacing-xl)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:var(--spacing-xs)}.gap-2{gap:var(--spacing-sm)}.gap-3{gap:var(--spacing-md)}.gap-4{gap:var(--spacing-lg)}.gap-5{gap:var(--spacing-xl)}
