:root{--vapor: #f4f6f8;--surface: #ffffff;--surface-2: #fbfcfd;--graphite: #18212e;--slate: #4a5563;--muted: #8b97a4;--mist: #e4e9ed;--mist-2: #eef2f5;--steel: #f97316;--steel-deep: #e2620c;--steel-tint: #fdeede;--temp-chilled: #2f7db6;--temp-chilled-tint: #e6f0f8;--temp-ambient: #6b7480;--temp-ambient-tint: #eceef1;--temp-heated: #b1492a;--temp-heated-tint: #f6e7e0;--ok: #2e8b6b;--ok-tint: #e4f1ec;--warn: #b8862a;--warn-tint: #f6eed9;--alert: #c0392b;--alert-tint: #f7e6e3;--info: #f97316;--font-sans: "IBM Plex Sans", system-ui, -apple-system, sans-serif;--font-mono: "IBM Plex Mono", ui-monospace, "SF Mono", monospace;--r-sm: 6px;--r-md: 10px;--r-lg: 16px;--r-xl: 22px;--shadow-sm: 0 1px 2px rgba(24, 33, 46, .06), 0 1px 1px rgba(24, 33, 46, .04);--shadow-md: 0 4px 14px rgba(24, 33, 46, .08);--shadow-lg: 0 18px 48px rgba(24, 33, 46, .14);--ring: 0 0 0 3px rgba(249, 115, 22, .28)}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;background:var(--vapor);color:var(--graphite);font-family:var(--font-sans);font-size:15px;line-height:1.5;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}h1,h2,h3,h4{margin:0;font-weight:600;letter-spacing:-.01em;line-height:1.2}h1{font-size:1.6rem}p{margin:0}a{color:inherit;text-decoration:none}button{font-family:inherit}.mono{font-family:var(--font-mono);font-feature-settings:"zero" 1;letter-spacing:.02em}.eyebrow{font-family:var(--font-mono);font-size:.66rem;font-weight:500;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}:focus-visible{outline:none;box-shadow:var(--ring);border-radius:var(--r-sm)}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.001ms!important;transition-duration:.001ms!important}}.row{display:flex;align-items:center}.col{display:flex;flex-direction:column}.gap-1{gap:6px}.gap-2{gap:12px}.gap-3{gap:18px}.gap-4{gap:28px}.grow{flex:1}.center{display:flex;align-items:center;justify-content:center}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:var(--font-sans);font-size:.92rem;font-weight:600;padding:11px 18px;border-radius:var(--r-md);border:1px solid transparent;cursor:pointer;transition:transform .06s ease,background .15s ease,box-shadow .15s ease;white-space:nowrap}.btn:active{transform:translateY(1px)}.btn:disabled{opacity:.45;cursor:not-allowed}.btn-primary{background:var(--steel);color:#fff;box-shadow:var(--shadow-sm)}.btn-primary:hover:not(:disabled){background:var(--steel-deep)}.btn-ghost{background:var(--surface);color:var(--graphite);border-color:var(--mist)}.btn-ghost:hover:not(:disabled){background:var(--mist-2)}.btn-danger{background:var(--alert-tint);color:var(--alert);border-color:#eccbc6}.btn-danger:hover:not(:disabled){background:#f1d8d3}.btn-block{width:100%}.btn-lg{padding:15px 22px;font-size:1rem}.btn-sm{padding:7px 13px;font-size:.82rem}.card{background:var(--surface);border:1px solid var(--mist);border-radius:var(--r-lg);box-shadow:var(--shadow-sm)}.card-pad{padding:22px}.card-head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:16px}.field{display:flex;flex-direction:column;gap:7px}.field label{font-size:.8rem;font-weight:600;color:var(--slate)}.field input,.field select{font-family:var(--font-sans);font-size:.95rem;color:var(--graphite);padding:11px 13px;border:1px solid var(--mist);border-radius:var(--r-md);background:var(--surface-2);transition:border-color .15s ease,box-shadow .15s ease}.field input:focus,.field select:focus{outline:none;border-color:var(--steel);box-shadow:var(--ring)}.chip{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-mono);font-size:.68rem;font-weight:500;letter-spacing:.06em;text-transform:uppercase;padding:4px 9px;border-radius:999px;border:1px solid transparent}.chip-dot{width:6px;height:6px;border-radius:50%;background:currentColor}.temp-chilled{color:var(--temp-chilled);background:var(--temp-chilled-tint)}.temp-ambient{color:var(--temp-ambient);background:var(--temp-ambient-tint)}.temp-heated{color:var(--temp-heated);background:var(--temp-heated-tint)}.status{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-mono);font-size:.68rem;font-weight:500;letter-spacing:.06em;text-transform:uppercase;padding:4px 9px;border-radius:999px}.st-ok{color:var(--ok);background:var(--ok-tint)}.st-warn{color:var(--warn);background:var(--warn-tint)}.st-alert{color:var(--alert);background:var(--alert-tint)}.st-neutral{color:var(--slate);background:var(--mist-2)}.st-steel{color:var(--steel);background:var(--steel-tint)}.door{position:relative;display:flex;flex-direction:column;justify-content:space-between;border-radius:var(--r-md);border:1px solid var(--mist);background:linear-gradient(160deg,#fff,#f3f6f8);padding:12px;min-height:92px;overflow:hidden;transition:box-shadow .18s ease,transform .18s ease,border-color .18s ease}.door:after{content:"";position:absolute;top:12px;bottom:12px;right:16px;width:1px;background:var(--mist)}.door:before{content:"";position:absolute;top:50%;right:13px;width:4px;height:18px;transform:translateY(-50%);border-radius:2px;background:var(--muted);opacity:.5}.door .door-label{font-family:var(--font-mono);font-weight:600;font-size:1rem;letter-spacing:.04em}.door .door-temp-stripe{position:absolute;left:0;top:0;bottom:0;width:4px}.door.is-available{border-color:#cfe6dc}.door.is-available .door-temp-stripe{background:var(--ok)}.door.is-reserved .door-temp-stripe{background:var(--warn)}.door.is-occupied .door-temp-stripe{background:var(--steel)}.door.is-sanitisation_required{border-color:#eccbc6;background:linear-gradient(160deg,#fff,#fbeeec)}.door.is-sanitisation_required .door-temp-stripe{background:var(--alert)}.door.is-out_of_service{opacity:.55}.door.is-out_of_service .door-temp-stripe{background:var(--muted)}.door.clickable{cursor:pointer}.door.clickable:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.countdown{font-family:var(--font-mono);font-weight:600;letter-spacing:.04em}.countdown.urgent{color:var(--alert)}.countdown.soon{color:var(--warn)}.tbl{width:100%;border-collapse:collapse}.tbl th{text-align:left;font-family:var(--font-mono);font-size:.64rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);padding:10px 14px;border-bottom:1px solid var(--mist)}.tbl td{padding:12px 14px;border-bottom:1px solid var(--mist-2);font-size:.9rem;vertical-align:middle}.tbl tr:last-child td{border-bottom:none}.tbl tr:hover td{background:var(--surface-2)}.spinner{width:18px;height:18px;border:2px solid var(--mist);border-top-color:var(--steel);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.banner{display:flex;gap:10px;align-items:flex-start;padding:12px 14px;border-radius:var(--r-md);font-size:.88rem}.banner-alert{background:var(--alert-tint);color:#8e2b20}.banner-info{background:var(--steel-tint);color:var(--steel-deep)}.banner-warn{background:var(--warn-tint);color:#7a5a16}.stat{background:var(--surface);border:1px solid var(--mist);border-radius:var(--r-md);padding:16px}.stat .stat-val{font-family:var(--font-mono);font-size:1.5rem;font-weight:600}.stat .stat-label{font-size:.78rem;color:var(--muted);margin-top:2px}.empty{text-align:center;color:var(--muted);padding:40px 20px}.empty .empty-title{color:var(--slate);font-weight:600;margin-bottom:4px}.copy-btn{font-family:var(--font-mono);font-size:.66rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;padding:6px 11px;border-radius:999px;cursor:pointer;background:var(--mist-2);color:var(--slate);border:1px solid var(--mist);transition:background .12s ease,color .12s ease}.copy-btn:hover{background:var(--steel-tint);color:var(--steel-deep);border-color:var(--steel-tint)}.copy-on-hero{background:#ffffff29;color:#fff;border-color:#ffffff52}.copy-on-hero:hover{background:#ffffff47;color:#fff;border-color:#ffffff80}.otp-copy{display:inline-flex;align-items:center;gap:6px;flex-shrink:0;font-family:var(--font-sans);font-size:.8rem;font-weight:600;letter-spacing:.01em;color:#fff;background:#ffffff2e;border:1px solid rgba(255,255,255,.42);border-radius:999px;padding:7px 13px;cursor:pointer;transition:background .12s ease,border-color .12s ease}.otp-copy:hover{background:#ffffff4d;border-color:#ffffff9e}.otp-copy svg{display:block}.otp-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.otp-icon-btn{display:inline-flex;align-items:center;justify-content:center;padding:6px;color:#fff;background:#ffffff29;border:1px solid rgba(255,255,255,.42);border-radius:12px;cursor:pointer;transition:background .12s ease,border-color .12s ease}.otp-icon-btn:hover{background:#ffffff4d;border-color:#ffffffa8}.otp-icon-btn:disabled{opacity:.5;cursor:default}.otp-icon-btn svg{display:block}.code-reveal{display:flex;align-items:center;justify-content:space-between;gap:10px;background:var(--graphite);color:#fff;border-radius:var(--r-md);padding:12px 14px}.code-reveal .code-digits{font-family:var(--font-mono);font-size:1.5rem;font-weight:600;letter-spacing:.28em}.powered-by{display:flex;align-items:center;justify-content:center;gap:7px;font-size:.72rem;letter-spacing:.04em;color:var(--muted);padding:18px 0 14px}.powered-light .powered-chip{display:inline-flex;align-items:center;background:var(--graphite);border-radius:6px;padding:3px 7px}.powered-dark{color:#ffffff8c}.config-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(168px,1fr));gap:12px}.config-cell{position:relative;border:1px solid var(--mist);border-radius:var(--r-md);background:var(--surface-2);padding:12px;display:flex;flex-direction:column;gap:9px;border-left:4px solid var(--temp-ambient)}.config-cell.t-chilled{border-left-color:var(--temp-chilled)}.config-cell.t-heated{border-left-color:var(--temp-heated)}.config-cell .cell-label{font-family:var(--font-mono);font-weight:600;width:100%;padding:6px 8px;border:1px solid var(--mist);border-radius:var(--r-sm);background:#fff}.config-cell select{width:100%;padding:6px 8px;border:1px solid var(--mist);border-radius:var(--r-sm);background:#fff;font-size:.82rem}.config-cell .cell-remove{position:absolute;top:7px;right:8px;border:none;background:transparent;color:var(--muted);cursor:pointer;font-size:1.1rem;line-height:1}.config-cell .cell-remove:hover{color:var(--alert)}.type-seg{display:flex;gap:4px}.type-seg button{flex:1;padding:5px 4px;border-radius:var(--r-sm);cursor:pointer;font-size:.72rem;border:1px solid var(--mist);background:#fff;color:var(--slate)}.type-seg button.on.t-ambient{background:var(--temp-ambient-tint);color:var(--temp-ambient);border-color:var(--temp-ambient)}.type-seg button.on.t-chilled{background:var(--temp-chilled-tint);color:var(--temp-chilled);border-color:var(--temp-chilled)}.type-seg button.on.t-heated{background:var(--temp-heated-tint);color:var(--temp-heated);border-color:var(--temp-heated)}.add-cell{border:1.5px dashed var(--mist);border-radius:var(--r-md);background:transparent;display:flex;align-items:center;justify-content:center;min-height:132px;color:var(--steel);font-weight:600;cursor:pointer;font-size:.9rem}.add-cell:hover{background:var(--steel-tint);border-color:var(--steel)}.size-badge{font-size:.64rem;font-weight:700;letter-spacing:.06em;color:var(--slate);background:var(--mist-2);border-radius:5px;padding:2px 6px}.cabinet{--cols: 6;background:linear-gradient(165deg,#f4f6f9,#e9edf2);border:1px solid var(--mist);border-radius:14px;padding:14px;box-shadow:inset 0 1px 2px #1018200a}.cabinet-scale{width:fit-content;max-width:100%;background:linear-gradient(165deg,#262d37,#1a1f27);border:1px solid #313a47;padding:16px;box-shadow:inset 0 1px #ffffff08,inset 0 2px 12px #00000059}.cabinet-grid{display:grid;grid-template-columns:repeat(var(--cols),1fr);gap:8px}.locker-door{--accent: var(--temp-ambient);position:relative;aspect-ratio:3 / 4;min-height:88px;border-radius:10px;padding:8px 10px 8px 13px;background:var(--surface);border:1px solid var(--mist);box-shadow:0 1px 2px #1018200d;display:flex;flex-direction:column;justify-content:space-between;cursor:pointer;transition:transform .12s ease,box-shadow .12s ease,border-color .12s ease;overflow:hidden}.locker-door:hover{transform:translateY(-1px);box-shadow:0 6px 16px #1018201f;border-color:#cdd5de}.locker-door:focus-visible{outline:2px solid var(--steel);outline-offset:2px}.locker-door .ld-accent{position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--accent)}.locker-door .ld-top{display:flex;align-items:center;justify-content:space-between;gap:6px}.locker-door .ld-label{font-family:var(--font-mono);font-weight:600;font-size:.82rem;letter-spacing:.02em;color:var(--graphite)}.locker-door .ld-light{flex:none;width:8px;height:8px;border-radius:50%;background:var(--muted)}.locker-door .ld-bottom{display:flex;align-items:flex-end;justify-content:space-between;gap:6px}.locker-door .ld-temp{font-size:.62rem;font-weight:600;letter-spacing:.02em;color:var(--accent);white-space:nowrap}.locker-door.t-ambient{--accent: var(--temp-ambient)}.locker-door.t-chilled{--accent: var(--temp-chilled)}.locker-door.t-heated{--accent: var(--temp-heated)}.locker-door.is-available .ld-light{background:var(--ok)}.locker-door.is-reserved{background:color-mix(in srgb,var(--warn) 8%,var(--surface))}.locker-door.is-reserved .ld-light{background:var(--warn)}.locker-door.is-occupied{background:color-mix(in srgb,var(--steel) 10%,var(--surface))}.locker-door.is-occupied .ld-light{background:var(--steel)}.locker-door.is-sanitisation_required{background:color-mix(in srgb,var(--alert) 8%,var(--surface))}.locker-door.is-sanitisation_required .ld-light{background:var(--alert)}.locker-door.is-out_of_service{background:var(--surface-2);opacity:.6}.locker-door.is-out_of_service .ld-light{background:var(--muted)}.locker-door.is-expired{background:color-mix(in srgb,var(--alert) 12%,var(--surface));border-color:color-mix(in srgb,var(--alert) 35%,var(--mist))}.locker-door.is-expired .ld-light{background:var(--alert)}.cabinet-rail{display:flex;align-items:center;gap:6px}.cabinet-rail .col-btn{width:30px;height:28px;border-radius:var(--r-sm);border:1px solid var(--mist);background:var(--surface-2);color:var(--slate);cursor:pointer;font-size:.8rem;font-weight:600}.cabinet-rail .col-btn.on{background:var(--steel-tint);color:var(--steel-deep);border-color:var(--steel)}.locker-door.editable{cursor:default;aspect-ratio:auto;min-height:0;padding:10px 10px 10px 13px;gap:7px}.scale-wall{display:flex;gap:6px;align-items:flex-start;overflow-x:auto;padding:2px}.scale-col{display:flex;flex-direction:column;gap:6px}.locker-door.scaled{aspect-ratio:auto;min-height:0;padding:6px 8px 6px 13px}.locker-door.scaled .ld-bottom{gap:4px}.ld-dims{font-family:var(--font-mono);font-size:.6rem;color:var(--slate);white-space:nowrap}.type-chip{display:inline-flex;align-items:center;gap:7px;padding:6px 10px;border:1px solid var(--mist);border-radius:999px;background:var(--surface-2);font-size:.8rem}.type-chip .dims{font-family:var(--font-mono);color:var(--slate)}.locker-door.editable .cell-label{font-family:var(--font-mono);font-weight:700;width:100%;padding:5px 7px;border:1px solid var(--mist);border-radius:var(--r-sm);background:#fff}.locker-door.editable select{width:100%;padding:5px 7px;border:1px solid var(--mist);border-radius:var(--r-sm);background:#fff;font-size:.78rem}.locker-door.editable .cell-remove{position:absolute;top:5px;right:7px;border:none;background:transparent;color:var(--muted);cursor:pointer;font-size:1.05rem;line-height:1;z-index:2}.locker-door.editable .cell-remove:hover{color:var(--alert)}.locker-card-body{display:flex;gap:18px;align-items:stretch;flex-wrap:wrap}.locker-card-wall{flex:0 1 auto;min-width:0}.locker-stats{flex:1 1 300px;display:flex;flex-direction:column;gap:12px}.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px;align-content:start}.stat-tile{background:var(--surface-2);border:1px solid var(--mist);border-radius:var(--r-sm);padding:11px 14px;display:flex;flex-direction:row;align-items:baseline;justify-content:space-between;gap:10px}.stat-tile .k{font-size:.7rem;text-transform:uppercase;letter-spacing:.04em;color:var(--muted)}.stat-tile .v{font-family:var(--font-mono);font-weight:600;font-size:1.1rem;line-height:1;color:var(--graphite);margin-left:auto}.stat-tile .v.stat-alert{color:var(--alert)}.stat-loc{background:var(--surface-2);border:1px solid var(--mist);border-radius:var(--r-sm);padding:12px 14px;display:flex;flex-direction:column;gap:4px}.telemetry{display:flex;flex-wrap:wrap;gap:10px;padding:10px 12px;background:var(--surface-2);border:1px solid var(--mist);border-radius:var(--r-sm)}.tele{display:flex;flex-direction:column;gap:2px;min-width:92px}.tele-k{font-size:.68rem;text-transform:uppercase;letter-spacing:.04em;color:var(--muted)}.tele-v{font-family:var(--font-mono);font-weight:600;font-size:.95rem;display:inline-flex;align-items:center;gap:6px}.tele-ok{color:var(--ok, #1a7f4b)}.tele-warn{color:#b6781e}.tele-alert{color:var(--alert)}.tele-steel{color:var(--steel)}.net-chip{font-family:var(--font-sans);font-size:.72rem;font-weight:600;padding:1px 7px;border-radius:999px;background:var(--steel);color:#fff}.power-chip{font-family:var(--font-sans);font-size:.78rem;padding:2px 9px;border-radius:999px;width:fit-content}.pw-ac{background:#e4f2ea;color:#1a7f4b}.pw-batt{background:#fdecea;color:var(--alert)}.seg{display:inline-flex;border:1px solid var(--mist);border-radius:999px;background:var(--surface-2);padding:2px}.seg button{border:none;background:transparent;padding:6px 14px;border-radius:999px;font-size:.82rem;font-weight:600;color:var(--muted);cursor:pointer}.seg button.on{background:var(--surface);color:var(--graphite);box-shadow:0 1px 2px #1018201a}.cabinet-scale .scale-wall,.cabinet-scale .scale-col{gap:8px}.cabinet-scale .locker-door{background:linear-gradient(165deg,#313945,#283039);border:1px solid #3c4654;border-radius:11px;box-shadow:0 1px 2px #00000040;padding:9px 11px 9px 14px}.cabinet-scale .locker-door:hover{border-color:#54607180;background:linear-gradient(165deg,#39424f,#2d3640);transform:translateY(-1px);box-shadow:0 8px 20px #00000059}.cabinet-scale .locker-door .ld-accent{width:3px;border-radius:11px 0 0 11px;opacity:.9}.cabinet-scale .locker-door .ld-label{color:#d8dde4;font-weight:600;letter-spacing:.04em}.cabinet-scale .locker-door .ld-dims{color:#8b94a1}.cabinet-scale .locker-door .ld-light{width:11px;height:11px;box-shadow:none;background:#5b6573}.cabinet-scale .locker-door.is-available .ld-light{background:#34d399;box-shadow:0 0 8px #34d39988}.cabinet-scale .locker-door.is-reserved .ld-light{background:#fbbf24;box-shadow:0 0 8px #fbbf2488}.cabinet-scale .locker-door.is-occupied .ld-light{background:#fb923c;box-shadow:0 0 8px #fb923c99}.cabinet-scale .locker-door.is-expired .ld-light{background:#f87171;box-shadow:0 0 9px #f87171aa}.cabinet-scale .locker-door.is-sanitisation_required .ld-light{background:#f472b6;box-shadow:0 0 8px #f472b688}.cabinet-scale .locker-door.is-out_of_service .ld-light{background:#64748b}.cabinet-scale .locker-door.is-occupied{border-color:#6b4f2e}.cabinet-scale .locker-door.is-reserved{border-color:#6b5a2a}.cabinet-scale .locker-door.is-expired{border-color:#7d3a3a;background:linear-gradient(165deg,#3a2e30,#2f2528)}.cabinet-scale .locker-door.is-out_of_service{opacity:.5}.locker-head{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;flex-wrap:wrap}.lh-left{display:flex;gap:12px;align-items:flex-start}.lh-dot{width:13px;height:13px;border-radius:50%;margin-top:7px;flex:none}.lh-name{font-size:1.35rem;font-weight:700;line-height:1.1;color:var(--graphite)}.lh-loc{display:flex;align-items:center;gap:5px;color:var(--muted);font-size:.85rem;margin-top:3px}.lh-right{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:flex-end}.uptime-pill{border:1px solid;border-radius:999px;padding:6px 14px;font-weight:700;font-size:.8rem;letter-spacing:.02em;white-space:nowrap}.uptime-pill.tele-ok{color:#1a7f4b;border-color:#bfe3d0;background:#ecf8f1}.uptime-pill.tele-warn{color:#b6781e;border-color:#f0dcb6;background:#fcf4e3}.uptime-pill.tele-alert{color:var(--alert);border-color:#f3c9c4;background:#fdecea}.tele-line{display:flex;gap:22px;align-items:center;flex-wrap:wrap;padding:10px 0 2px}.tele-item{display:flex;align-items:baseline;gap:7px}.tele-item .k{font-size:.7rem;text-transform:uppercase;letter-spacing:.04em;color:var(--muted)}.tele-item .v{font-family:var(--font-mono);font-weight:600;font-size:.9rem;color:var(--graphite)}.locker-foot{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:16px;border-top:1px solid var(--mist);padding-top:16px}.foot-group{display:flex;flex-direction:column;gap:9px}.foot-head{display:flex;align-items:center;gap:8px}.foot-head .dot{width:9px;height:9px;border-radius:50%;flex:none}.foot-head .lbl{font-size:.72rem;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);font-weight:700}.foot-head .tot{margin-left:auto;font-family:var(--font-mono);font-weight:700;font-size:1.1rem;color:var(--graphite)}.size-badges{display:flex;gap:6px;flex-wrap:wrap}.size-badges .sb{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:999px;background:var(--surface);border:1px solid var(--mist)}.size-badges .sb-k{font-weight:700;font-size:.7rem;color:var(--muted)}.size-badges .sb-v{font-family:var(--font-mono);font-weight:600;font-size:.82rem;color:var(--graphite)}.dot-available{background:#34d399}.dot-reserved{background:#fbbf24}.dot-occupied{background:#fb923c}.dot-expired{background:#f87171}.dot-out_of_service{background:#64748b}.dot-sanitisation_required{background:#f472b6}.cdetail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:10px}.cdetail-tile{background:var(--surface-2);border:1px solid var(--mist);border-radius:var(--r-sm);padding:10px 12px;display:flex;flex-direction:column;gap:4px}.cdetail-tile .k{font-size:.68rem;text-transform:uppercase;letter-spacing:.04em;color:var(--muted)}.cdetail-tile .v{font-family:var(--font-mono);font-weight:600;font-size:1.15rem;color:var(--graphite)}.cdetail-tile .v.stat-alert{color:var(--alert)}.overstay-note{display:inline-flex;align-items:center;gap:9px;align-self:flex-start;padding:8px 14px;border-radius:10px;font-size:.86rem;color:#b42318;background:#fdecea;border:1px solid #f3c9c4}.overstay-note strong{font-weight:700}.locker-headerzone{border-bottom:1px solid var(--mist);padding-bottom:8px}.locker-headerzone .tele-line{padding:12px 0 0}.locker-side{flex:1 1 300px;min-width:260px;display:flex;flex-direction:column;gap:16px}.side-sec{display:flex;flex-direction:column;gap:10px}.status-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.status-grp{display:flex;flex-direction:column;gap:8px;padding:11px 13px;min-width:0;overflow:hidden;background:var(--surface-2);border:1px solid var(--mist);border-radius:var(--r-sm)}.status-grp .foot-head{gap:7px;min-width:0}.status-grp .foot-head .lbl{font-size:.68rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.status-grp .foot-head .tot{font-size:1.05rem}.hbadge{display:inline-flex;align-items:center;gap:6px;padding:5px 11px;border-radius:999px;border:1px solid var(--mist);background:var(--surface-2);font-size:.8rem;white-space:nowrap}.hbadge .hb-k{color:var(--muted);font-size:.72rem;text-transform:uppercase;letter-spacing:.03em}.hbadge .hb-v{font-family:var(--font-mono);font-weight:600;color:var(--graphite)}.hbadge.power-chip{font-weight:600}.fleet-tbl-wrap{overflow:visible}.fleet-tbl td,.fleet-tbl th{white-space:nowrap}.fleet-tbl td{vertical-align:middle}.fleet-tbl .cell{display:flex;flex-direction:column;gap:3px;line-height:1.25}.fleet-tbl .c-main{font-weight:600;color:var(--graphite);font-size:.92rem;display:inline-flex;align-items:center}.fleet-tbl .c-sub{font-size:.74rem;color:var(--muted);display:inline-flex;align-items:center;gap:4px}.fleet-tbl .c-main.up-ok{color:#1a7f4b}.fleet-tbl .c-main.up-warn{color:#b6781e}.fleet-tbl .c-main.up-alert{color:var(--alert)}.row-dot{display:inline-block;width:9px;height:9px;border-radius:50%;margin-right:9px;flex:none}.row-archived td{opacity:.55}.fleet-tbl .act-cell{display:flex;flex-wrap:wrap;gap:5px 14px;max-width:280px;white-space:normal}.act-chip{display:inline-flex;align-items:baseline;gap:5px}.act-chip .ac-k{font-size:.72rem;color:var(--muted)}.act-chip .ac-v{font-family:var(--font-mono);font-weight:600;font-size:.86rem;color:var(--graphite)}.act-chip .ac-v.stat-alert{color:var(--alert)}.td-actions{width:44px;text-align:right}.kebab-wrap{position:relative;display:inline-block}.kebab-btn{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:8px;border:1px solid transparent;background:transparent;color:var(--slate);cursor:pointer}.kebab-btn:hover{background:var(--surface-2);border-color:var(--mist)}.kebab-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:40}.kebab-menu{position:absolute;right:0;top:calc(100% + 4px);z-index:41;min-width:140px;background:var(--surface);border:1px solid var(--mist);border-radius:var(--r-md);box-shadow:var(--shadow-md);padding:6px;display:flex;flex-direction:column;gap:2px}.kebab-menu button{text-align:left;padding:9px 11px;border:none;background:transparent;border-radius:7px;font-size:.88rem;color:var(--graphite);cursor:pointer;font-family:var(--font-sans)}.kebab-menu button:hover{background:var(--surface-2)}.kebab-menu button:disabled{color:var(--muted);cursor:not-allowed}.chart-legend{display:flex;flex-wrap:wrap;gap:8px 10px;margin-top:12px}.legend-item{display:inline-flex;align-items:center;gap:7px;padding:5px 11px;border-radius:999px;border:1px solid var(--mist);background:var(--surface-2);cursor:pointer;font-family:var(--font-sans);font-size:.8rem;color:var(--graphite);transition:opacity .12s ease,background .12s ease}.legend-item:hover{background:var(--mist-2)}.legend-item .legend-swatch{width:11px;height:11px;border-radius:3px;flex:none}.legend-item.off{opacity:.45;text-decoration:line-through}.legend-item.off .legend-swatch{background:var(--muted)!important}.fleet-tbl tr.row-clickable{cursor:pointer}.size-options{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px}.size-opt{text-align:left;display:flex;flex-direction:column;gap:8px;padding:14px 16px;border:1px solid var(--mist);border-radius:var(--r-md);background:var(--surface);cursor:pointer;transition:border-color .12s ease,box-shadow .12s ease,background .12s ease;font-family:var(--font-sans)}.size-opt:hover{border-color:var(--steel)}.size-opt.on{border-color:var(--steel);box-shadow:var(--ring);background:var(--steel-tint)}.size-opt .so-top{display:flex;align-items:baseline;justify-content:space-between;gap:10px}.size-opt .so-name{font-weight:700;font-size:1.05rem;color:var(--graphite)}.size-opt .so-count{font-family:var(--font-mono);font-size:.82rem;font-weight:600;color:var(--steel-deep)}.size-opt .so-dims{font-family:var(--font-mono);font-size:.8rem;color:var(--muted)}.profile-wrap{position:relative;display:inline-flex}.profile-btn{width:38px;height:38px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--mist);background:var(--surface);color:var(--slate);cursor:pointer;transition:border-color .12s ease,color .12s ease,background .12s ease}.profile-btn:hover{border-color:var(--steel);color:var(--steel-deep);background:var(--steel-tint)}.profile-menu{position:absolute;top:calc(100% + 8px);right:0;z-index:41;min-width:214px;background:var(--surface);border:1px solid var(--mist);border-radius:var(--r-md);box-shadow:var(--shadow-md);padding:6px}.profile-menu .profile-id{display:flex;flex-direction:column;gap:2px;padding:8px 10px 10px;margin-bottom:4px;border-bottom:1px solid var(--mist)}.profile-menu .profile-name{font-weight:600;color:var(--graphite);font-size:.92rem}.profile-menu .profile-email{font-size:.78rem;color:var(--muted);word-break:break-all}.profile-menu .profile-role{font-size:.68rem;text-transform:uppercase;letter-spacing:.05em;color:var(--steel-deep);margin-top:2px}.profile-menu button{display:flex;align-items:center;gap:9px;width:100%;text-align:left;border:0;background:transparent;border-radius:var(--r-sm);padding:9px 10px;cursor:pointer;font-family:var(--font-sans);font-size:.88rem;color:var(--graphite);transition:background .1s ease}.profile-menu button:hover{background:var(--surface-2)}.profile-menu button svg{width:16px;height:16px;flex-shrink:0;color:var(--slate)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:60;display:flex;align-items:center;justify-content:center;padding:20px;background:#0f172075}.modal-card{width:100%;max-width:380px;background:var(--surface);border-radius:var(--r-lg);border:1px solid var(--mist);box-shadow:var(--shadow-md);padding:22px}.close-timer{display:flex;flex-direction:column;align-items:center;gap:2px}.close-timer .countdown{font-family:var(--font-mono);font-weight:700;line-height:1}.success-screen{align-items:center;padding:40px 8px}.success-check{width:68px;height:68px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;background:var(--ok, #10b981);box-shadow:0 8px 24px #10b98159}.purpose-opts{display:grid;grid-template-columns:1fr 1fr;gap:10px}.purpose-opt{text-align:left;display:flex;flex-direction:column;gap:4px;padding:12px 14px;border:1px solid var(--mist);border-radius:var(--r-md);background:var(--surface);cursor:pointer;transition:border-color .12s ease,box-shadow .12s ease,background .12s ease;font-family:var(--font-sans)}.purpose-opt:hover{border-color:var(--steel)}.purpose-opt.on{border-color:var(--steel);box-shadow:var(--ring);background:var(--steel-tint)}.purpose-opt .po-name{font-weight:700;color:var(--graphite)}.purpose-opt .po-sub{font-size:.78rem;color:var(--muted)}.usage-cell{display:flex;flex-direction:column;gap:2px}.recent-card{background:var(--surface);border:1px solid var(--mist);border-radius:var(--r-lg);padding:14px 16px;display:flex;flex-direction:column;gap:12px;box-shadow:var(--shadow)}.recent-card .rc-head{display:flex;align-items:center;justify-content:flex-start;gap:8px;flex-wrap:wrap}.recent-card .rc-locker{font-weight:700;font-size:1.05rem;color:var(--graphite)}.recent-card .rc-meta{display:grid;grid-auto-flow:column;grid-auto-columns:minmax(0,1fr);gap:10px 12px}.recent-card .rc-cell{display:flex;flex-direction:column;gap:1px;min-width:0}.recent-card .rc-k{font-size:.68rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}.recent-card .rc-v{font-size:.84rem;color:var(--slate);font-variant-numeric:tabular-nums}.recent-card .rc-type{font-size:.66rem;letter-spacing:.06em;text-transform:uppercase;font-weight:600;padding:3px 8px;border-radius:999px;white-space:nowrap}.recent-card .rc-type.is-delivery{color:var(--steel-deep);background:var(--steel-tint)}.recent-card .rc-type.is-storage{color:#7a4d00;background:#fdecd2}.otp-icon-btn.otp-cancel{color:#ffe3e0;border-color:#ffb4aa8c;background:#ff78692e}.otp-icon-btn.otp-cancel:hover{background:#ff786957;border-color:#ffb4aacc}.success-locker{font-size:2.4rem;font-weight:700;color:var(--graphite);margin-top:10px;letter-spacing:.02em}.recent-card .rc-note{font-size:.8rem;color:var(--slate);background:var(--warn-tint, #fdf1d8);border-radius:var(--r-sm, 8px);padding:8px 10px}.recent-card .rc-log{margin-top:12px;padding-top:12px;border-top:1px solid var(--mist, #e7ebf0);display:flex;flex-direction:column;gap:6px}.recent-card .rc-log-list{display:flex;flex-direction:column;gap:4px;margin-top:2px}.recent-card .rc-log-row{display:grid;grid-template-columns:10px auto 1fr;align-items:center;gap:8px;font-size:.85rem}.recent-card .rc-log-row .rc-log-ev{font-weight:600;color:var(--graphite)}.recent-card .rc-log-row .rc-log-at{color:var(--slate);text-align:right;font-variant-numeric:tabular-nums}.recent-card .rc-log-dot{width:8px;height:8px;border-radius:50%}.recent-card .rc-log-dot.opened{background:var(--steel, #3b82f6)}.recent-card .rc-log-dot.closed{background:var(--mist-3, #9aa5b1)}.tbl .tx-row-click{cursor:pointer}.tbl .tx-row-click:hover{background:var(--mist-2, #f4f6f8)}.tbl .tx-log-row td{background:var(--mist-2, #f4f6f8);padding:14px 16px}.tx-log-title{font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);font-weight:700;margin-bottom:8px}.tx-access{display:grid;grid-template-columns:1.3fr 1fr 1fr;max-width:520px;background:var(--surface);border:1px solid var(--mist);border-radius:10px;overflow:hidden}.tx-access-h{padding:7px 14px;font-size:.66rem;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);font-weight:600;background:var(--surface-2)}.tx-access-c{padding:8px 14px;font-size:.85rem;color:var(--slate);border-top:1px solid var(--mist);font-variant-numeric:tabular-nums}.empty-hero{display:flex;flex-direction:column;align-items:center;text-align:center;gap:16px;padding:34px 24px 26px;border-radius:var(--r-lg, 16px);background:radial-gradient(120% 100% at 50% 0%,var(--steel-tint) 0%,var(--surface) 62%);border:1px solid var(--mist);box-shadow:0 12px 30px -18px #18212e47}.empty-hero-art{width:64px;height:64px;display:grid;place-items:center;border-radius:18px;color:var(--steel);background:var(--surface);border:1px solid var(--steel-tint);box-shadow:0 6px 16px -10px #f973168c}.empty-hero-text{display:flex;flex-direction:column;gap:6px}.empty-hero-title{margin:0;font-size:1.28rem;letter-spacing:-.01em;color:var(--graphite)}.empty-hero-body{margin:0 auto;max-width:30ch;color:var(--slate);font-size:.95rem;line-height:1.5}.policy-card{padding:0;overflow:hidden}.policy-head{padding:22px 22px 4px}.policy-head h3{margin:0}.policy-sub{margin:6px 0 0;color:var(--slate);font-size:.88rem;line-height:1.5;max-width:70ch}.policy-section{padding:18px 22px;border-top:1px solid var(--mist)}.policy-section-title{font-size:.72rem;letter-spacing:.09em;text-transform:uppercase;color:var(--muted);font-weight:700;margin-bottom:14px}.policy-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:18px 20px}.policy-hint{display:block;margin-top:5px;font-size:.76rem;color:var(--muted);line-height:1.35}.policy-foot{padding:16px 22px;border-top:1px solid var(--mist);background:var(--surface-2);display:flex;justify-content:flex-end}.input-affix{position:relative;display:flex;align-items:center}.input-affix>input{width:100%;padding-right:46px}.input-affix .affix{position:absolute;right:12px;color:var(--muted);font-size:.8rem;font-weight:500;pointer-events:none}.tx-log-tbl{background:var(--surface);border-radius:10px;overflow:hidden}.tx-log-tbl th{font-size:.68rem}.tx-log-tbl td,.tx-log-tbl th{padding:6px 12px}.ack-check{display:flex;align-items:flex-start;gap:10px;font-size:.88rem;color:var(--graphite);line-height:1.4;cursor:pointer}.ack-check input{margin-top:2px;width:16px;height:16px;accent-color:var(--steel);flex:none}.daterange{position:relative}.daterange-btn{display:inline-flex;align-items:center;gap:8px;height:40px;padding:0 14px;border:1px solid var(--mist);border-radius:10px;background:var(--surface);color:var(--slate);font-size:.9rem;cursor:pointer;white-space:nowrap}.daterange-btn:hover{border-color:var(--slate)}.daterange-btn.on{border-color:var(--steel);color:var(--steel-deep);background:var(--steel-tint)}.daterange-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:40}.daterange-pop{position:absolute;z-index:41;top:calc(100% + 6px);left:0;min-width:260px;display:flex;flex-direction:column;gap:12px;padding:14px;background:var(--surface);border:1px solid var(--mist);border-radius:14px;box-shadow:var(--shadow)}.daterange-row{display:flex;align-items:center;justify-content:space-between;gap:12px;font-size:.85rem;color:var(--slate)}.daterange-row input{flex:none}.auth-wrap{min-height:100%;display:grid;place-items:center;padding:24px;background:radial-gradient(900px 500px at 100% -10%,var(--steel-tint),transparent 60%),var(--vapor)}.auth-logo-band{background:var(--graphite);display:flex;align-items:center;justify-content:center;padding:26px 24px}.role-pills{display:flex;flex-wrap:wrap;gap:6px}.role-pill{font-family:var(--font-mono);font-size:.7rem;padding:5px 9px;border-radius:999px;background:var(--mist-2);color:var(--slate);cursor:pointer;border:1px solid transparent}.role-pill:hover{border-color:var(--mist)}.app-shell{max-width:520px;margin:0 auto;min-height:100%;display:flex;flex-direction:column;background:var(--vapor)}.app-top{position:sticky;top:0;z-index:5;display:flex;align-items:center;justify-content:space-between;padding:16px 18px;background:var(--graphite);border-bottom:1px solid rgba(255,255,255,.08)}.app-top .profile-btn{color:#fff;border-color:#ffffff57;background:#ffffff0f}.app-top .profile-btn:hover{color:#fff;border-color:#fff9;background:#ffffff29}.app-body{flex:1;padding:18px;display:flex;flex-direction:column;gap:16px}.app-tabbar{position:sticky;bottom:0;display:flex;background:var(--surface);border-top:1px solid var(--mist)}.app-tabbar a{flex:1;text-align:center;padding:11px 0 14px;font-size:.72rem;color:var(--muted);display:flex;flex-direction:column;align-items:center;gap:4px}.app-tabbar a.active{color:var(--steel)}.app-tabbar a .tab-ico{width:22px;height:22px}.hero-door{position:relative;border-radius:var(--r-xl);padding:24px;color:#fff;overflow:hidden;background:linear-gradient(155deg,var(--steel) 0%,var(--steel-deep) 100%);box-shadow:var(--shadow-md)}.hero-door .hero-dim{color:#ffffffb8}.hero-door .hero-label{font-family:var(--font-mono);font-size:2.05rem;font-weight:600;letter-spacing:.01em;line-height:1.08;word-break:break-word}.hero-door .hero-expiry{font-family:var(--font-mono);font-size:1.5rem;font-weight:600;line-height:1}.hero-door .otp-box{background:#ffffff21;border:1px dashed rgba(255,255,255,.45);border-radius:var(--r-lg);padding:13px 14px 14px;display:flex;flex-direction:column;gap:8px}.hero-door .otp-tag{font-size:.64rem}.hero-door .otp-line{display:flex;align-items:center;justify-content:space-between;gap:10px}.hero-door .otp-readout{font-family:var(--font-mono);font-size:1.85rem;font-weight:700;letter-spacing:.14em;line-height:1;padding-left:2px}.hero-door .hero-note{font-size:.82rem;color:#ffffffd1;line-height:1.5}.portal{display:grid;grid-template-columns:248px 1fr;min-height:100vh}.rail{background:var(--graphite);color:#cdd6e0;padding:20px 14px;display:flex;flex-direction:column;gap:4px;position:sticky;top:0;height:100vh}.rail .rail-brand{color:#fff;padding:6px 10px 18px}.rail a{display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:var(--r-md);color:#aeb9c6;font-size:.9rem;font-weight:500}.rail a:hover{background:#ffffff0f;color:#fff}.rail a.active{background:var(--steel);color:#fff}.rail-group{font-family:var(--font-mono);font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;color:#5d6b7b;padding:16px 12px 6px}.rail-foot{margin-top:auto;border-top:1px solid rgba(255,255,255,.08);padding-top:14px}.portal-main{display:flex;flex-direction:column;min-width:0}.portal-head{display:flex;align-items:center;justify-content:space-between;padding:12px 32px;border-bottom:1px solid var(--mist);background:var(--surface);position:sticky;top:0;z-index:4}.portal-content{padding:28px 32px;display:flex;flex-direction:column;gap:22px}.grid-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px}.fleet-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(112px,1fr));gap:12px}.toolbar{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.kiosk{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px;background:radial-gradient(900px 500px at 100% -10%,var(--steel-tint),transparent 60%),var(--vapor)}.kiosk-card{width:100%;max-width:540px;text-align:center}.kiosk-card .card-pad{padding:36px}.kiosk-band{flex-direction:column;gap:10px}.kiosk-band .kiosk-band-loc{font-family:var(--font-mono);font-size:.78rem;letter-spacing:.05em;color:#ffffffb8;text-align:center}.keypad{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:8px}.key{font-family:var(--font-mono);font-size:1.7rem;font-weight:600;padding:20px 0;border-radius:var(--r-md);border:1px solid var(--mist);background:var(--surface);cursor:pointer;color:var(--graphite);transition:transform .06s ease,background .12s ease}.key:hover{background:var(--mist-2)}.key:active{transform:translateY(2px)}.otp-cells{display:flex;gap:10px;justify-content:center;margin:8px 0 4px}.otp-cell{width:48px;height:60px;border-radius:var(--r-md);border:1px solid var(--mist);background:var(--surface-2);display:grid;place-items:center;font-family:var(--font-mono);font-size:1.8rem;font-weight:600}.otp-cell.filled{border-color:var(--steel);background:var(--steel-tint)}.kiosk-door{width:220px;height:260px;margin:0 auto 8px;perspective:900px;position:relative}.kiosk-door .frame{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:var(--r-lg);background:var(--mist-2);border:2px solid var(--mist);box-shadow:inset 0 0 0 6px var(--surface)}.kiosk-door .leaf{position:absolute;top:8px;right:8px;bottom:8px;left:8px;border-radius:var(--r-md);transform-origin:left center;background:linear-gradient(150deg,var(--steel),var(--steel-deep));box-shadow:var(--shadow-md);transition:transform 1.1s cubic-bezier(.22,.61,.36,1)}.kiosk-door .leaf .handle{position:absolute;right:14px;top:50%;width:6px;height:40px;transform:translateY(-50%);border-radius:3px;background:#ffffff8c}.kiosk-door.open .leaf{transform:rotateY(-105deg)}.kiosk-door .inside{position:absolute;top:8px;right:8px;bottom:8px;left:8px;border-radius:var(--r-md);display:grid;place-items:center;background:#0e1620;color:#7fb4c4;font-family:var(--font-mono)}.full-center{min-height:100vh;display:grid;place-items:center}.kiosk,.full-center{min-height:100dvh}@media (max-width: 860px){.portal{grid-template-columns:1fr}.rail{position:sticky;top:0;z-index:30;height:auto;flex-direction:row;align-items:center;flex-wrap:nowrap;gap:6px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding:10px 14px}.rail::-webkit-scrollbar{display:none}.rail .rail-brand{flex:none;padding:0 8px 0 0}.rail .rail-group,.rail .rail-foot{display:none}.rail a{flex:none;padding:8px 12px;white-space:nowrap}.rail a svg{width:16px;height:16px}.portal-head{padding:12px 16px}.portal-content{padding:18px 16px;gap:16px}h1{font-size:1.35rem}.card{overflow-x:auto;-webkit-overflow-scrolling:touch}.card .tbl{min-width:660px}.toolbar{gap:10px}.toolbar .field{flex:1 1 160px;min-width:0}.toolbar .field:first-child{flex:1 1 100%}.toolbar input,.toolbar select{width:100%}.daterange-pop{max-width:min(320px,calc(100vw - 40px))}input,select,textarea{font-size:16px}.status-list{grid-template-columns:1fr}}@media (max-width: 480px){.kiosk{padding:14px}.kiosk-card .card-pad{padding:22px 18px}.kiosk-door{width:180px;height:214px}.kiosk-mode{padding:14px;gap:12px}.kiosk-mode-chip{width:46px;height:46px;border-radius:13px}.kiosk-mode-title{font-size:1rem}.kiosk-landing{gap:18px}}.hero-door .hero-expiry,.hero-door .countdown,.hero-door .countdown.soon{color:#fff}.hero-door .countdown.urgent{color:#fff;background:#fff3;padding:0 8px;border-radius:999px}.kiosk-landing{display:flex;flex-direction:column;align-items:center;gap:24px;width:100%;padding:12px 0 4px}.kiosk-landing-brand{display:flex;flex-direction:column;align-items:center;gap:10px}.kiosk-landing-loc{font-size:.78rem;letter-spacing:.05em;color:var(--muted)}.kiosk-landing-title{font-size:1.3rem;font-weight:600;color:var(--graphite);text-align:center;margin:0}.kiosk-modes{display:flex;flex-direction:column;gap:12px;width:100%}.kiosk-mode{display:flex;align-items:center;gap:16px;width:100%;padding:18px;text-align:left;border:1px solid var(--mist);border-radius:18px;background:var(--surface);cursor:pointer;transition:transform .16s ease,box-shadow .16s ease,border-color .16s ease}.kiosk-mode:hover{transform:translateY(-2px);border-color:var(--steel);box-shadow:var(--shadow)}.kiosk-mode:active{transform:translateY(0)}.kiosk-mode-chip{width:54px;height:54px;border-radius:15px;display:grid;place-items:center;flex:none}.kiosk-mode-txt{display:flex;flex-direction:column;gap:2px;min-width:0}.kiosk-mode-title{font-size:1.12rem;font-weight:650;color:var(--graphite);text-transform:uppercase;letter-spacing:.04em}.kiosk-mode-sub{font-size:.84rem;color:var(--muted)}.kiosk-mode-arrow{margin-left:auto;color:var(--mist);flex:none}.kiosk-mode:hover .kiosk-mode-arrow{color:var(--steel)}.kiosk-back{position:absolute;left:0;top:2px;width:34px;height:34px;border-radius:10px;display:grid;place-items:center;background:var(--mist-2);color:var(--slate);cursor:pointer}.kiosk-back:hover{background:var(--mist);color:var(--graphite)}.kiosk{--vapor: #0e1116;--surface: #191d24;--surface-2: #20242c;--graphite: #f4f6f9;--slate: #c3c9d2;--muted: #8b93a1;--mist: #2c313a;--mist-2: #262b33;background:#0e1116;color:var(--graphite)}.kiosk h1,.kiosk h2,.kiosk h3{color:var(--graphite)}.kiosk .center svg{color:inherit}.kiosk .kiosk-card{border-color:#262b33;box-shadow:0 24px 60px #00000073}.kiosk .auth-logo-band{background:#14181e;border-bottom:1px solid #23272f}.kiosk .otp-cell.filled{border-color:var(--steel);background:#f973162e;color:#fff}.kiosk .banner-alert{background:#ef444426;color:#fca5a5;border-color:#ef444459}.kiosk .kiosk-door .frame{box-shadow:inset 0 0 0 6px #14181e}.kiosk .kiosk-mode:hover{box-shadow:0 12px 30px #0006}.kiosk .kiosk-done-check{background:#10b98129!important}.kiosk .kiosk-done-check svg{stroke:#34d399}.kiosk .kiosk-door .inside{background:#0b0f14;color:#6ab0c2}@media (max-width: 640px){.card .tbl.tbl-cards{min-width:0}.tbl-cards thead{display:none}.tbl-cards tbody{display:block}.tbl-cards tr{display:grid;grid-template-columns:1fr 1fr;gap:10px 16px;padding:14px 16px;border-bottom:1px solid var(--mist);position:relative}.tbl-cards tr:last-child{border-bottom:none}.tbl-cards td{display:block;padding:0;border:none;min-width:0;overflow-wrap:anywhere}.tbl-cards tr:hover td{background:transparent}.tbl-cards td[data-label]:before{content:attr(data-label);display:block;font-family:var(--font-mono);font-size:.58rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:3px}.tbl-cards td.tc-full{grid-column:1 / -1}.tbl-cards td.tc-actions{position:absolute;top:12px;right:14px;padding:0}.tbl-cards td:empty{display:none}}@media (max-width: 640px){.tbl-cards td.tc-full:first-child{padding-right:44px}}.auth-copyright{margin-top:16px;text-align:center;font-size:.76rem;color:var(--muted);letter-spacing:.02em}.sim-shell{min-height:100dvh;display:flex;flex-direction:column;background:var(--vapor, #f4f6f8)}.sim-top{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 20px;background:var(--graphite)}.sim-top .eyebrow{color:#ffffff9e}.sim-top select{background:#ffffff1a;color:#fff;border-color:#ffffff47}.sim-body{flex:1;display:flex;justify-content:center;align-items:stretch;gap:20px;padding:20px}.sim-cabinet{flex:0 1 auto;background:var(--surface);border:1px solid var(--mist);border-radius:var(--r-lg);padding:20px;display:flex;flex-direction:column}.sim-cabinet .cabinet-scale{margin:auto}.sim-cabinet-head{display:flex;flex-direction:column;gap:4px;margin-bottom:14px}.sim-hint{font-size:.8rem;color:var(--muted)}.sim-panel{flex:0 0 400px;width:400px;display:flex;flex-direction:column;gap:16px}.sim-card{background:var(--surface);border:1px solid var(--mist);border-radius:var(--r-lg);padding:16px;display:flex;flex-direction:column;gap:9px}.sim-door-state{display:inline-flex;align-items:center;gap:8px;font-size:.9rem;color:var(--slate)}.sim-dot{width:9px;height:9px;border-radius:50%;flex:none}.sim-dot.is-open{background:var(--steel);box-shadow:0 0 0 3px var(--steel-tint)}.sim-dot.is-closed{background:var(--mist)}.sim-log{display:flex;flex-direction:column;gap:2px;max-height:340px;overflow-y:auto}.sim-log-row{display:grid;grid-template-columns:12px 54px 1fr auto auto;align-items:center;gap:8px;padding:6px 2px;font-size:.8rem;border-bottom:1px solid var(--mist-2)}.sim-log-row:last-child{border-bottom:none}.sim-log-ev{color:var(--graphite);font-weight:600}.sim-log-src{color:var(--muted);font-size:.72rem}.sim-log-at{color:var(--muted);font-variant-numeric:tabular-nums;font-size:.72rem}.locker-door.scaled.door-open{border-color:var(--steel);box-shadow:0 0 0 2px var(--steel-tint),4px 4px 12px #00000024;transform:perspective(400px) rotateY(-16deg);transform-origin:left center;position:relative;z-index:2}.locker-door.scaled.door-open .ld-ajar{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;background:repeating-linear-gradient(45deg,transparent,transparent 5px,rgba(249,115,22,.1) 5px,rgba(249,115,22,.1) 10px);pointer-events:none}@media (max-width: 860px){.sim-body{flex-direction:column;align-items:stretch}.sim-cabinet{max-width:none}.sim-panel{flex:none;width:100%}}.sim-toggle{display:flex;gap:3px;background:var(--mist-2);border-radius:11px;padding:3px}.sim-toggle button{flex:1;padding:8px;border-radius:9px;font-size:.86rem;font-weight:600;color:var(--slate);background:transparent;cursor:pointer;border:none}.sim-toggle button.on{background:var(--surface);color:var(--graphite);box-shadow:var(--shadow-sm)}.sim-kiosk{display:flex;flex-direction:column}.kiosk.kiosk-embedded{min-height:0;background:transparent;padding:0}.kiosk.kiosk-embedded .kiosk-card{max-width:100%}.kiosk.kiosk-embedded>p,.kiosk.kiosk-embedded .powered-by{display:none}.auth2{min-height:100dvh;display:grid;grid-template-columns:1.05fr .95fr;background:var(--surface)}.auth2-brand{position:relative;overflow:hidden;display:flex;flex-direction:column;justify-content:space-between;padding:44px 48px;background:var(--graphite);color:#fff;background-image:linear-gradient(0deg,#00000047,#0000 55%),repeating-linear-gradient(90deg,rgba(255,255,255,.035) 0 1px,transparent 1px 88px),repeating-linear-gradient(0deg,rgba(255,255,255,.035) 0 1px,transparent 1px 64px)}.auth2-brand-glow{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background:radial-gradient(680px 420px at 118% -8%,rgba(249,115,22,.42),transparent 60%),radial-gradient(520px 360px at -10% 115%,rgba(249,115,22,.16),transparent 60%)}.auth2-brand-top,.auth2-brand-mid,.auth2-brand-foot{position:relative;z-index:1}.auth2-brand-mid{display:flex;flex-direction:column;gap:18px;max-width:440px}.auth2-brand-title{font-size:2.1rem;line-height:1.14;font-weight:600;letter-spacing:-.02em;color:#fff;margin:0}.auth2-brand-sub{font-size:1.02rem;line-height:1.55;color:#ffffffb8;margin:0}.auth2-points{list-style:none;margin:10px 0 0;padding:0;display:flex;flex-direction:column;gap:12px}.auth2-points li{display:flex;align-items:center;gap:12px;font-size:.95rem;color:#ffffffe6}.auth2-check{flex:none;width:24px;height:24px;border-radius:8px;display:grid;place-items:center;background:var(--steel);color:#fff}.auth2-brand-foot{font-size:.8rem;color:#ffffff80;letter-spacing:.02em}.auth2-form{display:flex;align-items:center;justify-content:center;padding:40px 28px;background:radial-gradient(700px 420px at 120% -20%,var(--steel-tint),transparent 62%),var(--surface)}.auth2-form-inner{width:100%;max-width:384px;display:flex;flex-direction:column;gap:22px}.auth2-mark{display:none}.auth2-head{display:flex;flex-direction:column;gap:6px}.auth2-head h1{font-size:1.7rem;letter-spacing:-.015em}.auth2-head p{color:var(--muted);font-size:.92rem;margin:0}.auth2-field{display:flex;flex-direction:column;gap:7px}.auth2-field label{font-size:.8rem;font-weight:600;color:var(--slate)}.auth2-input{display:flex;align-items:center;gap:10px;height:48px;padding:0 12px;border:1px solid var(--mist);border-radius:12px;background:var(--surface-2);transition:border-color .15s ease,box-shadow .15s ease,background .15s ease}.auth2-input:focus-within{border-color:var(--steel);background:var(--surface);box-shadow:0 0 0 4px var(--steel-tint)}.auth2-input-ico{color:var(--muted);display:grid;place-items:center;flex:none}.auth2-input:focus-within .auth2-input-ico{color:var(--steel-deep)}.auth2-input input{flex:1;align-self:stretch;height:100%;width:100%;margin:0;padding:0;border:none;border-radius:0;background:transparent;outline:none;box-shadow:none;-webkit-appearance:none;-moz-appearance:none;appearance:none;font-size:1rem;color:var(--graphite);min-width:0}.auth2-input input::placeholder{color:var(--muted)}.auth2-eye{flex:none;border:none;background:transparent;color:var(--muted);cursor:pointer;display:grid;place-items:center;padding:4px;border-radius:8px}.auth2-eye:hover{color:var(--graphite)}.auth2-foot-copy{display:none;text-align:center;font-size:.76rem;color:var(--muted);margin:4px 0 0}@media (max-width: 860px){.auth2{grid-template-columns:1fr}.auth2-brand{display:none}.auth2-mark{display:flex;justify-content:center;margin-bottom:2px}.auth2-head{align-items:center;text-align:center}.auth2-foot-copy{display:block}}
