@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";:root{--color-primary: #5A8F65;--color-primary-light: #7AB286;--color-primary-dark: #3D6B47;--color-secondary: #9B7BB8;--color-secondary-light: #B99BD4;--color-accent: #5A8F65;--color-gray-50: #FAFAFA;--color-gray-100: #F5F5F5;--color-gray-200: #EEEEEE;--color-gray-300: #E0E0E0;--color-gray-400: #BDBDBD;--color-gray-500: #9E9E9E;--color-gray-600: #757575;--color-gray-700: #616161;--color-gray-800: #424242;--color-gray-900: #212121;--color-success: #5A8F65;--color-warning: #E9B44C;--color-error: #D64550;--bg-page: #F8F9FA;--bg-nav: #5A8F65;--bg-card: #FFFFFF;--bg-card-hover: #FFFFFF;--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--font-size-4xl: 2.25rem;--spacing-1: .25rem;--spacing-2: .5rem;--spacing-3: .75rem;--spacing-4: 1rem;--spacing-5: 1.25rem;--spacing-6: 1.5rem;--spacing-8: 2rem;--spacing-10: 2.5rem;--spacing-12: 3rem;--spacing-16: 4rem;--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-2xl: 1.5rem;--radius-full: 9999px;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 10px 10px -5px rgba(0, 0, 0, .04);--shadow-glow: 0 0 20px rgba(90, 143, 101, .3);--transition-fast: .15s ease;--transition-base: .2s ease;--transition-slow: .3s ease;--z-dropdown: 100;--z-modal: 200;--z-toast: 300}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-family);font-size:var(--font-size-base);line-height:1.6;color:var(--color-gray-800);background:var(--bg-page);min-height:100vh}#root{min-height:100vh;display:flex;flex-direction:column}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.3;color:var(--color-gray-900)}h1{font-size:var(--font-size-4xl)}h2{font-size:var(--font-size-3xl)}h3{font-size:var(--font-size-2xl)}h4{font-size:var(--font-size-xl)}a{color:var(--color-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-primary-dark)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-2);padding:var(--spacing-3) var(--spacing-6);font-family:var(--font-family);font-size:var(--font-size-sm);font-weight:500;border-radius:var(--radius-lg);border:none;cursor:pointer;transition:all var(--transition-base)}.btn-primary{background:var(--color-primary);color:#fff;box-shadow:var(--shadow-md)}.btn-primary:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg),var(--shadow-glow)}.btn-secondary{background:#fff;color:var(--color-gray-700);border:1px solid var(--color-gray-200)}.btn-secondary:hover{background:var(--color-gray-50);border-color:var(--color-gray-300)}.btn-ghost{background:transparent;color:var(--color-gray-600)}.btn-ghost:hover{background:var(--color-gray-100)}.btn-icon{padding:var(--spacing-2);border-radius:var(--radius-md)}.card{background:var(--bg-card);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:var(--spacing-6);transition:all var(--transition-base)}.card:hover{box-shadow:var(--shadow-xl)}.glass{background:var(--bg-nav);border-bottom:1px solid rgba(0,0,0,.1)}input,textarea,select{font-family:var(--font-family);font-size:var(--font-size-base);padding:var(--spacing-3) var(--spacing-4);border:1px solid var(--color-gray-200);border-radius:var(--radius-lg);background:#fff;color:var(--color-gray-800);transition:all var(--transition-fast);width:100%}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #6366f11a}input::placeholder{color:var(--color-gray-400)}.checkbox-wrapper{display:flex;align-items:center;gap:var(--spacing-3);cursor:pointer}.checkbox-wrapper input[type=checkbox]{width:20px;height:20px;accent-color:var(--color-primary);cursor:pointer}.container{width:100%;max-width:1200px;margin:0 auto;padding:0 var(--spacing-4)}.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-2{gap:var(--spacing-2)}.gap-4{gap:var(--spacing-4)}.gap-6{gap:var(--spacing-6)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translate(-10px)}to{opacity:1;transform:translate(0)}}@keyframes checkmark{0%{transform:scale(0)}50%{transform:scale(1.2)}to{transform:scale(1)}}.animate-fade-in{animation:fadeIn var(--transition-slow) ease-out}.animate-slide-in{animation:slideIn var(--transition-slow) ease-out}@media(max-width:768px){:root{--font-size-4xl: 1.875rem;--font-size-3xl: 1.5rem}.container{padding:0 var(--spacing-4)}}@media(prefers-color-scheme:dark){:root{--bg-page: #1a1a2e;--bg-nav: #16213e;--bg-card: #1f1f3a;--bg-card-hover: #2a2a4a;--color-gray-50: #1a1a2e;--color-gray-100: #2a2a4a;--color-gray-200: #3a3a5a;--color-gray-300: #5a5a7a;--color-gray-400: #8a8aaa;--color-gray-500: #a0a0c0;--color-gray-600: #c0c0d0;--color-gray-700: #d0d0e0;--color-gray-800: #e8e8f0;--color-gray-900: #f5f5fa;--color-primary: #6AAF75;--color-primary-light: #8BC896;--color-secondary: #B08FD0}body{color:var(--color-gray-800)}h1,h2,h3,h4,h5,h6{color:var(--color-gray-900)}.card{background:var(--bg-card);border:1px solid var(--color-gray-200)}.card:hover{background:var(--bg-card-hover)}.glass{background:var(--bg-nav);border-bottom:1px solid var(--color-gray-200)}input,textarea,select{background:var(--bg-card);border-color:var(--color-gray-300);color:var(--color-gray-800)}input::placeholder,textarea::placeholder{color:var(--color-gray-500)}input:focus,textarea:focus,select:focus{border-color:var(--color-primary);background:var(--bg-card-hover)}.btn-secondary{background:var(--bg-card);color:var(--color-gray-800);border-color:var(--color-gray-300)}.btn-secondary:hover{background:var(--bg-card-hover)}.btn-ghost{color:var(--color-gray-600)}.btn-ghost:hover{background:var(--bg-card);color:var(--color-gray-800)}.modal-overlay{background:#000000b3}.modal{background:var(--bg-card);border:1px solid var(--color-gray-200)}.summary-card{color:#fff}th{background:var(--bg-card-hover);color:var(--color-gray-800)}td{border-color:var(--color-gray-200)}tr:hover td{background:var(--bg-card-hover)}}.notification-bell-container{position:relative}.notification-bell{width:36px;height:36px;border-radius:50%;border:none;background:#ffffff1a;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);position:relative}.notification-bell:hover:not(:disabled){background:#fff3;transform:scale(1.05)}.notification-bell:disabled{opacity:.5;cursor:not-allowed}.notification-bell.loading{animation:pulse 1s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.bell-icon{font-size:1.25rem;line-height:1}.notification-bell.enabled .bell-icon{animation:ring .5s ease-out}@keyframes ring{0%{transform:rotate(0)}25%{transform:rotate(15deg)}50%{transform:rotate(-15deg)}75%{transform:rotate(10deg)}to{transform:rotate(0)}}.bell-dot{position:absolute;top:6px;right:6px;width:8px;height:8px;border-radius:50%;background:var(--color-success, #22c55e);border:2px solid rgba(30,30,40,.95)}.bell-tooltip{position:absolute;top:100%;right:0;margin-top:var(--spacing-2);padding:var(--spacing-2) var(--spacing-3);background:#1e1e28f2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:var(--radius-md);color:var(--color-success, #22c55e);font-size:var(--font-size-sm);font-weight:500;white-space:nowrap;box-shadow:var(--shadow-lg);animation:fadeIn .2s ease-out;z-index:var(--z-dropdown)}@keyframes fadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.notification-bell.blocked{background:#ff64641a}.notification-bell.blocked .bell-icon{opacity:.5}.layout{min-height:100vh;display:flex;flex-direction:column}.header{position:sticky;top:0;z-index:var(--z-dropdown);padding:var(--spacing-3) var(--spacing-4);padding-top:calc(var(--spacing-3) + env(safe-area-inset-top,0px))}.header-content{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-4)}.logo{display:flex;align-items:center;gap:var(--spacing-2);text-decoration:none}.logo-image{height:36px;width:auto}.logo-icon{font-size:1.5rem}.header-actions{display:flex;align-items:center;gap:var(--spacing-3)}.user-placeholder{width:32px;height:32px;border-radius:50%;background:#fff3;display:flex;align-items:center;justify-content:center}.desktop-nav{display:none;align-items:center;gap:var(--spacing-1)}.nav-link{display:flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-2) var(--spacing-4);border-radius:var(--radius-lg);color:#fffc;font-weight:500;font-size:var(--font-size-sm);text-decoration:none;transition:all var(--transition-fast);background:none;border:none;cursor:pointer;font-family:inherit}.nav-link:hover{color:#fff;background:#ffffff1a}.nav-link.active{color:#fff;background:#fff3}.nav-link .nav-icon{font-size:1rem}.nav-link .nav-label{font-size:var(--font-size-sm)}.mobile-nav{position:fixed;bottom:0;left:0;right:0;display:flex;justify-content:space-around;align-items:center;padding:var(--spacing-2);padding-bottom:calc(var(--spacing-2) + env(safe-area-inset-bottom,0px));background:#fff;border-top:1px solid var(--color-gray-200);z-index:var(--z-sticky)}.tab{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:var(--spacing-2) var(--spacing-3);border-radius:var(--radius-xl);color:var(--color-gray-500);text-decoration:none;transition:all var(--transition-fast);min-width:64px}.tab:hover,.tab.active{color:var(--color-primary)}.tab .nav-icon{font-size:1.5rem;line-height:1;transition:transform var(--transition-fast)}.tab:hover .nav-icon,.tab.active .nav-icon{transform:scale(1.1)}.tab .nav-label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.main-content{flex:1;padding:var(--spacing-4);padding-bottom:calc(var(--spacing-4) + 80px)}@media(min-width:768px){.desktop-nav{display:flex}.mobile-nav{display:none}.main-content{padding-bottom:var(--spacing-4)}}.more-dropdown{position:relative}.more-menu{position:absolute;top:100%;right:0;margin-top:var(--spacing-1);min-width:160px;padding:var(--spacing-2);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);z-index:var(--z-dropdown);display:flex;flex-direction:column;gap:var(--spacing-1);background:#1e1e28f2;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1)}.more-item{display:flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-2) var(--spacing-3);border-radius:var(--radius-md);color:#fffc;text-decoration:none;font-size:var(--font-size-sm);transition:all var(--transition-fast)}.more-item:hover{background:#ffffff26;color:#fff}.more-item.active{background:#fff3;color:#fff}.mobile-more-overlay{position:fixed;inset:0;background:#00000080;z-index:var(--z-modal);display:flex;align-items:flex-end;justify-content:center;padding-bottom:calc(80px + env(safe-area-inset-bottom,0px))}.mobile-more-menu{width:90%;max-width:300px;padding:var(--spacing-4);border-radius:var(--radius-xl);display:flex;flex-direction:column;gap:var(--spacing-2);margin-bottom:var(--spacing-2);background:#1e1e28;border:1px solid rgba(255,255,255,.15);box-shadow:var(--shadow-lg)}.mobile-more-item{display:flex;align-items:center;gap:var(--spacing-3);padding:var(--spacing-3) var(--spacing-4);border-radius:var(--radius-lg);color:#ffffffe6;text-decoration:none;font-size:var(--font-size-base);font-weight:500;transition:all var(--transition-fast)}.mobile-more-item:hover,.mobile-more-item.active{background:#fff3;color:#fff}.mobile-more-item .nav-icon{font-size:1.5rem}.tab[type=button],button.tab{border:none;background:none;cursor:pointer;font-family:inherit}@media(prefers-color-scheme:dark){.mobile-nav{background:var(--bg-card);border-top-color:var(--color-gray-200)}.tab{color:var(--color-gray-500)}.tab.active{color:var(--color-primary)}.more-menu{background:var(--bg-card);border-color:var(--color-gray-200)}.more-item{color:var(--color-gray-700)}.more-item:hover,.more-item.active{background:var(--bg-card-hover);color:var(--color-gray-900)}.mobile-more-menu{background:var(--bg-card);border-color:var(--color-gray-200)}.mobile-more-item{color:var(--color-gray-700)}.mobile-more-item:hover,.mobile-more-item.active{background:var(--bg-card-hover);color:var(--color-gray-900)}}.landing{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--spacing-6)}.landing-content{text-align:center;max-width:600px}.landing-header{margin-bottom:var(--spacing-10)}.landing-icon{font-size:4rem;display:block;margin-bottom:var(--spacing-4)}.landing h1{font-size:var(--font-size-4xl);color:#fff;margin-bottom:var(--spacing-2);text-shadow:0 2px 10px rgba(0,0,0,.2)}.landing-tagline{font-size:var(--font-size-xl);color:#ffffffe6}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-4);margin-bottom:var(--spacing-10)}.feature-card{text-align:center;padding:var(--spacing-6)}.feature-icon{font-size:2.5rem;display:block;margin-bottom:var(--spacing-3)}.feature-card h3{margin-bottom:var(--spacing-2)}.feature-card p{color:var(--color-gray-600);font-size:var(--font-size-sm)}.landing-cta{margin-top:var(--spacing-8)}.btn-large{padding:var(--spacing-4) var(--spacing-8);font-size:var(--font-size-lg)}.btn-large svg{margin-left:var(--spacing-2)}.dashboard{max-width:800px;margin:0 auto}.dashboard-header{text-align:center;margin-bottom:var(--spacing-8);color:#fff}.dashboard-header h1{color:#fff;margin-bottom:var(--spacing-2)}.dashboard-header p{font-size:var(--font-size-lg);opacity:.9}.dashboard-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-4);margin-bottom:var(--spacing-6)}.dashboard-card{display:block;text-decoration:none;color:inherit;transition:all var(--transition-base);text-align:center}.dashboard-card:hover{transform:translateY(-4px)}.dashboard-card-icon{font-size:2rem;margin-bottom:var(--spacing-2)}.dashboard-card h3{margin-bottom:var(--spacing-1);font-size:var(--font-size-base)}.dashboard-card p{color:var(--color-gray-600);font-size:var(--font-size-xs);margin-bottom:var(--spacing-2);line-height:1.4}.dashboard-card-action{color:var(--color-primary);font-weight:500;font-size:var(--font-size-sm)}.quick-stats{margin-top:var(--spacing-6)}.quick-stats h3{margin-bottom:var(--spacing-4)}.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-4);text-align:center}.stat-value{display:block;font-size:var(--font-size-3xl);font-weight:700;color:var(--color-primary)}.stat-label{font-size:var(--font-size-sm);color:var(--color-gray-500)}@media(max-width:480px){.stats-grid{grid-template-columns:1fr;gap:var(--spacing-3)}.stat{display:flex;justify-content:space-between;align-items:center}.stat-value{font-size:var(--font-size-2xl)}}.dev-notice{margin-top:var(--spacing-6);padding:var(--spacing-4);display:flex;align-items:center;gap:var(--spacing-3);background:linear-gradient(135deg,#f59e0b1a,#ef44441a);border:1px solid rgba(245,158,11,.3)}.dev-notice span{font-size:1.5rem}.dev-notice p{font-size:var(--font-size-sm);color:var(--color-gray-700)}.dev-notice code{background:var(--color-gray-100);padding:.125rem .375rem;border-radius:var(--radius-sm);font-size:var(--font-size-xs)}.todos-page{max-width:700px;margin:0 auto;padding-bottom:calc(100px + env(safe-area-inset-bottom,0px))}@media(min-width:768px){.todos-page{padding-bottom:0}}.todos-header{text-align:center;margin-bottom:var(--spacing-6);color:var(--color-gray-800)}.todos-header h1{color:var(--color-gray-800)}.list-tabs{display:flex;gap:var(--spacing-2);margin-bottom:var(--spacing-4);background:#fff;padding:var(--spacing-2);border-radius:var(--radius-lg)}.list-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:var(--spacing-2);padding:var(--spacing-3) var(--spacing-4);background:transparent;border:none;border-radius:var(--radius-md);cursor:pointer;font-family:var(--font-family);font-size:var(--font-size-sm);font-weight:500;color:var(--color-gray-600);transition:all var(--transition-fast)}.list-tab:hover{background:var(--color-gray-100);color:var(--color-gray-800)}.list-tab.active{background:var(--color-primary);color:#fff}.tab-icon{font-size:1.25rem}.tab-label{display:none}@media(min-width:480px){.tab-label{display:inline}}.input-row{display:flex;gap:var(--spacing-2)}.todo-input{flex:1;min-width:0}.todo-list{padding:var(--spacing-2)}.todo-item{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-3) var(--spacing-4);border-radius:var(--radius-lg);transition:all var(--transition-fast)}.todo-item:hover{background:var(--color-gray-50)}.drag-handle{cursor:grab;padding:0 var(--spacing-2);color:var(--color-gray-400);font-size:1rem;-webkit-user-select:none;user-select:none}.todo-item.dragging{opacity:.5;background:var(--color-gray-100)}.todo-item .checkbox-wrapper{flex:1;min-width:0;overflow:hidden}.todo-text{font-size:var(--font-size-base);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.todo-item.completed .todo-text{text-decoration:line-through;color:var(--color-gray-400)}.delete-btn{opacity:.6;transition:opacity var(--transition-fast)}.todo-item:hover .delete-btn{opacity:1}.completed-section{margin-top:var(--spacing-4);padding-top:var(--spacing-4);border-top:1px solid var(--color-gray-200)}.completed-header{padding:0 var(--spacing-4);margin-bottom:var(--spacing-2);font-size:var(--font-size-sm);color:var(--color-gray-500);font-weight:500}.empty-state{text-align:center;padding:var(--spacing-10);color:var(--color-gray-500)}@media(max-width:480px){.tab-label{display:none}.tab-icon{font-size:1.5rem}.add-todo-form{flex-direction:column}}.offline-badge{display:inline-flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-1) var(--spacing-3);background:#f59e0b33;border:1px solid rgba(245,158,11,.5);border-radius:var(--radius-full);font-size:var(--font-size-sm);color:#f59e0b;margin-top:var(--spacing-2)}.loading-state{text-align:center;padding:var(--spacing-10);color:var(--color-gray-500)}.add-todo-form{display:flex;flex-direction:column;gap:var(--spacing-3);padding:var(--spacing-4);margin-bottom:var(--spacing-4)}.todo-input-row{display:flex;gap:var(--spacing-2)}.todo-input-row .todo-input{flex:1}.due-date-toggle{font-size:1.25rem}.due-date-toggle.active{background:var(--color-primary);color:#fff}.due-date-row{display:flex;align-items:center;gap:var(--spacing-3);font-size:var(--font-size-sm);color:var(--color-gray-600)}.date-input{padding:var(--spacing-2) var(--spacing-3);border:1px solid var(--color-gray-300);border-radius:var(--radius-md);font-family:var(--font-family)}.todo-content{display:flex;flex-direction:column;gap:var(--spacing-1)}.due-badge{display:inline-block;font-size:var(--font-size-xs);color:var(--color-gray-500);background:var(--color-gray-100);padding:.125rem .5rem;border-radius:var(--radius-full);width:fit-content}.due-badge.overdue{color:#fff;background:var(--color-error)}.todo-item.overdue{background:#ef44440d}.completed-header{display:flex;justify-content:space-between;align-items:center;padding:0 var(--spacing-4);margin-bottom:var(--spacing-2);font-size:var(--font-size-sm);color:var(--color-gray-500);font-weight:500}.clear-completed-btn{font-size:var(--font-size-xs);color:var(--color-gray-400)}.clear-completed-btn:hover{color:var(--color-error)}.todo-actions{display:flex;gap:var(--spacing-1);flex-shrink:0}.edit-btn{opacity:.6;transition:opacity var(--transition-fast)}.todo-item:hover .edit-btn{opacity:1}@media(hover:none){.delete-btn,.edit-btn{opacity:1}}.edit-form{display:flex;flex-direction:column;gap:var(--spacing-4);margin-bottom:var(--spacing-4)}.edit-form label span{font-size:var(--font-size-sm);color:var(--color-gray-600)}.edit-form input,.edit-form select{padding:var(--spacing-3);border:1px solid var(--color-gray-300);border-radius:var(--radius-md);font-size:var(--font-size-base);font-family:var(--font-family)}.edit-form input:focus,.edit-form select:focus{outline:none;border-color:var(--color-primary)}.edit-form select{background:#fff;cursor:pointer}.due-badge{display:inline-flex;padding:2px 6px;border-radius:4px;font-size:.7rem;background:var(--color-gray-100);color:var(--color-gray-600);margin-left:var(--spacing-2)}.due-badge.overdue{background:#fee2e2;color:#ef4444}.linked-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:12px;font-size:.75rem;font-weight:500;text-decoration:none;transition:background-color .2s;margin-left:var(--spacing-2)}.linked-badge.trip{background:#e0f2fe;color:#0284c7}.linked-badge.event{background:#f3e8ff;color:#9333ea}.linked-badge:hover{filter:brightness(.95)}.photos-page{display:flex;gap:var(--spacing-6);max-width:1400px;margin:0 auto;min-height:calc(100vh - 200px)}.photos-sidebar{display:none;flex-direction:column;width:280px;flex-shrink:0;background:var(--glass-bg);border:var(--glass-border);border-radius:var(--radius-xl);padding:var(--spacing-4);height:fit-content;max-height:calc(100vh - 200px);overflow-y:auto;position:sticky;top:var(--spacing-4)}@media(min-width:900px){.photos-sidebar{display:flex}}.sidebar-header{padding:var(--spacing-2) var(--spacing-3);margin-bottom:var(--spacing-2)}.sidebar-header h3{color:var(--color-gray-800);font-size:var(--font-size-sm);margin:0}.sidebar-item{display:flex;align-items:center;gap:var(--spacing-2);width:100%;padding:var(--spacing-2) var(--spacing-3);border:none;background:transparent;color:#fffc;font-family:var(--font-family);font-size:var(--font-size-sm);text-align:left;cursor:pointer;border-radius:var(--radius-md);transition:all var(--transition-fast)}.sidebar-item:hover{background:#ffffff1a;color:#fff}.sidebar-item.active{background:#ffffff26;color:#fff;font-weight:500}.sidebar-expand{font-size:10px;transition:transform var(--transition-fast);opacity:.6;padding:var(--spacing-1)}.sidebar-expand.expanded{transform:rotate(90deg)}.sidebar-icon{font-size:1rem}.sidebar-name{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-subfolders{padding-left:var(--spacing-4)}.sidebar-subfolder{font-size:var(--font-size-xs)}.sidebar-new{margin-top:var(--spacing-2);border:1px dashed rgba(255,255,255,.3);opacity:.7}.sidebar-new:hover{opacity:1;border-color:#ffffff80}.sidebar-upload{margin-top:auto;padding:var(--spacing-4);border:2px dashed rgba(255,255,255,.3);border-radius:var(--radius-lg);text-align:center;cursor:pointer;transition:all var(--transition-fast);color:#fffc;position:relative}.sidebar-upload:hover,.sidebar-upload.dragging{border-color:var(--color-primary);background:#6366f11a}.sidebar-upload .upload-icon{font-size:1.5rem;display:block;margin-bottom:var(--spacing-1)}.sidebar-upload small{display:block;font-size:var(--font-size-xs);opacity:.7;margin-top:var(--spacing-1)}.sidebar-upload.uploading{pointer-events:none;opacity:.7}.photos-main{flex:1;min-width:0}.photos-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:var(--spacing-3);margin-bottom:var(--spacing-4)}.breadcrumbs{display:flex;align-items:center;flex-wrap:wrap;gap:var(--spacing-1)}.breadcrumbs button{background:none;border:none;color:#ffffffb3;font-family:var(--font-family);font-size:var(--font-size-base);cursor:pointer;padding:var(--spacing-1) var(--spacing-2);border-radius:var(--radius-md);transition:all var(--transition-fast)}.breadcrumbs button:hover{color:#fff;background:#ffffff1a}.breadcrumbs button.active{color:#fff;font-weight:600}.breadcrumb-sep{color:#fff6;margin:0 var(--spacing-1)}.new-folder-btn{color:#fffc;border:1px dashed rgba(255,255,255,.4);white-space:nowrap}.new-folder-btn:hover{color:#fff;border-color:#fff9;background:#ffffff1a}.folders-section{margin-bottom:var(--spacing-4)}.section-header h3{color:var(--color-gray-800);font-size:var(--font-size-sm);text-transform:uppercase;letter-spacing:.5px;opacity:.9;margin:0}.photo-count{color:#fff9;font-size:var(--font-size-xs)}.folders-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:var(--spacing-3)}.folder-card{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-4);cursor:pointer;transition:all var(--transition-fast);text-align:center}.folder-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.folder-icon{font-size:2rem;margin-bottom:var(--spacing-2)}.folder-name{font-size:var(--font-size-xs);font-weight:500;color:var(--color-gray-800);word-break:break-word}.folder-delete-btn{position:absolute;top:var(--spacing-1);right:var(--spacing-1);width:22px;height:22px;border-radius:var(--radius-full);background:var(--color-gray-200);border:none;cursor:pointer;opacity:0;transition:all var(--transition-fast);font-size:.875rem;line-height:1;color:var(--color-gray-600)}.folder-card:hover .folder-delete-btn{opacity:1}.folder-delete-btn:hover{background:var(--color-error);color:#fff}.upload-zone-mobile{position:relative;border:2px dashed var(--color-gray-300);background:var(--color-gray-50);border-radius:var(--radius-xl);padding:var(--spacing-4);text-align:center;cursor:pointer;transition:all var(--transition-base);margin-bottom:var(--spacing-4)}@media(min-width:900px){.upload-zone-mobile{display:none}}.upload-zone-mobile:hover,.upload-zone-mobile.dragging{border-color:var(--color-primary);background:#6366f10d}.upload-zone-mobile.uploading{pointer-events:none;opacity:.7}.upload-content{pointer-events:none}.upload-icon{font-size:2rem;display:block;margin-bottom:var(--spacing-2)}.upload-icon.spinning{animation:pulse 1s ease-in-out infinite}.upload-zone-mobile h3{margin-bottom:var(--spacing-1);font-size:var(--font-size-base)}.upload-zone-mobile p{color:var(--color-gray-500);font-size:var(--font-size-xs)}.file-input{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.photos-section{margin-top:var(--spacing-2)}.photo-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:var(--spacing-3)}@media(min-width:900px){.photo-gallery{grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}}.photo-card{position:relative;aspect-ratio:1;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-md);cursor:pointer;transition:all var(--transition-base)}.photo-card:hover{transform:scale(1.02);box-shadow:var(--shadow-xl)}.photo-card img{width:100%;height:100%;object-fit:cover}.photo-overlay{position:absolute;bottom:0;left:0;right:0;padding:var(--spacing-2);background:linear-gradient(transparent,#000000b3);color:#fff;opacity:0;transition:opacity var(--transition-fast)}.photo-card:hover .photo-overlay{opacity:1}.raw-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;height:100%;background:linear-gradient(135deg,var(--color-gray-200) 0%,var(--color-gray-300) 100%)}.raw-placeholder.fallback{display:none;position:absolute;inset:0}.raw-placeholder.fallback.show{display:flex}.raw-icon{font-size:2.5rem;margin-bottom:var(--spacing-1)}.raw-label{font-size:var(--font-size-xs);font-weight:600;color:var(--color-gray-600);text-transform:uppercase;letter-spacing:1px}.photo-card.raw-file .photo-overlay{opacity:1;background:#0009}.photo-name{display:block;font-size:10px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.photo-size{font-size:10px;opacity:.8}.delete-photo-btn{position:absolute;top:var(--spacing-1);right:var(--spacing-1);width:28px;height:28px;border-radius:var(--radius-full);background:#00000080;border:none;cursor:pointer;opacity:0;transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center;font-size:14px}.photo-card:hover .delete-photo-btn{opacity:1}.delete-photo-btn:hover{background:#ef4444cc}.loading-state,.empty-state{text-align:center;padding:var(--spacing-8)}.empty-state h3{margin-bottom:var(--spacing-2)}.empty-state p{color:var(--color-gray-500);font-size:var(--font-size-sm)}.lightbox{position:fixed;inset:0;background:#000000e6;z-index:var(--z-modal);display:flex;align-items:center;justify-content:center;padding:var(--spacing-6);animation:fadeIn var(--transition-fast)}.lightbox-content{position:relative;max-width:90vw;max-height:90vh;display:flex;flex-direction:column;align-items:center}.lightbox-content img{max-width:100%;max-height:80vh;object-fit:contain;border-radius:var(--radius-lg);box-shadow:var(--shadow-xl)}.lightbox-close{position:absolute;top:-40px;right:0;width:32px;height:32px;border-radius:var(--radius-full);background:#ffffff1a;border:none;color:#fff;font-size:1.25rem;cursor:pointer;transition:all var(--transition-fast)}.lightbox-close:hover{background:#fff3}.lightbox-info{margin-top:var(--spacing-4);text-align:center;color:#fff}.lightbox-info h4{color:#fff;margin-bottom:var(--spacing-1)}.lightbox-info p{font-size:var(--font-size-sm);opacity:.8}.modal-overlay{position:fixed;inset:0;background:#00000080;z-index:var(--z-modal);display:flex;align-items:center;justify-content:center;padding:var(--spacing-4)}.modal{width:100%;max-width:400px;padding:var(--spacing-6)}.modal h3{margin-bottom:var(--spacing-4)}.folder-name-input{width:100%;margin-bottom:var(--spacing-4)}.modal-actions{display:flex;justify-content:flex-end;gap:var(--spacing-2)}.upload-progress-panel{margin-bottom:var(--spacing-4);padding:var(--spacing-3)}.progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-2);font-size:var(--font-size-sm);font-weight:500}.progress-list{display:flex;flex-direction:column;gap:var(--spacing-2);max-height:150px;overflow-y:auto}.progress-item{display:flex;align-items:center;gap:var(--spacing-2);font-size:var(--font-size-xs)}.progress-name{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:150px}.progress-bar{flex:2;height:6px;background:var(--color-gray-200);border-radius:var(--radius-full);overflow:hidden}.progress-fill{height:100%;background:var(--color-primary);transition:width .2s}.progress-percent{width:35px;text-align:right}.progress-item.complete .progress-fill{background:var(--color-success)}.progress-item.error .progress-fill{background:var(--color-error)}.section-actions{display:flex;align-items:center;gap:var(--spacing-2);flex-wrap:wrap}.photo-card.selection-mode{cursor:pointer}.photo-card.selected{outline:3px solid var(--color-primary);outline-offset:-3px}.photo-checkbox{position:absolute;top:var(--spacing-2);left:var(--spacing-2);z-index:10}.photo-checkbox input{width:20px;height:20px;cursor:pointer;accent-color:var(--color-primary)}.btn-danger{background:var(--color-error);color:#fff;border:none}.btn-danger:disabled{opacity:.5;cursor:not-allowed}.cancel-btn{margin-top:var(--spacing-1);padding:var(--spacing-1) var(--spacing-2);font-size:var(--font-size-xs);background:#fff3;border:none;border-radius:var(--radius-md);color:#fff;cursor:pointer}.cancel-btn:hover{background:#ffffff4d}@media(max-width:899px){.photos-page{flex-direction:column}.folders-grid{grid-template-columns:repeat(3,1fr)}.photo-gallery{grid-template-columns:repeat(2,1fr);gap:var(--spacing-2)}.section-actions{width:100%;justify-content:flex-start}}@media(max-width:480px){.folders-grid{grid-template-columns:repeat(2,1fr)}}.resolutions-page{max-width:700px;margin:0 auto}.resolutions-header{text-align:center;margin-bottom:var(--spacing-6);color:var(--color-gray-800)}.resolutions-header h1{color:var(--color-gray-800);display:flex;align-items:center;justify-content:center;gap:var(--spacing-2)}.resolutions-header p{opacity:.9}.back-btn{background:#fff3;border:none;color:#fff;padding:var(--spacing-2) var(--spacing-4);border-radius:var(--radius-full);cursor:pointer;font-family:var(--font-family);font-size:var(--font-size-sm);margin-bottom:var(--spacing-4);transition:all var(--transition-fast)}.back-btn:hover{background:#ffffff4d}.person-icon-sm{font-size:1.5rem}.progress-badge{display:inline-block;background:#fff3;padding:var(--spacing-1) var(--spacing-3);border-radius:var(--radius-full);font-size:var(--font-size-sm);margin-top:var(--spacing-2)}.person-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-4)}.person-card{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-8);cursor:pointer;transition:all var(--transition-base);border:2px solid transparent}.person-card:hover{transform:translateY(-4px);border-color:var(--person-color);box-shadow:0 8px 30px #00000026}.person-icon{font-size:4rem;margin-bottom:var(--spacing-3)}.person-name{font-size:var(--font-size-lg);font-weight:600;color:var(--color-gray-800)}.add-resolution-form{display:flex;gap:var(--spacing-3);padding:var(--spacing-4);margin-bottom:var(--spacing-4)}.resolution-input{flex:1}.resolutions-list{padding:var(--spacing-2)}.resolution-item{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-3) var(--spacing-4);border-radius:var(--radius-lg);transition:all var(--transition-fast)}.resolution-item:hover{background:var(--color-gray-50)}.resolution-item .checkbox-wrapper{flex:1}.resolution-text{font-size:var(--font-size-base)}.resolution-item.completed .resolution-text{text-decoration:line-through;color:var(--color-gray-400)}.resolution-item .delete-btn{opacity:1!important;position:static!important;visibility:visible!important}.resolution-actions{display:flex;align-items:center;gap:var(--spacing-1)}.year-selector{display:flex;align-items:center;justify-content:center;gap:var(--spacing-3);margin-bottom:var(--spacing-4)}.year-display{font-size:var(--font-size-2xl);font-weight:700;color:#fff;min-width:100px;text-align:center}.year-nav{font-size:var(--font-size-xl);padding:var(--spacing-2) var(--spacing-3)}.year-nav:disabled{opacity:.3;cursor:not-allowed}.edit-form{display:flex;align-items:center;gap:var(--spacing-2);width:100%}.edit-input{flex:1;padding:var(--spacing-2) var(--spacing-3);border:2px solid var(--color-primary);border-radius:var(--radius-md);font-size:var(--font-size-base);font-family:var(--font-family)}.edit-input:focus{outline:none;box-shadow:0 0 0 3px #667eea33}.wishlist-page{max-width:700px;margin:0 auto;padding-bottom:calc(100px + env(safe-area-inset-bottom,0px))}.wishlist-header{text-align:center;margin-bottom:var(--spacing-6);color:var(--color-gray-800)}.wishlist-header h1{color:var(--color-gray-800)}.wishlist-header p{opacity:.9}.add-idea-form{display:flex;gap:var(--spacing-3);padding:var(--spacing-4);margin-bottom:var(--spacing-4)}.idea-input{flex:1}.filter-tabs{display:flex;gap:var(--spacing-2);margin-bottom:var(--spacing-4);overflow-x:auto;padding-bottom:var(--spacing-2)}.filter-tab{padding:var(--spacing-2) var(--spacing-4);background:#fff3;border:none;border-radius:var(--radius-full);color:#fff;cursor:pointer;font-family:var(--font-family);font-size:var(--font-size-sm);white-space:nowrap;transition:all var(--transition-fast)}.filter-tab:hover{background:#ffffff4d}.filter-tab.active{background:#fff;color:var(--color-primary)}.ideas-list{padding:var(--spacing-2)}.idea-item{display:flex;align-items:center;gap:var(--spacing-3);padding:var(--spacing-3) var(--spacing-4);border-radius:var(--radius-lg);transition:all var(--transition-fast)}.idea-item:hover{background:var(--color-gray-50)}.idea-item.status-done{opacity:.6}.vote-btn{display:flex;flex-direction:column;align-items:center;padding:var(--spacing-2);background:var(--color-gray-100);border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);min-width:44px}.vote-btn:hover{background:var(--color-primary);color:#fff}.vote-btn:hover .vote-arrow{color:#fff}.vote-arrow{font-size:var(--font-size-sm);color:var(--color-primary);line-height:1}.vote-count{font-size:var(--font-size-sm);font-weight:600;color:var(--color-gray-700)}.vote-btn:hover .vote-count{color:#fff}.idea-content{flex:1}.idea-text{display:flex;align-items:center;gap:var(--spacing-2)}.status-emoji{flex-shrink:0}.idea-actions{display:flex;align-items:center;gap:var(--spacing-2)}.idea-item .delete-btn{opacity:0}.idea-item:hover .delete-btn{opacity:1}.empty-state,.loading-state{text-align:center;padding:var(--spacing-10);color:var(--color-gray-500)}@media(max-width:480px){.idea-actions{flex-direction:column}.status-select{width:100%}}.completed-section{margin-top:var(--spacing-6)}.completed-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-3);color:#fff}.completed-header h3{margin:0;font-size:var(--font-size-base);opacity:.8}.completed-list{background:#ffffffd9}.idea-item.done .idea-text{text-decoration:line-through;opacity:.6}.idea-item.done .vote-btn{opacity:.4;cursor:not-allowed}.idea-item.done .vote-btn:hover{background:var(--color-gray-100);color:inherit}.idea-item.done .vote-btn:hover .vote-arrow{color:var(--color-primary)}.health-page{max-width:1200px;margin:0 auto;padding-bottom:calc(100px + env(safe-area-inset-bottom,0px))}@media(min-width:768px){.health-page{padding-bottom:0}}.health-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:var(--spacing-4);margin-bottom:var(--spacing-6)}.health-header h1{color:var(--color-gray-800);margin:0}.person-toggle{display:flex;background:var(--glass-bg);border:var(--glass-border);border-radius:var(--radius-full);padding:var(--spacing-1)}.person-btn{display:flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-2) var(--spacing-4);border:none;background:transparent;color:#ffffffb3;font-family:var(--font-family);font-size:var(--font-size-sm);border-radius:var(--radius-full);cursor:pointer;transition:all var(--transition-fast)}.person-btn:hover{color:#fff}.person-btn.active{background:#fff;color:var(--color-primary);font-weight:600}.person-emoji{font-size:1.2rem}.health-grid{display:grid;grid-template-columns:1fr;gap:var(--spacing-6)}@media(min-width:900px){.health-grid{grid-template-columns:1fr 1fr}}.health-section{padding:var(--spacing-5)}.health-section .section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-4);flex-wrap:wrap;gap:var(--spacing-2)}.health-section h2{margin:0;font-size:var(--font-size-lg);color:#1f2937!important}.section-title-row{display:flex;align-items:center;gap:var(--spacing-2)}.section-title-row .goals-btn{font-size:1rem;padding:var(--spacing-1)}.hidden-input{display:none}.date-nav{display:flex;align-items:center;justify-content:center;gap:var(--spacing-3);margin-bottom:var(--spacing-4);padding:var(--spacing-2);background:var(--color-gray-50);border-radius:var(--radius-lg)}.date-nav-btn{width:32px;height:32px;border-radius:var(--radius-full);border:none;background:#fff;color:var(--color-gray-600);font-size:1.25rem;cursor:pointer;transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center}.date-nav-btn:hover:not(:disabled){background:var(--color-primary);color:#fff}.date-nav-btn:disabled{opacity:.3;cursor:not-allowed}.date-label{font-weight:600;min-width:100px;text-align:center}.totals-bar{display:flex;align-items:center;justify-content:center;gap:var(--spacing-6);padding:var(--spacing-4);background:linear-gradient(135deg,#6366f11a,#a855f71a);border-radius:var(--radius-lg);margin-bottom:var(--spacing-4)}.total-item{text-align:center}.total-value{display:block;font-size:var(--font-size-2xl);font-weight:700;color:var(--color-primary)}.total-label{font-size:var(--font-size-xs);color:var(--color-gray-500);text-transform:uppercase;letter-spacing:.5px}.total-divider{width:1px;height:40px;background:var(--color-gray-300)}.goals-btn{padding:var(--spacing-2);background:transparent;border:none;cursor:pointer;font-size:1.25rem;opacity:.6;transition:all var(--transition-fast)}.goals-btn:hover{opacity:1;transform:scale(1.1)}.progress-bar-mini{width:100%;height:4px;background:var(--color-gray-200);border-radius:var(--radius-full);margin-top:var(--spacing-1);overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--color-primary),var(--color-secondary));border-radius:var(--radius-full);transition:width var(--transition-fast)}.progress-fill.over{background:linear-gradient(90deg,#ef4444,#f97316)}.progress-fill.protein{background:linear-gradient(90deg,#22c55e,#10b981)}.total-value.over-goal{color:#ef4444}.total-value.under-goal{color:#f59e0b}.goals-form{display:flex;flex-direction:column;gap:var(--spacing-4);margin-bottom:var(--spacing-4)}.goals-form label{display:flex;flex-direction:column;gap:var(--spacing-1)}.goals-form label span{font-size:var(--font-size-sm);color:var(--color-gray-600)}.goals-form input{padding:var(--spacing-3);border:1px solid var(--color-gray-300);border-radius:var(--radius-md);font-size:var(--font-size-lg);font-family:var(--font-family)}.goals-form input:focus{outline:none;border-color:var(--color-primary)}.modal-actions{display:flex;gap:var(--spacing-2);justify-content:flex-end}.food-list{display:flex;flex-direction:column;gap:var(--spacing-3)}.food-item{display:flex;gap:var(--spacing-3);padding:var(--spacing-3);background:var(--color-gray-50);border-radius:var(--radius-lg);position:relative}.food-thumbnail{width:60px;height:60px;object-fit:cover;border-radius:var(--radius-md);flex-shrink:0}.food-info{flex:1;min-width:0}.food-description{margin:0 0 var(--spacing-1);font-size:var(--font-size-sm);font-weight:500;line-height:1.4}.food-stats{display:flex;flex-wrap:wrap;gap:var(--spacing-2);font-size:var(--font-size-xs);color:var(--color-gray-500)}.food-time{margin-left:auto}.health-page .delete-btn{position:absolute;top:var(--spacing-2);right:var(--spacing-2);width:24px;height:24px;border-radius:var(--radius-full);border:none;background:var(--color-gray-200);color:var(--color-gray-600);cursor:pointer;font-size:1rem;line-height:1;opacity:0;transition:all var(--transition-fast)}.food-item:hover .delete-btn,.workout-item:hover .delete-btn{opacity:1}.health-page .delete-btn:hover{background:var(--color-error);color:#fff}.workout-progress{text-align:center;padding:var(--spacing-4);margin-bottom:var(--spacing-4)}.progress-ring{font-size:var(--font-size-3xl);font-weight:700;color:var(--color-primary);margin-bottom:var(--spacing-3)}.progress-goal{font-size:var(--font-size-lg);color:var(--color-gray-400);font-weight:400}.progress-dots{display:flex;justify-content:center;gap:var(--spacing-2);margin-bottom:var(--spacing-2)}.progress-dot{width:16px;height:16px;border-radius:var(--radius-full);background:var(--color-gray-200);transition:all var(--transition-fast)}.progress-dot.filled{background:linear-gradient(135deg,var(--color-primary),var(--color-secondary))}.progress-dot.kids.filled{background:linear-gradient(135deg,#10b981,#059669)}.kids-exercise-desc{text-align:center;color:var(--color-gray-500);font-size:var(--font-size-sm);margin:0 0 var(--spacing-3)}.progress-message{font-size:var(--font-size-sm);color:var(--color-gray-500);margin:0}.workout-list{display:flex;flex-direction:column;gap:var(--spacing-2)}.workout-item{display:flex;align-items:center;gap:var(--spacing-3);padding:var(--spacing-3);background:var(--color-gray-50);border-radius:var(--radius-md);position:relative}.workout-type{font-weight:500;flex:1}.workout-date{font-size:var(--font-size-xs);color:var(--color-gray-500);margin-right:var(--spacing-6)}.workout-type-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-2);margin-bottom:var(--spacing-4)}.workout-type-btn{padding:var(--spacing-3);border:1px solid var(--color-gray-200);background:#fff;border-radius:var(--radius-md);cursor:pointer;font-family:var(--font-family);font-size:var(--font-size-sm);transition:all var(--transition-fast)}.workout-type-btn:hover{background:var(--color-gray-50);border-color:var(--color-primary)}.health-section .empty-state{text-align:center;padding:var(--spacing-6);color:var(--color-gray-500)}.health-section .empty-state p{margin:0 0 var(--spacing-1)}.health-section .empty-state small{font-size:var(--font-size-xs)}.health-page .loading-state{text-align:center;padding:var(--spacing-8)}.health-page .modal{max-width:400px}.health-page .modal h3{margin:0 0 var(--spacing-4);text-align:center}.log-food-form{display:flex;flex-direction:column;gap:var(--spacing-4);margin-bottom:var(--spacing-4)}.log-food-form label{display:flex;flex-direction:column;gap:var(--spacing-1)}.log-food-form label span{font-size:var(--font-size-sm);color:var(--color-gray-600)}.log-food-form textarea{padding:var(--spacing-3);border:1px solid var(--color-gray-300);border-radius:var(--radius-md);font-size:var(--font-size-base);font-family:var(--font-family);resize:vertical}.log-food-form textarea:focus{outline:none;border-color:var(--color-primary)}.photo-upload-section{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-2)}.photo-upload-btn{padding:var(--spacing-4) var(--spacing-6);border:2px dashed var(--color-gray-300);border-radius:var(--radius-lg);background:transparent;font-size:var(--font-size-base);color:var(--color-gray-600);cursor:pointer;transition:all var(--transition-fast);width:100%}.photo-upload-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.photo-preview{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-2)}.photo-preview img{max-width:100%;max-height:200px;border-radius:var(--radius-md);object-fit:cover}.edit-food-current{font-size:var(--font-size-sm);color:var(--color-gray-500);margin:0 0 var(--spacing-3);text-align:center}.food-actions{display:flex;flex-direction:row;gap:var(--spacing-2);flex-shrink:0;align-items:center}.food-item .edit-btn,.food-item .delete-btn{background:transparent;border:none;font-size:1.25rem;cursor:pointer;opacity:.6;transition:opacity var(--transition-fast);padding:var(--spacing-2);min-width:36px;min-height:36px;display:flex;align-items:center;justify-content:center}.food-item .edit-btn:hover,.food-item .delete-btn:hover{opacity:1}.food-context{font-size:var(--font-size-xs);color:var(--color-gray-500);margin-top:var(--spacing-1);font-style:italic}.food-thumbnail-placeholder{width:60px;height:60px;border-radius:var(--radius-md);background:var(--color-gray-100);display:flex;align-items:center;justify-content:center;font-size:1.5rem;flex-shrink:0}.portion-selector{display:flex;gap:2px;margin-top:var(--spacing-2);background:var(--color-gray-200);border-radius:var(--radius-md);padding:2px;width:fit-content}.portion-btn{padding:var(--spacing-1) var(--spacing-2);border:none;background:transparent;color:var(--color-gray-600);font-size:var(--font-size-xs);font-weight:500;cursor:pointer;border-radius:calc(var(--radius-md) - 2px);transition:all var(--transition-fast);min-width:36px}.portion-btn:hover{background:var(--color-gray-100)}.portion-btn.active{background:#fff;color:var(--color-primary);box-shadow:0 1px 2px #0000001a}@media(max-width:480px){.portion-btn{padding:var(--spacing-1);min-width:32px;font-size:11px}}.trips-page{max-width:1000px;margin:0 auto;padding-bottom:calc(100px + env(safe-area-inset-bottom,0px))}.trips-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-6);color:var(--color-gray-800)}.trips-header h1{margin:0;color:var(--color-gray-800)}.trips-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--spacing-4)}.trip-card{position:relative;text-decoration:none;color:inherit;padding:var(--spacing-5);transition:all var(--transition-fast);cursor:pointer}.trip-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.trip-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-2)}.trip-card h3{margin:0;font-size:var(--font-size-lg);color:var(--color-primary)}.trip-days{background:linear-gradient(135deg,var(--color-primary),var(--color-secondary));color:#fff;padding:var(--spacing-1) var(--spacing-2);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:600}.trip-dates{font-size:var(--font-size-sm);color:var(--color-gray-600);margin:0 0 var(--spacing-2)}.trip-description{font-size:var(--font-size-sm);color:var(--color-gray-500);margin:0;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.trip-card .delete-btn{position:absolute;top:var(--spacing-3);right:var(--spacing-3);opacity:0}.trip-card:hover .delete-btn{opacity:1}.trip-form{display:flex;flex-direction:column;gap:var(--spacing-4)}.trip-form label{display:flex;flex-direction:column;gap:var(--spacing-1)}.trip-form label span{font-size:var(--font-size-sm);color:var(--color-gray-600);font-weight:500}.trip-form input,.trip-form textarea{padding:var(--spacing-3);border:1px solid var(--color-gray-300);border-radius:var(--radius-md);font-size:var(--font-size-base);font-family:var(--font-family)}.trip-form input:focus,.trip-form textarea:focus{outline:none;border-color:var(--color-primary)}.trips-page .empty-state,.trips-page .loading-state{text-align:center;padding:var(--spacing-10);color:var(--color-gray-500)}.trip-detail-page{max-width:1200px;margin:0 auto}.trip-detail-header{display:flex;align-items:center;gap:var(--spacing-4);margin-bottom:var(--spacing-6);color:var(--color-gray-800)}.trip-title{flex:1}.trip-title h1{margin:0;color:var(--color-gray-800)}.trip-date-range{margin:var(--spacing-1) 0 0;opacity:.8;font-size:var(--font-size-sm)}.trip-layout{display:grid;grid-template-columns:240px 1fr;gap:var(--spacing-4)}.days-sidebar{padding:var(--spacing-4);height:fit-content;position:sticky;top:var(--spacing-4)}.days-sidebar h3{margin:0 0 var(--spacing-3);font-size:var(--font-size-sm);color:var(--color-gray-500);text-transform:uppercase;letter-spacing:.05em}.day-item{display:flex;flex-direction:column;align-items:flex-start;width:100%;padding:var(--spacing-2) var(--spacing-3);margin-bottom:var(--spacing-1);border:none;background:transparent;border-radius:var(--radius-md);cursor:pointer;text-align:left;transition:all var(--transition-fast);position:relative}.day-item:hover{background:var(--color-gray-100)}.day-item.active{background:linear-gradient(135deg,var(--color-primary),var(--color-secondary));color:#fff}.day-date{font-weight:500;font-size:var(--font-size-sm)}.day-hub{font-size:var(--font-size-xs);opacity:.7}.day-count{position:absolute;right:var(--spacing-2);top:50%;transform:translateY(-50%);background:var(--color-gray-200);padding:2px 6px;border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:600}.day-item.active .day-count{background:#ffffff4d}.trip-main{display:flex;flex-direction:column;gap:var(--spacing-4)}.day-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-4)}.day-header h2{margin:0}.current-hub{font-size:var(--font-size-sm);color:var(--color-gray-500);margin-left:var(--spacing-2)}.hubs-section{padding:var(--spacing-4)}.hubs-section h3{margin:0 0 var(--spacing-3)}.hubs-list{display:flex;flex-wrap:wrap;gap:var(--spacing-2)}.hub-item{display:flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-2) var(--spacing-3);background:linear-gradient(135deg,#6366f11a,#a855f71a);border-radius:var(--radius-lg)}.hub-name{font-weight:600}.hub-dates{font-size:var(--font-size-xs);color:var(--color-gray-500)}.items-section{padding:var(--spacing-4)}.items-section h3{margin:0 0 var(--spacing-3);font-size:var(--font-size-base)}.items-list{display:flex;flex-direction:column;gap:var(--spacing-2)}.item-card{display:flex;flex-wrap:wrap;align-items:flex-start;gap:var(--spacing-3);padding:var(--spacing-3);background:var(--color-gray-50);border-radius:var(--radius-md);border-left:3px solid var(--color-gray-300)}.item-card.status-idea{border-left-color:var(--color-gray-400)}.item-card.status-planned{border-left-color:#f59e0b}.item-card.status-booked{border-left-color:#10b981}.item-main{flex:1;min-width:200px}.item-title{font-weight:500;display:block}.item-notes{font-size:var(--font-size-sm);color:var(--color-gray-600);margin:var(--spacing-1) 0 0}.item-location{font-size:var(--font-size-xs);color:var(--color-gray-500)}.item-actions{display:flex;align-items:center;gap:var(--spacing-2)}.status-select{padding:var(--spacing-1) var(--spacing-2);border:1px solid var(--color-gray-200);border-radius:var(--radius-md);background:#fff;font-size:var(--font-size-xs);cursor:pointer}.comment-btn{background:transparent;border:none;cursor:pointer;font-size:1rem;opacity:.5}.comment-btn:hover{opacity:1}.item-comment{width:100%;padding:var(--spacing-2);background:#fff;border-radius:var(--radius-sm);font-size:var(--font-size-sm);margin-top:var(--spacing-2)}.type-selector{display:flex;gap:var(--spacing-2);flex-wrap:wrap;margin-bottom:var(--spacing-3)}.type-btn{padding:var(--spacing-2) var(--spacing-3);border:1px solid var(--color-gray-200);border-radius:var(--radius-md);background:#fff;cursor:pointer;font-size:var(--font-size-sm);transition:all var(--transition-fast)}.type-btn:hover{border-color:var(--color-primary)}.type-btn.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.item-form,.hub-form{display:flex;flex-direction:column;gap:var(--spacing-4)}.item-form label,.hub-form label{display:flex;flex-direction:column;gap:var(--spacing-1)}.item-form label span,.hub-form label span{font-size:var(--font-size-sm);color:var(--color-gray-600)}.item-form input,.item-form textarea,.item-form select,.hub-form input{padding:var(--spacing-3);border:1px solid var(--color-gray-300);border-radius:var(--radius-md);font-size:var(--font-size-base);font-family:var(--font-family)}.date-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-3)}.trip-detail-page .empty-state{text-align:center;padding:var(--spacing-6);color:var(--color-gray-500)}.trip-detail-page .loading-state{text-align:center;padding:var(--spacing-10)}.items-section .delete-btn,.hubs-list .delete-btn{opacity:.5;position:static;width:auto;height:auto}.items-section .delete-btn:hover,.hubs-list .delete-btn:hover{opacity:1}.ai-panel{padding:var(--spacing-4);min-width:320px;max-width:400px;height:fit-content;position:sticky;top:var(--spacing-4)}.ai-panel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-3)}.close-btn{background:transparent;border:none;font-size:1.5rem;cursor:pointer;opacity:.5;line-height:1}.close-btn:hover{opacity:1}.ai-form{display:flex;flex-direction:column;gap:var(--spacing-3);margin-bottom:var(--spacing-4)}.ai-form textarea{padding:var(--spacing-3);border:1px solid var(--color-gray-300);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-family:var(--font-family);resize:vertical}.ai-form textarea:focus{outline:none;border-color:var(--color-primary)}.ai-summary{font-size:var(--font-size-sm);color:var(--color-gray-600);padding:var(--spacing-3);background:var(--color-gray-50);border-radius:var(--radius-md);margin-bottom:var(--spacing-3)}.suggestions-list{display:flex;flex-direction:column;gap:var(--spacing-3)}.suggestion-card{padding:var(--spacing-3);background:linear-gradient(135deg,#6366f10d,#a855f70d);border-radius:var(--radius-md);border:1px solid rgba(99,102,241,.2)}.suggestion-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-1)}.suggestion-type{font-size:var(--font-size-xs);color:var(--color-primary);text-transform:capitalize}.suggestion-cost{font-size:var(--font-size-xs);color:var(--color-gray-500);font-weight:600}.suggestion-title{margin:0 0 var(--spacing-1);font-size:var(--font-size-base)}.suggestion-notes{font-size:var(--font-size-sm);color:var(--color-gray-600);margin:0 0 var(--spacing-2)}.suggestion-location{font-size:var(--font-size-xs);color:var(--color-gray-500);display:block;margin-bottom:var(--spacing-2)}.btn-sm{padding:var(--spacing-1) var(--spacing-2);font-size:var(--font-size-xs)}.trip-layout.with-ai{grid-template-columns:240px 1fr 350px}@media(max-width:900px){.trip-layout,.trip-layout.with-ai{grid-template-columns:1fr}.days-sidebar,.ai-panel{position:static;width:100%;max-width:none;height:auto;margin-bottom:var(--spacing-4)}.days-sidebar{display:flex;overflow-x:auto;padding-bottom:var(--spacing-2);gap:var(--spacing-2)}.day-item{width:auto;min-width:120px;margin-bottom:0;flex-shrink:0}.day-count{top:var(--spacing-2);right:var(--spacing-2);transform:none}}.explorer-page{padding:1rem;max-width:1400px;margin:0 auto}.explorer-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.header-left{display:flex;flex-direction:column;gap:.25rem}.header-left .back-link{color:var(--accent);text-decoration:none;font-size:.9rem}.header-left h1{margin:0;font-size:1.75rem}.header-left .trip-name{color:var(--text-secondary);margin:0}.header-actions{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}.person-select{background:var(--surface);border:1px solid var(--border);color:var(--text);padding:.5rem;border-radius:.375rem;font-size:.9rem}.explorer-layout{display:flex;gap:1.5rem}.explorer-layout.with-ai .explorer-main{flex:1;max-width:calc(100% - 380px)}.explorer-main{flex:1}.itineraries-grid{display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.itinerary-card{background:var(--surface);border:1px solid var(--border);border-radius:.75rem;padding:1rem;transition:all .2s}.itinerary-card:hover{border-color:var(--accent)}.itinerary-card.favorite{border-color:gold;box-shadow:0 0 12px #ffd70033}.itinerary-card.discarded{opacity:.6}.itinerary-card.expanded{grid-column:1 / -1}.itinerary-header{margin-bottom:.75rem}.itinerary-title-row{display:flex;align-items:center;gap:.5rem}.itinerary-title-row h3{margin:0;font-size:1.1rem}.itinerary-title-row .star{font-size:1rem}.ai-badge{font-size:.7rem;background:linear-gradient(135deg,var(--accent),#9333ea);color:#fff;padding:.15rem .4rem;border-radius:.25rem}.itinerary-meta{display:flex;justify-content:space-between;color:var(--text-secondary);font-size:.85rem;margin-top:.25rem}.itinerary-timeline{display:flex;gap:.25rem;flex-wrap:wrap;margin:.75rem 0;padding:.5rem;background:var(--bg);border-radius:.5rem}.timeline-stop{display:flex;align-items:center;gap:.35rem;padding:.25rem .5rem;background:var(--surface);border-radius:.375rem;border:1px solid var(--border)}.stop-marker{width:1.25rem;height:1.25rem;display:flex;align-items:center;justify-content:center;background:var(--accent);color:#fff;border-radius:50%;font-size:.7rem;font-weight:700}.stop-info{display:flex;flex-direction:column}.stop-city{font-size:.8rem;font-weight:500}.stop-days{font-size:.7rem;color:var(--text-secondary)}.itinerary-ratings{display:flex;gap:1rem;margin:.75rem 0}.rating-group{display:flex;align-items:center;gap:.25rem}.rating-label{font-size:.8rem;color:var(--text-secondary)}.rating-btn{padding:.25rem .4rem;background:transparent;border:1px solid var(--border);border-radius:.25rem;cursor:pointer;font-size:.9rem;transition:all .2s}.rating-btn:hover{background:var(--surface-hover)}.rating-btn.active{background:var(--accent);border-color:var(--accent)}.itinerary-actions{display:flex;flex-wrap:wrap;gap:.25rem;margin-top:.5rem;padding-top:.5rem;border-top:1px solid var(--border)}.itinerary-actions .btn{font-size:.75rem;padding:.25rem .5rem}.text-danger{color:#ef4444}.itinerary-expanded{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border)}.comments-section h4,.stops-edit-section h4{margin:0 0 .5rem;font-size:.9rem}.no-comments{color:var(--text-secondary);font-size:.85rem}.comment{background:var(--bg);padding:.5rem;border-radius:.375rem;margin-bottom:.5rem;font-size:.85rem}.comment-form{display:flex;gap:.5rem;margin-top:.5rem}.comment-form input{flex:1;padding:.5rem;background:var(--bg);border:1px solid var(--border);border-radius:.375rem;color:var(--text)}.stops-edit-section{margin-top:1rem}.stop-edit-row{display:flex;justify-content:space-between;align-items:center;padding:.5rem;background:var(--bg);border-radius:.375rem;margin-bottom:.25rem}.stop-edit-row .delete-btn{background:none;border:none;color:#ef4444;cursor:pointer;font-size:1.2rem}.discarded-section{margin-top:2rem}.discarded-toggle{color:var(--text-secondary)}.discarded-grid{display:grid;gap:.75rem;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));margin-top:.75rem}.ai-panel{width:360px;flex-shrink:0;padding:1rem;max-height:calc(100vh - 140px);overflow-y:auto;position:sticky;top:1rem}.ai-panel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.ai-panel-header h3{margin:0}.close-btn{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--text-secondary)}.ai-form{display:flex;flex-direction:column;gap:.75rem}.ai-form textarea{width:100%;padding:.75rem;background:var(--bg);border:1px solid var(--border);border-radius:.5rem;color:var(--text);font-family:inherit;resize:vertical}.ai-summary{padding:.75rem;background:var(--bg);border-radius:.5rem;font-size:.9rem;color:var(--text-secondary)}.suggestions-list{display:flex;flex-direction:column;gap:.75rem;margin-top:1rem}.suggestion-card{background:var(--bg);padding:.75rem;border-radius:.5rem;border:1px solid var(--border)}.suggestion-card h4{margin:0 0 .25rem;font-size:1rem}.suggestion-flight{font-size:.85rem;color:var(--text-secondary)}.suggestion-reasoning{font-size:.8rem;color:var(--text-secondary);margin:.5rem 0}.suggestion-stops{display:flex;flex-wrap:wrap;gap:.25rem;margin:.5rem 0}.suggestion-stop{font-size:.75rem;background:var(--surface);padding:.2rem .5rem;border-radius:.25rem}.refine-section{border-bottom:1px solid var(--border);padding-bottom:1rem;margin-bottom:1rem}.refine-target-name{font-weight:500;margin-bottom:.75rem}.refinement-result{margin-top:1rem;padding:.75rem;background:var(--bg);border-radius:.5rem}.refinement-result h5{margin:0 0 .5rem}.refined-preview{background:var(--surface);padding:.5rem;border-radius:.375rem;margin:.5rem 0}.refined-preview ul{margin:.5rem 0 0 1rem;padding:0}.refinement-actions{display:flex;gap:.5rem;margin-top:.75rem}.back-to-suggest{margin-top:1rem;font-size:.85rem}.modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal{background:var(--surface);border-radius:.75rem;padding:1.5rem;width:100%;max-width:500px;max-height:90vh;overflow-y:auto}.modal h3{margin:0 0 1rem}.itinerary-form{display:flex;flex-direction:column;gap:1rem}.itinerary-form label{display:flex;flex-direction:column;gap:.25rem}.itinerary-form label span{font-size:.85rem;color:var(--text-secondary)}.itinerary-form input,.itinerary-form textarea{padding:.5rem;background:var(--bg);border:1px solid var(--border);border-radius:.375rem;color:var(--text)}.flight-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.stops-section{border:1px solid var(--border);border-radius:.5rem;padding:.75rem}.stops-section h4{margin:0 0 .5rem;font-size:.9rem}.stop-row{display:flex;justify-content:space-between;align-items:center;padding:.5rem;background:var(--bg);border-radius:.25rem;margin-bottom:.25rem}.stop-row button{background:none;border:none;color:#ef4444;cursor:pointer;font-size:1.2rem}.add-stop-row{display:flex;gap:.5rem;margin-top:.5rem}.add-stop-row input[type=text]{flex:1}.add-stop-row input[type=number]{width:60px}.modal-actions{display:flex;justify-content:flex-end;gap:.5rem;margin-top:.5rem}@media(max-width:768px){.explorer-header{flex-direction:column}.header-actions{width:100%;justify-content:flex-start}.explorer-layout{flex-direction:column}.explorer-layout.with-ai .explorer-main{max-width:100%}.ai-panel{width:100%;position:static;max-height:none}.itineraries-grid,.flight-row{grid-template-columns:1fr}}.lists-page{max-width:1200px;margin:0 auto}.lists-header{margin-bottom:var(--spacing-4)}.lists-header h1{font-size:var(--font-size-2xl);font-weight:700;color:var(--color-gray-800)}.lists-container{display:grid;grid-template-columns:300px 1fr;gap:var(--spacing-4);min-height:500px}@media(max-width:768px){.lists-container{grid-template-columns:1fr}}.lists-sidebar{display:flex;flex-direction:column;height:fit-content;max-height:calc(100vh - 200px)}.sidebar-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:var(--spacing-3);border-bottom:1px solid rgba(255,255,255,.1);margin-bottom:var(--spacing-3)}.sidebar-header h3{font-size:var(--font-size-lg);font-weight:600;margin:0;color:var(--color-gray-800)}.sidebar-header .btn{padding:var(--spacing-2) var(--spacing-4);font-size:var(--font-size-base);min-height:44px}@media(max-width:768px){.sidebar-header{flex-direction:column;gap:var(--spacing-3);align-items:stretch}.sidebar-header .btn{width:100%;justify-content:center;padding:var(--spacing-3) var(--spacing-4);font-size:var(--font-size-lg)}}.new-list-form{display:flex;flex-direction:column;gap:var(--spacing-2);padding:var(--spacing-3);background:#ffffff0d;border-radius:var(--radius-lg);margin-bottom:var(--spacing-3)}.new-list-form input{width:100%}.icon-picker{display:flex;flex-wrap:wrap;gap:var(--spacing-1)}.icon-btn{width:36px;height:36px;border-radius:var(--radius-md);border:2px solid transparent;background:#ffffff1a;font-size:1.2rem;cursor:pointer;transition:all var(--transition-fast)}.icon-btn:hover{background:#fff3}.icon-btn.active{border-color:var(--color-primary);background:rgba(var(--color-primary-rgb),.2)}.list-items{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:var(--spacing-1)}.list-item{display:flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-2) var(--spacing-3);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast)}.list-item:hover{background:var(--color-gray-100)}.list-item.active{background:var(--color-gray-200)}.drag-handle{cursor:grab;padding:0 var(--spacing-2);color:var(--color-gray-400);font-size:1rem;-webkit-user-select:none;user-select:none;transition:color var(--transition-fast)}.drag-handle:hover{color:var(--color-gray-600)}.drag-handle:active{cursor:grabbing}.list-item.dragging{opacity:.5;background:var(--color-gray-100)}.list-item.drag-over{border-top:2px solid var(--color-primary);margin-top:-2px}.list-icon{font-size:1.5rem}.list-info{flex:1;display:flex;flex-direction:column}.list-name{font-weight:500}.list-count{font-size:var(--font-size-xs);color:#fff9}.list-detail{display:flex;flex-direction:column}.detail-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:var(--spacing-3);border-bottom:1px solid rgba(255,255,255,.1);margin-bottom:var(--spacing-3)}.detail-header h2{font-size:var(--font-size-xl);font-weight:600;margin:0}.add-item-form{display:flex;flex-direction:column;gap:var(--spacing-2);margin-bottom:var(--spacing-4)}.add-item-form .input-row{display:flex;gap:var(--spacing-2)}.add-item-form input[type=text]{flex:1}.notes-input{width:100%}.items-list{display:flex;flex-direction:column;gap:var(--spacing-1)}.item-row{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-2) var(--spacing-3);background:#ffffff0d;border-radius:var(--radius-lg);transition:all var(--transition-fast)}.item-row:hover{background:#ffffff1a}.item-row.purchased{opacity:.6}.item-row.purchased .item-name{text-decoration:line-through}.checkbox-wrapper{display:flex;align-items:center;gap:var(--spacing-3);flex:1;cursor:pointer}.item-content{display:flex;flex-direction:column;gap:2px}.item-name{font-weight:500}.item-qty{margin-left:var(--spacing-1);color:var(--color-primary);font-weight:600}.item-notes{font-size:var(--font-size-sm);color:#fff9}.item-actions{display:flex;gap:var(--spacing-1);opacity:0;transition:opacity var(--transition-fast)}.item-row:hover .item-actions{opacity:1}.purchased-section{margin-top:var(--spacing-4);padding-top:var(--spacing-3);border-top:1px solid rgba(255,255,255,.1)}.purchased-header{font-size:var(--font-size-sm);color:#ffffff80;margin-bottom:var(--spacing-2);font-weight:500}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-8);text-align:center;color:#fff9}.empty-icon{font-size:3rem;margin-bottom:var(--spacing-2)}.hint{font-size:var(--font-size-sm);opacity:.7}.loading-state{padding:var(--spacing-4);text-align:center;color:#fff9}.modal{width:100%;max-width:400px}.modal h3{margin-bottom:var(--spacing-4);font-size:var(--font-size-lg)}.edit-form{display:flex;flex-direction:column;gap:var(--spacing-3)}.edit-form label{display:flex;flex-direction:column;gap:var(--spacing-1)}.edit-form label span{font-size:var(--font-size-sm);font-weight:500;color:#ffffffb3}.modal-actions{display:flex;justify-content:space-between;align-items:center;gap:var(--spacing-2);margin-top:var(--spacing-4);padding-top:var(--spacing-4);border-top:1px solid rgba(255,255,255,.1)}.modal-actions-right{display:flex;gap:var(--spacing-2)}.btn-danger{background:var(--color-error, #ef4444);color:#fff}.investments-page{max-width:900px;margin:0 auto}.investments-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-4)}.investments-header h1{font-size:var(--font-size-2xl);font-weight:700;color:var(--color-gray-800);margin:0}.summary-card{background:linear-gradient(135deg,#667eea,#764ba2)!important;color:#fff!important;padding:var(--spacing-6);margin-bottom:var(--spacing-6)}.demo-banner{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;padding:var(--spacing-3) var(--spacing-4);border-radius:var(--radius-md);margin-bottom:var(--spacing-4);font-size:var(--font-size-sm);text-align:center}.pin-help{color:var(--color-gray-600);font-size:var(--font-size-sm);margin-bottom:var(--spacing-4)}.pin-input{width:100%;font-size:2rem;text-align:center;letter-spacing:.5rem;padding:var(--spacing-3);border:2px solid var(--color-gray-300);border-radius:var(--radius-md);transition:border-color .2s}.pin-input.pin-error{border-color:var(--color-error);animation:shake .4s ease}.pin-error-text{color:var(--color-error);font-size:var(--font-size-sm);margin-top:var(--spacing-2)}@keyframes shake{0%,to{transform:translate(0)}20%,60%{transform:translate(-5px)}40%,80%{transform:translate(5px)}}.summary-main{text-align:center;margin-bottom:var(--spacing-4)}.summary-value{font-size:2.5rem;font-weight:700;letter-spacing:-1px}.summary-label{font-size:var(--font-size-sm);opacity:.9}.summary-details{display:flex;justify-content:space-around;padding-top:var(--spacing-4);border-top:1px solid rgba(255,255,255,.2)}.summary-item{text-align:center}.summary-item .label{display:block;font-size:var(--font-size-xs);opacity:.8;margin-bottom:var(--spacing-1)}.summary-item .value{font-weight:600}.summary-item .value.positive{color:#4ade80}.summary-item .value.negative{color:#f87171}.summary-breakdown{display:flex;justify-content:space-around;padding-top:var(--spacing-4);margin-top:var(--spacing-4);border-top:1px solid rgba(255,255,255,.2)}.breakdown-item{text-align:center}.breakdown-label{display:block;font-size:var(--font-size-xs);opacity:.9;margin-bottom:var(--spacing-1)}.breakdown-value{font-weight:600;font-size:var(--font-size-lg)}.retirement-badge{display:inline-block;font-size:var(--font-size-xs);font-weight:500;padding:2px 6px;border-radius:var(--radius-sm);margin-left:var(--spacing-2);vertical-align:middle}.retirement-badge.retirement{background:#4ade8026;color:#16a34a}.retirement-badge.non-retirement{background:#3b82f626;color:#2563eb}.retirement-badge.unset{background:#9ca3af26;color:#6b7280}.accounts-section{margin-bottom:var(--spacing-6)}.accounts-list{display:flex;flex-direction:column;gap:var(--spacing-3)}.account-card{overflow:hidden}.account-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-4);cursor:pointer;transition:background var(--transition-fast)}.account-header:hover{background:var(--color-gray-50)}.account-info{display:flex;align-items:center;gap:var(--spacing-3)}.account-icon{font-size:1.5rem}.account-name{font-weight:600;color:var(--color-gray-800)}.account-meta{font-size:var(--font-size-sm);color:var(--color-gray-500)}.account-values{text-align:right}.account-value{font-weight:600;font-size:var(--font-size-lg)}.account-gain{font-size:var(--font-size-sm)}.account-gain.positive{color:var(--color-success)}.account-gain.negative{color:var(--color-error)}.account-details{padding:var(--spacing-4);background:var(--color-gray-50);border-top:1px solid var(--color-gray-200)}.holdings-list{display:flex;flex-direction:column;gap:var(--spacing-2);margin-bottom:var(--spacing-3)}.holdings-table{width:100%;border-collapse:collapse;table-layout:fixed;font-size:var(--font-size-sm);background:#fff;border-radius:var(--radius-md);overflow:hidden}.holdings-table colgroup .col-symbol{width:80px}.holdings-table colgroup .col-name{width:auto}.holdings-table colgroup .col-qty,.holdings-table colgroup .col-value{width:100px}.holdings-table colgroup .col-action{width:40px}.holdings-table thead{background:var(--color-gray-50)}.holdings-table th{padding:var(--spacing-2) var(--spacing-3);text-align:left;font-weight:600;color:var(--color-gray-600);font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.5px}.holdings-table td{padding:var(--spacing-2) var(--spacing-3);border-top:1px solid var(--color-gray-100)}.holdings-table tbody tr:hover{background:var(--color-gray-50)}.holdings-table .text-right,.holdings-table .holding-qty,.holdings-table .holding-price,.holdings-table .holding-cost,.holdings-table .holding-value{text-align:right}.holdings-table .holding-symbol{font-weight:600;color:var(--color-primary)}.holdings-table .holding-name{color:var(--color-gray-600);max-width:300px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.holdings-table .holding-qty{color:var(--color-gray-500)}.holdings-table .holding-price{color:var(--color-gray-600);font-weight:500}.holdings-table .holding-value{font-weight:600}.no-holdings{color:var(--color-gray-500);font-size:var(--font-size-sm);text-align:center;padding:var(--spacing-4)}.account-actions{display:flex;justify-content:space-between;padding-top:var(--spacing-3);border-top:1px solid var(--color-gray-200)}.modal{width:100%;max-width:400px;max-height:90vh;overflow-y:auto}.modal-form .checkbox-label{flex-direction:row;align-items:center;gap:var(--spacing-2);padding:var(--spacing-2) 0}.modal-form .checkbox-label input[type=checkbox]{width:18px;height:18px;accent-color:var(--color-primary)}.modal-form .checkbox-label span{font-weight:400;color:var(--color-gray-700)}@media(max-width:600px){.summary-value{font-size:2rem}.summary-details{flex-direction:column;gap:var(--spacing-3)}.account-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-2)}.account-values{text-align:left}}@media(max-width:480px){.holdings-table{display:block}.holdings-table colgroup,.holdings-table thead{display:none}.holdings-table tbody{display:flex;flex-direction:column;gap:var(--spacing-2)}.holdings-table tbody tr{display:grid;grid-template-columns:1fr auto auto;grid-template-rows:auto auto;grid-template-areas:"symbol value action" "name cost action";gap:var(--spacing-1) var(--spacing-2);padding:var(--spacing-3);background:#fff;border-radius:var(--radius-md);border:1px solid var(--color-gray-100);align-items:center}.holdings-table tbody tr:hover{background:var(--color-gray-50)}.holdings-table td{padding:0;border:none}.holdings-table .holding-symbol{grid-area:symbol;font-size:var(--font-size-base);font-weight:700}.holdings-table .holding-name{grid-area:name;font-size:var(--font-size-xs);color:var(--color-gray-500);max-width:none;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.holdings-table .holding-qty{display:none}.holdings-table .holding-symbol:after{content:attr(data-qty);font-weight:400;font-size:var(--font-size-xs);color:var(--color-gray-500);margin-left:var(--spacing-2)}.holdings-table .holding-cost{grid-area:cost;font-size:var(--font-size-xs);color:var(--color-gray-500);text-align:right}.holdings-table .holding-value{grid-area:value;font-size:var(--font-size-base);font-weight:600;text-align:right}.holdings-table td:last-child{grid-area:action;display:flex;align-items:center;justify-content:center}.holdings-table td:last-child .btn{padding:var(--spacing-1)}.account-actions{flex-direction:column;gap:var(--spacing-2)}.account-actions .btn{width:100%;justify-content:center}.header-actions{flex-wrap:wrap;gap:var(--spacing-1)}.header-actions .btn{font-size:var(--font-size-sm);padding:var(--spacing-2) var(--spacing-3)}}.modal-wide{max-width:600px}.import-step{display:flex;flex-direction:column;gap:var(--spacing-3)}.import-help{color:var(--color-gray-600);font-size:var(--font-size-sm);line-height:1.5}.csv-textarea{width:100%;min-height:200px;font-family:monospace;font-size:var(--font-size-sm);padding:var(--spacing-3);border:1px solid var(--color-gray-300);border-radius:var(--radius-md);resize:vertical}.csv-textarea:focus{outline:none;border-color:var(--color-primary)}.import-summary{display:flex;align-items:center;gap:var(--spacing-2)}.badge{background:var(--color-primary);color:#fff;padding:2px 8px;border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:500;text-transform:capitalize}.import-preview-table{max-height:300px;overflow-y:auto;border:1px solid var(--color-gray-200);border-radius:var(--radius-md)}.import-preview-table table{width:100%;border-collapse:collapse;font-size:var(--font-size-sm)}.import-preview-table th,.import-preview-table td{padding:var(--spacing-2);text-align:left;border-bottom:1px solid var(--color-gray-100)}.import-preview-table th{background:var(--color-gray-50);font-weight:600;position:sticky;top:0}.import-preview-table .symbol{font-weight:600;color:var(--color-primary)}.import-preview-table .name{color:var(--color-gray-500)}.more-items{text-align:center;color:var(--color-gray-500);font-size:var(--font-size-sm);padding:var(--spacing-2)}.account-actions{gap:var(--spacing-2);flex-wrap:wrap}.import-options{display:flex;gap:var(--spacing-3)}.import-options label{flex:1;display:flex;flex-direction:column;gap:var(--spacing-1)}.import-options label span{font-size:var(--font-size-sm);font-weight:500;color:var(--color-gray-600)}.accounts-preview{display:flex;flex-direction:column;gap:var(--spacing-2);padding:var(--spacing-2)}.account-preview-row{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-2) var(--spacing-3);background:var(--color-gray-50);border-radius:var(--radius-sm)}.holdings-count{color:var(--color-gray-500);font-size:var(--font-size-sm)}.account-preview-info{display:flex;flex-direction:column;gap:var(--spacing-1)}.owner-select{padding:var(--spacing-1) var(--spacing-2);border:1px solid var(--color-gray-300);border-radius:var(--radius-sm);font-size:var(--font-size-sm);min-width:80px}.file-upload-area{margin:var(--spacing-3) 0}.file-upload-area input[type=file]{display:none}.file-upload-label{display:flex;align-items:center;justify-content:center;gap:var(--spacing-2);padding:var(--spacing-4);border:2px dashed var(--color-gray-300);border-radius:var(--radius-md);background:var(--color-gray-50);cursor:pointer;font-weight:500;transition:all .2s}.file-upload-label:hover{border-color:var(--color-primary);background:var(--color-primary-light)}.portfolio-chart{background:#fff;border-radius:var(--radius-lg);padding:var(--spacing-4);margin-bottom:var(--spacing-4)}.chart-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-3)}.chart-title{font-weight:600;color:var(--color-gray-800)}.chart-change{font-weight:600;font-size:var(--font-size-sm)}.chart-change.positive{color:#22c55e}.chart-change.negative{color:#ef4444}.chart-container{position:relative;height:calc(100% - 60px);padding-left:60px}.chart-svg{width:100%;height:100%}.y-labels{position:absolute;left:0;top:0;bottom:20px;width:55px;display:flex;flex-direction:column;justify-content:space-between}.y-label{position:absolute;width:100%;text-align:right;font-size:11px;color:var(--color-gray-500);transform:translateY(-50%);padding-right:8px}.x-labels{display:flex;justify-content:space-between;margin-top:var(--spacing-2)}.x-label{font-size:11px;color:var(--color-gray-500)}.portfolio-chart-empty{background:#fff;border-radius:var(--radius-lg);padding:var(--spacing-4);margin-bottom:var(--spacing-4);text-align:center}.modal-form .input-disabled,.modal-form input:disabled{background-color:var(--color-gray-100);color:var(--color-gray-500);cursor:not-allowed;opacity:.7}.spending-dashboard{max-width:1000px;margin:0 auto;padding:var(--spacing-4)}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-6);flex-wrap:wrap;gap:var(--spacing-3)}.dashboard-header h1{font-size:var(--font-size-2xl);font-weight:700;color:var(--color-gray-900);margin:0}.dashboard-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-4);margin-bottom:var(--spacing-6)}.stat-card{background:var(--bg-card);border-radius:var(--radius-xl);padding:var(--spacing-5);text-align:center;box-shadow:0 1px 3px #00000014}.stat-label{display:block;font-size:var(--font-size-xs);color:var(--color-gray-500);margin-bottom:var(--spacing-2);text-transform:uppercase;letter-spacing:.5px;font-weight:500}.stat-value{font-size:1.5rem;font-weight:700;color:var(--color-gray-800)}.chart-section{background:var(--bg-card);border-radius:var(--radius-xl);padding:var(--spacing-5);margin-bottom:var(--spacing-6);box-shadow:0 1px 3px #00000014}.chart-header{margin-bottom:var(--spacing-4)}.chart-header h2{font-size:var(--font-size-lg);font-weight:700;color:var(--color-gray-800);margin:0;display:flex;align-items:center;gap:var(--spacing-3)}.category-indicator{width:16px;height:16px;border-radius:4px;display:inline-block}.clear-category{background:var(--bg-page);border:none;color:var(--color-gray-600);font-size:var(--font-size-sm);padding:4px 12px;border-radius:100px;cursor:pointer;margin-left:var(--spacing-2);transition:background .2s}.clear-category:hover{background:var(--bg-card-hover)}.chart-container{width:100%;overflow:hidden}.spending-chart{width:100%;height:auto}.spending-chart text{fill:var(--color-gray-500)}.spending-chart line{stroke:var(--color-gray-200)}.chart-dot{transition:r .2s,filter .2s}.chart-dot:hover{r:8;filter:drop-shadow(0 0 6px currentColor)}.category-legend{background:var(--bg-card);border-radius:var(--radius-xl);padding:var(--spacing-5);box-shadow:0 1px 3px #00000014}.category-legend h3{font-size:var(--font-size-sm);font-weight:600;color:var(--color-gray-500);text-transform:uppercase;letter-spacing:.5px;margin:0 0 var(--spacing-4) 0}.legend-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--spacing-3)}.legend-item{display:flex;align-items:center;gap:var(--spacing-3);padding:var(--spacing-3);background:var(--bg-page);border-radius:var(--radius-lg);cursor:pointer;transition:all .2s;border:2px solid transparent}.legend-item:hover{background:var(--bg-card-hover)}.legend-item.active{background:var(--bg-card-hover);border-color:var(--color-primary)}.legend-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}.legend-name{flex:1;color:var(--color-gray-800);font-weight:500;font-size:var(--font-size-sm)}.legend-amount{color:var(--color-gray-600);font-weight:600;font-size:var(--font-size-sm)}@media(max-width:768px){.spending-dashboard{padding:var(--spacing-3)}.dashboard-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-4)}.dashboard-header h1{font-size:var(--font-size-xl)}.dashboard-header .header-actions{width:100%;justify-content:space-between}.demo-banner{font-size:var(--font-size-xs);padding:var(--spacing-2) var(--spacing-3)}.dashboard-stats{grid-template-columns:1fr;gap:var(--spacing-3)}.stat-card{padding:var(--spacing-4)}.stat-value{font-size:1.25rem}.chart-section{padding:var(--spacing-4);overflow-x:auto}.chart-container{min-width:500px}.category-legend{padding:var(--spacing-4)}.category-legend h3{font-size:var(--font-size-xs)}.legend-grid{grid-template-columns:1fr;gap:var(--spacing-2)}.legend-item{padding:var(--spacing-2)}.legend-name,.legend-amount{font-size:var(--font-size-xs)}}@media(max-width:480px){.spending-dashboard{padding:var(--spacing-2)}.dashboard-header h1{font-size:var(--font-size-lg)}.dashboard-header .header-actions{flex-wrap:wrap;gap:var(--spacing-2)}.dashboard-header .header-actions .btn{font-size:var(--font-size-xs);padding:var(--spacing-2) var(--spacing-3)}.stat-card{padding:var(--spacing-3)}.stat-label{font-size:10px}.stat-value{font-size:1.1rem}}.spending-page{max-width:1000px;margin:0 auto;padding:var(--spacing-4)}.spending-page .demo-banner{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;padding:var(--spacing-3) var(--spacing-4);border-radius:var(--radius-md);margin-bottom:var(--spacing-4);font-size:var(--font-size-sm);text-align:center}.pin-modal{text-align:center;max-width:320px}.pin-modal h3{font-size:var(--font-size-xl);margin-bottom:var(--spacing-2)}.pin-modal>p{color:var(--color-gray-500);margin-bottom:var(--spacing-4)}.pin-modal input{font-size:2rem;text-align:center;letter-spacing:.5rem;padding:var(--spacing-3);width:150px;margin:0 auto var(--spacing-3);display:block;background:var(--color-gray-50);border:2px solid var(--color-gray-200);border-radius:var(--radius-lg);color:var(--color-gray-800)}.pin-modal input:focus{outline:none;border-color:var(--color-primary)}.pin-modal input.error{border-color:var(--color-error);animation:shake .3s}.pin-error{color:var(--color-error);font-size:var(--font-size-sm);margin-bottom:var(--spacing-3)}.spending-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-6);flex-wrap:wrap;gap:var(--spacing-3)}.spending-header h1{font-size:var(--font-size-2xl);font-weight:700;color:var(--color-gray-900);margin:0}.month-nav{display:flex;justify-content:center;align-items:center;gap:var(--spacing-4);margin-bottom:var(--spacing-6);padding:var(--spacing-4);background:var(--bg-card);border-radius:var(--radius-xl);box-shadow:0 1px 3px #00000014}.month-picker{font-size:var(--font-size-xl);font-weight:700;color:var(--color-gray-800);background:var(--bg-page);border:1px solid var(--color-gray-200);border-radius:var(--radius-lg);cursor:pointer;text-align:center;padding:var(--spacing-2) var(--spacing-4);min-width:200px;transition:all .2s}.month-picker:hover{background:var(--bg-card-hover);border-color:var(--color-gray-300)}.month-picker option{background:var(--bg-card);color:var(--color-gray-800);padding:10px}.summary-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-4);margin-bottom:var(--spacing-6)}.summary-cards .summary-card{background:var(--bg-card);padding:var(--spacing-5);border-radius:var(--radius-xl);text-align:center;box-shadow:0 1px 3px #00000014}.category-breakdown{background:var(--bg-card);border-radius:var(--radius-xl);padding:var(--spacing-5);margin-bottom:var(--spacing-6);box-shadow:0 1px 3px #00000014}.category-breakdown h2{font-size:var(--font-size-sm);font-weight:600;color:var(--color-gray-500);text-transform:uppercase;letter-spacing:.5px;margin-bottom:var(--spacing-4)}.category-list{display:flex;flex-direction:column;gap:var(--spacing-2)}.category-row{display:grid;grid-template-columns:1fr auto 120px;align-items:center;gap:var(--spacing-4);padding:var(--spacing-3);border-radius:var(--radius-lg);cursor:pointer;transition:all .2s}.category-row:hover{background:var(--bg-card-hover)}.category-row.active{background:var(--bg-card-hover);border:2px solid var(--color-primary)}.category-info{display:flex;align-items:center;gap:var(--spacing-3)}.category-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}.category-name{color:var(--color-gray-800);font-size:var(--font-size-sm);font-weight:500}.category-stats{display:flex;align-items:center;gap:var(--spacing-4);text-align:right}.category-amount{color:var(--color-gray-800);font-weight:600;font-size:var(--font-size-sm)}.category-percent{color:var(--color-gray-500);font-size:var(--font-size-sm);min-width:45px}.category-bar{height:6px;background:var(--color-gray-200);border-radius:3px;overflow:hidden}.category-bar-fill{height:100%;border-radius:3px;transition:width .3s ease}.transactions-section{background:var(--bg-card);border-radius:var(--radius-xl);padding:var(--spacing-5);margin-bottom:var(--spacing-6);box-shadow:0 1px 3px #00000014}.transactions-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-4)}.transactions-section h2{font-size:var(--font-size-sm);font-weight:600;color:var(--color-gray-500);text-transform:uppercase;letter-spacing:.5px;margin:0;display:flex;align-items:center;gap:var(--spacing-3)}.filter-badge{display:inline-flex;align-items:center;gap:var(--spacing-2);font-size:var(--font-size-xs);font-weight:600;padding:4px 12px;border-radius:100px;color:#fff;text-transform:none;letter-spacing:normal}.clear-filter{background:none;border:none;color:#fff;cursor:pointer;font-size:14px;font-weight:700;padding:0 0 0 4px;opacity:.7;transition:opacity .2s}.clear-filter:hover{opacity:1}.transactions-list{display:flex;flex-direction:column}.transaction-row{display:grid;grid-template-columns:24px 80px 1fr auto auto;gap:var(--spacing-3);align-items:center;padding:var(--spacing-3);border-bottom:1px solid var(--color-gray-100);transition:background .2s;cursor:pointer}.transaction-row:last-child{border-bottom:none}.transaction-row:hover{background:var(--color-gray-50)}.transaction-row.selected{background:#6366f11a}.transaction-checkbox{width:18px;height:18px;cursor:pointer;accent-color:var(--color-primary)}.bulk-action-bar{display:flex;align-items:center;gap:var(--spacing-3);padding:var(--spacing-3) var(--spacing-4);background:linear-gradient(135deg,#667eea,#764ba2);border-radius:var(--radius-lg);margin-bottom:var(--spacing-4);color:#fff;font-size:var(--font-size-sm);font-weight:500}.bulk-category-select{flex:1;max-width:250px;padding:var(--spacing-2) var(--spacing-3);border-radius:var(--radius-md);border:1px solid rgba(255,255,255,.3);background:#ffffff1a;color:#fff;font-size:var(--font-size-sm)}.bulk-category-select option{background:#1f2937;color:#fff}.transaction-date{font-size:var(--font-size-sm);color:var(--color-gray-500);font-weight:500}.transaction-details{min-width:0}.transaction-description{color:var(--color-gray-800);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:var(--font-size-sm)}.transaction-meta{display:flex;gap:var(--spacing-2);margin-top:var(--spacing-1);font-size:var(--font-size-xs);color:var(--color-gray-500)}.category-badge{display:inline-block;padding:2px 8px;border-radius:100px;font-size:var(--font-size-xs);font-weight:500;color:#fff}.transaction-amount{font-weight:600;color:var(--color-gray-800);white-space:nowrap}.transaction-amount.expense{color:var(--color-gray-800)}.transaction-amount.income{color:#16a34a}.transaction-actions{display:flex;gap:var(--spacing-2)}.transaction-actions button{padding:var(--spacing-2);background:none;border:none;border-radius:var(--radius-md);cursor:pointer;opacity:.4;transition:all .2s}.transaction-actions button:hover{opacity:1;background:var(--color-gray-100)}.empty-state p{margin:var(--spacing-2) 0}.modal{background:var(--bg-card);border-radius:var(--radius-xl);padding:var(--spacing-6);width:100%;max-width:480px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 40px #0000004d}.modal h3{font-size:var(--font-size-xl);font-weight:700;color:var(--color-gray-800);margin-bottom:var(--spacing-4)}.modal>p{color:var(--color-gray-600);margin-bottom:var(--spacing-4);line-height:1.5}.modal-form label{display:flex;flex-direction:column;gap:var(--spacing-1);margin-bottom:var(--spacing-3)}.modal-form label span{font-size:var(--font-size-sm);color:var(--color-gray-600);font-weight:500}.modal-form input,.modal-form select{padding:var(--spacing-3);border:1px solid var(--color-gray-200);border-radius:var(--radius-md);font-size:var(--font-size-base);background:var(--bg-page);color:var(--color-gray-800)}.modal-form input:focus,.modal-form select:focus{outline:none;border-color:var(--color-primary);background:var(--bg-card)}.modal-actions{display:flex;gap:var(--spacing-3);justify-content:flex-end;margin-top:var(--spacing-4);padding-top:var(--spacing-4);border-top:1px solid var(--color-gray-100)}.import-info{padding:var(--spacing-4);background:var(--color-gray-50);border-radius:var(--radius-md)}.import-info p{margin:var(--spacing-2) 0;color:var(--color-gray-600);font-size:var(--font-size-sm)}.import-loading{text-align:center;padding:var(--spacing-6)}.import-loading p{color:var(--color-gray-700);margin-bottom:var(--spacing-2)}.import-loading-subtext{color:var(--color-gray-500);font-size:var(--font-size-sm)}.import-progress-bar{width:100%;height:8px;background:var(--color-gray-200);border-radius:9999px;overflow:hidden;margin:var(--spacing-4) 0 var(--spacing-2)}.import-progress-fill{height:100%;background:linear-gradient(90deg,#667eea,#764ba2);border-radius:9999px;transition:width .3s ease}@media(max-width:768px){.spending-page{padding:var(--spacing-3)}.spending-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-3)}.spending-header h1{font-size:var(--font-size-xl)}.header-title{flex-wrap:wrap}.header-actions{width:100%;flex-wrap:wrap}.demo-banner{font-size:var(--font-size-xs);padding:var(--spacing-2) var(--spacing-3)}.month-nav{padding:var(--spacing-3);gap:var(--spacing-2)}.month-picker{font-size:var(--font-size-base);min-width:auto;flex:1}.summary-cards{grid-template-columns:1fr;gap:var(--spacing-3)}.summary-cards .summary-card{padding:var(--spacing-4)}.summary-cards .summary-card .value{font-size:1.5rem}.category-breakdown{padding:var(--spacing-4)}.category-breakdown h2{font-size:var(--font-size-xs)}.category-row{grid-template-columns:1fr auto;gap:var(--spacing-2)}.category-bar{grid-column:1 / -1}.transactions-section{padding:var(--spacing-4)}.transaction-row{grid-template-columns:1fr auto;gap:var(--spacing-2);padding:var(--spacing-3) var(--spacing-2)}.transaction-date{grid-column:1 / -1;font-size:var(--font-size-xs)}.transaction-description{font-size:var(--font-size-xs)}.transaction-actions{display:none}.modal{padding:var(--spacing-4);max-width:100%;margin:var(--spacing-3)}}@media(max-width:480px){.spending-page{padding:var(--spacing-2)}.spending-header h1{font-size:var(--font-size-lg)}.header-actions .btn{font-size:var(--font-size-xs);padding:var(--spacing-2) var(--spacing-3)}.month-nav{flex-wrap:wrap}.month-nav .btn{font-size:var(--font-size-xs);padding:var(--spacing-2)}.summary-cards .summary-card .label{font-size:10px}.summary-cards .summary-card .value{font-size:1.25rem}.category-name,.category-amount{font-size:var(--font-size-xs)}.transactions-section h2{font-size:10px}.transaction-amount{font-size:var(--font-size-sm)}.category-badge{font-size:10px;padding:1px 6px}}.networth-page{max-width:800px;margin:0 auto;padding:var(--spacing-4)}.networth-page .demo-banner{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;padding:var(--spacing-3) var(--spacing-4);border-radius:var(--radius-md);margin-bottom:var(--spacing-4);font-size:var(--font-size-sm);text-align:center}.networth-page .pin-modal{text-align:center;max-width:320px}.networth-page .pin-modal h3{font-size:var(--font-size-xl);margin-bottom:var(--spacing-2)}.networth-page .pin-modal p{color:var(--color-gray-500);margin-bottom:var(--spacing-4)}.networth-page .pin-modal input{font-size:2rem;text-align:center;letter-spacing:.5rem;padding:var(--spacing-3);width:150px;margin:0 auto var(--spacing-3);display:block;background:var(--color-gray-50);border:2px solid var(--color-gray-200);border-radius:var(--radius-lg);color:var(--color-gray-800)}.networth-page .pin-modal input:focus{outline:none;border-color:var(--color-primary)}.networth-page .pin-modal input.error{border-color:var(--color-error);animation:shake .3s}.networth-page .pin-error{color:var(--color-error);font-size:var(--font-size-sm);margin-bottom:var(--spacing-3)}.networth-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-4)}.networth-header h1{font-size:var(--font-size-2xl);font-weight:700;color:var(--color-gray-800);margin:0}.networth-header .header-actions{display:flex;gap:var(--spacing-3)}.networth-hero{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:var(--spacing-6);margin-bottom:var(--spacing-6);text-align:center;border-radius:var(--radius-xl)}.hero-main{margin-bottom:var(--spacing-4)}.hero-label{display:block;font-size:var(--font-size-sm);opacity:.9;margin-bottom:var(--spacing-2)}.hero-value{font-size:3rem;font-weight:700;letter-spacing:-1px}.hero-value.positive{color:#4ade80}.hero-value.negative{color:#f87171}.hero-breakdown{display:flex;justify-content:center;gap:var(--spacing-8);padding-top:var(--spacing-4);border-top:1px solid rgba(255,255,255,.2)}.hero-breakdown .breakdown-item{text-align:center}.hero-breakdown .breakdown-item .label{display:block;font-size:var(--font-size-sm);opacity:.9;margin-bottom:var(--spacing-1)}.hero-breakdown .breakdown-item .value{font-size:var(--font-size-xl);font-weight:600}.section h2{font-size:var(--font-size-sm);font-weight:600;color:var(--color-gray-500);text-transform:uppercase;letter-spacing:.5px;margin-bottom:var(--spacing-3)}.asset-card,.liability-card{background:#fff;border-radius:var(--radius-xl);margin-bottom:var(--spacing-3);box-shadow:0 1px 3px #00000014;overflow:hidden}.card-header{display:flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-4)}.card-icon{font-size:var(--font-size-xl)}.card-title{flex:1;font-size:var(--font-size-base);font-weight:600;color:var(--color-gray-800)}.card-value{font-size:var(--font-size-lg);font-weight:700;color:var(--color-gray-800)}.card-value.negative{color:#dc2626}.card-details{border-top:1px solid var(--color-gray-100);padding:var(--spacing-3) var(--spacing-4);background:var(--color-gray-50)}.detail-row{display:flex;justify-content:space-between;padding:var(--spacing-2) 0;font-size:var(--font-size-sm);color:var(--color-gray-600)}.detail-row.clickable{cursor:pointer;border-radius:var(--radius-sm);padding:var(--spacing-2);margin:0 calc(-1 * var(--spacing-2))}.detail-row.clickable:hover{background:var(--color-gray-100)}.detail-divider{height:1px;background:var(--color-gray-200);margin:var(--spacing-2) 0}.empty-text{color:var(--color-gray-400);font-size:var(--font-size-sm);text-align:center;padding:var(--spacing-2)}.card-action{width:100%;margin-top:0;padding:var(--spacing-3) var(--spacing-4);border-top:1px solid var(--color-gray-100);background:#fff}.positive{color:#16a34a!important}.negative{color:#dc2626!important}.form-divider{display:flex;align-items:center;margin:var(--spacing-4) 0;color:var(--color-gray-400);font-size:var(--font-size-sm)}.form-divider:before,.form-divider:after{content:"";flex:1;height:1px;background:var(--color-gray-200)}.form-divider span{padding:0 var(--spacing-3)}.btn-danger{color:#dc2626;margin-right:auto}.btn-danger:hover{background:#dc26261a}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-8);color:var(--color-gray-500)}.loading-spinner{width:40px;height:40px;border:3px solid var(--color-gray-200);border-top-color:var(--color-primary);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:var(--spacing-4)}@media(max-width:600px){.networth-page{padding:var(--spacing-3)}.hero-value{font-size:2.5rem}.hero-breakdown{gap:var(--spacing-4)}.hero-breakdown .breakdown-item .value{font-size:var(--font-size-lg)}}.finances-page{padding:var(--spacing-6);max-width:900px;margin:0 auto}.finances-page .demo-banner{background:linear-gradient(135deg,#f97316,#ea580c);color:#fff;padding:var(--spacing-2) var(--spacing-4);border-radius:var(--radius-lg);font-size:var(--font-size-sm);font-weight:600;text-align:center;margin-bottom:var(--spacing-4)}.finances-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-6)}.finances-header h1{font-size:var(--font-size-2xl);font-weight:700;color:var(--color-gray-800)}.hero-card{border-radius:var(--radius-xl);padding:var(--spacing-8);margin-bottom:var(--spacing-6);text-align:center}.networth-hero{background:linear-gradient(135deg,#8b5cf6,#6366f1,#4f46e5);color:#fff;box-shadow:0 10px 30px #6366f14d}.hero-label{font-size:var(--font-size-xs);letter-spacing:.1em;opacity:.9;margin-bottom:var(--spacing-2)}.hero-value{font-size:3rem;font-weight:700;margin-bottom:var(--spacing-4)}.hero-breakdown{display:flex;justify-content:center;gap:var(--spacing-8)}.breakdown-item{display:flex;flex-direction:column;gap:var(--spacing-1)}.breakdown-label{font-size:var(--font-size-xs);opacity:.8}.breakdown-value{font-size:var(--font-size-lg);font-weight:600}.breakdown-value.positive{color:#86efac}.breakdown-value.negative{color:#fca5a5}.summary-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-4);margin-bottom:var(--spacing-6)}.summary-card{background:#fff;border-radius:var(--radius-xl);padding:var(--spacing-5);box-shadow:0 2px 8px #0000000f;display:flex;flex-direction:column;gap:var(--spacing-3)}.card-icon{font-size:2rem}.card-label{font-size:10px;letter-spacing:.1em;color:var(--color-gray-500);font-weight:600}.card-value{font-size:var(--font-size-2xl);font-weight:700;color:var(--color-gray-800)}.card-change{font-size:var(--font-size-sm);font-weight:500}.card-change.positive{color:var(--color-success)}.card-change.negative{color:var(--color-danger)}.card-categories{display:flex;flex-wrap:wrap;gap:var(--spacing-1)}.category-tag{font-size:10px;padding:2px 8px;border-radius:9999px;color:#fff;font-weight:500}.card-link{font-size:var(--font-size-sm);color:var(--color-primary);font-weight:500;text-decoration:none;margin-top:auto}.card-link:hover{text-decoration:underline}.quick-links{margin-top:var(--spacing-6)}.quick-links h2{font-size:var(--font-size-xs);letter-spacing:.1em;color:var(--color-gray-500);text-transform:uppercase;margin-bottom:var(--spacing-4);font-weight:600}.links-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-4)}.quick-link-card{background:#fff;border-radius:var(--radius-xl);padding:var(--spacing-5);text-decoration:none;display:flex;flex-direction:column;align-items:center;text-align:center;gap:var(--spacing-2);box-shadow:0 2px 8px #0000000f;transition:transform .2s,box-shadow .2s}.quick-link-card:hover{transform:translateY(-2px);box-shadow:0 8px 20px #0000001a}.link-icon{font-size:2rem}.link-title{font-size:var(--font-size-base);font-weight:600;color:var(--color-gray-800)}.link-desc{font-size:var(--font-size-xs);color:var(--color-gray-500)}.finances-page .modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:var(--z-modal);padding:var(--spacing-4)}.finances-page .modal{background:#fff;border-radius:var(--radius-xl);padding:var(--spacing-6);width:100%;max-width:360px;text-align:center}.finances-page .modal h3{font-size:var(--font-size-xl);margin-bottom:var(--spacing-2);color:var(--color-gray-800)}.finances-page .modal>p{color:var(--color-gray-500);margin-bottom:var(--spacing-4)}.pin-input{width:100%;padding:var(--spacing-4);font-size:var(--font-size-2xl);text-align:center;letter-spacing:.5em;border:2px solid var(--color-gray-200);border-radius:var(--radius-lg);margin-bottom:var(--spacing-2)}.pin-input:focus{outline:none;border-color:var(--color-primary)}.pin-input.error{border-color:var(--color-danger);animation:shake .3s}.error-text{color:var(--color-danger);font-size:var(--font-size-sm);margin-bottom:var(--spacing-4)}.finances-page .modal-actions{display:flex;gap:var(--spacing-3);justify-content:center}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}.finances-page .loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-16);color:var(--color-gray-500)}.finances-page .loading-spinner{width:40px;height:40px;border:3px solid var(--color-gray-200);border-top-color:var(--color-primary);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:var(--spacing-4)}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:768px){.finances-page{padding:var(--spacing-4)}.finances-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-3)}.hero-value{font-size:2rem}.hero-breakdown{flex-direction:column;gap:var(--spacing-3)}.summary-grid,.links-grid{grid-template-columns:1fr}}@media(max-width:480px){.finances-page{padding:var(--spacing-3)}.hero-card{padding:var(--spacing-5)}.hero-value{font-size:1.75rem}}.calendar-page{max-width:800px;margin:0 auto;padding-bottom:calc(100px + env(safe-area-inset-bottom,0px))}@media(min-width:768px){.calendar-page{padding-bottom:0}}.calendar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-4);flex-wrap:wrap;gap:var(--spacing-2)}.calendar-header h1{font-size:var(--font-size-2xl);font-weight:700;color:var(--color-gray-800);margin:0}.header-actions{display:flex;gap:var(--spacing-2)}.month-section{margin-bottom:var(--spacing-6)}.month-header{margin-bottom:var(--spacing-3)}.month-header h2{font-size:var(--font-size-lg);font-weight:600;color:#ffffffe6;margin:0;padding-left:var(--spacing-2);border-left:3px solid var(--color-primary)}.month-items{display:flex;flex-direction:column;gap:var(--spacing-2)}.calendar-item{display:flex;align-items:center;gap:var(--spacing-3);padding:var(--spacing-4);text-decoration:none;transition:all var(--transition-fast);cursor:pointer}.calendar-item:hover{transform:translate(4px);box-shadow:var(--shadow-md)}.item-icon{font-size:1.75rem;flex-shrink:0}.item-content{flex:1;min-width:0}.item-name{font-weight:600;font-size:var(--font-size-base);color:var(--color-gray-800);margin-bottom:var(--spacing-1)}.item-meta{display:flex;flex-wrap:wrap;gap:var(--spacing-2);font-size:var(--font-size-sm);color:var(--color-gray-500)}.item-meta>span{display:inline-flex;align-items:center}.item-dates{font-weight:500;color:var(--color-gray-600)}.item-type{background:var(--color-gray-100);padding:0 var(--spacing-2);border-radius:var(--radius-sm);font-size:var(--font-size-xs)}.item-bookings{color:var(--color-primary);font-weight:500}.item-location{max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.item-recurrence{color:var(--color-primary)}.item-arrow{color:var(--color-gray-400);font-size:1.5rem;font-weight:300}.trip-item{border-left:4px solid #3b82f6}.event-item{border-left:4px solid #10b981}.import-email-modal{max-width:550px}.modal-subtitle{color:var(--color-gray-500);font-size:var(--font-size-sm);margin-bottom:var(--spacing-4)}.parse-result{padding:var(--spacing-4);border-radius:var(--radius-md);margin-top:var(--spacing-2)}.parse-result.success{background:#ecfdf5;border:1px solid #10b981}.parse-result.error{background:#fef2f2;border:1px solid #ef4444}.result-header{font-weight:600;margin-bottom:var(--spacing-2)}.parse-result p{margin:var(--spacing-1) 0;font-size:var(--font-size-sm)}.parsed-details{margin-top:var(--spacing-3)}.parsed-details summary{cursor:pointer;font-size:var(--font-size-sm);color:var(--color-gray-500)}.parsed-details pre{margin-top:var(--spacing-2);padding:var(--spacing-2);background:var(--color-gray-100);border-radius:var(--radius-sm);font-size:var(--font-size-xs);overflow-x:auto;max-height:200px}.hint{font-size:var(--font-size-sm);color:var(--color-gray-400);margin-top:var(--spacing-1)}@media(max-width:480px){.calendar-header{flex-direction:column;align-items:flex-start}.header-actions{width:100%}.header-actions .btn{flex:1;justify-content:center}.calendar-item{padding:var(--spacing-3)}.item-icon{font-size:1.5rem}.item-meta{flex-direction:column;gap:var(--spacing-1)}}.trip-detail-page2{max-width:700px;margin:0 auto;padding-bottom:calc(100px + env(safe-area-inset-bottom,0px))}@media(min-width:768px){.trip-detail-page2{padding-bottom:0}}.back-link{color:#fffc;text-decoration:none;font-weight:500;transition:color var(--transition-fast)}.trip-header{display:flex;gap:var(--spacing-4);padding:var(--spacing-5);margin-bottom:var(--spacing-4);background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff}.trip-icon{font-size:2.5rem;flex-shrink:0}.trip-info{flex:1}.trip-header h1{font-size:var(--font-size-xl);font-weight:700;margin:0 0 var(--spacing-2) 0;color:#fff}.trip-meta{display:flex;flex-wrap:wrap;gap:var(--spacing-3);font-size:var(--font-size-sm);opacity:.9}.trip-dates{font-weight:500}.trip-type{background:#fff3;padding:0 var(--spacing-2);border-radius:var(--radius-sm)}.trip-notes{margin-top:var(--spacing-3);font-size:var(--font-size-sm);opacity:.85;line-height:1.5}.bookings-list{display:flex;flex-direction:column;gap:var(--spacing-2)}.booking-card{display:flex;align-items:flex-start;gap:var(--spacing-3);padding:var(--spacing-4)}.booking-icon{font-size:1.5rem;flex-shrink:0}.booking-content{flex:1;min-width:0}.booking-provider{font-weight:600;color:var(--color-gray-800);margin-bottom:var(--spacing-1)}.booking-meta{font-size:var(--font-size-sm);color:var(--color-gray-500);margin-bottom:var(--spacing-1)}.booking-confirmation{font-size:var(--font-size-sm);color:var(--color-primary);font-weight:500}.booking-airline{font-size:var(--font-size-xs);color:var(--color-gray-400);margin-bottom:var(--spacing-1)}.booking-room-type{font-size:var(--font-size-xs);color:var(--color-gray-500);margin-bottom:var(--spacing-1)}.booking-nights{opacity:.7}details.booking-card{cursor:pointer}details.booking-card>summary{display:flex;align-items:flex-start;gap:var(--spacing-3);list-style:none}details.booking-card>summary::-webkit-details-marker{display:none}details.booking-card>summary:before{content:"▶";font-size:.6rem;color:var(--color-gray-400);margin-top:.5rem;transition:transform var(--transition-fast)}details.booking-card[open]>summary:before{transform:rotate(90deg)}.booking-details{margin-top:var(--spacing-3);padding-top:var(--spacing-3);border-top:1px solid var(--color-gray-200);display:flex;flex-direction:column;gap:var(--spacing-2)}.detail-row{display:flex;gap:var(--spacing-2);font-size:var(--font-size-sm)}.detail-label{color:var(--color-gray-500);min-width:100px;flex-shrink:0}.detail-value{color:var(--color-gray-700);word-break:break-word}.detail-value a{color:var(--color-primary);text-decoration:none}.detail-value a:hover{text-decoration:underline}.detail-price{font-weight:600;color:var(--color-gray-800)}.empty-section .hint{font-size:var(--font-size-sm);color:var(--color-gray-400);margin-top:var(--spacing-1)}.modal-form input:focus,.modal-form select:focus,.modal-form textarea:focus{outline:none;border-color:var(--color-primary)}.event-detail-page{max-width:700px;margin:0 auto;padding-bottom:calc(100px + env(safe-area-inset-bottom,0px))}@media(min-width:768px){.event-detail-page{padding-bottom:0}}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-4)}.back-link{color:#fffc;text-decoration:none;font-weight:500}.back-link:hover{color:#fff}.event-header{display:flex;gap:var(--spacing-4);padding:var(--spacing-5);margin-bottom:var(--spacing-4);background:linear-gradient(135deg,#10b981,#059669);color:#fff}.event-icon{font-size:2.5rem;flex-shrink:0}.event-info{flex:1}.event-header h1{font-size:var(--font-size-xl);font-weight:700;margin:0 0 var(--spacing-2) 0;color:#fff}.event-meta{display:flex;flex-wrap:wrap;gap:var(--spacing-2);font-size:var(--font-size-sm);opacity:.9}.event-date{font-weight:500}.event-location{margin-top:var(--spacing-2);font-size:var(--font-size-sm);opacity:.9}.event-recurrence{margin-top:var(--spacing-2);font-size:var(--font-size-sm);background:#fff3;padding:0 var(--spacing-2);border-radius:var(--radius-sm);display:inline-block}.event-notes{margin-top:var(--spacing-3);font-size:var(--font-size-sm);opacity:.85;line-height:1.5}.section{margin-bottom:var(--spacing-6)}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-3)}.section-header h2{font-size:var(--font-size-lg);font-weight:600;color:var(--color-gray-800);margin:0}.todos-list{padding:var(--spacing-2)}.todo-item{display:flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-2) var(--spacing-3);border-radius:var(--radius-sm)}.todo-item.completed{opacity:.6}.todo-item.completed .todo-text{text-decoration:line-through}.todo-checkbox{font-size:1.25rem}.todo-text{flex:1;font-size:var(--font-size-sm)}.todo-owner{font-size:var(--font-size-xs);color:var(--color-gray-400);text-transform:capitalize}.empty-section{text-align:center;padding:var(--spacing-6);color:var(--color-gray-500)}.danger-zone{margin-top:var(--spacing-8);padding-top:var(--spacing-4);border-top:1px solid rgba(255,255,255,.1);text-align:center}.btn-danger{background:var(--color-error);color:#fff}.btn-danger:hover{background:#dc2626}.modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:var(--z-modal);padding:var(--spacing-4)}.modal{width:100%;max-width:450px;max-height:90vh;overflow-y:auto}.modal h3{margin-bottom:var(--spacing-4);font-size:var(--font-size-lg);color:var(--color-gray-800)}.modal-form{display:flex;flex-direction:column;gap:var(--spacing-3)}.modal-form label{display:flex;flex-direction:column;gap:var(--spacing-1)}.modal-form label span{font-size:var(--font-size-sm);font-weight:500;color:var(--color-gray-600)}.modal-form input,.modal-form select,.modal-form textarea{padding:var(--spacing-3);border:1px solid var(--color-gray-300);border-radius:var(--radius-md);font-size:var(--font-size-base);font-family:var(--font-family)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-3)}@media(max-width:480px){.form-row{grid-template-columns:1fr}}.modal-actions{display:flex;justify-content:flex-end;gap:var(--spacing-2);margin-top:var(--spacing-4);padding-top:var(--spacing-4);border-top:1px solid var(--color-gray-200)}.loading-state{text-align:center;padding:var(--spacing-10);color:#ffffffb3}.loading-spinner{font-size:2rem;display:block;margin-bottom:var(--spacing-3);animation:pulse 1.5s ease-in-out infinite}.empty-state{text-align:center;padding:var(--spacing-8);color:var(--color-gray-500)}.meals-page{max-width:1200px;margin:0 auto;padding-bottom:calc(100px + env(safe-area-inset-bottom,0px))}.meals-header{margin-bottom:var(--spacing-4)}.meals-header h1{color:var(--color-gray-800);margin:0}.tabs{display:flex;gap:var(--spacing-2);margin-bottom:var(--spacing-4);background:var(--bg-card);padding:var(--spacing-2);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.tab{flex:1;padding:var(--spacing-3);border:none;background:transparent;font-family:var(--font-family);font-size:var(--font-size-sm);font-weight:500;color:var(--color-gray-600);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.tab:hover{background:var(--color-gray-100)}.tab.active{background:var(--color-primary);color:#fff}.filters-bar{display:flex;flex-wrap:wrap;gap:var(--spacing-2);margin-bottom:var(--spacing-4);padding:var(--spacing-3);background:var(--bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.search-input{flex:1;min-width:200px}.filter-btn{padding:var(--spacing-2) var(--spacing-3);border:1px solid var(--color-gray-200);background:#fff;border-radius:var(--radius-md);font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-fast)}.filter-btn.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.recipes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:var(--spacing-4)}.recipe-card{background:var(--bg-card);border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow-md);cursor:pointer;transition:all var(--transition-base)}.recipe-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.recipe-image{width:100%;height:180px;object-fit:cover}.recipe-image-placeholder{width:100%;height:180px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#fef3c7,#fed7aa);font-size:4rem}.recipe-content{padding:var(--spacing-4)}.recipe-content h3{margin:0 0 var(--spacing-2);font-size:var(--font-size-base);color:var(--color-gray-800)}.recipe-meta{display:flex;gap:var(--spacing-2);font-size:var(--font-size-sm);color:var(--color-gray-500);margin-bottom:var(--spacing-2)}.type-badge{background:var(--color-gray-100);padding:2px 8px;border-radius:var(--radius-full);text-transform:capitalize}.recipe-actions{display:flex;align-items:center;justify-content:space-between}.fav-btn{background:none;border:none;font-size:1.25rem;cursor:pointer;padding:var(--spacing-1)}.fav-btn.active{transform:scale(1.1)}.rating{color:#f59e0b;font-size:var(--font-size-sm)}.week-tab{display:flex;flex-direction:column;gap:var(--spacing-4)}.week-nav{display:flex;align-items:center;justify-content:center;gap:var(--spacing-4)}.week-nav h3{min-width:150px;text-align:center;color:var(--color-gray-800)}.holding-area{padding:var(--spacing-4);background:var(--bg-card);border-radius:var(--radius-xl)}.holding-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-3)}.holding-header h4{margin:0;color:var(--color-gray-700)}.holding-items{display:flex;flex-wrap:wrap;gap:var(--spacing-2)}.empty-hint{color:var(--color-gray-400);font-size:var(--font-size-sm)}.week-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:var(--spacing-2)}@media(max-width:900px){.week-grid{grid-template-columns:repeat(4,1fr)}}@media(max-width:600px){.week-grid{grid-template-columns:repeat(2,1fr)}}.day-column{background:var(--bg-card);border-radius:var(--radius-lg);padding:var(--spacing-3);min-height:200px;display:flex;flex-direction:column}.day-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:var(--spacing-2);border-bottom:1px solid var(--color-gray-100);margin-bottom:var(--spacing-2)}.day-name{font-weight:600;color:var(--color-gray-700)}.day-num{font-size:var(--font-size-sm);color:var(--color-gray-400)}.day-meals{flex:1;display:flex;flex-direction:column;gap:var(--spacing-2)}.add-meal-btn{margin-top:auto;padding:var(--spacing-2);background:var(--color-gray-100);border:none;border-radius:var(--radius-md);font-size:var(--font-size-lg);cursor:pointer;color:var(--color-gray-500);transition:all var(--transition-fast)}.add-meal-btn:hover{background:var(--color-primary);color:#fff}.meal-entry{background:linear-gradient(135deg,#6366f11a,#a855f71a);border-radius:var(--radius-md);padding:var(--spacing-2) var(--spacing-3)}.meal-entry.compact{padding:var(--spacing-2)}.meal-entry-main{display:flex;justify-content:space-between;align-items:center}.meal-name{font-weight:500;font-size:var(--font-size-sm);color:var(--color-gray-800)}.meal-time{font-size:var(--font-size-xs);color:var(--color-gray-500)}.meal-entry-actions{display:flex;gap:var(--spacing-1);margin-top:var(--spacing-1)}.btn-icon{background:none;border:none;padding:2px 6px;font-size:var(--font-size-sm);cursor:pointer;border-radius:var(--radius-sm)}.btn-icon:hover{background:var(--color-gray-200)}.btn-icon.delete:hover{background:#fee2e2;color:#dc2626}.assign-dropdown{display:flex;gap:2px;background:#fff;padding:2px;border-radius:var(--radius-md);box-shadow:var(--shadow-md)}.assign-dropdown button{padding:4px 8px;font-size:var(--font-size-xs);border:none;background:none;cursor:pointer;border-radius:var(--radius-sm)}.assign-dropdown button:hover{background:var(--color-primary);color:#fff}.shopping-tab{display:flex;flex-direction:column;gap:var(--spacing-4)}.shopping-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:var(--spacing-3)}.shopping-header h3{margin:0;color:var(--color-gray-800)}.view-toggle{display:flex;background:var(--bg-card);border-radius:var(--radius-full);padding:4px}.view-btn{padding:var(--spacing-2) var(--spacing-4);border:none;background:transparent;font-size:var(--font-size-sm);cursor:pointer;border-radius:var(--radius-full);transition:all var(--transition-fast)}.view-btn.active{background:var(--color-primary);color:#fff}.shopping-summary{color:var(--color-gray-500);font-size:var(--font-size-sm)}.category-section,.recipe-section{background:var(--bg-card);border-radius:var(--radius-lg);padding:var(--spacing-4)}.category-section h4,.recipe-section h4{margin:0 0 var(--spacing-3);color:var(--color-gray-700)}.shopping-item{display:flex;align-items:center;gap:var(--spacing-3);padding:var(--spacing-2) 0;cursor:pointer;transition:opacity var(--transition-fast)}.shopping-item.checked{opacity:.5}.shopping-item.checked .item-name{text-decoration:line-through}.check-box{font-size:1.25rem}.item-name{flex:1;color:var(--color-gray-800)}.item-amount{font-size:var(--font-size-sm);color:var(--color-gray-500)}.recipe-detail-modal{max-width:600px;max-height:90vh;overflow-y:auto}.detail-image{width:100%;height:250px;object-fit:cover;border-radius:var(--radius-lg);margin-bottom:var(--spacing-4)}.detail-meta{display:flex;flex-wrap:wrap;gap:var(--spacing-3);margin-bottom:var(--spacing-4);color:var(--color-gray-600);font-size:var(--font-size-sm)}.detail-section{margin-bottom:var(--spacing-4)}.detail-section h4{margin:0 0 var(--spacing-2);color:var(--color-gray-700)}.ingredients-list,.instructions-list{padding-left:var(--spacing-5);color:var(--color-gray-700)}.ingredients-list li,.instructions-list li{margin-bottom:var(--spacing-2)}.detail-actions{display:flex;gap:var(--spacing-3);flex-wrap:wrap}.rating-selector{display:flex;gap:var(--spacing-1)}.rating-selector button{padding:var(--spacing-1) var(--spacing-2);background:var(--color-gray-100);border:none;border-radius:var(--radius-md);color:#f59e0b;cursor:pointer}.rating-selector button:hover{background:var(--color-gray-200)}.source-link{display:block;margin-top:var(--spacing-4);text-align:center;color:var(--color-primary);font-size:var(--font-size-sm)}.import-section{margin-bottom:var(--spacing-4)}.url-input-row{display:flex;gap:var(--spacing-2)}.url-input-row input{flex:1}.preview-section{text-align:center}.preview-image{max-width:100%;max-height:200px;border-radius:var(--radius-lg);margin-bottom:var(--spacing-3)}.recipe-picker{max-height:400px;overflow-y:auto;margin-bottom:var(--spacing-4)}.recipe-pick-item{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-3);border-bottom:1px solid var(--color-gray-100);cursor:pointer;transition:background var(--transition-fast)}.recipe-pick-item:hover{background:var(--color-gray-50)}.pick-time{color:var(--color-gray-500);font-size:var(--font-size-sm)}.close-btn{position:absolute;top:var(--spacing-3);right:var(--spacing-3);background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--color-gray-500)}.close-btn:hover{color:var(--color-gray-800)}.empty-state,.loading-state{text-align:center;padding:var(--spacing-8);color:var(--color-gray-500)}.empty-icon{font-size:3rem;display:block;margin-bottom:var(--spacing-3);opacity:.5}.hint{font-size:var(--font-size-sm);color:var(--color-gray-400)}.error-text{color:var(--color-error);font-size:var(--font-size-sm);margin-top:var(--spacing-2)}.suggestion-section{background:linear-gradient(135deg,#5a8f6514,#9b7bb80f);border:2px solid rgba(90,143,101,.2);border-radius:var(--radius-xl);padding:var(--spacing-5);margin-bottom:var(--spacing-4)}.suggestion-section h4{margin:0 0 var(--spacing-3);color:var(--color-gray-800);font-size:var(--font-size-lg)}.suggestion-input-row{display:flex;gap:var(--spacing-2)}.suggestion-input{flex:1;padding:var(--spacing-3) var(--spacing-4);border:2px solid var(--color-gray-200);border-radius:var(--radius-lg);font-size:var(--font-size-base);transition:all var(--transition-fast)}.suggestion-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 4px #5a8f6526}.suggestions-container{margin-top:var(--spacing-5)}.suggestions-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-4);color:var(--color-gray-600);font-size:var(--font-size-sm);font-weight:500}.suggestion-cards{display:flex;flex-direction:column;gap:var(--spacing-4)}.suggestion-card{background:var(--bg-card);border:2px solid var(--color-gray-200);border-radius:var(--radius-xl);overflow:hidden;transition:all .2s ease;box-shadow:var(--shadow-sm)}.suggestion-image-container{width:100%;height:180px;overflow:hidden;cursor:pointer}.suggestion-image{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.suggestion-card:hover .suggestion-image{transform:scale(1.05)}.suggestion-image-placeholder{width:100%;height:180px;display:flex;align-items:center;justify-content:center;font-size:4rem;background:linear-gradient(135deg,#5a8f651a,#9b7bb81a);cursor:pointer}.suggestion-card-content{padding:0}.suggestion-card:hover{border-color:var(--color-gray-300);box-shadow:var(--shadow-md);transform:translateY(-2px)}.suggestion-card.selected{border-color:var(--color-primary);box-shadow:0 4px 20px #5a8f6533}.suggestion-card-header{display:flex;align-items:flex-start;gap:var(--spacing-4);padding:var(--spacing-5);cursor:pointer}.suggestion-emoji{font-size:2.5rem;line-height:1;flex-shrink:0}.suggestion-info{flex:1;min-width:0}.suggestion-title-row{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--spacing-3);margin-bottom:var(--spacing-2)}.suggestion-title-row h4{margin:0;color:var(--color-gray-800);font-size:var(--font-size-lg);font-weight:700;line-height:1.3}.suggestion-check-btn{width:32px;height:32px;border-radius:50%;border:2px solid var(--color-gray-300);background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;flex-shrink:0}.suggestion-check-btn .check-icon{font-size:14px;font-weight:700;color:var(--color-gray-300);transition:all .2s ease}.suggestion-check-btn:hover{border-color:var(--color-primary)}.suggestion-check-btn:hover .check-icon{color:var(--color-primary)}.suggestion-check-btn.selected{background:var(--color-primary);border-color:var(--color-primary)}.suggestion-check-btn.selected .check-icon{color:#fff}.suggestion-pills{display:flex;flex-wrap:wrap;gap:var(--spacing-2);margin-bottom:var(--spacing-3)}.pill{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:500;text-transform:capitalize}.pill-time{background:var(--color-gray-100);color:var(--color-gray-600)}.pill-type{background:#9b7bb826;color:#7c4dab}.pill-protein{background:#5a8f6526;color:var(--color-primary-dark)}.pill-difficulty{text-transform:capitalize}.pill-difficulty-easy{background:#5a8f6533;color:var(--color-primary-dark)}.pill-difficulty-medium{background:#e9b44c33;color:#92400e}.pill-difficulty-hard{background:#d6455026;color:var(--color-error)}.suggestion-desc{margin:0;color:var(--color-gray-600);font-size:var(--font-size-sm);line-height:1.5}.expand-chevron{color:var(--color-gray-400);font-size:var(--font-size-sm);flex-shrink:0;transition:color .2s ease}.suggestion-card:hover .expand-chevron{color:var(--color-gray-600)}.suggestion-card-expanded{border-top:1px solid var(--color-gray-100);padding:var(--spacing-5);background:var(--color-gray-50)}.why-great-section{background:#5a8f651a;border-radius:var(--radius-lg);padding:var(--spacing-4);margin-bottom:var(--spacing-4)}.why-great-label{margin:0 0 var(--spacing-1);font-size:var(--font-size-sm);font-weight:600;color:var(--color-primary-dark)}.why-great-text{margin:0;font-size:var(--font-size-sm);color:var(--color-primary);line-height:1.5}.expanded-details{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-4);margin-bottom:var(--spacing-4)}@media(max-width:600px){.expanded-details{grid-template-columns:1fr}}.expanded-section{background:#fff;border-radius:var(--radius-md);padding:var(--spacing-3)}.expanded-section h5{margin:0 0 var(--spacing-2);color:var(--color-gray-700);font-size:var(--font-size-sm);font-weight:600}.expanded-section ul,.expanded-section ol{margin:0;padding-left:var(--spacing-5);color:var(--color-gray-700);font-size:var(--font-size-sm)}.expanded-section li{margin-bottom:var(--spacing-1);line-height:1.4}.more-items{color:var(--color-gray-400);font-style:italic}.expanded-tips{background:#9b7bb81a;border-radius:var(--radius-md);padding:var(--spacing-4)}.expanded-tips h5{margin:0 0 var(--spacing-2);color:#7c4dab;font-size:var(--font-size-sm);font-weight:600}.expanded-tips p{margin:0;color:var(--color-gray-700);font-size:var(--font-size-sm);line-height:1.5}.suggestion-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-8)}.loading-scene{position:relative;width:100%;max-width:300px;height:100px;margin-bottom:var(--spacing-4);overflow:hidden;border-radius:var(--radius-xl);background:linear-gradient(to bottom,#e8f5e9,#fff 70%,#a5d6a7)}.loading-emoji{position:absolute;font-size:2.5rem;top:40%;animation:driveAcross 3s ease-in-out infinite}@keyframes driveAcross{0%{left:-15%;opacity:0}10%{opacity:1}50%{left:50%}90%{opacity:1}to{left:115%;opacity:0}}.loading-text{font-size:var(--font-size-lg);font-weight:600;color:var(--color-gray-800);margin-bottom:var(--spacing-2)}.loading-dots span{display:inline-block;animation:bounce .6s ease infinite}.loading-dots span:nth-child(2){animation-delay:.15s}.loading-dots span:nth-child(3){animation-delay:.3s}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}.loading-subtext{font-size:var(--font-size-sm);color:var(--color-gray-500);margin-bottom:var(--spacing-4)}.loading-progress{width:200px;height:6px;background:var(--color-gray-200);border-radius:var(--radius-full);overflow:hidden}.loading-progress-bar{height:100%;background:linear-gradient(90deg,var(--color-primary),var(--color-secondary));border-radius:var(--radius-full);animation:progressPulse 2s ease-in-out infinite}@keyframes progressPulse{0%{width:5%}50%{width:85%}to{width:5%}}@media(max-width:600px){.filters-bar{flex-direction:column}.recipes-grid{grid-template-columns:1fr}.tabs{flex-direction:row}.tab{padding:var(--spacing-2);font-size:var(--font-size-xs)}.suggestion-input-row{flex-direction:column}.suggestion-card-header{padding:var(--spacing-4)}.suggestion-emoji{font-size:2rem}.suggestion-title-row h4{font-size:var(--font-size-base)}}.sign-in-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--spacing-6)}.sign-in-container{width:100%;max-width:400px}.clerk-card{border-radius:var(--radius-xl)!important;box-shadow:var(--shadow-xl)!important}
