:root{--touch-min: 44px;--bottom-nav-h: 3.75rem;--safe-bottom: env(safe-area-inset-bottom, 0px);--safe-top: env(safe-area-inset-top, 0px)}button,[role=button],a.btn-primary,a.btn-secondary,input[type=submit],input[type=button],.btn-link{touch-action:manipulation;-webkit-tap-highlight-color:rgb(79 70 229 / 18%)}select.input,textarea.input,.input{font-size:max(16px,1rem)}@media (hover: none),(pointer: coarse){.card.clickable:hover{outline:none}.card.clickable:active{outline:2px solid var(--primary);background:#4f46e50f}}@media (max-width: 768px){html{-webkit-text-size-adjust:100%;overflow-x:clip}body{overflow-x:clip}.main{padding:1rem;padding-bottom:calc(var(--bottom-nav-h) + var(--safe-bottom) + 1rem);overflow-x:clip}.page-header{flex-direction:column;align-items:stretch;gap:.75rem}.page-header .row,.page-header>.row{width:100%;justify-content:stretch;gap:.5rem}.page-header .btn-primary,.page-header .btn-ghost,.page-header .fab{flex:1;min-height:var(--touch-min);justify-content:center}.page-header h1{font-size:1.35rem}.btn-primary,.btn-secondary,.btn-ghost,.btn-danger,.btn-primary.btn-sm,.btn-ghost.btn-sm,.btn-secondary.btn-sm{min-height:var(--touch-min);padding:.65rem 1rem;font-size:.9375rem}.btn-sm:not(.btn-link){min-height:var(--touch-min);padding:.5rem .85rem;font-size:.875rem}.btn-link{min-height:var(--touch-min);display:inline-flex;align-items:center;padding:.35rem .25rem}.check-row{min-height:var(--touch-min);padding:.35rem 0}.check-row input[type=checkbox]{width:1.25rem;height:1.25rem;flex-shrink:0}.list-item{flex-direction:column;align-items:stretch;gap:.75rem}.list-item>.flex-1,.list-item>.member-info,.list-item>.shopping-info,.list-item>.text-stack{width:100%}.item-actions,.row-actions{width:100%;gap:.5rem}.item-actions .btn-ghost,.item-actions .btn-sm,.row-actions .btn-ghost,.row-actions .btn-sm,.row-actions .btn-primary{flex:1 1 auto;min-width:calc(50% - .25rem);justify-content:center}.admin-user-row,.admin-house-row{flex-direction:column;align-items:stretch}.pagination{flex-wrap:wrap;gap:.5rem}.pagination .btn-ghost{flex:1;min-width:7rem}.filter-tabs{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;gap:.35rem;padding-bottom:.25rem;margin-bottom:1rem}.filter-tabs::-webkit-scrollbar{display:none}.filter-tab{flex-shrink:0;min-height:var(--touch-min);padding:.5rem .85rem;white-space:nowrap}.status-btn{min-height:var(--touch-min);padding:.5rem .65rem}.modal{align-items:flex-end;padding:0;padding-top:var(--safe-top)}.modal-card,.modal-card-wide,.webcam-card{max-width:none;width:100%;max-height:min(92vh,100dvh);overflow-y:auto;-webkit-overflow-scrolling:touch;border-radius:16px 16px 0 0;margin:0;padding:1.25rem 1rem calc(1rem + var(--safe-bottom))}.help-modal{align-items:flex-end;padding:0}.help-modal-card{width:100%;max-width:none;max-height:min(88vh,100dvh);border-radius:16px 16px 0 0;margin:0;padding-bottom:calc(1rem + var(--safe-bottom))}.help-modal-close{width:var(--touch-min);height:var(--touch-min);font-size:1.75rem}.bottom-nav{padding:.35rem .25rem calc(.35rem + var(--safe-bottom));min-height:calc(var(--bottom-nav-h) + var(--safe-bottom));z-index:150}.bottom-nav a{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:var(--touch-min);padding:.35rem .25rem;font-size:.6875rem;text-align:center;line-height:1.2}.help-fab{width:3.25rem;height:3.25rem;right:max(1rem,env(safe-area-inset-right,0px))}.help-fab--nav{bottom:calc(var(--bottom-nav-h) + var(--safe-bottom) + .65rem)}.auth-page{padding:max(1rem,var(--safe-top)) 1rem calc(1rem + var(--safe-bottom));align-items:flex-start;padding-top:max(2rem,var(--safe-top))}.auth-card{padding:1.5rem 1.25rem}.admin-filters{flex-direction:column}.admin-filters .input{min-width:0;width:100%}.admin-subnav{overflow-x:auto;-webkit-overflow-scrolling:touch;flex-wrap:nowrap;padding-bottom:.25rem}.admin-subnav a{flex-shrink:0;min-height:var(--touch-min);display:inline-flex;align-items:center}.settings-tabs-scroll{display:flex;gap:.35rem;overflow-x:auto;-webkit-overflow-scrolling:touch;flex-wrap:nowrap;margin-bottom:1rem;padding-bottom:.25rem;scrollbar-width:none}.settings-tabs-scroll::-webkit-scrollbar{display:none}.settings-tabs-scroll button{flex-shrink:0;min-height:var(--touch-min);white-space:nowrap}.attach-actions{flex-direction:column}.attach-actions .btn-ghost,.attach-actions .btn-secondary{width:100%}.percent-input{max-width:100%}.status-select{max-width:100%;width:100%}}@media (max-width: 768px){.super-shell{flex-direction:column}.super-mobile-bar{display:flex;align-items:center;justify-content:space-between;gap:.75rem;position:sticky;top:0;z-index:380;padding:.65rem 1rem;padding-top:calc(.65rem + var(--safe-top));background:#120b22;border-bottom:1px solid var(--border)}.super-mobile-toggle{display:inline-flex;align-items:center;justify-content:center;min-width:var(--touch-min);min-height:var(--touch-min);padding:0;border:1px solid var(--border);border-radius:10px;background:#1a1228;color:var(--text);font-size:1.35rem;cursor:pointer;touch-action:manipulation}.super-nav-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:390;background:#0000008c;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.super-sidebar{position:fixed;top:0;left:0;bottom:0;z-index:400;width:min(300px,88vw);transform:translate(-105%);transition:transform .22s ease;box-shadow:8px 0 32px #00000059}.super-sidebar.is-open{transform:translate(0)}.super-nav-link{min-height:var(--touch-min);display:flex;align-items:center;font-size:1rem;padding:.65rem .85rem}.super-main{padding:1rem;padding-bottom:calc(1rem + var(--safe-bottom));width:100%}.super-page-header.row-actions{flex-direction:column;align-items:stretch}.super-page-header .btn-ghost,.super-page-header .btn-primary{width:100%;min-height:var(--touch-min)}.super-search{max-width:none}.search-dropdown{max-height:min(50vh,320px)}}@media (min-width: 769px){.super-mobile-bar,.super-nav-backdrop{display:none!important}}.badge{font-size:.75rem;font-weight:600;background:#e2e8f0;color:#334155;padding:.25rem .55rem;border-radius:999px;display:inline-block;flex-shrink:0;white-space:nowrap;line-height:1.3;border:1px solid rgb(15 23 42 / 8%)}.badge-muted{background:#f1f5f9;color:#64748b;border-color:#0f172a0f}.badge-ok{background:#dcfce7;color:#15803d;border-color:#16a34a33}.badge-warn{background:#fef3c7;color:#b45309;border-color:#f59e0b40}.badge-role--admin{background:#dbeafe;color:#1d4ed8;border-color:#3b82f640}.badge-role--super{background:#ede9fe;color:#4338ca;border-color:#4f46e540}.badge.status-tobuy{background:#fef3c7;color:#b45309;border-color:#f59e0b40}.badge.status-cart{background:#dbeafe;color:#1d4ed8;border-color:#3b82f640}.badge.status-bought{background:#dcfce7;color:#15803d;border-color:#16a34a33}.badge.status-stock{background:#e0e7ff;color:#4338ca;border-color:#4f46e540}.item-actions>.badge,.list-item>.badge:not(.text-group .badge){flex:0 0 auto;align-self:center}html:not(.super-theme)[data-theme=dark] .badge{background:#334155;color:#e2e8f0;border-color:#ffffff1f}html:not(.super-theme)[data-theme=dark] .badge-muted{background:#1e293b;color:#94a3b8}html:not(.super-theme)[data-theme=dark] .badge-ok{background:#1665347f;color:#bbf7d0}html:not(.super-theme)[data-theme=dark] .badge-warn{background:#78350f8c;color:#fde68a}html:not(.super-theme)[data-theme=dark] .badge-role--admin{background:#1e40af73;color:#bfdbfe}html:not(.super-theme)[data-theme=dark] .badge-role--super{background:#4338ca73;color:#e9d5ff}html:not(.super-theme)[data-theme=dark] .filter-tab:not(.active) .tab-count{background:#475569;color:#e2e8f0}html:not(.super-theme)[data-theme=dark] .offline-banner{background:#78350f59;color:#fde68a;border-left-color:#f59e0b}html.super-theme .badge{background:#3b2a5c;color:#e9d5ff;border-color:#a78bfa59}html.super-theme .badge-muted{background:#2a1f42;color:#a78bfa}html.super-theme .badge-warn{background:#78350f;color:#fef3c7;border-color:#fbbf2466}html.super-theme .badge-ok,html.super-theme .badge-role--admin{background:#16653473;color:#bbf7d0;border-color:#22c55e59}html.super-theme .badge-role--super{background:#5b21b68c;color:#ede9fe;border-color:#a78bfa73}html.super-theme .btn-ghost{color:#c4b5fd}html.super-theme .btn-ghost:hover:not(:disabled){background:#7c3aed2e;color:#ede9fe}html.super-theme .btn-ghost.danger,html.super-theme .btn-ghost.btn-danger-text{color:#fca5a5}html.super-theme .link{color:#c4b5fd}html.super-theme .filter-tab{border-color:var(--border);background:#1a1228;color:var(--muted)}html.super-theme .filter-tab.active{background:var(--primary);border-color:var(--primary);color:#fff}html.super-theme .filter-tab:not(.active) .tab-count{background:#3b2a5c;color:#e9d5ff}html.super-theme .item-actions-hint{margin:0;font-size:.8rem;white-space:nowrap;align-self:center;color:var(--muted)}:root{--primary: #4f46e5;--primary-dark: #4338ca;--accent: #f59e0b;--bg: #f8fafc;--surface: #ffffff;--text: #0f172a;--muted: #64748b;--danger: #dc2626;--success: #16a34a;--border: #e2e8f0;--border-input: #cbd5e1;--radius: 12px;--shadow: 0 1px 3px rgb(0 0 0 / 8%)}@media (prefers-color-scheme: dark){:root{--bg: #0f172a;--surface: #1e293b;--text: #f1f5f9;--muted: #94a3b8;--border: #334155;--border-input: #475569}}*{box-sizing:border-box}body{margin:0;font-family:Segoe UI,system-ui,sans-serif;background:var(--bg);color:var(--text)}#app{min-height:100vh}.app-shell{display:grid;grid-template-columns:240px 1fr;min-height:100vh}.sidebar{background:var(--surface);border-right:1px solid var(--border);padding:0;display:flex;flex-direction:column;min-height:100vh;position:sticky;top:0;align-self:start}.sidebar-header{padding:1.25rem 1rem 1rem;border-bottom:1px solid var(--border)}.brand{font-size:1.25rem;font-weight:700;color:var(--primary);text-decoration:none;display:inline-block}.brand-lockup{display:flex;align-items:center;gap:.65rem;text-decoration:none;color:inherit;min-width:0}.brand-lockup--compact{gap:.5rem}.brand-lockup--compact .brand-icon{width:28px;height:28px}.brand-icon{width:36px;height:36px;border-radius:10px;object-fit:cover;flex-shrink:0;box-shadow:0 2px 8px #4f46e538}.brand-lockup-text{display:flex;flex-direction:column;gap:.1rem;min-width:0}.brand-lockup-name{font-size:1.125rem;font-weight:700;color:var(--primary);line-height:1.2}.brand-lockup-sub{font-size:.7rem;color:var(--muted);font-weight:500}.auth-brand{justify-content:center;margin-bottom:.5rem}.auth-brand .brand-lockup-name{font-size:1.35rem}.auth-brand .brand-icon{width:48px;height:48px;border-radius:14px}.auth-tagline{text-align:center;margin:0 0 1.25rem!important}.auth-card--brand{text-align:center}html.super-theme .brand-lockup-name{color:#ede9fe}html.super-theme .brand-icon{box-shadow:0 2px 12px #00000059}.super-brand .brand-lockup{width:100%}.sidebar-nav{display:flex;flex-direction:column;gap:.2rem;flex:1;padding:1rem;overflow-y:auto}.sidebar-section-label{display:flex;align-items:center;gap:.4rem;margin:0 0 .35rem;padding:0 .5rem;font-size:.7rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}.sidebar-section-label--spaced{margin-top:.5rem;padding-top:0;border-top:none}.sidebar-divider{border:none;height:1px;margin:.85rem .25rem;background:linear-gradient(90deg,transparent,var(--border) 12%,var(--border) 88%,transparent)}.sidebar-section-dot{width:6px;height:6px;border-radius:50%;background:var(--primary);flex-shrink:0}.sidebar-hint{font-size:.8125rem;padding:.75rem!important;margin-bottom:.5rem;box-shadow:none}.sidebar-hint a{color:var(--primary);font-weight:600}.sidebar a{color:var(--text);text-decoration:none;padding:.55rem .75rem;border-radius:8px;font-size:.9375rem;font-weight:400}.sidebar-footer{margin-top:auto;padding:1rem;border-top:1px solid var(--border);background:var(--bg-muted, #f8fafc)}.sidebar-user{display:flex;align-items:center;gap:.65rem;margin-bottom:.75rem;min-width:0}.sidebar-avatar{width:2.25rem;height:2.25rem;border-radius:50%;background:var(--primary);color:#fff;font-size:.75rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.sidebar-user-text{display:flex;flex-direction:column;min-width:0;gap:.1rem}.sidebar-user-name{font-size:.875rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user-email{font-size:.75rem;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-logout{width:100%;justify-content:center;border:1px solid var(--border)!important;background:var(--surface)!important;color:var(--muted)!important;font-size:.875rem}.sidebar-logout:hover:not(:disabled){border-color:var(--danger)!important;color:var(--danger)!important;background:#dc26260f!important}.sidebar a.router-link-active{background:#e0e7ff;color:var(--primary-dark);font-weight:600}.main{padding:1.5rem 1.5rem 5rem}.bottom-nav{display:none}.page{max-width:720px;margin:0 auto}.page-header{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.page-header h1{margin:0;font-size:1.5rem}.card{background:var(--surface);border-radius:var(--radius);padding:1rem;margin-bottom:.75rem;box-shadow:var(--shadow)}.card.clickable{cursor:pointer}@media (hover: hover) and (pointer: fine){.card.clickable:hover{outline:2px solid var(--primary)}}.list-item{display:flex;justify-content:space-between;align-items:center;gap:1rem}.input{width:100%;padding:.75rem 1rem;border:1px solid var(--border-input);border-radius:10px;font-size:1rem;margin-bottom:.75rem;background:var(--surface);color:var(--text)}.input.money{font-variant-numeric:tabular-nums;font-weight:600}.btn-primary,.btn-secondary,.btn-ghost{border:none;border-radius:10px;padding:.75rem 1.25rem;font-weight:600;cursor:pointer;transition:opacity .15s ease}.btn-primary:disabled,.btn-secondary:disabled,.btn-ghost:disabled,.btn-link:disabled,button.is-busy:disabled{cursor:wait;opacity:.72}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-dark)}.btn-secondary{background:var(--border);color:var(--text)}.btn-ghost{background:transparent;color:var(--muted)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){background:#b91c1c}.btn-inner{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;min-height:1.25em}.btn-spinner{width:1em;height:1em;border:2px solid currentColor;border-right-color:transparent;border-radius:50%;animation:btn-spin .65s linear infinite;flex-shrink:0}.btn-sm .btn-spinner{width:.85em;height:.85em}@keyframes btn-spin{to{transform:rotate(360deg)}}.btn-block{width:100%}.auth-card .btn-primary:disabled{min-height:2.75rem}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1rem}.auth-card{background:var(--surface);padding:2rem;border-radius:var(--radius);width:100%;max-width:400px;box-shadow:var(--shadow)}.auth-card h1{margin:0 0 .25rem;font-size:1.5rem}.auth-card .muted,.auth-card .muted-sm{margin:0 0 1.25rem}.auth-card-top{display:flex;justify-content:space-between;align-items:flex-start;gap:.75rem;margin-bottom:1rem}.auth-card-top h1{margin:0 0 .25rem}.auth-card-top .muted-sm{margin:0}.auth-card-top--super h1{margin-top:.5rem}.help-link-btn{flex-shrink:0;display:inline-flex;align-items:center;gap:.35rem;padding:.4rem .65rem;border:1px solid var(--border);border-radius:999px;background:var(--bg);color:var(--primary);font-size:.8125rem;font-weight:600;cursor:pointer;white-space:nowrap}.help-link-btn:hover{background:var(--surface);border-color:var(--primary)}.help-link-btn svg{flex-shrink:0}html.super-theme .help-link-btn{background:#0f0a1a;border-color:#4c1d95;color:#c4b5fd}html.super-theme .help-link-btn:hover{border-color:#a78bfa;background:#1a1228}.auth-divider{border:none;border-top:1px solid var(--border);margin:1.25rem 0}.balance-card{text-align:center;padding:1.5rem}.balance-card.creditor{border-left:4px solid var(--success)}.balance-card.debtor{border-left:4px solid var(--danger)}.balance-card .amount{font-size:2rem;font-weight:700}.balance-card .label,.balance-list .name{font-size:.875rem;color:var(--muted);margin:0 0 .25rem}.balance-card:has(.balance-list){text-align:left;padding:1rem 1.25rem}.balance-list{display:flex;justify-content:space-between;align-items:center;gap:1rem}.balance-card:has(.balance-list){text-align:left;padding:1rem}.balance-list .amount{font-size:1.125rem;font-weight:700}.muted{color:var(--muted)}.muted-sm{font-size:.875rem;color:var(--muted)}.error{color:var(--danger)}.link{display:block;margin-top:1rem;color:var(--primary)}.row{display:flex;gap:.5rem}.row .input{flex:1;margin-bottom:0}.check-row{display:flex;align-items:center;gap:.5rem;cursor:pointer}.done{text-decoration:line-through;opacity:.6}.filter-tabs{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}.filter-tab{border:1px solid #cbd5e1;background:var(--surface);color:var(--text);border-radius:999px;padding:.4rem .75rem;font-size:.8125rem;cursor:pointer;display:inline-flex;align-items:center;gap:.35rem}.filter-tab.active{background:var(--primary);border-color:var(--primary);color:#fff}.tab-count{font-size:.7rem;background:#ffffff40;padding:.1rem .4rem;border-radius:999px}.filter-tab:not(.active) .tab-count{background:#e2e8f0;color:var(--muted)}.shopping-card{padding:.75rem 1rem}.shopping-card-main{display:flex;justify-content:space-between;align-items:flex-start;gap:.75rem;margin-bottom:.5rem}.shopping-info{flex:1;min-width:0}.item-note{margin:.25rem 0 0}.status-actions{display:flex;flex-wrap:wrap;gap:.35rem;margin-bottom:.5rem}.status-btn:disabled{cursor:wait;opacity:.55}.status-btn{border:1px solid #cbd5e1;background:var(--surface);color:var(--muted);border-radius:8px;padding:.35rem .5rem;font-size:.75rem;cursor:pointer}.status-btn.active.status-tobuy{background:#fef3c7;border-color:#f59e0b;color:#b45309}.status-btn.active.status-cart{background:#dbeafe;border-color:#3b82f6;color:#1d4ed8}.status-btn.active.status-bought{background:#dcfce7;border-color:#22c55e;color:#15803d}.status-btn.active.status-stock{background:#e0e7ff;border-color:#6366f1;color:#4338ca}.item-actions{display:flex;flex-wrap:wrap;gap:.25rem;border-top:1px solid #e2e8f0;padding-top:.5rem}.btn-sm{padding:.35rem .6rem;font-size:.8125rem}.btn-ghost.danger,.btn-ghost.btn-danger-text{color:var(--danger)}.btn-ghost.danger:hover:not(:disabled),.btn-ghost.btn-danger-text:hover:not(:disabled){background:#dc262614}.danger,.section-title.danger,h2.danger,h3.danger,h4.danger{color:var(--danger)}.danger-zone{border:1px solid rgb(220 38 38 / 35%);background:#dc26260a;box-shadow:none}.field-label{display:block;font-size:.875rem;font-weight:600;color:var(--text);margin-bottom:.35rem}.mt-6{margin-top:1.5rem}.flex-1{flex:1;min-width:0}.link-block{display:block;margin-top:.5rem}.row-actions{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:.5rem}.section-title{font-size:1rem;font-weight:600;margin:1.25rem 0 .5rem}.flash-ok{color:var(--success);font-size:.875rem;margin-bottom:.5rem}.settings-row .item-actions{border-top:none;padding-top:0}.budget-card{margin-top:.5rem;padding:.75rem 1rem;box-shadow:none;border:1px solid #e2e8f0}.member-info,.text-group{flex:1;min-width:0;display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.text-group{flex:unset}.text-stack{display:flex;flex-direction:column;gap:.2rem;align-items:flex-start;min-width:0}.text-stack .muted-sm,.text-stack .muted,.text-stack p{margin:0}.meta-inline{display:flex;flex-wrap:wrap;align-items:center;gap:.35rem .5rem}.modal-card{width:100%;max-width:400px}.empty-state{text-align:center;padding:2.5rem 1.5rem;margin-bottom:.75rem}.empty-state-icon{width:3.5rem;height:3.5rem;margin:0 auto 1rem;border-radius:50%;background:var(--primary-subtle, #e0e7ff);color:var(--primary);display:flex;align-items:center;justify-content:center}.empty-state-title{margin:0 0 .35rem;font-size:1.05rem;font-weight:600}.empty-state-desc{margin:0 auto 1rem;max-width:22rem;font-size:.875rem;color:var(--muted);line-height:1.5}.empty-state-actions{display:flex;justify-content:center;gap:.5rem;flex-wrap:wrap}.page-header-desc{margin:.25rem 0 0;font-size:.875rem;color:var(--muted);font-weight:400;width:100%}.skip-expense{margin:.75rem 0;font-size:.875rem}label{display:block;font-size:.875rem;color:var(--muted);margin-bottom:.25rem}.hidden-input{position:absolute;width:0;height:0;opacity:0;pointer-events:none}.attachment-panel{margin-top:.75rem;padding-top:.75rem;border-top:1px solid #e2e8f0}.attachment-panel.compact{margin-top:.5rem;padding-top:.5rem}.attach-hint{margin:.25rem 0}.attach-toolbar{display:flex;flex-wrap:wrap;gap:.35rem;align-items:center;margin-bottom:.5rem}.attach-list{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:.5rem}.attach-item{display:flex;align-items:center;gap:.25rem;background:#f1f5f9;border-radius:8px;padding:.25rem}.attach-thumb-btn{border:none;background:none;padding:0;cursor:pointer}.attach-thumb{width:56px;height:56px;object-fit:cover;border-radius:6px;display:block}.attach-file-btn{border:none;background:none;cursor:pointer;font-size:.8125rem;max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.webcam-video{width:100%;max-height:320px;background:#000;border-radius:8px;margin:.75rem 0}.webcam-card{max-width:480px}.camera-picker{margin-bottom:.75rem}.camera-picker label{margin-bottom:.35rem}.camera-single{margin:0 0 .5rem}.expense-card .expense-row,.task-card .task-row{cursor:pointer}.expense-detail,.task-detail,.settlement-detail{margin-top:.75rem;padding-top:.75rem;border-top:1px solid #e2e8f0}.budget-bar,.progress-bar{height:6px;background:var(--border);border-radius:4px;margin-top:.35rem;overflow:hidden}.budget-fill,.progress-fill{height:100%;background:var(--primary);border-radius:4px;max-width:100%}.percent-input{max-width:6.5rem;margin-bottom:0;text-align:right;font-variant-numeric:tabular-nums}.member-row{align-items:center;margin-bottom:.75rem;gap:.75rem}.member-name{flex:1;min-width:0}.percent-field{display:flex;align-items:center;gap:.25rem}.percent-suffix{color:var(--muted);font-weight:600}.offline-banner{background:#fef3c7;border-left:4px solid var(--accent)}.clickable{cursor:pointer}.status-select{max-width:10rem;margin-bottom:0}textarea.input{resize:vertical;min-height:4rem}[data-theme=dark]{--bg: #0f172a;--surface: #1e293b;--text: #f1f5f9;--muted: #94a3b8;--border: #334155;--border-input: #475569}[data-theme=dark] .sidebar a.router-link-active{background:#4f46e538}[data-theme=dark] .sidebar,[data-theme=dark] .bottom-nav{border-color:var(--border)}[data-theme=dark] .btn-secondary{background:#334155}[data-theme=dark] .danger-zone{background:#dc26261a;border-color:#dc262666}[data-theme=dark] .filter-tab:not(.active) .tab-count{background:#334155}.modal{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;padding:1rem}.section{margin-top:1.5rem}.section h2{font-size:1rem;margin-bottom:.75rem}.fab{white-space:nowrap}.btn-link{background:none;border:none;padding:0;color:var(--primary);cursor:pointer;font:inherit;text-align:left}.comment-row{display:flex;align-items:flex-start;justify-content:space-between;gap:.5rem}.budget-mini{margin-top:.5rem;padding:.75rem}@media (max-width: 768px){.app-shell{grid-template-columns:1fr}.sidebar{display:none}.bottom-nav{display:flex;position:fixed;bottom:0;left:0;right:0;background:var(--surface);border-top:1px solid var(--border);justify-content:space-around;padding:.75rem}.bottom-nav a{text-decoration:none;color:var(--muted);font-size:.75rem}.bottom-nav a.router-link-active{color:var(--primary);font-weight:600}.bottom-nav-more{color:var(--muted);font-weight:500}}@media (min-width: 1024px){.page{max-width:960px}.card-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}}.admin-page .page-header{flex-wrap:wrap;gap:1rem}.admin-subnav{display:flex;flex-wrap:wrap;gap:.5rem;width:100%}.admin-subnav a{padding:.35rem .75rem;border-radius:8px;text-decoration:none;color:var(--muted);font-size:.9rem}.admin-subnav a.router-link-active,.admin-subnav a.router-link-exact-active{background:#e0e7ff;color:var(--primary-dark);font-weight:600}.sidebar a.admin-nav-link{color:var(--primary-dark);font-weight:600}.admin-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:1rem;margin-bottom:1.5rem}.stat-card{text-align:center}.stat-label{display:block;font-size:.85rem;color:var(--muted)}.stat-value{display:block;font-size:1.75rem;margin:.25rem 0}.admin-quick-links{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem;margin-top:1.5rem}.admin-link-card h3{margin:0 0 .35rem}.admin-filters{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:1rem}.admin-filters .input{flex:1;min-width:180px}.admin-user-row,.admin-house-row{align-items:center;justify-content:space-between}.pagination{display:flex;align-items:center;justify-content:center;gap:1rem;margin-top:1rem}.modal-card-wide{max-width:520px}html:not(.super-theme){--bg-muted: #f1f5f9;--bg-accent: #eef2ff;--primary-subtle: #e0e7ff;--shadow-sm: 0 1px 2px rgb(15 23 42 / 5%), 0 1px 3px rgb(15 23 42 / 4%);--shadow-md: 0 4px 14px rgb(15 23 42 / 7%), 0 2px 4px rgb(15 23 42 / 4%);--shadow-lg: 0 16px 40px rgb(15 23 42 / 10%), 0 4px 12px rgb(15 23 42 / 5%)}html:not(.super-theme) body,html:not(.super-theme) #app{background:linear-gradient(160deg,var(--bg-accent) 0%,var(--bg) 38%,var(--bg-muted) 100%);background-attachment:fixed}html:not(.super-theme) .sidebar{box-shadow:2px 0 20px #0f172a0d;z-index:1}html:not(.super-theme) .sidebar a{transition:background .15s ease,color .15s ease}html:not(.super-theme) .sidebar a:hover:not(.router-link-active){background:var(--bg-muted)}html:not(.super-theme) .sidebar a.router-link-active{background:var(--primary-subtle);font-weight:600;box-shadow:inset 3px 0 0 var(--primary)}html:not(.super-theme) .sidebar-footer{background:var(--bg-muted)}html:not(.super-theme) .sidebar-header{background:var(--surface)}html:not(.super-theme) .main{position:relative}html:not(.super-theme) .page-header h1{letter-spacing:-.02em}html:not(.super-theme) .card{border:1px solid rgb(15 23 42 / 6%);box-shadow:var(--shadow-sm);transition:box-shadow .2s ease,border-color .2s ease,transform .2s ease}html:not(.super-theme) .card.clickable:hover{outline:none;border-color:#4f46e547;box-shadow:var(--shadow-md);transform:translateY(-1px)}html:not(.super-theme) .card-grid .card{margin-bottom:0}html:not(.super-theme) .auth-page{background:linear-gradient(145deg,#e0e7ff 0%,var(--bg) 42%,#f5f3ff 100%);background-attachment:fixed}html:not(.super-theme) .auth-card{border:1px solid rgb(255 255 255 / 70%);box-shadow:var(--shadow-lg);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}html:not(.super-theme) .input{background:var(--bg);box-shadow:inset 0 1px 2px #0f172a0a;transition:border-color .15s ease,box-shadow .15s ease}html:not(.super-theme) .input:focus{outline:none;border-color:var(--primary);box-shadow:inset 0 1px 2px #0f172a0a,0 0 0 3px #4f46e52e}html:not(.super-theme) .btn-primary{box-shadow:0 2px 8px #4f46e547}html:not(.super-theme) .btn-primary:hover:not(:disabled){box-shadow:0 4px 14px #4f46e559}html:not(.super-theme) .btn-secondary{border:1px solid var(--border);box-shadow:var(--shadow-sm)}html:not(.super-theme) .filter-tabs{background:var(--surface);padding:.35rem;border-radius:12px;border:1px solid rgb(15 23 42 / 6%);box-shadow:var(--shadow-sm);margin-bottom:1rem}html:not(.super-theme) .filter-tab:not(.active){background:transparent}html:not(.super-theme) .filter-tab.active{box-shadow:var(--shadow-sm)}html:not(.super-theme) .offline-banner,html:not(.super-theme) .global-offline{border-radius:var(--radius);box-shadow:var(--shadow-sm)}html:not(.super-theme) .empty-state{background:var(--surface);border-radius:var(--radius);border:1px dashed var(--border);box-shadow:var(--shadow-sm)}html:not(.super-theme) .modal{background:#0f172a52;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}html:not(.super-theme) .modal-card{border:1px solid rgb(15 23 42 / 8%);box-shadow:var(--shadow-lg)}html:not(.super-theme) .attach-item{background:var(--bg-muted);border:1px solid rgb(15 23 42 / 5%)}html:not(.super-theme) .admin-subnav a.router-link-active,html:not(.super-theme) .admin-subnav a.router-link-exact-active{background:var(--primary-subtle);box-shadow:var(--shadow-sm)}html:not(.super-theme) .help-fab{box-shadow:var(--shadow-md)}html:not(.super-theme) .help-fab:hover{box-shadow:var(--shadow-lg)}@media (max-width: 768px){html:not(.super-theme) .bottom-nav{box-shadow:0 -6px 24px #0f172a1a;border-top:1px solid rgb(15 23 42 / 6%);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffffffeb}html:not(.super-theme) .bottom-nav a{padding:.35rem .5rem;border-radius:8px;transition:background .15s ease}html:not(.super-theme) .bottom-nav a.router-link-active{background:var(--primary-subtle)}}html:not(.super-theme)[data-theme=dark]{--bg-muted: #1e293b;--bg-accent: #1e1b4b;--primary-subtle: rgb(79 70 229 / 22%);--shadow-sm: 0 1px 3px rgb(0 0 0 / 35%);--shadow-md: 0 6px 18px rgb(0 0 0 / 40%);--shadow-lg: 0 20px 48px rgb(0 0 0 / 45%)}html:not(.super-theme)[data-theme=dark] body,html:not(.super-theme)[data-theme=dark] #app{background:linear-gradient(160deg,#1e1b4b 0%,var(--bg) 35%,#0f172a 100%)}html:not(.super-theme)[data-theme=dark] .auth-page{background:linear-gradient(145deg,#312e81 0%,var(--bg) 45%,#0f172a 100%)}html:not(.super-theme)[data-theme=dark] .auth-card{border-color:#ffffff14;background:#1e293bf2}html:not(.super-theme)[data-theme=dark] .card{border-color:#ffffff12}html:not(.super-theme)[data-theme=dark] .input{background:#0f172a}html:not(.super-theme)[data-theme=dark] .filter-tabs{border-color:#ffffff14}html:not(.super-theme)[data-theme=dark] .attach-item{background:#0f172a;border-color:var(--border)}html:not(.super-theme)[data-theme=dark] .sidebar-footer{background:#0f172a}html:not(.super-theme)[data-theme=dark] .sidebar-logout{background:var(--surface)!important}@media (max-width: 768px){html:not(.super-theme)[data-theme=dark] .bottom-nav{background:#1e293bf0;border-top-color:var(--border)}}html.super-theme{--primary: #7c3aed;--primary-dark: #5b21b6;--bg: #0f0a1a;--card: #1a1228;--text: #f3e8ff;--muted: #a78bfa;--border: #3b2a5c}.super-shell{display:flex;min-height:100vh;background:var(--bg);color:var(--text)}.super-sidebar{width:240px;flex-shrink:0;background:#120b22;border-right:1px solid var(--border);display:flex;flex-direction:column;padding:1.25rem 1rem}.super-brand{display:flex;gap:.75rem;align-items:center;margin-bottom:2rem}.super-brand-mark{color:#c4b5fd;font-size:1.5rem}.super-brand-text{display:flex;flex-direction:column;gap:.15rem;line-height:1.2}.super-nav{display:flex;flex-direction:column;gap:.25rem;flex:1}.super-nav-link{padding:.5rem .75rem;border-radius:8px;text-decoration:none;color:var(--muted);font-size:.95rem}.super-nav-link.active,.super-nav-link.router-link-active{background:#4c1d95;color:#ede9fe;font-weight:600}.super-sidebar-foot{border-top:1px solid var(--border);padding-top:1rem}.super-user-email{font-size:.8rem;margin-bottom:.5rem;word-break:break-all}.super-main{flex:1;overflow:auto;padding:1.5rem 2rem}.super-page-header{margin-bottom:1.5rem}.super-page-header h1{margin:0 0 .25rem}.super-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:.75rem;margin-bottom:1.5rem}.super-stat-card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:1rem;text-align:center}.super-grid-2{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1rem}.super-quick-links{margin-top:1.5rem}.super-link-card.danger-outline{border-color:#7f1d1d}.super-login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(145deg,#0f0a1a,#2e1065);padding:1rem}.super-login-card{background:#1a1228;border:1px solid #4c1d95;border-radius:16px;padding:2rem;width:100%;max-width:400px;color:#f3e8ff}.super-login-badge{display:inline-block;background:#4c1d95;color:#ede9fe;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:.25rem .6rem;border-radius:6px;margin-bottom:.5rem}.super-login-card h1{margin:0 0 .35rem}.super-danger-panel{margin-top:2rem;border-color:#7f1d1d!important}html.super-theme .card{background:var(--card);border-color:var(--border);color:var(--text)}html.super-theme .input{background:#0f0a1a;border-color:var(--border);color:var(--text)}html.super-theme .muted-sm{color:var(--muted)}html.super-theme .btn-primary{background:var(--primary)}.help-fab{position:fixed;right:1rem;bottom:1rem;z-index:200;width:3rem;height:3rem;border-radius:50%;border:none;background:var(--primary);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 14px #0003;transition:transform .15s ease,box-shadow .15s ease}.help-fab:hover{transform:scale(1.05);box-shadow:0 6px 18px #00000040}.help-fab:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.help-fab--nav{bottom:4.75rem}@media (min-width: 769px){.help-fab--nav{bottom:1rem}}html.super-theme .help-fab{background:var(--primary);color:#fff}.help-modal{z-index:300;align-items:flex-start;padding-top:2rem;padding-bottom:2rem;overflow-y:auto}.help-modal-card{max-height:min(85vh,640px);overflow-y:auto;margin:auto}.help-modal-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:.75rem}.help-modal-header h2{font-size:1.25rem;margin:0;line-height:1.3}.help-modal-close{flex-shrink:0;width:2rem;height:2rem;border:none;border-radius:var(--radius);background:transparent;color:var(--muted);font-size:1.5rem;line-height:1;cursor:pointer}.help-modal-close:hover{background:#0000000f;color:var(--text)}.help-purpose{font-size:.95rem;color:var(--muted);margin:0 0 1.25rem;line-height:1.5}.help-section{margin-bottom:1rem}.help-section h3{font-size:.9rem;font-weight:600;margin:0 0 .35rem;color:var(--text)}.help-section p{margin:0;font-size:.875rem;line-height:1.55;color:var(--muted)}.help-tips{margin-top:1.25rem;padding-top:1rem;border-top:1px solid #e2e8f0}.help-tips h3{font-size:.9rem;margin:0 0 .5rem}.help-tips ul{margin:0;padding-left:1.25rem;font-size:.875rem;color:var(--muted);line-height:1.55}.help-tips li+li{margin-top:.35rem}[data-theme=dark] .help-tips{border-top-color:#334155}[data-theme=dark] .help-modal-close:hover{background:#ffffff14}.toast-container{position:fixed;bottom:1.5rem;right:1.5rem;z-index:9999;display:flex;flex-direction:column;gap:.5rem;max-width:360px}.toast-item{padding:.75rem 1rem;border-radius:10px;box-shadow:0 4px 20px #00000040;cursor:pointer;font-size:.9rem}.toast-success{background:#14532d;color:#dcfce7}.toast-error{background:#7f1d1d;color:#fee2e2}.toast-info{background:#312e81;color:#e0e7ff}.super-breadcrumbs{font-size:.85rem;margin-bottom:1rem;color:var(--muted)}.super-breadcrumbs .bc-link{color:#c4b5fd;text-decoration:none}.super-breadcrumbs .bc-current{color:var(--text)}.super-breadcrumbs .bc-sep{margin:0 .35rem;opacity:.5}.super-search{position:relative;margin-bottom:1rem;max-width:420px}.super-search-results{position:absolute;top:100%;left:0;right:0;z-index:50;margin-top:.25rem;max-height:280px;overflow:auto}.search-hit{display:flex;flex-direction:column;align-items:flex-start;width:100%;padding:.6rem .75rem;border:none;background:transparent;text-align:left;cursor:pointer;color:inherit}.search-hit:hover{background:#7c3aed26}.super-alert{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;padding:.75rem 1rem}.super-alert-warn{border-left:4px solid #f59e0b}.super-alert-info{border-left:4px solid #6366f1}.super-stat-card.clickable{text-decoration:none;color:inherit;transition:transform .15s}@media (hover: hover) and (pointer: fine){.super-stat-card.clickable:hover{transform:translateY(-2px)}}.user-link{text-decoration:none;color:inherit}.bar-chart{display:flex;flex-direction:column;gap:.5rem}.bar-row{display:grid;grid-template-columns:2.5rem 1fr 2rem;gap:.5rem;align-items:center;font-size:.8rem}.bar-track{height:8px;background:#ffffff14;border-radius:4px;overflow:hidden}.bar-fill{height:100%;background:#7c3aed;border-radius:4px}.bar-val{text-align:right}html.super-theme .super-sidebar{overflow-y:auto}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
