:root{
  --bg:#eef3f8;
  --panel:#ffffff;
  --panel-soft:#f7fafc;
  --text:#14263a;
  --muted:#64778a;
  --line:#d8e2ec;
  --nav:#0f2238;
  --nav-2:#16304c;
  --gold:#f2c14f;
  --gold-2:#dca739;
  --green:#0c8f65;
  --red:#cb4f4f;
  --blue:#2f6fb2;
  --orange:#d98b2b;
  --shadow:0 12px 30px rgba(17,38,62,.08);
  --font:"Aptos","Segoe UI",Arial,sans-serif;
  --display:"Bahnschrift","Aptos","Segoe UI",Arial,sans-serif;
}
*{box-sizing:border-box}
html{scrollbar-gutter:stable}
body{margin:0;background:var(--bg);color:var(--text);font-family:var(--font);font-size:13px;line-height:1.35}
a{color:inherit}
.login-page{min-height:100vh;background:linear-gradient(135deg,#0f2238 0%,#16304c 48%,#eef3f8 48%,#eef3f8 100%)}
.login-shell{min-height:100vh;display:grid;place-items:center;padding:18px}
.login-panel{width:min(420px,100%);display:grid;gap:18px;padding:22px;border:1px solid rgba(216,226,236,.88);border-radius:8px;background:#fff;box-shadow:0 28px 70px rgba(17,38,62,.24)}
.login-brand{display:flex;align-items:center;gap:12px}
.login-brand img{width:46px;height:46px;border-radius:8px;object-fit:contain;border:1px solid var(--line);padding:4px;background:#fff}
.login-brand strong{display:block;font:850 18px/1.1 var(--display);color:var(--text)}
.login-brand span{display:block;margin-top:4px;color:var(--muted);font-size:11px;letter-spacing:.1em;text-transform:uppercase;font-weight:850}
.login-copy h1{font:850 28px/1.05 var(--display);margin:0;color:var(--text)}
.login-copy p{margin-top:8px}
.login-form{display:grid;gap:12px}
.login-form button{width:100%;min-height:42px;font-size:13px}
.app-shell{display:grid;grid-template-columns:276px minmax(0,1fr);min-height:100vh}
.app-shell.collapsed{grid-template-columns:92px minmax(0,1fr)}
.sidebar{position:sticky;top:0;height:100vh;overflow:auto;background:linear-gradient(180deg,var(--nav),var(--nav-2));color:#fff;padding:14px;border-right:1px solid rgba(255,255,255,.08)}
.brand{display:flex;align-items:center;gap:10px;min-height:58px;padding:10px;border:1px solid rgba(255,255,255,.1);border-radius:8px;background:rgba(255,255,255,.06)}
.brand img{width:36px;height:36px;border-radius:8px;background:#fff;padding:3px;object-fit:contain}
.brand strong{display:block;font:800 15px/1.1 var(--display)}
.brand span{display:block;margin-top:3px;font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.68);font-weight:750}
.nav-section{margin-top:14px}
.nav-title{margin:0 0 7px 8px;font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.58);font-weight:750}
.nav-card{display:grid;gap:6px;padding:8px;border:1px solid rgba(255,255,255,.08);border-radius:8px;background:rgba(255,255,255,.04)}
.nav-link{display:grid;grid-template-columns:32px minmax(0,1fr);align-items:center;gap:10px;min-height:48px;padding:8px 10px;border-radius:10px;color:rgba(255,255,255,.9);text-decoration:none;border:1px solid transparent;transition:background .16s ease,border-color .16s ease,transform .16s ease}
.nav-link:hover{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.08);transform:translateX(2px)}
.nav-link.active{background:rgba(242,193,79,.18);box-shadow:inset 0 0 0 1px rgba(242,193,79,.24);border-color:rgba(242,193,79,.18);color:#fff}
.nav-icon{position:relative;display:block;width:32px;height:32px;border-radius:10px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.08)}
.nav-icon:before{content:"";position:absolute;inset:9px;border-radius:999px;background:currentColor;opacity:.92}
.nav-text{display:grid;gap:2px;min-width:0}
.nav-label{display:block;font-size:13px;font-weight:800;line-height:1.15;color:#fff}
.nav-desc{display:block;font-size:11px;color:rgba(255,255,255,.62);line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tone-gold{color:#f2c14f}.tone-blue{color:#7fb6ff}.tone-green{color:#6dd3ad}
.userbox{display:grid;gap:8px;padding:8px;border:1px solid rgba(255,255,255,.08);border-radius:8px;background:rgba(255,255,255,.04)}
.userbox strong{font-size:13px;color:#fff}.userbox span{color:rgba(255,255,255,.62);font-size:12px;font-weight:750}
.userbox a{color:#fff;text-decoration:none;font-weight:800;padding:9px 10px;border-radius:8px;background:rgba(255,255,255,.07);border:1px solid transparent}
.userbox a:hover{border-color:rgba(242,193,79,.28);background:rgba(242,193,79,.14)}
.content{min-width:0;padding:14px 16px;max-width:1480px;width:100%;margin:0 auto}
.app-topbar{display:flex;align-items:center;gap:8px;margin-bottom:12px}
.icon-btn{display:grid;place-items:center;width:38px;height:38px;border:1px solid var(--line);border-radius:8px;background:#fff;color:var(--text);cursor:pointer;font-weight:800;box-shadow:0 4px 12px rgba(17,38,62,.04)}
.env-chip{display:flex;align-items:center;gap:8px;min-height:38px;padding:0 12px;border:1px solid var(--line);border-radius:8px;background:#fff;color:var(--muted);font-size:12px;font-weight:700}
.env-chip:before{content:"";width:8px;height:8px;border-radius:999px;background:var(--green);box-shadow:0 0 0 3px rgba(12,143,101,.12)}
.topbar{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:14px;align-items:end;padding:16px;margin-bottom:10px;border:1px solid var(--line);border-radius:8px;background:linear-gradient(135deg,#fff,#f8fbfd);box-shadow:var(--shadow)}
.update-widget{display:flex;align-items:center;gap:10px;justify-content:flex-end;flex-wrap:wrap}
.update-status{display:grid;grid-template-columns:auto auto;gap:2px 7px;align-items:center;min-height:38px;padding:7px 10px;border:1px solid var(--line);border-radius:8px;background:#fff;color:var(--muted);font-size:11px;font-weight:800}
.update-status strong{grid-column:2;font-size:12px;color:var(--text);white-space:nowrap}
.status-dot{display:inline-block;width:9px;height:9px;border-radius:999px;background:#a8b5c3;box-shadow:0 0 0 3px rgba(100,119,138,.12)}
.status-dot.ok,.status-dot.success{background:var(--green);box-shadow:0 0 0 3px rgba(12,143,101,.13)}
.status-dot.error{background:var(--red);box-shadow:0 0 0 3px rgba(203,79,79,.13)}
.status-dot.running{background:var(--gold-2);box-shadow:0 0 0 3px rgba(220,167,57,.16);animation:pulse 1s ease-in-out infinite}
.status-dot.pending{background:#a8b5c3}
h1{margin:0;font:800 25px/1.08 var(--display);letter-spacing:0}
h2{margin:0 0 12px;font-size:15px;color:var(--text)}
p{color:var(--muted);font-weight:650;margin:8px 0 0}
.panel{background:var(--panel);border:1px solid var(--line);border-radius:8px;padding:16px;margin-bottom:10px;box-shadow:var(--shadow)}
.operations-panel{display:grid;gap:14px}
.section-head{display:flex;align-items:flex-end;justify-content:space-between;gap:12px}
.section-head h2{margin:0}
.section-head p{margin-top:5px}
.operation-chip{display:inline-flex;align-items:center;min-height:32px;padding:0 10px;border:1px solid var(--line);border-radius:8px;background:var(--panel-soft);color:var(--muted);font-size:11px;font-weight:850;white-space:nowrap}
.form-grid{display:grid;grid-template-columns:minmax(180px,280px) minmax(220px,360px) 150px;gap:10px;align-items:end}
.form-grid.single{grid-template-columns:minmax(220px,420px) 150px}
.form-grid.two{grid-template-columns:repeat(2,minmax(0,1fr));align-items:start}
.operation-form{padding:12px;border:1px solid #edf2f7;border-radius:8px;background:linear-gradient(180deg,#fff,#f8fbfd)}
.operation-grid{grid-template-columns:minmax(220px,420px) 170px 180px}
.quick-stats{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}
.quick-stats div{display:grid;grid-template-columns:30px minmax(0,1fr);gap:8px;align-items:center;padding:10px;border:1px solid var(--line);border-radius:8px;background:var(--panel-soft)}
.quick-stats strong{display:grid;place-items:center;width:30px;height:30px;border-radius:8px;background:#fff;color:var(--blue);border:1px solid #dbe7f3;font-size:14px}
.quick-stats span{color:var(--muted);font-size:12px;font-weight:750;line-height:1.25}
label span,.plate-form label>span{display:block;color:var(--muted);font-size:10px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;margin-bottom:6px}
input,select{width:100%;height:38px;background:#fff;border:1px solid var(--line);border-radius:8px;color:var(--text);padding:0 10px;font-size:13px;font-weight:650;min-width:0}
input[name="plate"]{text-transform:uppercase;font-size:17px;font-weight:850;letter-spacing:0}
input:focus,select:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(47,111,178,.14)}
button,.btn-link{border:1px solid transparent;border-radius:8px;background:linear-gradient(180deg,var(--gold),var(--gold-2));color:#2a2109;font-weight:800;padding:0 13px;cursor:pointer;min-height:38px;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;gap:8px;font-size:12px;white-space:nowrap}
.btn-link.secondary{background:#fff;color:var(--text);border-color:var(--line)}
.success-btn{background:linear-gradient(180deg,#15a171,var(--green));color:white}
.paid-btn{background:linear-gradient(180deg,#3f7fbe,var(--blue));color:white}
.tag{display:inline-flex;align-items:center;min-height:24px;padding:0 9px;border-radius:999px;background:#eef3f8;color:var(--text);font-size:10px;font-weight:800;line-height:1;margin:0 6px 8px 0}
.tag.soft{background:#fff4d8;color:#8f6500}
.table-wrap,.modal-table{overflow:auto;max-width:100%;-webkit-overflow-scrolling:touch;scrollbar-gutter:stable}
table{width:100%;border-collapse:collapse;table-layout:auto}
th,td{padding:8px 9px;border-bottom:1px solid #edf2f7;font-size:12px;text-align:left;vertical-align:middle;line-height:1.25}
th{position:sticky;top:0;background:#f8fafc;color:var(--muted);font-size:10px;letter-spacing:.04em;text-transform:uppercase;font-weight:750;white-space:nowrap;z-index:1}
tbody tr:hover{background:#fbfdff}
.right{text-align:right}
.table-action{font-weight:800;color:var(--blue);text-decoration:none}
.alert{padding:10px 12px;border-radius:8px;margin-bottom:10px;font-weight:700}
.alert.error{background:#fdeeee;border:1px solid #f2c9c9;color:var(--red)}
.alert.success{background:#e8f7f1;border:1px solid #c8ecd9;color:var(--green)}
.admin-form{display:grid;gap:14px}
.checks,.post-grid{display:grid;gap:10px}
.stack-form{display:grid;gap:12px;margin-top:14px}
.post-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
.check-card{display:flex;gap:10px;align-items:center;padding:10px 11px;border:1px solid var(--line);border-radius:8px;background:var(--panel-soft);font-weight:750}
.check-card input{width:18px;height:18px;min-height:18px;accent-color:var(--gold-2)}
.check-card span{margin:0;color:var(--text);font-size:13px;text-transform:none;letter-spacing:0}
.sso-picker{display:grid;gap:12px}
.sso-picker-head{display:flex;align-items:flex-end;justify-content:space-between;gap:12px}
.sso-picker-head h2{margin:0}
.sso-user-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;max-height:460px;overflow:auto;padding-right:4px}
.sso-user-card{align-items:flex-start}
.sso-user-card span{display:grid;gap:3px;min-width:0}
.sso-user-card strong{font-size:13px;line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.sso-user-card small{font-size:11px;line-height:1.25;overflow-wrap:anywhere}
.empty-state{padding:14px;border:1px dashed var(--line);border-radius:8px;background:var(--panel-soft);color:var(--muted);font-weight:700}
.form-actions{display:flex;justify-content:flex-end;gap:8px;flex-wrap:wrap}
.modal-backdrop{position:fixed;inset:0;background:rgba(9,20,34,.56);backdrop-filter:blur(4px);display:none;align-items:center;justify-content:center;padding:18px;z-index:100}
.modal-backdrop.show{display:flex}
.modal-card{width:min(680px,100%);max-height:90vh;overflow:auto;background:#fff;border-radius:8px;border:1px solid var(--line);box-shadow:0 30px 60px rgba(0,0,0,.28);padding:20px;position:relative}
.result-card{border-left:5px solid var(--orange)}
.result-card.courtesy{border-left-color:var(--green)}
.result-card.paid{border-left-color:var(--gold)}
.result-card.error{border-left-color:var(--red)}
.paid-confirm-card{width:min(520px,100%);border-top:5px solid var(--blue)}
.paid-confirm-card h2{font:800 24px/1.1 var(--display);margin:0 38px 10px 0}
.payment-warning{display:block;margin-bottom:4px;color:var(--text);font-size:15px;line-height:1.25;font-weight:900}
.confirm-summary{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin:16px 0}
.confirm-summary div{padding:12px;border:1px solid var(--line);border-radius:8px;background:var(--panel-soft);min-width:0}
.confirm-summary span{display:block;margin-bottom:5px;color:var(--muted);font-size:10px;font-weight:850;letter-spacing:.08em;text-transform:uppercase}
.confirm-summary strong{display:block;color:var(--text);font-size:13px;line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.modal-close{position:absolute;top:10px;right:10px;width:34px;height:34px;min-height:34px;border-radius:8px;padding:0;background:#fff;color:var(--text);border-color:var(--line);font-size:20px}
.modal-table{margin:14px 0;border:1px solid var(--line);border-radius:8px}
.loading-card{text-align:center;width:min(380px,100%)}
.password-card{width:min(560px,100%);text-align:center;border-top:5px solid var(--gold)}
.password-kicker{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);font-weight:800;margin-bottom:8px}
.password-card h2{font:800 24px/1.1 var(--display);margin:0 0 12px}
.password-display{font:800 clamp(58px,12vw,112px)/1 var(--display);letter-spacing:.04em;color:var(--nav);padding:18px 12px;margin:12px 0 16px;border:1px dashed #c6d4e3;border-radius:8px;background:linear-gradient(135deg,#fff,#f8fbfd)}
.password-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:10px;margin:12px 0 16px}
.password-list-item{font:800 34px/1 var(--display);color:var(--nav);padding:14px 10px;border:1px dashed #c6d4e3;border-radius:8px;background:linear-gradient(135deg,#fff,#f8fbfd)}
.password-meta{display:grid;grid-template-columns:120px minmax(0,1fr);gap:10px;align-items:center;text-align:left;padding:12px 0;border-top:1px solid #edf2f7}
.password-meta span{font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);font-weight:800}
.password-meta strong{font-size:18px;color:var(--text)}
.spinner{width:44px;height:44px;border-radius:50%;border:5px solid #dbe3ef;border-top-color:var(--gold-2);margin:0 auto 14px;animation:spin .8s linear infinite}
.spinner.small{width:34px;height:34px;border-width:4px;margin:0}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes pulse{50%{transform:scale(1.18);box-shadow:0 0 0 5px rgba(220,167,57,.08)}}
.update-modal-card{width:min(560px,100%);border-top:5px solid var(--gold)}
.update-modal-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:8px}
.update-modal-head h2{font:800 22px/1.1 var(--display);margin:0}
.progress-track{height:10px;border-radius:999px;background:#e6edf5;overflow:hidden;margin:16px 0 12px}
.progress-fill{width:0;height:100%;border-radius:999px;background:linear-gradient(90deg,var(--gold-2),var(--green));transition:width .28s ease}
.update-pane{border:1px solid var(--line);border-radius:8px;background:var(--panel-soft);padding:12px;min-width:0}
.update-pane.visual-only{margin:0 0 14px}
.update-pane h3{margin:0 0 10px;font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted)}
.update-checklist{list-style:none;padding:0;margin:0;display:grid;gap:8px}
.update-check-item{display:grid;gap:4px;padding:9px;border:1px solid #e2eaf2;border-radius:8px;background:#fff}
.update-check-item>div{display:flex;align-items:center;gap:8px;min-width:0}
.update-check-item strong{font-size:12px;line-height:1.2}
.update-check-item small{padding-left:17px;font-size:11px;line-height:1.25}
.update-hint{margin-right:auto;color:var(--muted);font-size:12px;font-weight:800;align-self:center}
.station-body{min-height:100vh;display:grid;place-items:center;padding:20px;background:var(--bg)}
.station-card{width:min(520px,100%);background:#fff;border:1px solid var(--line);border-radius:8px;padding:28px;box-shadow:var(--shadow)}
.station-logo{width:118px;display:block;margin:0 auto 18px}
.station-card h1{text-align:center}
.station-card p{text-align:center}
.station-card button{width:100%;margin-top:18px}
.station-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin:18px 0}
.station-option{cursor:pointer}
small{color:var(--muted);font-weight:700}
.overlay{display:none}
.app-shell.collapsed .brand-text,.app-shell.collapsed .nav-title,.app-shell.collapsed .nav-text,.app-shell.collapsed .userbox strong,.app-shell.collapsed .userbox span{display:none}
.app-shell.collapsed .sidebar{padding:14px 10px}
.app-shell.collapsed .brand{justify-content:center}
.app-shell.collapsed .nav-card{gap:10px;padding:0;border:0;background:transparent}
.app-shell.collapsed .nav-link{position:relative;grid-template-columns:1fr;justify-items:center;width:56px;min-height:56px;padding:0;margin:0 auto;border-radius:18px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08)}
.app-shell.collapsed .nav-link::after{content:attr(aria-label);position:absolute;left:calc(100% + 12px);top:50%;transform:translateY(-50%);padding:8px 11px;border-radius:12px;background:rgba(11,22,37,.94);color:#fff;font-size:11px;font-weight:800;white-space:nowrap;opacity:0;pointer-events:none;box-shadow:0 14px 28px rgba(0,0,0,.26)}
.app-shell.collapsed .nav-link:hover::after{opacity:1}
@media (max-width:900px){
  .app-shell{grid-template-columns:1fr}
  .sidebar{position:fixed;left:0;top:0;bottom:0;width:286px;z-index:40;transform:translateX(-100%);transition:.18s ease;box-shadow:0 20px 48px rgba(0,0,0,.24)}
  .app-shell.mobile-open .sidebar{transform:translateX(0)}
  .overlay{position:fixed;inset:0;background:rgba(0,0,0,.35);z-index:30}
  .app-shell.mobile-open .overlay{display:block}
  .desktop-only{display:none}
  .content{padding:12px}
  .topbar{grid-template-columns:1fr}
  .section-head{display:grid;align-items:start}
  .update-widget{justify-content:stretch}
  .update-widget>*{flex:1}
  .form-grid,.form-grid.single,.form-grid.two,.operation-grid,.quick-stats,.post-grid,.station-list,.sso-user-grid{grid-template-columns:1fr}
  .confirm-summary{grid-template-columns:1fr}
  .form-actions{justify-content:stretch}
  .form-actions>*{flex:1}
  table{min-width:720px}
  .password-meta{grid-template-columns:1fr;text-align:center}
}
@media (max-width:540px){
  .content{padding:10px}
  .topbar{padding:13px}
  h1{font-size:22px}
}
