@import url("https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Outfit:wght@400;500;600;700;800&display=swap");:root{--font-sans:"Inter",system-ui,-apple-system,sans-serif;--font-display:"Outfit",system-ui,-apple-system,sans-serif;--bg-primary:#070a13;--bg-secondary:rgba(16,22,42,0.7);--bg-tertiary:rgba(26,34,60,0.9);--border-color:rgba(255,255,255,0.08);--border-color-hover:rgba(255,255,255,0.16);--border-glow:rgba(79,70,229,0.4);--text-primary:#f8fafc;--text-secondary:#94a3b8;--text-muted:#64748b;--accent-primary:#6366f1;--accent-primary-hover:#4f46e5;--accent-primary-glow:rgba(99,102,241,0.15);--accent-secondary:#a855f7;--accent-secondary-hover:#9333ea;--color-success:#10b981;--color-success-bg:rgba(16,185,129,0.1);--color-danger:#f43f5e;--color-danger-bg:rgba(244,63,94,0.1);--color-warning:#f59e0b;--color-warning-bg:rgba(245,158,11,0.1);--color-info:#3b82f6;--color-info-bg:rgba(59,130,246,0.1);--glass-blur:16px;--shadow-sm:0 2px 8px -1px rgba(0,0,0,0.3);--shadow-md:0 4px 20px -2px rgba(0,0,0,0.4);--shadow-lg:0 10px 40px -4px rgba(0,0,0,0.5);--transition-smooth:all 0.3s cubic-bezier(0.4,0,0.2,1);--transition-fast:all 0.15s ease}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg-primary);color:var(--text-primary);font-family:var(--font-sans);min-height:100vh;overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);font-weight:600;letter-spacing:-.02em}a{color:inherit;text-decoration:none}button,input,select,textarea{font-family:inherit}.app-container,.main-content{display:flex;min-height:100vh}.main-content{flex:1;flex-direction:column;padding-left:260px;transition:var(--transition-smooth)}@media (max-width:1024px){.main-content{padding-left:0}}.content-body{flex:1;padding:2rem;max-width:1600px;width:100%;margin:0 auto}@media (max-width:640px){.content-body{padding:1rem}}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:rgba(255,255,255,.1);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,.2)}.glass-card{background:var(--bg-secondary);backdrop-filter:blur(var(--glass-blur));-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--border-color);border-radius:16px;padding:1.5rem;box-shadow:var(--shadow-md);transition:var(--transition-smooth)}.glass-card:hover{border-color:var(--border-color-hover);box-shadow:var(--shadow-lg);transform:translateY(-2px)}.glass-card-interactive{cursor:pointer}.glass-card-interactive:active{transform:translateY(0)}.form-group{margin-bottom:1.25rem;display:flex;flex-direction:column;gap:.5rem}.form-label{font-size:.875rem;font-weight:500;color:var(--text-secondary)}.form-input,.form-select,.form-textarea{background:rgba(10,15,30,.6);border:1px solid var(--border-color);border-radius:10px;color:var(--text-primary);padding:.75rem 1rem;font-size:.95rem;transition:var(--transition-smooth);width:100%}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px var(--accent-primary-glow);outline:none}.form-input::placeholder,.form-textarea::placeholder{color:var(--text-muted)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;font-family:var(--font-sans);font-weight:500;font-size:.95rem;padding:.75rem 1.25rem;border-radius:10px;border:1px solid transparent;cursor:pointer;transition:var(--transition-smooth)}.btn-primary{background:linear-gradient(135deg,var(--accent-primary) 0,var(--accent-secondary) 100%);color:#ffffff;box-shadow:0 4px 15px rgba(99,102,241,.3)}.btn-primary:hover{filter:brightness(1.1);box-shadow:0 6px 20px rgba(99,102,241,.4);transform:translateY(-1px)}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:rgba(255,255,255,.05);border:1px solid var(--border-color);color:var(--text-primary)}.btn-secondary:hover{background:rgba(255,255,255,.1);border-color:var(--border-color-hover)}.btn-danger{background:var(--color-danger-bg);border:1px solid rgba(244,63,94,.2);color:var(--color-danger)}.btn-danger:hover{background:var(--color-danger);color:white}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(4,6,12,.8);backdrop-filter:blur(8px);z-index:1000;display:flex;align-items:flex-start;justify-content:center;padding:1rem;overflow-y:auto;animation:fadeIn .2s ease-out}.modal-content{background:var(--bg-tertiary);border:1px solid rgba(255,255,255,.1);border-radius:20px;width:100%;max-width:500px;max-height:calc(100dvh - 2rem);box-shadow:var(--shadow-lg);overflow:hidden;display:flex;flex-direction:column;margin:auto 0;animation:slideUp .3s cubic-bezier(.34,1.56,.64,1)}.quick-add-modal{max-height:calc(100dvh - 1rem)}.modal-content>form{min-height:0;display:flex;flex:1;flex-direction:column}.modal-header{padding:1.5rem;border-bottom:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.modal-title{font-size:1.25rem;font-family:var(--font-display)}.modal-close{background:none;border:none;color:var(--text-secondary);cursor:pointer;font-size:1.5rem;line-height:1}.modal-body{padding:1.5rem;overflow-y:auto;flex:1 1 auto;min-height:0;overscroll-behavior:contain;-webkit-overflow-scrolling:touch}.modal-footer{padding:1rem 1.5rem;border-top:1px solid var(--border-color);display:flex;justify-content:flex-end;gap:.75rem;background:rgba(0,0,0,.15);flex-shrink:0}@media (max-height:720px){.modal-body,.modal-header{padding:1rem 1.25rem}.modal-footer{padding:.85rem 1.25rem}.modal-body .form-group{margin-bottom:.9rem}}@media (max-height:820px),(max-width:1024px){.quick-add-modal{height:calc(100dvh - 1rem)}}@media (max-width:520px){.modal-content{max-height:calc(100dvh - 1rem)}.modal-footer{flex-direction:column-reverse}.modal-footer .btn{width:100%}}.logout-confirm-overlay{z-index:1200}.logout-confirm-modal{max-width:420px;padding:1.5rem;display:grid;grid-template-columns:auto 1fr;gap:1rem}.logout-confirm-icon{width:52px;height:52px;border-radius:14px;background:var(--color-danger-bg);color:var(--color-danger);display:flex;align-items:center;justify-content:center;border:1px solid rgba(244,63,94,.2)}.logout-confirm-copy{min-width:0}.logout-confirm-copy p{color:var(--text-secondary);line-height:1.6;margin-top:.5rem}.logout-confirm-actions{grid-column:1/-1;display:flex;justify-content:flex-end;gap:.75rem;margin-top:.5rem}.logout-confirm-actions .btn:disabled{opacity:.6;cursor:not-allowed;transform:none}@media (max-width:480px){.logout-confirm-modal{grid-template-columns:1fr}.logout-confirm-actions{flex-direction:column-reverse}.logout-confirm-actions .btn{width:100%}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.text-success{color:var(--color-success)}.text-danger{color:var(--color-danger)}.text-warning{color:var(--color-warning)}.text-info{color:var(--color-info)}.bg-success-subtle{background-color:var(--color-success-bg)}.bg-danger-subtle{background-color:var(--color-danger-bg)}.bg-warning-subtle{background-color:var(--color-warning-bg)}.bg-info-subtle{background-color:var(--color-info-bg)}.custom-table-wrapper{overflow-x:auto;border-radius:12px;border:1px solid var(--border-color)}.custom-table{width:100%;border-collapse:collapse;text-align:left;font-size:.925rem}.custom-table th{background:rgba(255,255,255,.02);color:var(--text-secondary);font-weight:500}.custom-table td,.custom-table th{padding:1rem 1.25rem;border-bottom:1px solid var(--border-color)}.custom-table td{color:var(--text-primary);transition:var(--transition-fast)}.custom-table tr:last-child td{border-bottom:none}.custom-table tr:hover td{background:rgba(255,255,255,.02)}.badge{display:inline-flex;align-items:center;gap:.25rem;font-size:.75rem;font-weight:600;padding:.25rem .625rem;border-radius:9999px;text-transform:uppercase;letter-spacing:.03em}.sidebar{position:fixed;top:0;left:0;bottom:0;width:260px;background:var(--bg-secondary);backdrop-filter:blur(var(--glass-blur));-webkit-backdrop-filter:blur(var(--glass-blur));border-right:1px solid var(--border-color);display:flex;flex-direction:column;z-index:100;transition:var(--transition-smooth)}.sidebar-header{height:70px;padding:0 1.5rem;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border-color)}.logo-text{font-family:var(--font-display);font-size:1.5rem;font-weight:800;background:linear-gradient(135deg,var(--accent-primary) 0,var(--accent-secondary) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;letter-spacing:-.03em}.sidebar-close-btn{display:none;background:none;border:none;color:var(--text-secondary);cursor:pointer}.sidebar-nav{flex:1;padding:1.5rem 1rem;display:flex;flex-direction:column;gap:.35rem;overflow-y:auto}.sidebar-link{display:flex;align-items:center;gap:1rem;padding:.85rem 1rem;color:var(--text-secondary);font-weight:500;border-radius:12px;transition:var(--transition-fast)}.sidebar-link:hover{color:var(--text-primary);background:rgba(255,255,255,.03)}.sidebar-link.active{color:#ffffff;background:linear-gradient(135deg,rgba(99,102,241,.15),rgba(168,85,247,.15));border:1px solid rgba(99,102,241,.25);box-shadow:0 4px 12px rgba(99,102,241,.05)}.sidebar-footer{padding:1rem;border-top:1px solid var(--border-color)}.sidebar-logout-btn{display:flex;align-items:center;gap:1rem;width:100%;padding:.85rem 1rem;color:var(--color-danger);background:none;border:none;font-weight:500;font-size:.95rem;border-radius:12px;cursor:pointer;transition:var(--transition-fast);text-align:left}.sidebar-logout-btn:hover{background:var(--color-danger-bg)}.header{position:fixed;top:0;right:0;left:260px;height:70px;background:rgba(7,10,19,.8);backdrop-filter:blur(var(--glass-blur));-webkit-backdrop-filter:blur(var(--glass-blur));border-bottom:1px solid var(--border-color);justify-content:space-between;padding:0 2rem;z-index:90;transition:var(--transition-smooth)}.header,.header-left{display:flex;align-items:center}.header-left{gap:1rem}.mobile-menu-btn{display:none;background:none;border:none;color:var(--text-primary);cursor:pointer}.household-selector{display:flex;flex-direction:column}.household-label{font-size:.7rem;text-transform:uppercase;color:var(--text-muted);font-weight:600;letter-spacing:.05em}.household-name{font-size:.95rem}.household-name,.household-select{font-weight:600;color:var(--text-primary)}.household-select{max-width:240px;min-width:180px;background:rgba(10,15,30,.7);border:1px solid var(--border-color);border-radius:8px;font-size:.9rem;padding:.35rem .55rem;outline:none}.household-select:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px var(--accent-primary-glow)}.header-right{display:flex;align-items:center;gap:1.5rem}.quick-add-container{position:relative}.btn-quick-add{height:40px;padding:0 1rem;font-size:.875rem}.quick-add-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;z-index:150;background:transparent}.quick-add-dropdown{position:absolute;top:calc(100% + 8px);right:0;background:var(--bg-tertiary);border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:.5rem;width:180px;box-shadow:var(--shadow-lg);z-index:160;display:flex;flex-direction:column;gap:.25rem;animation:slideUp .15s ease-out}.quick-add-item{display:flex;align-items:center;gap:.75rem;padding:.65rem .75rem;background:none;border:none;width:100%;text-align:left;font-size:.875rem;font-weight:500;border-radius:8px;cursor:pointer;transition:var(--transition-fast)}.quick-add-item:hover{background:rgba(255,255,255,.04)}.user-profile-badge{display:flex;align-items:center;gap:.75rem}.user-avatar{width:36px;height:36px;border-radius:50%;object-fit:cover;border:1px solid rgba(255,255,255,.2)}.user-avatar-fallback{width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;color:var(--text-secondary);border:1px solid var(--border-color)}.user-name{font-size:.9rem;font-weight:500;color:var(--text-primary)}@media (max-width:1024px){.header{left:0;padding:0 1.25rem}.mobile-menu-btn{display:block}.sidebar{transform:translateX(-100%);box-shadow:none}.sidebar-mobile-open{transform:translateX(0);box-shadow:10px 0 30px rgba(0,0,0,.6)}.sidebar-close-btn{display:block}.sidebar-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);backdrop-filter:blur(4px);z-index:95}}@media (max-width:640px){.hide-mobile{display:none!important}.header-right{gap:.75rem}}