:root{--bg: #000000;--surface: #070a0f;--surface-muted: #10151e;--border: #202938;--border-strong: #344257;--text: #eef4fb;--text-muted: #94a3b8;--accent: #22d3ee;--accent-glow: rgba(34, 211, 238, .15);--success: #34d399;--success-glow: rgba(52, 211, 153, .15);--warning: #fbbf24;--warning-glow: rgba(251, 191, 36, .15);--danger: #fb7185;--danger-glow: rgba(251, 113, 133, .15);--blue: #60a5fa;--blue-soft: rgba(96, 165, 250, .15);--purple: #c084fc;--purple-soft: rgba(192, 132, 252, .15);--radius-sm: 8px;--radius-md: 14px;--radius-lg: 20px;--shadow-ambient: 0 18px 44px rgba(0,0,0,.6);--shadow-glow: 0 0 0 1px rgba(34, 211, 238, .18), 0 18px 44px rgba(0, 0, 0, .55);--ease-spring: cubic-bezier(.175, .885, .32, 1.1);--ease-out: cubic-bezier(.16, 1, .3, 1)}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html{background:var(--bg);min-height:100%;scrollbar-gutter:stable;-webkit-text-size-adjust:100%;overflow-x:hidden;scroll-behavior:smooth}body{margin:0;min-height:100vh;background:radial-gradient(circle at 16% -8%,rgba(34,211,238,.13),transparent 30%),radial-gradient(circle at 84% 0%,rgba(20,184,166,.1),transparent 28%),var(--bg);color:var(--text);font-family:Inter,system-ui,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden}body.modal-open,html.modal-open{overflow:hidden!important;overscroll-behavior:none}body.mobile-modal-lock{position:fixed;left:0;right:0;width:100%;touch-action:none}.mono{font-family:Roboto Mono,monospace}.hidden{display:none!important}button,input,select,a{font:inherit;outline:none}button{cursor:pointer;transition:transform .08s cubic-bezier(.4,0,.2,1),background-color .15s ease,opacity .15s ease;touch-action:manipulation}button:active{transform:scale(.94)}.auth-gate{min-height:100dvh;display:grid;place-items:center;padding:20px;position:relative;z-index:999}body:not(.auth-locked) .auth-gate{display:none}body.auth-locked .topbar,body.auth-locked .app-main{display:none}.auth-card{width:min(440px,100%);background:linear-gradient(180deg,#0a0e14,#06080d);border:1px solid rgba(34,211,238,.2);border-radius:var(--radius-lg);padding:32px 24px;box-shadow:var(--shadow-ambient);text-align:center;will-change:transform,opacity;animation:fadeUp .5s var(--ease-out) forwards}.auth-brand{display:flex;flex-direction:column;align-items:center;margin-bottom:22px}.auth-brand .brand-mark{width:44px;height:44px;margin-bottom:12px;border-radius:12px;background:linear-gradient(135deg,#22d3ee29,#14b8a614);border:1px solid rgba(34,211,238,.28);display:grid;place-items:center;color:var(--accent);font-size:22px}.auth-copy h2{margin:0;color:var(--text);font-size:24px;font-weight:800;line-height:1.15}.auth-copy p{margin:8px 0 24px;color:var(--text-muted);font-size:13px;font-weight:650;text-transform:uppercase;letter-spacing:.5px}.auth-form{display:grid;gap:16px;text-align:left}.auth-form label{display:grid;gap:8px;position:relative;transition:all .3s ease}.auth-form span{font-size:11px;font-weight:800;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.auth-form input{width:100%;height:52px;background:#080c12;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);padding:0 16px;font-size:16px;font-weight:600;transition:all .3s ease}.auth-form input:focus{border-color:#22d3ee94;box-shadow:0 0 0 3px #22d3ee1a}.auth-form input:disabled{opacity:.5;cursor:not-allowed}.auth-submit,.auth-secondary{height:52px;border-radius:var(--radius-sm);font-size:14px;font-weight:800;text-transform:uppercase;letter-spacing:.5px}.auth-submit{background:linear-gradient(135deg,#0891b2,#0f766e);color:#fff;border:1px solid rgba(34,211,238,.46);box-shadow:0 4px 12px #0000004d}.auth-secondary{background:#080c12;color:#dff8ff;border:1px solid rgba(148,163,184,.24)}.auth-switch{text-align:center;font-size:13px;color:var(--text-muted);margin-top:16px}.auth-link{background:none;border:none;color:var(--accent);font-weight:800;padding:10px;margin:-10px}.auth-error{color:var(--danger);font-size:13px;font-weight:700;text-align:center;margin:0}.auth-success{color:var(--success);font-size:13px;font-weight:700;text-align:center;margin:0}.topbar{position:sticky;top:0;z-index:100;background:#000000f2;border-bottom:1px solid rgba(34,211,238,.16);box-shadow:0 14px 36px #00000080;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.topbar-inner{display:grid;grid-template-columns:minmax(180px,280px) minmax(0,1fr) auto;gap:8px 20px;align-items:center;padding:10px 24px 12px;min-height:92px;max-width:1600px;margin:0 auto;position:relative}.brand{grid-column:2;grid-row:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px}.brand-mark{width:44px;height:44px;border-radius:12px;background:linear-gradient(135deg,#22d3ee29,#14b8a614);border:1px solid rgba(34,211,238,.28);display:grid;place-items:center;color:var(--accent);font-size:20px}#mobileMenuToggle{cursor:pointer;transition:transform .15s ease,filter .15s ease}#mobileMenuToggle:active{transform:scale(.9);filter:brightness(1.2)}.brand #mobileMenuToggle{position:absolute;left:24px;top:10px}.brand h1{margin:0;font-size:18px;font-weight:800;letter-spacing:0;color:#fff;text-align:center}.brand p{margin:0;font-size:11px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;text-align:center}.header-actions{display:flex;align-items:center;justify-content:flex-end;gap:8px;min-width:0}.install-btn{height:40px;background:linear-gradient(135deg,#0891b2,#0f766e);border:1px solid rgba(34,211,238,.46);border-radius:var(--radius-sm);color:#fff;padding:0 14px;font-size:13px;font-weight:700;display:flex;align-items:center;gap:6px;box-shadow:0 4px 12px #0000004d}.install-btn i{font-size:16px}.owner-controls{padding:0 24px;max-width:1600px;margin:0 auto;display:flex;gap:12px}.driver-select,.month-select,.clock{height:40px;background:#080c12;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);padding:0 14px;font-size:14px;font-weight:600}.clock{display:flex;align-items:center;justify-content:center;text-align:center;width:72px;padding:0 8px}.driver-select,.month-select{flex:1;width:100%;max-width:280px}.topbar-inner>.driver-select{grid-column:1;grid-row:1;justify-self:start;max-width:220px;margin-left:56px}.driver-select option,.month-select option{background:#0f172a;color:#fff}.driver-select.force-hidden,.month-select.force-hidden{display:none!important}body.access-owner .driver-select,body.access-owner .month-select{display:block}.page-rail{display:none;padding:0 24px;background:transparent;width:100%;max-width:1600px;margin:0 auto;text-align:center}.tabs{display:inline-flex;gap:8px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding:12px 0;margin:0;justify-content:center;max-width:100%}.topbar-inner>.tabs{justify-content:center}.topbar-inner>.tabs{grid-column:1 / -1;grid-row:2}.tabs::-webkit-scrollbar{display:none}.tab-btn{height:44px;padding:0 16px;border-radius:99px;background:#080c12;border:1px solid rgba(52,66,87,.72);color:#a8b4c5;font-size:13px;font-weight:700;white-space:nowrap;display:flex;align-items:center;gap:8px;transition:border-color .15s ease,color .15s ease,box-shadow .15s ease,transform .08s var(--ease-out);box-shadow:0 0 0 1px transparent,0 18px 44px transparent;-webkit-user-select:none;user-select:none;outline:none;position:relative;z-index:1}.tab-btn i{font-size:17px}@media (hover: hover){.tab-btn:hover:not(.active){background:#0e1620;border-color:#22d3ee6b;color:#dff8ff}}.tab-btn.active{border-color:#22d3eea3;background:linear-gradient(135deg,#22d3ee38,#14b8a624);color:#fff;box-shadow:var(--shadow-glow);z-index:2}.tab-btn:focus-visible{outline:2px solid var(--accent);outline-offset:-2px}.app-main{padding:24px 24px 90px;max-width:1600px;margin:0 auto}.page-head,.sync-card{display:none!important}.metrics{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:24px}.metric-card{background:linear-gradient(180deg,#0a0e14,#06080d);border:1px solid rgba(32,41,56,.95);border-radius:12px;padding:14px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;box-shadow:var(--shadow-ambient);text-align:center}.metric-card>div:first-child{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;width:100%}.metric-label{margin:0;font-size:11px;font-weight:800;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;text-align:center;width:100%}.metric-value{margin:0;font-size:22px;font-weight:800;color:var(--text);line-height:1;text-align:center;width:100%}.metric-icon{display:none}.panel{background:linear-gradient(180deg,#0a0e14,#06080d);border:1px solid rgba(32,41,56,.95);border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow-ambient)}.panel+.panel{margin-top:24px}.panel-header{padding:16px 20px;border-bottom:1px solid var(--border);background:#080c12;display:flex;align-items:center;justify-content:space-between}.panel-title{margin:0;font-size:15px;font-weight:700;color:var(--text)}.panel-caption{margin:4px 0 0;font-size:12px;color:var(--text-muted)}.search-input{width:300px;height:40px;background:#080c12;border:1px solid var(--border);border-radius:99px;padding:0 16px;color:var(--text);font-size:14px;transition:all .2s ease}.search-input:focus{border-color:var(--accent)}.table-scroll{width:100%;overflow-x:auto;overflow-y:hidden!important;max-height:none!important;-webkit-overflow-scrolling:touch;overscroll-behavior-y:auto;scrollbar-width:thin;scrollbar-color:#334155 #06080d}.table-scroll::-webkit-scrollbar{height:6px;width:6px}.table-scroll::-webkit-scrollbar-thumb{background:#334155;border-radius:3px}table{width:100%;border-collapse:separate;border-spacing:0;font-size:13px;color:var(--text)}th{position:sticky;top:0;z-index:10;background:#0d131c;color:#b8c4d6;padding:14px 16px;font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border);white-space:nowrap}td{padding:14px 16px;border-bottom:1px solid rgba(32,41,56,.72);white-space:nowrap;color:#d8e2ef;font-weight:500}@media (hover: hover){tr:hover td{background:#22d3ee0e}}.text-center{text-align:center}.text-left{text-align:left}.link-button{background:none;border:none;padding:10px 14px;margin:-10px -14px;color:#67e8f9;font-weight:700;cursor:pointer;text-align:left;border-radius:6px}.badge{display:inline-flex;align-items:center;justify-content:center;padding:4px 10px;border-radius:6px;font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.5px}.badge.green{background:var(--success-glow);color:var(--success);border:1px solid rgba(0,230,118,.2)}.badge.red{background:var(--danger-glow);color:var(--danger);border:1px solid rgba(255,23,68,.2)}.badge.amber{background:var(--warning-glow);color:var(--warning);border:1px solid rgba(255,171,0,.2)}.badge.blue{background:var(--blue-soft);color:var(--blue);border:1px solid rgba(96,165,250,.2)}.badge.purple{background:var(--purple-soft);color:var(--purple);border:1px solid rgba(192,132,252,.2)}.badge.muted{background:#ffffff0d;color:var(--text-muted);border:1px solid var(--border)}.date-head{padding:8px 10px;min-width:58px}.date-head-stack{display:inline-flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;line-height:1}.date-head-number{font-size:13px;font-weight:900;color:inherit}.date-head-day{font-size:9px;font-weight:800;color:var(--text-muted);letter-spacing:.5px;text-transform:uppercase}.today-head{background:linear-gradient(#22d3ee1c,#22d3ee1c),#0d131c!important;color:var(--accent)!important;box-shadow:inset 0 -2px 0 var(--accent)}.today-cell{background:#22d3ee0d}.modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:#0000;display:block;padding:0;opacity:0;pointer-events:none;transition:opacity .35s cubic-bezier(.16,1,.3,1),background-color .35s cubic-bezier(.16,1,.3,1);overflow-y:auto;-webkit-overflow-scrolling:touch}.modal.is-open{opacity:1;pointer-events:auto;background-color:#000}.modal.is-closing{opacity:0;pointer-events:none;background-color:#0000}.modal-card{width:100%;min-height:100dvh;height:auto;max-height:none;background:linear-gradient(180deg,#0a0e14,#06080d);border:none;border-radius:0;transform:translateY(100%);transition:transform .35s cubic-bezier(.16,1,.3,1);display:flex;flex-direction:column}.modal.is-open .modal-card{transform:translateY(0)}.modal-body{padding:32px 24px 40px;display:flex;flex-direction:column;flex-grow:1}.profile-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-bottom:24px}.profile-item{background:linear-gradient(180deg,#0a0e14,#06080d);border:1px solid rgba(32,41,56,.95);border-radius:12px;box-shadow:0 18px 44px #0009;padding:16px 12px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;transition:all .2s ease;text-decoration:none;min-height:72px;word-break:break-word;overflow-wrap:anywhere;-webkit-hyphens:auto;hyphens:auto}.profile-item.clickable:hover{border-color:#86efac;background:var(--success-glow)}.profile-item span{display:block;font-size:10px;font-weight:800;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;width:100%;line-height:1}.profile-item strong{display:block;font-size:13px;font-weight:600;color:var(--text);width:100%;line-height:1.3}.profile-item.phone-card strong{color:var(--success);font-size:14px}.profile-icon{display:grid;place-items:center;font-size:28px;margin:0 auto 6px;color:var(--success)}.modal-metrics{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-bottom:24px}.modal-metrics .metric-card{padding:12px 8px;flex-direction:column;justify-content:center;text-align:center}.modal-metrics .metric-card>div:first-child{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%}.modal-metrics .metric-label{font-size:10px;margin-bottom:6px;text-align:center;width:100%}.modal-metrics .metric-value{font-size:20px;text-align:center;width:100%}.calendar{border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden;background:#070a0f;display:flex;flex-direction:column;flex-grow:1;min-height:0}.calendar-head{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));background:#0d131c;flex-shrink:0}.calendar-head div{padding:12px 0;text-align:center;font-size:11px;font-weight:800;color:var(--text-muted);text-transform:uppercase}.calendar-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));grid-auto-rows:1fr;gap:1px;background:#202938b8;border-top:1px solid var(--border);flex-grow:1}.calendar-day{padding:6px 2px;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#070a0f;overflow:hidden;min-height:0}.calendar-day.empty{background:#040608}.calendar-number{font-size:12px;font-weight:700;color:var(--text-muted);margin-bottom:6px;line-height:1}.calendar-day.today{background:#22d3ee1f;box-shadow:inset 0 0 0 1px #22d3ee80}.calendar-day.today .calendar-number{color:var(--accent)}.calendar-status{width:100%;text-align:center;display:flex;justify-content:center}.calendar-status .badge{font-size:8.5px;padding:3px 4px;letter-spacing:-.2px;white-space:nowrap;max-width:100%;overflow:hidden;text-overflow:ellipsis}.toast{position:fixed;top:24px;right:24px;z-index:1000;width:380px;max-width:calc(100vw - 48px);background:linear-gradient(180deg,#0a0e14,#06080d);border:1px solid rgba(32,41,56,.95);border-left:4px solid var(--accent);border-radius:var(--radius-sm);padding:16px 20px;box-shadow:var(--shadow-ambient);transform:translate(120%);opacity:0;transition:transform .4s var(--ease-spring),opacity .3s var(--ease-out);will-change:transform,opacity}.toast.show{transform:translate(0);opacity:1}.toast-title{margin:0 0 6px;font-size:12px;font-weight:800;text-transform:uppercase;color:var(--accent);letter-spacing:.5px}.toast-message{margin:0;font-size:14px;font-weight:500;line-height:1.4;color:var(--text)}.panel.headerless .panel-header,.panel.jadwal-full .panel-header{display:none!important}.panel.captionless .panel-caption{display:none}.panel.center-title .panel-header,.panel.skema-view .panel-header{justify-content:center;align-items:center!important;text-align:center}.panel.center-title .panel-header>div:first-child,.panel.skema-view .panel-header>div:first-child{display:flex;flex-direction:column;align-items:center;text-align:center;width:100%}.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;padding:20px}.resource-card{background:linear-gradient(180deg,#0a0e14,#06080d);border:1px solid rgba(32,41,56,.95);border-radius:var(--radius-sm);padding:20px;display:flex;flex-direction:column;gap:12px;transition:all .2s ease;text-align:center}.resource-card:active{transform:scale(.96)}.resource-card p{margin:0;font-size:11px;font-weight:800;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.resource-card h4{margin:0;font-size:15px;font-weight:600;line-height:1.4;color:var(--text)}.card-action{margin-top:auto;display:inline-flex;align-items:center;justify-content:center;gap:8px;height:48px;background:linear-gradient(135deg,#0891b2,#0f766e);border:1px solid rgba(34,211,238,.46);border-radius:8px;color:#fff;font-size:14px;font-weight:800;text-decoration:none;transition:all .2s ease}.card-action.disabled{background:linear-gradient(135deg,#0f1722,#060a0f);border:1px solid rgba(52,66,87,.5);color:#475569;cursor:default}.empty-state{min-height:300px;display:grid;place-items:center;text-align:center;color:var(--text-muted)}.empty-state i{font-size:48px;margin-bottom:16px;opacity:.5}.empty-state h3{margin:0 0 8px;font-size:16px;font-weight:600;color:var(--text)}.empty-state p{margin:0;font-size:13px}@media (min-width: 761px){.panel.jadwal-full{overflow:visible!important}.panel.jadwal-full th:nth-child(1),.panel.jadwal-full td:nth-child(1){position:sticky;left:0;z-index:11;width:85px;min-width:85px;max-width:85px;background:#080c12}.panel.jadwal-full th:nth-child(2),.panel.jadwal-full td:nth-child(2){position:sticky;left:85px;z-index:11;min-width:220px;background:#080c12;border-right:1px solid var(--border-strong)}.panel.jadwal-full th:nth-child(1),.panel.jadwal-full th:nth-child(2){z-index:21;background:#0d131c}@media (hover: hover){.panel.jadwal-full tr:hover td:nth-child(1),.panel.jadwal-full tr:hover td:nth-child(2){background:#0b1722}}}@media (max-width: 1180px){.topbar{position:relative}th{top:0}.page-rail{padding:0 24px;width:100%;min-width:0;display:none}.tabs{padding:12px 0;justify-content:flex-start;scroll-snap-type:x proximity}.tab-btn{flex:0 0 auto;scroll-snap-align:start}}@media (max-width: 760px){.topbar-inner{grid-template-columns:minmax(120px,1fr) auto;padding:12px 16px;min-height:60px}.brand{grid-column:1 / -1;grid-row:1}.topbar-inner>.driver-select{grid-column:1;grid-row:2;margin-left:0;max-width:none}.header-actions{grid-column:2;grid-row:2}.topbar-inner>.tabs{grid-column:1 / -1}.brand #mobileMenuToggle{left:16px;top:12px}.brand-mark{width:34px;height:34px;font-size:16px}.brand h1{font-size:14px}.brand p{font-size:9px}.install-btn{padding:0 10px;height:32px;font-size:15px}.install-btn span{display:none}.clock{height:32px;padding:0 10px;font-size:12px;min-width:50px}.owner-controls{padding:0 16px;flex-direction:row;gap:8px}.driver-select,.month-select{max-width:none;font-size:13px;padding:0 8px}.tab-btn{min-height:40px;padding:0 12px;font-size:12px}.page-rail{padding:0 16px}.tabs{padding:12px 0}.app-main{padding:16px 16px 40px}.metrics{grid-template-columns:repeat(2,1fr);gap:8px;margin-bottom:16px}.metric-card{padding:12px}.metric-card>div:first-child{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;width:100%}.metric-label{font-size:9.5px;margin:0;width:100%;text-align:center;line-height:1.2}.metric-value{font-size:20px;margin:0;text-align:center;line-height:1}th,td{padding:12px}.search-input{width:100%}.panel-header{flex-direction:column;align-items:flex-start;gap:12px}#tableTools{width:100%}.modal-body{padding:20px 16px}.profile-grid{gap:10px;margin-bottom:16px}.profile-item{padding:12px 10px;min-height:68px;gap:8px;justify-content:center}.profile-item span{font-size:10px;margin-bottom:0}.profile-item strong{font-size:13.5px}.profile-item.phone-card strong{font-size:16px}.profile-icon{font-size:32px;margin:0}.modal-metrics{gap:10px;margin-bottom:16px}.modal-metrics .metric-card{padding:12px 6px;justify-content:center}.modal-metrics .metric-card>div:first-child{gap:6px}.modal-metrics .metric-label{font-size:10px;margin-bottom:0}.modal-metrics .metric-value{font-size:22px}.calendar-head div{padding:8px 0;font-size:10px}.calendar-day{padding:4px 2px;min-height:0}.calendar-number{font-size:11px;margin-bottom:4px}.calendar-status .badge{font-size:8.5px;padding:2.5px 0;max-width:95%;letter-spacing:-.3px}}@media (max-width: 760px) and (orientation: portrait){.page-rail{display:block;position:absolute;top:66px;left:16px;width:220px;padding:10px;background:#080c12fa;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border-strong);border-radius:var(--radius-md);box-shadow:0 24px 48px #000c,0 0 0 1px #22d3ee1a;opacity:0;pointer-events:none;transform:translateY(-10px) scale(.95);transform-origin:top left;transition:transform .25s var(--ease-spring),opacity .2s ease;z-index:200}.page-rail.is-open{opacity:1;pointer-events:auto;transform:translateY(0) scale(1)}.page-rail .tabs{flex-direction:column;padding:0;gap:6px;align-items:stretch}.page-rail .tab-btn{height:44px;border-radius:var(--radius-sm);background:transparent;border:1px solid transparent;justify-content:flex-start;padding:0 16px}.page-rail .tab-btn.active{background:#22d3ee26;border:1px solid rgba(34,211,238,.3)}.modal{overflow:hidden;touch-action:none}.modal-card{height:100dvh;min-height:100dvh;max-height:100dvh;overflow:hidden}.modal-body{overflow:hidden;padding-bottom:24px;display:flex;flex-direction:column}#driverDetailsContainer{display:flex;flex-direction:column;flex-grow:1.5;min-height:0}.profile-grid,.modal-metrics{flex-grow:1;min-height:0;margin-bottom:12px}.calendar{flex-grow:0;min-height:auto;display:flex;flex-direction:column}.calendar-grid{grid-auto-rows:minmax(50px,1fr);display:grid}.calendar-day{min-height:50px}}@media (max-height: 500px) and (orientation: landscape),(max-width: 930px) and (orientation: landscape){.topbar{display:contents}.topbar-inner,.owner-controls{background:#000000f2}.page-rail{display:none}.tabs{justify-content:center;padding:8px 0}.tab-btn{height:36px;min-height:36px;font-size:11.5px;padding:0 12px}.app-main{padding:12px 16px 0}.metrics{grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:12px}.metric-card{padding:8px}.metric-label{font-size:9px;margin-bottom:2px}.metric-value{font-size:16px}.panel-header{padding:8px 12px}.table-scroll{max-height:none!important;overflow-y:hidden!important}.modal-body{display:block;padding:16px;height:auto;overflow-y:auto}.profile-grid,.modal-metrics{margin-bottom:12px}.calendar{display:block;min-height:max-content}.calendar-grid{grid-auto-rows:minmax(50px,auto);display:grid}.calendar-day{min-height:50px}.package-grid{display:flex!important;flex-wrap:wrap!important;justify-content:center!important;align-items:stretch!important;gap:8px!important;padding:12px!important}.package-grid .mini-card{flex:0 0 calc(25% - 8px)!important;min-width:110px!important;max-width:200px!important;padding:14px 4px!important}.package-grid .mini-card .label{font-size:8.5px!important;margin-bottom:6px!important;letter-spacing:-.2px!important;line-height:1.2!important;word-wrap:break-word!important}.package-grid .mini-card .value{font-size:16px!important}}.stack{display:flex;flex-direction:column;gap:20px;padding:20px}.subpanel{background:#0003;border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden}.subpanel h3{margin:0;padding:16px;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border);background:#080c12;text-align:center;color:var(--text)}.kpi-grid,.package-grid{display:grid;gap:12px;padding:16px}.kpi-grid{grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}.package-grid{grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}.mini-card{background:#0006;border:1px solid var(--border);border-radius:12px;padding:16px;text-align:center}.mini-card.highlight{border-color:var(--accent);box-shadow:0 0 15px var(--accent-glow)}.mini-card .label{margin:0 0 8px;font-size:10px;font-weight:800;color:var(--text-muted);text-transform:uppercase}.mini-card .value{margin:0;font-size:24px;font-weight:800;color:var(--text)}.hub-ratio-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px;padding:16px}.bank-card{background:linear-gradient(135deg,#020617,#07111c 54%,#082f49);border:1px solid rgba(34,211,238,.18);border-radius:var(--radius-md);padding:24px;margin-bottom:20px;text-align:center}.bank-heading h3{margin:0 0 4px;font-size:16px;font-weight:800;color:var(--accent);text-transform:uppercase}.bank-heading p{display:none}.bank-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px;margin-top:16px}.bank-field{background:#ffffff0b;border:1px solid rgba(148,163,184,.18);padding:12px 16px;border-radius:8px}.bank-field span{display:block;font-size:10px;font-weight:800;color:#94a3b8;text-transform:uppercase;margin-bottom:6px}.bank-field strong{display:block;font-size:16px;font-weight:600;color:#fff}.reaction-area{min-height:400px;height:60vh;max-height:600px;border-radius:var(--radius-md);display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;cursor:pointer;-webkit-user-select:none;user-select:none;touch-action:manipulation;transition:background-color .15s var(--ease-out);position:relative;padding:24px;outline:none;border:1px solid var(--border);box-shadow:var(--shadow-ambient)}.reaction-area:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.reaction-area.state-idle{background:#0f172a}.reaction-area.state-waiting{background:#7f1d1d}.reaction-area.state-clickable{background:#14532d}.reaction-area.state-early{background:#7c2d12}.reaction-area.state-finished{background:#020617;cursor:default}.reaction-dash{position:absolute;top:16px;left:16px;right:16px;z-index:10;pointer-events:none}.reaction-dash-head{display:flex;justify-content:center;align-items:center;margin-bottom:12px}.reaction-dash-head span{font-size:11px;font-weight:700;padding:4px 10px;background:#0006;border-radius:99px;color:var(--text-muted);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.reaction-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:6px}.reaction-box{background:#0003;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:8px 2px;display:flex;flex-direction:column;align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.reaction-box.filled{background:#0006;border-color:#ffffff40}.reaction-box span:first-child{font-size:10px;font-weight:700;color:#ffffff80;margin-bottom:4px}.reaction-box span:last-child{font-size:12px;font-weight:800;color:#ffffff4d;font-family:Roboto Mono,monospace}.reaction-box.filled span:last-child{color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.6)}.reaction-content{pointer-events:none;z-index:10;display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;margin-top:70px;transition:margin-top .2s ease}.state-finished .reaction-content{margin-top:30px}.reaction-icon{font-size:48px;color:#fff;opacity:.9;margin-bottom:16px;filter:drop-shadow(0 2px 8px rgba(0,0,0,.4))}.state-waiting .reaction-icon{animation:pulse 1.5s infinite}.reaction-title{margin:0 0 8px;font-size:28px;font-weight:800;color:#fff;line-height:1.1;text-shadow:0 2px 8px rgba(0,0,0,.5)}.state-finished .reaction-title{font-size:22px;margin-bottom:0}@media (min-width: 768px){.reaction-title{font-size:42px}.state-finished .reaction-title{font-size:28px}}.reaction-sub{margin:0;font-size:14px;font-weight:500;color:#fffc;text-shadow:0 1px 4px rgba(0,0,0,.5);max-width:280px}.reaction-result{display:flex;flex-direction:column;align-items:center;padding-top:16px;border-top:1px solid rgba(255,255,255,.1);pointer-events:auto;gap:14px;width:100%;max-width:240px;margin-top:16px}.reaction-result p{margin:0;font-size:10.5px;font-weight:800;text-transform:uppercase;color:var(--text-muted);letter-spacing:.5px}.reaction-result h2{margin:0;font-size:34px;font-weight:800;font-family:Roboto Mono,monospace;color:#fff;text-shadow:0 4px 12px rgba(0,0,0,.5);line-height:1}.reaction-btn{height:38px;padding:0 20px;background:#fff;color:#020617;border-radius:var(--radius-sm);font-size:13px;font-weight:800;box-shadow:0 4px 12px #0000004d;transition:transform .15s ease;border:none;width:100%}.reaction-btn:active{transform:scale(.95)}.camera-wrapper{text-align:center;padding:24px 16px;display:flex;flex-direction:column;align-items:center}.camera-input{display:none}.stamp-inputs{width:100%;max-width:320px;margin-bottom:20px;text-align:center}.stamp-inputs label{display:grid;gap:8px}.stamp-inputs span{font-size:11px;font-weight:800;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;text-align:center}.stamp-inputs input,.stamp-inputs select{width:100%;height:48px;background:#080c12;border:1px solid var(--border);border-radius:var(--radius-sm);padding:0 16px;color:var(--text);font-size:14px;transition:all .3s ease;text-align:center}.stamp-inputs input:focus,.stamp-inputs select:focus{border-color:var(--accent)}.camera-trigger-btn{width:100%;max-width:320px;height:56px;border-radius:var(--radius-sm);background:linear-gradient(135deg,#0891b2,#0f766e);color:#fff;border:1px solid rgba(34,211,238,.46);font-size:15px;font-weight:800;text-transform:uppercase;letter-spacing:.5px;display:inline-flex;align-items:center;justify-content:center;gap:10px;box-shadow:0 8px 24px #0006;transition:transform .08s cubic-bezier(.4,0,.2,1),box-shadow .15s ease;cursor:pointer}.camera-trigger-btn:active{transform:scale(.94);box-shadow:0 4px 12px #0000004d}.camera-trigger-btn i{font-size:22px}.camera-gallery-btn{width:100%;max-width:320px;height:50px;border-radius:var(--radius-sm);background:#0f172a;color:#e2e8f0;border:1px solid rgba(148,163,184,.2);font-size:13px;font-weight:800;text-transform:uppercase;letter-spacing:.5px;display:inline-flex;align-items:center;justify-content:center;gap:8px;box-shadow:0 4px 12px #0000004d;transition:transform .08s cubic-bezier(.4,0,.2,1),background-color .2s ease;cursor:pointer;margin-top:12px}.camera-gallery-btn:active{transform:scale(.94)}.camera-gallery-btn:hover{background:#1e293b}.camera-disclaimer{margin:16px 0 0;font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.canvas-container{display:flex;flex-direction:column;align-items:center;width:100%;max-width:600px;margin:24px auto 0}.photo-canvas{max-width:100%;height:auto;border-radius:12px;border:1px solid var(--border-strong);box-shadow:var(--shadow-ambient);background:#000;display:block}.camera-action-row{display:flex;gap:10px;width:100%;max-width:320px;margin-top:20px}.camera-retake-btn{flex:1;height:50px;border-radius:var(--radius-sm);font-size:13px;font-weight:800;text-transform:uppercase;letter-spacing:.5px;display:inline-flex;align-items:center;justify-content:center;gap:8px;box-shadow:0 4px 12px #0000004d;transition:background-color .2s ease,transform .08s cubic-bezier(.4,0,.2,1);cursor:pointer;border:none;outline:none;background:#1e293b;color:#fff;border:1px solid #334155}.camera-retake-btn:active{transform:scale(.94)}.camera-retake-btn:hover{background:#293548}.content-enter,.content-enter-alt{animation:fadeUp .3s cubic-bezier(.16,1,.3,1) forwards;will-change:opacity,transform}@keyframes fadeUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.app-footer{display:flex;flex-direction:column;justify-content:center;align-items:center;gap:4px;margin-top:32px;padding-top:24px;border-top:1px solid var(--border);color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.footer-sync-status{display:flex;align-items:center;gap:6px;font-size:8.5px;font-weight:700}.sync-glow-dot{width:6px;height:6px;border-radius:50%;background-color:var(--success);box-shadow:0 0 6px var(--success);transition:background-color .3s ease,box-shadow .3s ease}.sync-glow-dot.error{background-color:var(--danger);box-shadow:0 0 6px var(--danger)}.footer-credit{font-size:7.5px;font-weight:600;opacity:.6}
