.header{height:70px;padding:0 var(--spacing-lg);box-shadow:var(--shadow-card);z-index:99;background:#fff;justify-content:space-between;align-items:center;display:flex;position:fixed;top:0;left:240px;right:0}.header-left{align-items:center;display:flex}.logo{align-items:center;gap:var(--spacing-xs);display:flex}.logo-img{border-radius:8px;width:32px;height:32px}.header-center{max-width:500px;margin:0 var(--spacing-lg);flex:1}.search-trigger{align-items:center;gap:var(--spacing-sm);background:var(--secondary);border-radius:var(--radius-sm);width:100%;color:var(--text-secondary);cursor:pointer;transition:all var(--transition);border:none;padding:10px 16px;font-size:14px;display:flex}.search-trigger:hover{background:#f5e6d3}.search-icon{width:18px;height:18px}.search-trigger span{text-align:left;flex:1}.search-trigger kbd{background:#fff;border:1px solid #dfe6e9;border-radius:4px;padding:2px 8px;font-size:12px}.header-right{align-items:center;display:flex}.user-menu{position:relative}.user-btn{align-items:center;gap:var(--spacing-xs);cursor:pointer;border-radius:var(--radius-sm);transition:all var(--transition);background:0 0;border:none;padding:6px 12px;display:flex}.user-btn:hover{background:var(--secondary)}.user-avatar{background:var(--primary);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;font-size:16px;font-weight:700;display:flex}.user-name{color:var(--text-primary);font-weight:600}.user-dropdown{border-radius:var(--radius-sm);box-shadow:var(--shadow-card);background:#fff;min-width:180px;margin-top:8px;position:absolute;top:100%;right:0;overflow:hidden}.dropdown-item{align-items:center;gap:var(--spacing-xs);color:var(--text-primary);transition:all var(--transition);padding:12px 16px;font-size:14px;text-decoration:none;display:flex}.dropdown-item:hover{background:var(--secondary)}.dropdown-item.active{background:var(--secondary);color:var(--primary)}.dropdown-divider{background:#e8e8e8;height:1px;margin:4px 0}.logout-btn{align-items:center;gap:var(--spacing-xs);width:100%;color:var(--error);cursor:pointer;transition:all var(--transition);background:0 0;border:none;padding:12px 16px;font-size:14px;display:flex}.logout-btn:hover{background:#fdedec}.mobile-search-btn{cursor:pointer;color:var(--text-primary);transition:all var(--transition);background:0 0;border:none;justify-content:center;align-items:center;padding:8px;display:none}.mobile-search-btn:hover{color:var(--primary)}.refresh-btn{cursor:pointer;color:var(--text-primary);transition:all var(--transition);background:0 0;border:none;justify-content:center;align-items:center;padding:8px;display:flex}.refresh-btn:hover{color:var(--primary)}@media (width<=768px){.header{padding:0 var(--spacing-sm);left:0}.header-center{display:none}.mobile-search-btn,.refresh-btn{display:flex}.logo-text,.user-name{display:none}}.sidebar{width:240px;height:100vh;box-shadow:var(--shadow-card);padding:var(--spacing-md) 0;z-index:100;background:#fff;position:fixed;top:0;left:0}.sidebar-nav{gap:var(--spacing-xs);padding:0 var(--spacing-sm);flex-direction:column;display:flex}.nav-item{align-items:center;gap:var(--spacing-sm);border-radius:var(--radius-sm);color:var(--text-secondary);transition:all var(--transition);cursor:pointer;background:0 0;border:none;width:100%;padding:12px 16px;font-size:16px;text-decoration:none;display:flex}.nav-item:hover{background:var(--secondary);color:var(--primary)}.nav-item.active{background:var(--secondary);color:var(--primary);border-left:3px solid var(--accent);margin-left:-3px}.nav-icon{flex-shrink:0;width:20px;height:20px}.nav-label{font-weight:600}.search-btn{margin-top:var(--spacing-sm);padding-top:var(--spacing-sm);border-top:1px solid #dfe6e9}@media (width<=768px){.sidebar{width:100%;height:auto;padding:var(--spacing-xs) 0;box-shadow:0 -4px 20px var(--card-shadow);position:fixed;top:auto;bottom:0}.sidebar-nav{flex-direction:row;justify-content:space-around;gap:0;padding:0}.nav-label{display:none}.nav-item{flex-direction:column;gap:4px;padding:8px 12px;font-size:12px}.search-btn{border-top:none;margin-top:0;padding-top:8px}}.search-overlay{z-index:1000;background:#2d343680;justify-content:center;align-items:flex-start;padding-top:100px;animation:.15s ease-out fadeIn;display:flex;position:fixed;inset:0}.search-modal{border-radius:var(--radius-md);background:#fff;flex-direction:column;width:100%;max-width:600px;max-height:70vh;display:flex;overflow:hidden;box-shadow:0 20px 60px #0003}.search-header{align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);border-bottom:1px solid #dfe6e9;display:flex}.search-header .search-icon{color:var(--primary);flex-shrink:0;width:20px;height:20px}.search-input{background:0 0;border:none;outline:none;flex:1;padding:8px 0;font-size:16px}.search-input:focus{box-shadow:none}.close-btn{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:4px;display:flex}.close-btn:hover{background:var(--secondary);color:var(--text-primary)}.search-content{padding:var(--spacing-sm);overflow-y:auto}.ai-response{border-radius:var(--radius-sm);padding:var(--spacing-md);margin-bottom:var(--spacing-sm);background:linear-gradient(135deg,#e8f8f5 0%,#fdf6ec 100%)}.ai-header{align-items:center;gap:var(--spacing-xs);color:var(--primary);margin-bottom:var(--spacing-xs);font-size:14px;font-weight:600;display:flex}.ai-icon{width:18px;height:18px}.ai-response h4{color:var(--primary-dark);margin-bottom:var(--spacing-sm)}.side-effects-list{gap:var(--spacing-xs);margin-bottom:var(--spacing-sm);flex-wrap:wrap;list-style:none;display:flex}.side-effects-list li{color:var(--text-primary);border:1px solid var(--primary);background:#fff;border-radius:20px;padding:6px 12px;font-size:14px}.ai-disclaimer{color:var(--text-secondary);font-size:12px;font-style:italic}.search-results{gap:var(--spacing-sm);flex-direction:column;display:flex}.result-section h4{align-items:center;gap:var(--spacing-xs);color:var(--primary);margin-bottom:var(--spacing-xs);font-size:14px;font-weight:600;display:flex}.result-section ul{list-style:none}.result-section li{border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition);flex-direction:column;gap:2px;padding:10px 12px;display:flex}.result-section li:hover{background:var(--secondary)}.result-title{color:var(--text-primary);font-weight:600}.result-meta{color:var(--text-secondary);font-size:13px}.no-results{text-align:center;color:var(--text-secondary);padding:var(--spacing-md)}.quick-questions{padding:var(--spacing-sm)}.quick-title{color:var(--text-secondary);text-transform:uppercase;margin-bottom:var(--spacing-sm);font-size:12px;font-weight:600}.quick-btn{text-align:left;border-radius:var(--radius-sm);width:100%;color:var(--text-primary);cursor:pointer;transition:all var(--transition);background:0 0;border:none;padding:10px 12px;font-size:14px;display:block}.quick-btn:hover{background:var(--secondary);color:var(--primary)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.layout{min-height:100vh}.main-content{padding:var(--spacing-lg);width:calc(100% - 240px);min-height:calc(100vh - 70px);margin-top:70px;margin-left:240px;display:block}@media (width<=768px){.main-content{width:100%;padding:var(--spacing-sm);margin-top:70px;margin-left:0;padding-bottom:80px}}.login-page{min-height:100vh;padding:var(--spacing-md);justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.login-background{z-index:0;position:absolute;inset:0;overflow:hidden}.bg-shape{opacity:.08;border-radius:50%;position:absolute}.bg-shape-1{background:var(--primary);width:600px;height:600px;animation:20s ease-in-out infinite float;top:-200px;right:-100px}.bg-shape-2{background:var(--accent);width:400px;height:400px;animation:25s ease-in-out infinite reverse float;bottom:-150px;left:-100px}.bg-shape-3{background:var(--primary);width:300px;height:300px;animation:15s ease-in-out infinite pulse;top:50%;left:50%;transform:translate(-50%,-50%)}@keyframes float{0%,to{transform:translate(0)rotate(0)}25%{transform:translate(20px,-20px)rotate(5deg)}50%{transform:translateY(-30px)rotate(0)}75%{transform:translate(-20px,-20px)rotate(-5deg)}}@keyframes pulse{0%,to{transform:translate(-50%,-50%)scale(1)}50%{transform:translate(-50%,-50%)scale(1.1)}}.login-card{border-radius:var(--radius-md);box-shadow:var(--shadow-card);padding:var(--spacing-xl);z-index:1;background:#fff;width:100%;max-width:420px;position:relative}.login-header{text-align:center;margin-bottom:var(--spacing-lg)}.logo{justify-content:center;align-items:center;gap:var(--spacing-xs);margin-bottom:var(--spacing-sm);display:flex}.logo-icon{width:40px;height:40px;color:var(--primary)}.logo-text{font-family:var(--font-heading);color:var(--primary-dark);font-size:32px;font-weight:700}.tagline{color:var(--text-secondary);font-size:16px}.login-form{gap:var(--spacing-sm);flex-direction:column;display:flex}.form-group input{width:100%}.error-message{color:var(--error);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);text-align:center;background:#fdedec;font-size:14px}.login-btn{width:100%;margin-top:var(--spacing-sm);padding:14px}.btn-link{color:var(--primary);cursor:pointer;padding:var(--spacing-xs);width:100%;margin-top:var(--spacing-xs);background:0 0;border:none;font-size:14px;text-decoration:underline}.btn-link:hover{color:var(--primary-dark)}.demo-hint{margin-top:var(--spacing-md);padding-top:var(--spacing-md);text-align:center;color:var(--text-secondary);border-top:1px solid #dfe6e9;font-size:14px}.demo-hint p{margin:2px 0}@media (width<=480px){.login-card{padding:var(--spacing-md)}.logo-text{font-size:28px}}.dashboard{max-width:1000px;margin:0 auto}.dashboard-header{margin-bottom:var(--spacing-lg)}.dashboard-header h1{color:var(--primary-dark);margin-bottom:var(--spacing-xs)}.dashboard-header p{color:var(--text-secondary)}.stats-grid{gap:var(--spacing-md);margin-bottom:var(--spacing-lg);grid-template-columns:repeat(4,1fr);display:grid}.stat-card{border-radius:var(--radius-md);box-shadow:var(--shadow-card);padding:var(--spacing-md);align-items:center;gap:var(--spacing-sm);cursor:pointer;transition:all var(--transition);background:#fff;display:flex;position:relative}.stat-card:hover{box-shadow:var(--shadow-hover);transform:translateY(-2px)}.stat-icon{border-radius:var(--radius-sm);flex-shrink:0;justify-content:center;align-items:center;width:50px;height:50px;display:flex}.stat-content{flex-direction:column;flex:1;display:flex}.stat-value{color:var(--text-primary);font-size:28px;font-weight:700;line-height:1}.stat-value.positive{color:#4caf50}.stat-value.negative{color:#e53935}.stat-label{color:var(--text-secondary);font-size:14px}.stat-arrow{color:var(--text-secondary);width:20px;height:20px}.dashboard-grid{gap:var(--spacing-md);margin-bottom:var(--spacing-lg);grid-template-columns:repeat(3,1fr);display:grid}.dashboard-card{border-radius:var(--radius-md);box-shadow:var(--shadow-card);padding:var(--spacing-md);background:#fff}.card-header{align-items:center;gap:var(--spacing-xs);margin-bottom:var(--spacing-sm);padding-bottom:var(--spacing-sm);border-bottom:1px solid #dfe6e9;display:flex}.card-icon{color:var(--primary);width:20px;height:20px}.card-header h3{color:var(--text-primary);font-size:16px;font-weight:600}.next-medication .med-info h4{color:var(--primary-dark);margin-bottom:4px;font-size:18px}.next-medication .med-info p{color:var(--text-secondary);margin-bottom:8px;font-size:14px}.med-instructions{color:var(--text-secondary);font-size:13px;font-style:italic;display:block}.events-list,.messages-list{gap:var(--spacing-xs);flex-direction:column;list-style:none;display:flex}.events-list li{align-items:center;gap:var(--spacing-sm);border-radius:var(--radius-sm);transition:background var(--transition);padding:8px;display:flex}.events-list li:hover{background:var(--secondary)}.event-date{background:var(--secondary);color:var(--primary);border-radius:4px;padding:4px 8px;font-size:12px;font-weight:600}.event-title{color:var(--text-primary);flex:1;font-size:14px;font-weight:600}.event-time{color:var(--text-secondary);font-size:13px}.messages-list li{border-radius:var(--radius-sm);transition:background var(--transition);padding:8px}.messages-list li:hover{background:var(--secondary)}.msg-header{justify-content:space-between;align-items:center;margin-bottom:4px;display:flex}.msg-sender{color:var(--text-primary);font-size:14px;font-weight:600}.msg-content{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;font-size:13px;overflow:hidden}.empty-state{color:var(--text-secondary);text-align:center;padding:var(--spacing-md);font-size:14px}.allergies-summary{background:#fef3c7;border:2px solid #f59e0b}.allergies-summary .card-header{flex-wrap:wrap}.allergy-count-badge{color:#fff;background:#f59e0b;border-radius:12px;margin-left:auto;padding:2px 10px;font-size:14px;font-weight:600}.allergies-list{margin:var(--spacing-sm) 0;padding:0;list-style:none}.allergies-list li{border-bottom:1px solid #f59e0b4d;flex-direction:column;gap:2px;padding:6px 0;display:flex}.allergies-list li:last-child{border-bottom:none}.allergies-list .allergy-name{color:#92400e;font-size:14px;font-weight:600}.allergies-list .allergy-note{color:var(--text-secondary);font-size:12px;font-style:italic}.allergies-list .more-allergies{color:#f59e0b;font-size:13px;font-weight:600}.edit-link{color:var(--primary);cursor:pointer;margin-top:var(--spacing-xs);background:0 0;border:none;padding:0;font-size:13px;font-weight:600}.edit-link:hover{color:var(--primary-dark);text-decoration:underline}.quick-actions{gap:var(--spacing-sm);display:flex}@media (width<=900px){.stats-grid,.dashboard-grid{grid-template-columns:1fr}}.medications-page{max-width:1000px;margin:0 auto}.filters{gap:var(--spacing-sm);margin-bottom:var(--spacing-lg);flex-wrap:wrap;display:flex}.search-box{flex:1;align-items:center;min-width:250px;display:flex;position:relative}.search-box .search-icon{color:var(--text-secondary);position:absolute;left:12px}.search-box input{width:100%;padding-left:40px}.filter-buttons{gap:var(--spacing-xs);display:flex}.filter-btn{border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition);background:#fff;border:2px solid #dfe6e9;padding:8px 16px;font-weight:600}.filter-btn:hover{border-color:var(--primary);color:var(--primary)}.filter-btn.active{background:var(--primary);border-color:var(--primary);color:#fff}.medications-list{gap:var(--spacing-xs);flex-direction:column;display:flex}.med-item{border-radius:var(--radius-sm);box-shadow:var(--shadow-card);padding:var(--spacing-sm) var(--spacing-md);align-items:center;gap:var(--spacing-md);transition:all var(--transition);background:#fff;display:flex}.med-item:hover{box-shadow:var(--shadow-hover)}.med-item.inactive{opacity:.6}.med-item .med-icon{background:var(--secondary);border-radius:var(--radius-sm);width:40px;height:40px;color:var(--primary);flex-shrink:0;justify-content:center;align-items:center;display:flex}.med-info{flex:1;min-width:0}.med-name-row{align-items:center;gap:var(--spacing-sm);flex-wrap:wrap;display:flex}.med-name-row h3{color:var(--text-primary);margin:0;font-size:16px}.med-name-row .dosage{color:var(--text-secondary);font-size:14px}.med-name-row .status-badge{border-radius:10px;padding:2px 8px;font-size:11px;font-weight:600}.med-name-row .status-badge.active{color:var(--success);background:#e8f8f5}.med-name-row .status-badge.inactive{color:var(--error);background:#fdedec}.med-meta{gap:var(--spacing-xs) var(--spacing-sm);flex-wrap:wrap;align-items:center;margin-top:4px;display:flex}.med-meta .meta-item{color:var(--text-secondary);align-items:center;gap:4px;font-size:13px;display:flex}.med-meta .meta-item.instructions{font-style:italic}.med-meta .meta-item.side-effects{color:var(--warning)}.med-meta .meta-item.refill{color:var(--primary);font-weight:600}.med-meta .meta-item.pillbox-category{border-radius:10px;padding:2px 8px;font-size:12px;font-weight:600}.med-meta .meta-item.pillbox-category.morning{color:#fff;background:#f59e0b}.med-meta .meta-item.pillbox-category.breakfast{color:#fff;background:#14b8a6}.med-meta .meta-item.pillbox-category.dinner{color:#fff;background:#10b981}.med-meta .meta-item.pillbox-category.bedtime{color:#fff;background:#8b5cf6}.med-meta .meta-item.pillbox-category.eyedrops{background:var(--accent);color:#fff}.med-meta .pillbox-categories{flex-wrap:wrap;gap:4px;display:flex}.med-meta .time-slots{gap:4px;display:flex}.med-meta .time-badge{background:var(--secondary);color:var(--primary);border-radius:10px;padding:2px 8px;font-size:12px;font-weight:600}.allergies-section{border-radius:var(--radius-md);padding:var(--spacing-md);margin-bottom:var(--spacing-lg);background:#fef3c7;border:2px solid #f59e0b}.allergies-header{margin-bottom:var(--spacing-sm);justify-content:space-between;align-items:center;display:flex}.allergies-title{align-items:center;gap:var(--spacing-sm);display:flex}.allergies-title h2{color:#92400e;margin:0;font-size:18px}.allergies-icon{color:#f59e0b}.allergy-count{color:#fff;background:#f59e0b;border-radius:12px;padding:2px 10px;font-size:14px;font-weight:600}.allergies-list{gap:var(--spacing-xs);flex-wrap:wrap;display:flex}.allergy-chip{background:#fff;border:1px solid #f59e0b;border-radius:20px;align-items:center;gap:8px;padding:6px 12px;font-size:14px;display:flex}.allergy-name{color:#92400e;font-weight:600}.allergy-notes{color:var(--text-secondary);font-size:13px}.allergy-delete{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;margin-left:4px;padding:2px;display:flex}.allergy-delete:hover{color:var(--error);background:#fdedec}.allergy-actions{gap:2px;margin-left:4px;display:flex}.allergy-edit{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;padding:2px;display:flex}.allergy-edit:hover{background:var(--secondary);color:var(--primary)}.allergies-empty{color:#92400e;margin:0;font-style:italic}.btn-sm{padding:6px 12px;font-size:13px}.btn-sm svg{width:16px;height:16px}.med-item .med-actions{flex-shrink:0;gap:4px;display:flex}.med-item .med-actions button{color:var(--text-secondary);cursor:pointer;transition:all var(--transition);background:0 0;border:none;border-radius:4px;padding:6px}.med-item .med-actions button:hover{background:var(--secondary);color:var(--primary)}.empty-state{text-align:center;padding:var(--spacing-xl);color:var(--text-secondary);border-radius:var(--radius-md);box-shadow:var(--shadow-card);background:#fff}.med-form{padding:var(--spacing-md);gap:var(--spacing-sm);flex-direction:column;display:flex}.form-group input,.form-group select,.form-group textarea{width:100%}.toggle{cursor:pointer;align-items:center;display:flex}.toggle input{display:none}.toggle-slider{width:48px;height:26px;transition:background var(--transition);background:#dfe6e9;border-radius:13px;position:relative}.toggle-slider:after{content:"";width:20px;height:20px;transition:transform var(--transition);background:#fff;border-radius:50%;position:absolute;top:3px;left:3px;box-shadow:0 2px 4px #0003}.toggle input:checked+.toggle-slider{background:var(--primary)}.toggle input:checked+.toggle-slider:after{transform:translate(22px)}.times-list{gap:var(--spacing-xs);flex-direction:column;display:flex}.time-input{gap:var(--spacing-xs);display:flex}.time-input input{flex:1}.time-input button{color:var(--error);cursor:pointer;background:#fdedec;border:none;border-radius:4px;padding:8px}.add-time-btn{background:var(--secondary);border-radius:var(--radius-sm);color:var(--primary);cursor:pointer;border:none;align-self:flex-start;align-items:center;gap:4px;padding:8px 12px;font-size:14px;font-weight:600;display:flex}.add-time-btn:hover{background:#f5e6d3}@media (width<=600px){.form-row{grid-template-columns:1fr}.page-header{align-items:flex-start;gap:var(--spacing-sm);flex-direction:column}}.side-effects-chips{gap:var(--spacing-xs);flex-direction:column;display:flex}.chips-hint{color:var(--text-secondary);margin:0;font-size:13px}.chips-list{gap:var(--spacing-xs);flex-wrap:wrap;display:flex}.side-effect-chip{background:var(--secondary);color:var(--text-primary);cursor:pointer;transition:all var(--transition);border:2px solid #0000;border-radius:16px;padding:6px 12px;font-size:13px}.side-effect-chip:hover{background:#f5e6d3}.side-effect-chip.selected{background:var(--primary);color:#fff;border-color:var(--primary)}.fda-disclaimer{color:var(--text-secondary);margin:var(--spacing-xs) 0 0 0;font-size:12px;font-style:italic}.manual-entry-btn{color:var(--primary);cursor:pointer;margin-top:var(--spacing-xs);background:0 0;border:none;padding:0;font-size:13px;text-decoration:underline}.manual-entry-btn:hover{color:var(--primary-dark)}.fetch-side-effects-btn.full-width{justify-content:center;width:100%;padding:12px 16px;font-size:14px}.modal-body{padding:var(--spacing-md)}.side-effects-view .view-label{color:var(--text-primary);margin-bottom:var(--spacing-sm);font-weight:600}.side-effects-view .side-effects-chips{gap:var(--spacing-xs);flex-wrap:wrap;display:flex}.side-effects-view .side-effect-chip{background:var(--secondary);color:var(--text-primary);border-radius:16px;padding:6px 12px;font-size:13px}.side-effects-view .fda-disclaimer{margin-top:var(--spacing-md)}.no-side-effects{text-align:center;color:var(--text-secondary);padding:var(--spacing-lg)}.pill-icon{font-size:16px;line-height:1}.side-effects-btn{background:var(--secondary);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);cursor:pointer;transition:all var(--transition);white-space:nowrap;align-items:center;gap:6px;min-width:110px;padding:6px 12px;font-size:13px;font-weight:500;display:flex}.side-effects-btn:hover{background:var(--primary);color:#fff;border-color:var(--primary)}.checkbox-group{flex-wrap:wrap;gap:12px;display:flex}.checkbox-label{cursor:pointer;color:var(--text-primary);align-items:center;gap:6px;font-size:14px;display:flex}.checkbox-label input[type=checkbox]{cursor:pointer;width:18px;height:18px;accent-color:var(--primary)}@media print{.page-header .btn,.filters,.med-item .med-actions,.modal-overlay,.empty-state .btn{display:none!important}.medications-page{max-width:100%;margin:0}.page-header{border-bottom:2px solid #333;margin-bottom:20px;padding-bottom:10px}.page-header h1{font-size:24px}.med-item{box-shadow:none;break-inside:avoid;page-break-inside:avoid;border:1px solid #ddd}.med-item .med-icon{background:#f5f5f5}.med-name-row .status-badge,.med-meta .time-badge{-webkit-print-color-adjust:exact;print-color-adjust:exact}}.calendar-page{max-width:1000px;margin:0 auto}.calendar-container{border-radius:var(--radius-md);box-shadow:var(--shadow-card);margin-bottom:var(--spacing-lg);background:#fff;overflow:hidden}.calendar-header{padding:var(--spacing-md);background:var(--secondary);border-bottom:1px solid #dfe6e9;justify-content:space-between;align-items:center;display:flex}.calendar-header h2{color:var(--text-primary);font-size:20px}.nav-btn{border-radius:var(--radius-sm);cursor:pointer;color:var(--text-secondary);transition:all var(--transition);background:#fff;border:none;padding:8px}.nav-btn:hover{background:var(--primary);color:#fff}.calendar-grid{padding:var(--spacing-sm)}.weekdays{margin-bottom:var(--spacing-xs);grid-template-columns:repeat(7,1fr);gap:2px;display:grid}.weekday{text-align:center;color:var(--text-secondary);padding:var(--spacing-xs);text-transform:uppercase;font-size:12px;font-weight:600}.days{grid-template-rows:repeat(6,100px);grid-template-columns:repeat(7,1fr);align-content:start;gap:2px;display:grid}.day{height:100px;min-height:80px;padding:var(--spacing-xs);border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition);flex-direction:column;display:flex;overflow:hidden}.day:hover:not(.empty){background:var(--secondary)}.day.empty{cursor:default}.day.today{background:#e8f8f5}.day.today .day-number{background:var(--primary);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;display:flex}.day-number{color:var(--text-primary);flex-shrink:0;margin-bottom:4px;font-size:14px;font-weight:600}.day-events{flex-direction:column;flex:1;gap:2px;display:flex}.event-dot{color:#fff;white-space:nowrap;text-overflow:ellipsis;cursor:pointer;box-sizing:border-box;border-radius:4px;max-width:100%;padding:2px 6px;font-size:11px;overflow:hidden}.more-events{color:var(--text-secondary);font-size:10px}.upcoming-events h3{margin-bottom:var(--spacing-sm);color:var(--text-primary)}.events-list{gap:var(--spacing-sm);flex-direction:column;display:flex}.event-card{border-radius:var(--radius-md);box-shadow:var(--shadow-card);padding:var(--spacing-md);gap:var(--spacing-sm);transition:all var(--transition);background:#fff;display:flex}.event-card:hover{box-shadow:var(--shadow-hover)}.event-category{color:#fff;white-space:nowrap;border-radius:20px;height:fit-content;padding:6px 12px;font-size:12px;font-weight:600}.event-info{flex:1}.event-info h4{color:var(--text-primary);margin-bottom:4px;font-size:16px}.event-details{gap:var(--spacing-sm);color:var(--text-secondary);flex-wrap:wrap;font-size:14px;display:flex}.event-details span{align-items:center;gap:4px;display:flex}.event-notes{color:var(--text-secondary);margin-top:var(--spacing-xs);font-size:13px;font-style:italic}.event-actions{gap:4px;display:flex}.event-actions button{color:var(--text-secondary);cursor:pointer;transition:all var(--transition);background:0 0;border:none;border-radius:4px;padding:6px}.event-actions button:hover{background:var(--secondary);color:var(--primary)}.event-form{padding:var(--spacing-md);gap:var(--spacing-sm);flex-direction:column;display:flex}.form-row{gap:var(--spacing-sm);grid-template-columns:1fr 1fr;display:grid}.form-group input,.form-group textarea{width:100%}.form-group textarea{resize:vertical}.cat-btn{border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition);background:#fff;border:2px solid;padding:8px 16px;font-weight:600}.cat-btn.active{background:var(--cat-color);color:#fff}.form-actions{justify-content:space-between;align-items:center;gap:var(--spacing-sm);margin-top:var(--spacing-sm);padding-top:var(--spacing-sm);border-top:1px solid #dfe6e9;display:flex}.form-actions-right{gap:var(--spacing-sm);display:flex}@media (width<=768px){.days{grid-template-rows:repeat(6,80px)}.day{height:80px;min-height:60px;padding:4px}.event-dot{padding:1px 4px;font-size:10px}.event-card{flex-direction:column}}.messages-page{max-width:800px;margin:0 auto}.page-header{margin-bottom:var(--spacing-lg);justify-content:space-between;align-items:center;display:flex}.page-header h1{color:var(--primary-dark);margin-bottom:4px}.page-header p{color:var(--text-secondary)}.messages-list,.notes-list{gap:var(--spacing-md);flex-direction:column;display:flex}.message-card{border-radius:var(--radius-md);box-shadow:var(--shadow-card);padding:var(--spacing-md);gap:var(--spacing-sm);transition:all var(--transition);background:#fff;display:flex}.note-card{border-radius:var(--radius-lg);box-shadow:var(--shadow-card);padding:var(--spacing-md);gap:var(--spacing-md);transition:all var(--transition);border:1px solid var(--border);background:#fff;display:flex}.note-card:hover{box-shadow:var(--shadow-hover);transform:translateY(-2px)}.note-avatar{background:var(--primary);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:16px;font-weight:700;display:flex}.note-content{flex:1;min-width:0}.note-header{align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-xs);flex-wrap:wrap;display:flex}.author-name{color:var(--text-primary);font-size:14px;font-weight:600}.note-text{color:var(--text-primary);word-wrap:break-word;line-height:1.5}.note-actions{flex-direction:column;flex-shrink:0;gap:4px;display:flex}.note-actions button{background:var(--secondary);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition);border:none;justify-content:center;align-items:center;padding:6px;display:flex}.note-actions button:hover{background:var(--primary);color:#fff}.note-category{border-radius:var(--radius-sm);white-space:nowrap;padding:3px 8px;font-size:11px}.note-category.badge-general{color:#666;background:#e0e0e0}.note-category.badge-reminder{color:#e65100;background:#fff3e0}.note-category.badge-update{color:#1565c0;background:#e3f2fd}.note-category.badge-urgent{color:#c62828;background:#ffebee}.message-card:hover{box-shadow:var(--shadow-hover)}.message-avatar{background:var(--primary);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:18px;font-weight:700;display:flex}.message-content{flex:1}.message-header{align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-xs);flex-wrap:wrap;display:flex}.sender-name{color:var(--text-primary);font-size:15px;font-weight:700}.timestamp{color:var(--text-secondary);margin-left:auto;font-size:13px}.message-text{color:var(--text-primary);line-height:1.5}.message-actions{flex-shrink:0;gap:4px;display:flex}.message-actions button{color:var(--text-secondary);cursor:pointer;transition:all var(--transition);background:0 0;border:none;border-radius:4px;padding:6px}.message-actions button:hover{background:var(--secondary);color:var(--primary)}.empty-state{text-align:center;padding:var(--spacing-xl);color:var(--text-secondary)}.empty-state svg{margin-bottom:var(--spacing-sm);opacity:.5}.empty-state h3{color:var(--text-primary);margin-bottom:var(--spacing-xs)}.modal-overlay{z-index:1000;background:#2d343680;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal{border-radius:var(--radius-md);background:#fff;flex-direction:column;width:100%;max-width:600px;max-height:calc(100vh - 40px);display:flex;overflow-y:auto;box-shadow:0 20px 60px #0003}.modal-header{padding:var(--spacing-md);border-bottom:1px solid #dfe6e9;justify-content:space-between;align-items:center;display:flex}.modal-header h2{color:var(--text-primary);font-size:20px}.close-btn{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:4px}.close-btn:hover{background:var(--secondary)}.message-form{padding:var(--spacing-md);gap:var(--spacing-sm);flex-direction:column;display:flex}.note-form{padding:var(--spacing-md);gap:var(--spacing-sm);flex-direction:column;flex:1;display:flex;overflow-y:auto}.form-group{flex-direction:column;gap:6px;display:flex}.form-group label{color:var(--text-primary);font-size:14px;font-weight:600}.category-buttons{gap:var(--spacing-xs);flex-wrap:wrap;display:flex}.cat-btn{border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition);background:#fff;border:2px solid #dfe6e9;padding:8px 16px;font-weight:600}.cat-btn:hover{border-color:var(--primary);color:var(--primary)}.cat-btn.active{background:var(--primary);border-color:var(--primary);color:#fff}.form-group textarea{resize:vertical;width:100%;min-height:100px}.form-actions{justify-content:flex-end;gap:var(--spacing-sm);margin-top:var(--spacing-sm);padding-top:var(--spacing-sm);border-top:1px solid #dfe6e9;display:flex}.delete-modal{text-align:center;padding:var(--spacing-lg)}.delete-modal h3{margin-bottom:var(--spacing-sm)}.delete-modal p{color:var(--text-secondary);margin-bottom:var(--spacing-md)}.delete-actions{justify-content:center;gap:var(--spacing-sm);display:flex}@media (width<=600px){.message-card{flex-direction:column}.message-actions{margin-left:52px}.timestamp{width:100%;margin-left:0}}.settings-page{max-width:600px;margin:0 auto}.settings-page .page-header{margin-bottom:var(--spacing-lg)}.settings-page .page-header h1{color:var(--primary-dark);margin-bottom:var(--spacing-xs)}.settings-page .page-header p{color:var(--text-secondary)}.settings-card{margin-bottom:var(--spacing-md)}.settings-card .card-header{align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-sm);border-bottom:1px solid #dfe6e9;display:flex}.settings-card .card-icon{color:var(--primary);width:24px;height:24px}.settings-card h3{color:var(--text-primary)}.s3-status{align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-md);padding:var(--spacing-sm);border-radius:var(--radius-sm);background:#e8f8f5;display:flex}.s3-status .status-badge{border-radius:12px;padding:4px 12px;font-size:12px;font-weight:600}.s3-status .status-badge.connected{background:var(--success);color:#fff}.s3-status .bucket-info{color:var(--text-secondary);font-size:14px}.settings-form{gap:var(--spacing-md);flex-direction:column;display:flex}.settings-form .form-group{flex-direction:column;gap:6px;display:flex}.settings-form label{color:var(--text-primary);font-size:14px;font-weight:600}.settings-form input,.settings-form select{width:100%}.form-group select{padding:12px 16px}.success-message{color:var(--success);padding:var(--spacing-sm);border-radius:var(--radius-sm);background:#e8f8f5;font-weight:600}.info-card{background:#f8f9fa}.info-card h3{margin-bottom:var(--spacing-sm);color:var(--text-primary)}.info-card ul{gap:var(--spacing-xs);flex-direction:column;list-style:none;display:flex}.info-card li{color:var(--text-secondary);padding-left:var(--spacing-md);font-size:14px;position:relative}.info-card li:before{content:"•";color:var(--primary);position:absolute;left:0}.settings-card .card-header{justify-content:space-between;align-items:center;display:flex}.settings-card .card-header h3{flex:1}.btn-sm{align-items:center;gap:6px;padding:8px 12px;font-size:13px;display:flex}.card-description{color:var(--text-secondary);margin-bottom:var(--spacing-md);font-size:14px}.empty-state-small{text-align:center;color:var(--text-secondary);padding:20px}.recurring-info{flex-direction:column;gap:4px;display:flex}.recurring-amount{color:var(--text-primary);font-weight:600}.recurring-total{background:var(--primary);color:#fff;border-radius:8px;justify-content:space-between;margin-top:8px;padding:12px 16px;font-weight:600;display:flex}.contacts-page{max-width:1000px;margin:0 auto}.contacts-list{gap:var(--spacing-xs);flex-direction:column;display:flex}.contact-item{border-radius:var(--radius-sm);box-shadow:var(--shadow-card);padding:var(--spacing-sm) var(--spacing-md);align-items:center;gap:var(--spacing-md);transition:all var(--transition);background:#fff;display:flex}.contact-item:hover{box-shadow:var(--shadow-hover)}.contact-icon{background:var(--secondary);border-radius:var(--radius-sm);width:40px;height:40px;color:var(--primary);flex-shrink:0;justify-content:center;align-items:center;display:flex}.contact-info{flex:1;min-width:0}.contact-name-row{align-items:center;gap:var(--spacing-sm);flex-wrap:wrap;display:flex}.contact-name-row h3{color:var(--text-primary);margin:0;font-size:16px}.contact-role{color:var(--text-secondary);background:var(--secondary);border-radius:10px;padding:2px 8px;font-size:13px}.contact-details{gap:var(--spacing-xs) var(--spacing-sm);flex-wrap:wrap;align-items:center;margin-top:4px;display:flex}.contact-detail{color:var(--text-secondary);align-items:center;gap:4px;font-size:13px;display:flex}a.contact-phone{color:var(--text-secondary);transition:color var(--transition);text-decoration:none}a.contact-phone:hover{color:var(--primary)}.contact-notes{color:var(--text-secondary);margin:4px 0 0;font-size:13px;font-style:italic}.contact-actions{flex-shrink:0;gap:4px;display:flex}.contact-actions button{color:var(--text-secondary);cursor:pointer;transition:all var(--transition);background:0 0;border:none;border-radius:4px;padding:6px}.contact-actions button:hover{background:var(--secondary);color:var(--primary)}.contact-form{padding:var(--spacing-md);gap:var(--spacing-sm);flex-direction:column;display:flex}@media (width<=600px){.contact-item{flex-direction:column;align-items:flex-start}.contact-actions{align-self:flex-end}}.expenses-page{max-width:1200px;margin:0 auto;padding:24px}.month-navigator{background:#fff;border-radius:12px;justify-content:center;align-items:center;gap:16px;margin-bottom:20px;padding:12px;display:flex;box-shadow:0 2px 8px #8b6d5914}.month-navigator button{cursor:pointer;color:#636e72;background:0 0;border:none;border-radius:8px;align-items:center;gap:4px;padding:8px;transition:all .2s;display:flex}.month-navigator button:hover{color:#2d3436;background:#f0f0f0}.month-navigator .today-btn{padding:6px 12px;font-size:13px}.month-navigator .current-month{color:#2d3436;text-align:center;min-width:160px;font-size:18px;font-weight:600}.budget-overview{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px;display:grid}.budget-card{background:#fff;border-radius:12px;flex-direction:column;gap:8px;padding:20px;display:flex;box-shadow:0 4px 20px #8b6d591f}.budget-label{color:#636e72;text-transform:uppercase;letter-spacing:.5px;font-size:13px}.budget-value{color:#2d3436;font-size:24px;font-weight:700}.budget-card.starting-balance .budget-value{color:#1565c0}.budget-card.starting-balance .budget-input-wrapper{align-items:center;gap:4px;display:flex}.budget-card.starting-balance .currency{color:#1565c0;font-size:20px}.budget-card.starting-balance .budget-input{color:#1565c0;background:0 0;border:none;outline:none;width:100%;font-size:24px;font-weight:700}.budget-card.expenses-total .budget-value{color:#e17055}.budget-card.net.positive .budget-value{color:#6bbf7a}.budget-card.net.negative .budget-value{color:#e17055}.budget-card.recurring{background:#fdf6ec}.budget-card.recurring .budget-value{color:#7c9a8e}.budget-note{color:#636e72;font-size:11px;font-style:italic}.expense-summary{flex-wrap:wrap;gap:16px;margin-bottom:24px;display:flex}.summary-card{background:#fff;border-radius:12px;align-items:center;gap:12px;min-width:140px;padding:16px 20px;display:flex;box-shadow:0 4px 20px #8b6d591f}.summary-card.total{color:#fff;background:linear-gradient(135deg,#7c9a8e,#5a7568)}.summary-card.total svg{color:#fff}.summary-label{color:#636e72;margin-bottom:4px;font-size:12px;display:block}.summary-card.total .summary-label{color:#fffc}.summary-value{color:#2d3436;font-size:20px;font-weight:600}.summary-card.total .summary-value{color:#fff}.expense-filters{flex-wrap:wrap;gap:16px;margin-bottom:24px;display:flex}.search-box{background:#fff;border:1px solid #e0e0e0;border-radius:8px;flex:1;align-items:center;min-width:200px;max-width:400px;padding:8px 12px;display:flex}.search-box svg{color:#636e72;margin-right:8px}.search-box input{color:#2d3436;border:none;outline:none;width:100%;font-size:14px}.category-filter{color:#2d3436;cursor:pointer;background:#fff;border:1px solid #e0e0e0;border-radius:8px;min-width:160px;padding:10px 16px;font-size:14px}.expense-table-wrapper{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 4px 20px #8b6d591f}.expense-table{border-collapse:collapse;width:100%}.expense-table th{text-align:left;color:#2d3436;text-transform:uppercase;letter-spacing:.5px;background:#fdf6ec;padding:14px 16px;font-size:13px;font-weight:600}.expense-table td{color:#2d3436;border-bottom:1px solid #f0f0f0;padding:14px 16px;font-size:14px}.expense-table tbody tr:hover{background:#fafafa}.expense-table tbody tr:last-child td{border-bottom:none}.expense-table .amount{color:#2d3436;font-family:SF Mono,Monaco,Inconsolata,monospace;font-weight:600}.expense-table .actions{gap:8px;display:flex}.expense-table .actions button{cursor:pointer;color:#636e72;background:0 0;border:none;border-radius:6px;padding:6px;transition:all .2s}.expense-table .actions button:hover{color:#2d3436;background:#f0f0f0}.expense-table tfoot{background:#fdf6ec}.expense-table tfoot td{padding:14px 16px;font-weight:600}.expense-table .total-label{text-align:right;color:#2d3436}.expense-table .total-amount{color:#7c9a8e;font-family:SF Mono,Monaco,Inconsolata,monospace;font-size:16px;font-weight:700}.category-badge{color:#636e72;background:#f0f0f0;border-radius:20px;padding:4px 10px;font-size:12px;font-weight:500;display:inline-block}.category-badge.medical{color:#2e7d32;background:#e8f5e9}.category-badge.pharmacy{color:#1565c0;background:#e3f2fd}.category-badge.food{color:#e65100;background:#fff3e0}.category-badge.transportation{color:#7b1fa2;background:#f3e5f5}.category-badge.utilities{color:#00838f;background:#e0f7fa}.category-badge.caregiving{color:#c2185b;background:#fce4ec}.category-badge.other{color:#546e7a;background:#eceff1}.empty-row{text-align:center;color:#636e72;padding:40px!important}.expense-form input,.expense-form select{color:#2d3436;box-sizing:border-box;border:1px solid #e0e0e0;border-radius:8px;width:100%;padding:10px 12px;font-size:14px;transition:border-color .2s}@media (width<=768px){.expense-summary{flex-direction:column}.summary-card{width:100%}.expense-filters{flex-direction:column}.search-box{max-width:none}.expense-table-wrapper{overflow-x:auto}.expense-table{min-width:600px}.expense-form .form-row{grid-template-columns:1fr}}.modal-overlay{z-index:1000;padding:var(--spacing-md);background:#2d343680;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{border-radius:var(--radius-md);background:#fff;width:100%;max-width:500px;max-height:calc(100vh - 40px);overflow-y:auto;box-shadow:0 20px 60px #0003}.modal-header{border-bottom:1px solid #eee;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.modal-header h2{color:#2d3436;margin:0;font-size:18px}.modal-header .close-btn{cursor:pointer;color:#636e72;background:0 0;border:none;justify-content:center;align-items:center;padding:4px;display:flex}.modal-header .close-btn:hover{color:#2d3436}.expense-form{padding:20px}.expense-form .form-group{margin-bottom:16px}.expense-form label{color:#2d3436;margin-bottom:6px;font-size:14px;font-weight:500;display:block}.expense-form input,.expense-form select{border-radius:var(--radius-sm);color:#2d3436;background:#fff;border:1px solid #ddd;width:100%;padding:10px 12px;font-size:14px}.expense-form input:focus,.expense-form select:focus{border-color:#7c9a8e;outline:none;box-shadow:0 0 0 3px #7c9a8e1a}.expense-form .form-row{grid-template-columns:1fr 1fr;gap:16px;display:grid}.expense-form .form-actions{border-top:1px solid #eee;gap:12px;margin-top:24px;padding-top:16px;display:flex}.expense-form .btn{flex:1;padding:12px 20px;font-size:14px;font-weight:500}.budget-card.deposits{grid-column:span 1}.deposit-inputs{gap:16px;margin-top:8px;display:flex}.deposit-input-group{flex:1}.deposit-input-group label{color:#636e72;margin-bottom:4px;font-size:12px;display:block}.deposit-input-group .deposit-value{color:#2d3436;font-size:18px;font-weight:600}.budget-note{color:#636e72;margin-top:4px;font-size:11px;display:block}.recurring-section{background:#fff;border-radius:12px;margin-top:24px;overflow:hidden;box-shadow:0 2px 8px #8b6d5914}.recurring-toggle{cursor:pointer;width:100%;color:var(--text-primary);text-align:left;background:0 0;border:none;justify-content:space-between;align-items:center;padding:16px 20px;font-size:16px;font-weight:600;display:flex}.recurring-toggle:hover{background:#f8f9fa}.recurring-toggle-right{color:var(--text-secondary);align-items:center;gap:10px;display:flex}.recurring-total-badge{color:var(--text-primary);background:#f0f0f0;border-radius:12px;padding:3px 10px;font-size:13px;font-weight:600}.recurring-body{border-top:1px solid #f0f0f0;padding:8px 20px 20px}.empty-recurring{color:var(--text-secondary);padding:12px 0;font-size:14px}.recurring-list{flex-direction:column;gap:8px;display:flex}.recurring-item{background:#f8f9fa;border-radius:8px;justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.recurring-info{flex-direction:column;flex:1;gap:4px;display:flex}.recurring-name{color:var(--text-primary);font-weight:600}.recurring-category{color:var(--text-secondary);font-size:12px}.recurring-amount{color:var(--text-primary);margin:0 16px;font-weight:600}.recurring-actions{gap:8px;display:flex}.recurring-actions button{cursor:pointer;color:var(--text-secondary);background:0 0;border:none;border-radius:6px;padding:6px;transition:all .2s}.recurring-actions button:hover{color:var(--text-primary);background:#e0e0e0}.recurring-total-row{background:var(--primary,#8b6d59);color:#fff;border-radius:8px;justify-content:space-between;margin-top:4px;padding:12px 16px;font-weight:600;display:flex}:root{--primary:#6366f1;--primary-dark:#4f46e5;--primary-light:#818cf8;--secondary:#f0f9ff;--accent:#f59e0b;--background:#fafbfc;--surface:#fff;--text-primary:#111827;--text-secondary:#6b7280;--success:#10b981;--warning:#f59e0b;--error:#ef4444;--info:#3b82f6;--card-shadow:#00000014;--font-heading:"Inter", -apple-system, BlinkMacSystemFont, sans-serif;--font-body:"Inter", -apple-system, BlinkMacSystemFont, sans-serif;--spacing-xs:8px;--spacing-sm:16px;--spacing-md:24px;--spacing-lg:32px;--spacing-xl:48px;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:24px;--shadow-card:0 1px 3px #0000001a, 0 1px 2px #0000000f;--shadow-hover:0 10px 15px -3px #0000001a, 0 4px 6px -2px #0000000d;--shadow-lg:0 20px 25px -5px #0000001a, 0 10px 10px -5px #0000000a;--transition:.2s cubic-bezier(.4, 0, .2, 1)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-body);background-color:var(--background);color:var(--text-primary);min-height:100vh;line-height:1.6}#root{min-height:100vh}h1,h2,h3,h4,h5,h6{font-family:var(--font-body);font-weight:700;line-height:1.3}h1{font-size:28px}h2{font-size:22px;font-weight:600}h3{font-size:18px;font-weight:600}a{color:var(--primary);transition:color var(--transition);text-decoration:none}a:hover{color:var(--primary-dark)}button{font-family:var(--font-body);cursor:pointer;transition:all var(--transition);border:none;outline:none;font-size:16px;font-weight:600}input,textarea,select{font-family:var(--font-body);border-radius:var(--radius-sm);transition:border-color var(--transition), box-shadow var(--transition);background:#fff;border:2px solid #dfe6e9;outline:none;padding:12px 16px;font-size:16px}input:focus,textarea:focus,select:focus{border-color:var(--primary);box-shadow:0 0 0 3px #ff7f5026}input::placeholder,textarea::placeholder{color:var(--text-secondary)}.btn{border-radius:var(--radius-sm);transition:all var(--transition);justify-content:center;align-items:center;gap:8px;padding:12px 24px;font-weight:600;display:inline-flex}.btn-primary{background-color:var(--primary);color:#fff}.btn-primary:hover{background-color:var(--primary-dark);box-shadow:var(--shadow-card);transform:translateY(-2px)}.btn-secondary{color:var(--primary);border:2px solid var(--primary);background-color:#fff}.btn-secondary:hover{background-color:var(--secondary)}.btn-danger{background-color:var(--error);color:#fff}.btn-danger:hover{background-color:#d63031}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.card{border-radius:var(--radius-md);box-shadow:var(--shadow-card);padding:var(--spacing-md);transition:all var(--transition);background:#fff}.card:hover{box-shadow:var(--shadow-hover)}.page-enter{opacity:0;transform:translateY(10px)}.page-enter-active{opacity:1;transition:opacity .3s ease-out,transform .3s ease-out;transform:translateY(0)}.container{max-width:1200px;padding:0 var(--spacing-md);margin:0 auto}.badge{text-transform:uppercase;border-radius:20px;align-items:center;padding:4px 12px;font-size:12px;font-weight:600;display:inline-flex}.badge-general{color:#3498db;background-color:#e8f4fd}.badge-reminder{color:var(--warning);background-color:#fef9e7}.badge-update{color:var(--success);background-color:#e8f8f5}.badge-urgent{color:var(--error);background-color:#fdedec}.fade-in{animation:.3s ease-out forwards fadeIn}.stagger-1{animation-delay:50ms}.stagger-2{animation-delay:.1s}.stagger-3{animation-delay:.15s}.stagger-4{animation-delay:.2s}.stagger-5{animation-delay:.25s}@media (width<=768px){h1{font-size:24px}h2{font-size:20px}.container{padding:0 var(--spacing-sm)}}
