:root{--bg-base: #0F1117;--bg-surface: #171B24;--bg-elevated: #1E2433;--bg-card: #242A38;--border: #2E3547;--border-subtle: #242A38;--text-primary: #F0F2F8;--text-secondary: #8B93A8;--text-muted: #545F78;--accent: #E8A020;--accent-hover: #F0B030;--accent-dim: rgba(232,160,32,.15);--red: #E05252;--green: #3DBD7D;--blue: #4A90E2;--purple: #9B6EF3;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--shadow-sm: 0 1px 3px rgba(0,0,0,.4);--shadow-md: 0 4px 12px rgba(0,0,0,.5);--shadow-lg: 0 8px 32px rgba(0,0,0,.6);--font-display: "DM Serif Display", Georgia, serif;--font-body: "DM Sans", system-ui, sans-serif;--header-h: 58px;--transition: .18s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px}body{font-family:var(--font-body);background:var(--bg-base);color:var(--text-primary);min-height:100vh;overflow-x:hidden}.screen{min-height:100vh}.screen.hidden{display:none}.screen.active{display:block}.login-container{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;background:radial-gradient(ellipse 60% 50% at 50% 0%,rgba(232,160,32,.08) 0%,transparent 70%),var(--bg-base)}.login-brand{text-align:center;margin-bottom:2.5rem}.brand-icon{font-size:3rem;color:var(--accent);display:block;margin-bottom:.5rem;filter:drop-shadow(0 0 12px rgba(232,160,32,.4))}.login-brand h1{font-family:var(--font-display);font-size:2.4rem;color:var(--text-primary);letter-spacing:-.02em}.login-brand p{color:var(--text-muted);margin-top:.25rem;font-size:.9rem;letter-spacing:.06em;text-transform:uppercase}.login-form{width:100%;max-width:360px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:2rem;box-shadow:var(--shadow-lg)}.form-group{margin-bottom:1.25rem}.form-group label{display:block;font-size:.78rem;font-weight:500;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;margin-bottom:.4rem}input[type=text],input[type=password],input[type=number],input[type=date],input[type=time],input[type=url],select,textarea{width:100%;background:var(--bg-base);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);padding:.65rem .85rem;font-family:var(--font-body);font-size:.9rem;transition:border-color var(--transition);outline:none}input:focus,select:focus,textarea:focus{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-dim)}input::placeholder{color:var(--text-muted)}select{cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%238B93A8' d='M1 1l5 5 5-5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;padding-right:2rem}textarea{resize:vertical;min-height:80px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:.75rem}.btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;background:var(--accent);color:#0f0f0f;border:none;border-radius:var(--radius-sm);padding:.65rem 1.25rem;font-family:var(--font-body);font-size:.88rem;font-weight:600;cursor:pointer;transition:background var(--transition),transform var(--transition)}.btn-primary:hover{background:var(--accent-hover);transform:translateY(-1px)}.btn-primary:active{transform:translateY(0)}.btn-secondary{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;background:transparent;color:var(--text-secondary);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.6rem 1rem;font-family:var(--font-body);font-size:.88rem;font-weight:500;cursor:pointer;transition:all var(--transition)}.btn-secondary:hover{border-color:var(--text-secondary);color:var(--text-primary)}.btn-ghost{background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:.4rem .6rem;font-size:.85rem;border-radius:var(--radius-sm);transition:color var(--transition),background var(--transition)}.btn-ghost:hover{color:var(--text-primary);background:var(--bg-elevated)}.btn-sm{padding:.4rem .85rem;font-size:.82rem}.btn-full{width:100%}.btn-icon{background:transparent;border:none;color:var(--text-muted);cursor:pointer;font-size:1.1rem;padding:.4rem .6rem;border-radius:var(--radius-sm);transition:color var(--transition)}.btn-icon:hover{color:var(--accent)}.btn-danger{background:transparent;border:1px solid var(--red);color:var(--red);border-radius:var(--radius-sm);padding:.4rem .75rem;font-size:.82rem;cursor:pointer;transition:all var(--transition)}.btn-danger:hover{background:var(--red);color:#fff}.app-header{position:sticky;top:0;z-index:100;height:var(--header-h);background:var(--bg-surface);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 1.5rem;gap:1rem}.header-brand{font-family:var(--font-display);font-size:1.15rem;color:var(--accent);white-space:nowrap;letter-spacing:-.01em}.header-center{flex:1;display:flex;justify-content:center}.header-right{display:flex;align-items:center;gap:.5rem}.main-nav{display:flex;gap:.25rem;background:var(--bg-elevated);padding:.25rem;border-radius:var(--radius-md)}.nav-btn{background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:.4rem 1rem;border-radius:var(--radius-sm);font-family:var(--font-body);font-size:.85rem;font-weight:500;transition:all var(--transition);white-space:nowrap}.nav-btn:hover{color:var(--text-primary);background:var(--bg-card)}.nav-btn.active{background:var(--accent);color:#0f0f0f;font-weight:600}.user-chip{font-size:.78rem;color:var(--text-muted);background:var(--bg-elevated);padding:.25rem .65rem;border-radius:20px;border:1px solid var(--border)}.calendar-section{background:var(--bg-surface);border-bottom:1px solid var(--border);padding:1.25rem 1.5rem}.calendar-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.calendar-header h2{font-family:var(--font-display);font-size:1.4rem;flex:1;text-align:center}.cal-nav-btn{background:var(--bg-elevated);border:1px solid var(--border);color:var(--text-primary);width:32px;height:32px;border-radius:var(--radius-sm);font-size:1.1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition)}.cal-nav-btn:hover{border-color:var(--accent);color:var(--accent)}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}.cal-day-header{text-align:center;font-size:.72rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;padding:.4rem 0}.cal-day{background:var(--bg-card);border-radius:var(--radius-sm);min-height:90px;padding:.4rem;position:relative;cursor:default;transition:background var(--transition)}.cal-day:hover{background:var(--bg-elevated)}.cal-day.other-month{opacity:.35}.cal-day.today{background:var(--accent-dim);border:1px solid var(--accent)}.cal-day.past{position:relative}.cal-day.past:after{content:"✕";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:2.5rem;color:#ffffff0a;pointer-events:none;font-weight:900}.cal-day-num{font-size:.78rem;font-weight:600;color:var(--text-muted);margin-bottom:.25rem}.cal-day.today .cal-day-num{color:var(--accent);font-weight:700}.cal-events{display:flex;flex-direction:column;gap:2px}.cal-event{font-size:.68rem;padding:1px 4px;border-radius:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;cursor:pointer;font-weight:500;line-height:1.5}.cal-event.paid{text-decoration:line-through;opacity:.6}.cal-event-more{font-size:.65rem;color:var(--text-muted);padding:0 4px;cursor:pointer}.calendar-legend{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:.75rem}.legend-item{display:flex;align-items:center;gap:.3rem;font-size:.75rem;color:var(--text-secondary)}.legend-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.section-content{padding:1.5rem;max-width:1400px;margin:0 auto}.section-panel{display:none}.section-panel.active{display:block}.section-tabs{display:flex;gap:.25rem;border-bottom:1px solid var(--border);margin-bottom:1.5rem;overflow-x:auto;padding-bottom:0}.tab-btn{background:transparent;border:none;border-bottom:2px solid transparent;color:var(--text-muted);cursor:pointer;padding:.65rem 1rem;font-family:var(--font-body);font-size:.85rem;font-weight:500;white-space:nowrap;margin-bottom:-1px;transition:all var(--transition)}.tab-btn:hover{color:var(--text-primary)}.tab-btn.active{color:var(--accent);border-bottom-color:var(--accent);font-weight:600}.tab-panel{display:none}.tab-panel.active{display:block}.panel-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem;gap:1rem}.panel-header h3{font-family:var(--font-display);font-size:1.25rem;color:var(--text-primary)}.panel-header h4{font-size:.95rem;font-weight:600;color:var(--text-secondary)}.bills-list{display:flex;flex-direction:column;gap:.5rem}.bill-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);padding:.9rem 1.1rem;display:grid;grid-template-columns:auto 1fr auto auto auto;align-items:center;gap:.75rem;transition:border-color var(--transition)}.bill-card:hover{border-color:var(--border-subtle)}.bill-card.paid{opacity:.6}.bill-category-badge{font-size:.72rem;padding:.2rem .5rem;border-radius:20px;background:var(--bg-elevated);color:var(--text-muted);white-space:nowrap}.bill-vendor{font-weight:500;font-size:.92rem}.bill-vendor.paid{text-decoration:line-through;color:var(--text-muted)}.bill-amount{font-weight:600;color:var(--accent);font-size:.95rem}.bill-due{font-size:.8rem;color:var(--text-muted)}.bill-due.overdue{color:var(--red);font-weight:600}.bill-actions{display:flex;align-items:center;gap:.5rem}.bill-paid-check{width:18px;height:18px;cursor:pointer;accent-color:var(--green)}.items-list{display:flex;flex-direction:column;gap:.5rem}.item-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);padding:.9rem 1.1rem;display:flex;align-items:center;justify-content:space-between;gap:1rem}.item-main{flex:1}.item-title{font-weight:500;margin-bottom:.2rem}.item-sub{font-size:.8rem;color:var(--text-muted)}.item-actions{display:flex;gap:.5rem}.shopping-add-row{display:flex;gap:.5rem;margin-bottom:1rem;align-items:center}.shopping-input-wrap{flex:1}.qty-input{width:80px!important}.shopping-item{display:flex;align-items:center;gap:.75rem;padding:.65rem .9rem;background:var(--bg-card);border-radius:var(--radius-sm);margin-bottom:.35rem;border:1px solid var(--border)}.shopping-item.checked{opacity:.5}.shopping-item.checked .shopping-item-name{text-decoration:line-through}.shopping-check{width:16px;height:16px;cursor:pointer;accent-color:var(--green);flex-shrink:0}.shopping-item-name{flex:1;font-size:.9rem}.shopping-item-qty{font-size:.8rem;color:var(--text-muted)}.devices-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:.75rem}.device-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);padding:1rem;text-align:center;cursor:pointer;transition:all var(--transition)}.device-card:hover{border-color:var(--accent)}.device-card.on{background:var(--accent-dim);border-color:var(--accent)}.device-icon{font-size:1.8rem;margin-bottom:.5rem}.device-name{font-size:.82rem;font-weight:500;margin-bottom:.25rem}.device-room{font-size:.72rem;color:var(--text-muted)}.device-status{font-size:.72rem;margin-top:.4rem;color:var(--text-muted)}.device-status.on{color:var(--green)}.meal-grid{display:grid;grid-template-columns:80px repeat(7,1fr);gap:2px}.meal-col-header{text-align:center;font-size:.75rem;font-weight:600;color:var(--text-muted);padding:.4rem;text-transform:uppercase;letter-spacing:.05em}.meal-row-label{display:flex;align-items:center;justify-content:flex-end;padding-right:.75rem;font-size:.78rem;color:var(--text-muted);font-weight:500;text-transform:uppercase;letter-spacing:.04em}.meal-cell{background:var(--bg-card);border-radius:var(--radius-sm);padding:.5rem;min-height:64px;cursor:pointer;transition:background var(--transition);font-size:.78rem;position:relative}.meal-cell:hover{background:var(--bg-elevated)}.meal-cell.has-meal{color:var(--text-primary)}.meal-cell.empty{color:var(--text-muted);font-style:italic}.meal-cell.today-col{border:1px solid var(--accent)}.media-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:1rem}.media-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden;cursor:pointer;transition:all var(--transition)}.media-card:hover{border-color:var(--accent);transform:translateY(-2px)}.media-poster{width:100%;aspect-ratio:2/3;object-fit:cover;background:var(--bg-elevated);display:block}.media-poster-placeholder{width:100%;aspect-ratio:2/3;background:var(--bg-elevated);display:flex;align-items:center;justify-content:center;font-size:2rem;color:var(--text-muted)}.media-info{padding:.65rem}.media-title{font-size:.8rem;font-weight:500;line-height:1.3;margin-bottom:.25rem}.media-meta{font-size:.72rem;color:var(--text-muted)}.media-status{font-size:.68rem;margin-top:.3rem}.media-status.watching{color:var(--blue)}.media-status.completed{color:var(--green)}.media-status.want_to_watch{color:var(--text-muted)}.media-status.reading{color:var(--blue)}.media-status.currently-reading{color:var(--accent)}.sports-feeds{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem}.feed-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);padding:1.1rem;display:flex;align-items:center;justify-content:space-between;gap:1rem}.feed-info{flex:1}.feed-name{font-weight:600;margin-bottom:.2rem}.feed-sport{font-size:.78rem;color:var(--text-muted)}.feed-last-sync{font-size:.72rem;color:var(--text-muted);margin-top:.25rem}.toggle-switch{position:relative;width:44px;height:24px;flex-shrink:0}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--bg-elevated);border-radius:24px;cursor:pointer;transition:background var(--transition);border:1px solid var(--border)}.toggle-slider:before{content:"";position:absolute;width:18px;height:18px;background:var(--text-muted);border-radius:50%;top:2px;left:2px;transition:all var(--transition)}input:checked+.toggle-slider{background:var(--accent-dim);border-color:var(--accent)}input:checked+.toggle-slider:before{transform:translate(20px);background:var(--accent)}.modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:500;display:flex;align-items:center;justify-content:center}.modal.hidden{display:none}.modal-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-box{position:relative;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);width:90%;max-width:500px;max-height:85vh;overflow-y:auto;box-shadow:var(--shadow-lg);z-index:1}.modal-box.modal-lg{max-width:700px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border)}.modal-header h3{font-family:var(--font-display);font-size:1.15rem}.modal-close{background:transparent;border:none;color:var(--text-muted);cursor:pointer;font-size:1rem;padding:.25rem .5rem;border-radius:var(--radius-sm);transition:color var(--transition)}.modal-close:hover{color:var(--text-primary)}.modal-body{padding:1.5rem}.modal-footer{padding:1rem 1.5rem;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:.75rem}.event-popup{position:fixed;bottom:2rem;right:2rem;width:300px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);z-index:200;animation:slideUp .2s ease}.event-popup.hidden{display:none}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.popup-header{display:flex;align-items:center;justify-content:space-between;padding:.9rem 1.1rem;border-bottom:1px solid var(--border);font-weight:600;font-size:.9rem}#popup-close{background:transparent;border:none;color:var(--text-muted);cursor:pointer;font-size:.85rem}#popup-body{padding:1rem 1.1rem;font-size:.85rem;line-height:1.6}#popup-body .popup-row{display:flex;justify-content:space-between;margin-bottom:.35rem}#popup-body .popup-label{color:var(--text-muted)}#popup-body .popup-value{font-weight:500}.work-baseline{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.75rem 1rem;font-size:.88rem;color:var(--text-secondary);margin-bottom:1rem}.hidden{display:none!important}.error-msg{color:var(--red);font-size:.82rem;margin-bottom:.75rem;background:#e052521a;border:1px solid rgba(224,82,82,.3);border-radius:var(--radius-sm);padding:.5rem .75rem}.success-msg{color:var(--green);font-size:.82rem;background:#3dbd7d1a;border:1px solid rgba(61,189,125,.3);border-radius:var(--radius-sm);padding:.5rem .75rem}.text-muted{color:var(--text-muted)}.text-accent{color:var(--accent)}.text-green{color:var(--green)}.text-red{color:var(--red)}.empty-state{text-align:center;padding:3rem 1rem;color:var(--text-muted);font-size:.9rem}.loading{text-align:center;padding:2rem;color:var(--text-muted);font-size:.85rem}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}@media (max-width: 768px){.app-header{padding:0 1rem}.header-brand{display:none}.main-nav{gap:0}.nav-btn{padding:.4rem .65rem;font-size:.78rem}.calendar-section{padding:1rem}.cal-day{min-height:70px;padding:.3rem}.cal-event{font-size:.62rem}.section-content{padding:1rem}.media-grid{grid-template-columns:repeat(auto-fill,minmax(110px,1fr))}.devices-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr))}.bill-card{grid-template-columns:1fr auto;gap:.5rem}.bill-category-badge{display:none}.form-row,.form-row-3{grid-template-columns:1fr}.event-popup{right:1rem;left:1rem;width:auto}}@media (max-width: 480px){.calendar-grid{gap:1px}.cal-day{min-height:55px}.meal-grid{grid-template-columns:60px repeat(7,1fr)}}
