:root{
  --bg:#f3f6fb;
  --surface:#ffffff;
  --surface-2:#f7f9fd;
  --text:#111827;
  --muted:#667085;
  --line:#e5eaf2;
  --primary:#2864ff;
  --primary-dark:#174fe0;
  --ok:#17a672;
  --danger:#ef4056;
  --warning:#f59e0b;
  --ink:#101828;
  --sidebar:#101828;
  --sidebar-2:#172033;
  --shadow:0 12px 34px rgba(16,24,40,.07);
}
*{box-sizing:border-box}
body{margin:0;font-family:"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;background:var(--bg);color:var(--text);font-weight:400}
a{color:inherit;text-decoration:none}
button,input,select,textarea{font:inherit;max-width:100%}
button{cursor:pointer}
.hidden,[hidden]{display:none!important}

.btn{border:0;border-radius:4px;min-height:36px;padding:9px 13px;font-weight:600;display:inline-flex;align-items:center;justify-content:center;white-space:nowrap}
.btn.primary{background:var(--primary);color:#fff;box-shadow:0 8px 16px rgba(40,100,255,.16)}.btn.primary:hover{background:var(--primary-dark)}
.btn.secondary{background:#fff;border:1px solid var(--line);color:var(--text)}.btn.ghost{background:transparent;border:1px solid rgba(255,255,255,.35);color:#dbe8e2}
.badge{display:inline-flex;width:max-content;border:1px solid #b7ddd1;background:#eff8f5;color:#075f52;border-radius:4px;padding:5px 9px;font-size:12px;font-weight:600}

.login-screen{position:fixed;inset:0;z-index:50;display:none;grid-template-columns:1fr minmax(360px,460px);background:#edf4f1}
.login-screen.active{display:grid}
.login-visual{background:linear-gradient(160deg,#0f231d,#0b6f5e);color:#fff;padding:8vw;display:flex;flex-direction:column;justify-content:center;gap:22px}
.brand-mark{width:62px;height:62px;border-radius:14px;background:#fff;color:#0b6f5e;display:grid;place-items:center;font-size:32px;font-weight:650;background-size:contain;background-position:center;background-repeat:no-repeat}.brand-mark.has-image{color:transparent}
.login-visual h1{font-size:clamp(42px,7vw,76px);line-height:1;margin:0;font-weight:650}.login-visual p{font-size:20px;line-height:1.55;color:#dbe8e2;max-width:650px}
.login-stats{display:flex;gap:12px;flex-wrap:wrap}.login-stats span{border:1px solid rgba(255,255,255,.2);border-radius:8px;padding:12px 14px;color:#dbe8e2}.login-stats b{display:block;color:#fff}
.login-panel{background:#fff;margin:auto;width:min(390px,calc(100% - 32px));border:1px solid var(--line);border-radius:6px;box-shadow:var(--shadow);padding:28px;display:grid;gap:14px}
.login-panel h2{font-size:30px;margin:0;font-weight:650}.login-panel label,.modal-card label,.stack-form label{display:grid;gap:6px;color:var(--muted);font-size:13px;font-weight:600}
.login-panel input,.modal-card input,.modal-card select,.modal-card textarea,.stack-form input,.stack-form select,.search-input,.compact-select,.table-input{width:100%;border:1px solid var(--line);border-radius:4px;background:#fff;min-height:38px;padding:9px 12px;outline:0}
.checkin-keypad{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.checkin-keypad button{border:1px solid #d5e4de;background:linear-gradient(180deg,#fff,#f4f8f6);border-radius:18px;min-height:64px;font-size:26px;font-weight:650;color:var(--text);box-shadow:0 8px 18px rgba(16,35,29,.08);transition:transform .14s ease,box-shadow .14s ease,background .14s ease,border-color .14s ease}.checkin-keypad button:hover,.checkin-keypad button:focus{border-color:var(--primary);background:#eef8f4;box-shadow:0 12px 22px rgba(8,122,104,.14);transform:translateY(-1px)}.checkin-keypad button:active,.checkin-keypad button.pressed{transform:scale(.96);box-shadow:inset 0 4px 12px rgba(16,35,29,.14)}.checkin-keypad .key-enter{background:linear-gradient(180deg,#316cff,#1e56f0);border-color:#1e56f0;color:#fff;font-size:16px;font-weight:650}.checkin-keypad .key-cancel{background:linear-gradient(180deg,#fff6f5,#ffe8e6);border-color:#f0c5c1;color:#9f2f2f;font-size:16px;font-weight:650}
input:focus,select:focus,textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(8,122,104,.14)}

.app-shell{min-height:100vh;display:grid;grid-template-columns:236px 1fr;background:var(--bg)}
.sidebar{position:sticky;top:0;height:100vh;background:var(--sidebar);color:#eef4ff;padding:16px 12px;display:flex;flex-direction:column;gap:16px;border-right:0;overflow:hidden}
.brand{display:flex;align-items:center;gap:10px;font-size:17px;font-weight:650}.side-brand{height:44px;padding:0 6px;color:#fff}.brand-icon{width:32px;height:32px;border-radius:7px;background:linear-gradient(135deg,#2f6bff,#7c9dff);color:#fff;display:grid;place-items:center;font-weight:650;background-size:contain;background-position:center;background-repeat:no-repeat}.brand-icon.has-image{background-color:#fff;background-image:var(--brand-logo);color:transparent}
.quick-action{border:0;border-radius:6px;background:#2864ff;color:#fff;padding:11px 12px;text-align:center;font-weight:600;box-shadow:0 8px 20px rgba(40,100,255,.22)}.quick-action:hover{background:#1d55e8}
.side-nav{display:grid;gap:4px;min-height:0;overflow:auto;padding-right:2px}.side-nav button{border:0;background:transparent;color:#b7c2d6;text-align:left;border-radius:7px;padding:10px 12px;font-weight:500}.side-nav button.active,.side-nav button:hover{background:var(--sidebar-2);color:#fff}.side-nav .has-subnav{display:flex;align-items:center;justify-content:space-between;gap:8px}.subnav-arrow{font-size:18px;line-height:1;transition:transform .18s ease}.side-nav .has-subnav.open .subnav-arrow{transform:rotate(90deg)}.side-nav .side-logout{margin-top:8px;border-top:1px solid rgba(255,255,255,.1);border-radius:0;padding-top:14px;color:#fff}.side-nav .side-logout:hover{background:transparent;color:#fca5a5}.side-subnav{display:grid;gap:2px;margin:-2px 0 4px 14px;padding-left:10px;border-left:1px solid rgba(255,255,255,.12)}.side-subnav.collapsed{display:none}.side-subnav button{padding:7px 9px;font-size:12px;color:#98a6bd}.side-subnav button.active,.side-subnav button:hover{background:rgba(255,255,255,.06);color:#fff}
.side-footer{margin-top:auto;border-top:1px solid rgba(255,255,255,.1);padding-top:9px;display:grid;gap:4px;flex-shrink:0}.side-footer strong{font-size:12px;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.side-footer span{font-size:10px;line-height:1.2;color:#98a6bd;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.side-footer .btn{min-height:26px;padding:5px 8px;font-size:11px}
.workspace{min-width:0;padding:22px 26px 30px}.workspace-top{height:58px;display:flex;align-items:center;justify-content:space-between;gap:16px;margin:-22px -26px 18px;padding:0 26px;background:#fff;border-bottom:1px solid var(--line)}.workspace-top h1{margin:0;font-size:20px;line-height:1;font-weight:650}.workspace-top p{margin:5px 0 0;color:var(--muted);font-size:12px}
.icon-btn{display:none;border:1px solid var(--line);background:#fff;border-radius:6px;min-height:36px;padding:0 12px;font-weight:600}.compact-select{width:auto;min-width:220px;background:#f8fafc}
.view{display:none}.view.active{display:block}
.app-version{position:fixed;right:10px;bottom:8px;z-index:10;color:#98a2b3;font-size:10px;font-weight:600;letter-spacing:0;opacity:.55;pointer-events:none}

.panel,.kpi,.checkin-box{background:var(--surface);border:1px solid var(--line);border-radius:8px;box-shadow:var(--shadow)}
.panel{padding:16px;overflow:hidden}.panel-title{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}.panel-title h2{margin:0;font-size:15px;font-weight:650;color:#1d2939}
.kpi-grid,.finance-head{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin-bottom:12px}.finance-head{grid-template-columns:repeat(5,minmax(0,1fr))}
.kpi{min-height:112px;padding:16px;position:relative;overflow:hidden}.kpi:after{content:"";position:absolute;right:14px;top:14px;width:30px;height:30px;border-radius:50%;background:#eef3ff}.kpi small{display:block;color:var(--muted);font-size:12px;font-weight:600;margin-bottom:10px}.kpi strong{display:block;font-size:clamp(22px,2.4vw,28px);font-weight:700;line-height:1.1}.kpi span{display:block;margin-top:8px;color:#16a069;font-size:12px;font-weight:600}.kpi.ok strong{color:var(--ok)}.kpi.danger strong{color:var(--danger)}.kpi-blue:after{background:#eef3ff}.kpi-red:after{background:#fff0f3}.kpi-amber:after{background:#fff7e8}.kpi-green:after{background:#eafaf3}.kpi-red span{color:var(--danger)}.kpi-amber span{color:#d97706}
.kpi-strip{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin-bottom:14px}.kpi-strip article{background:#fff;border:1px solid var(--line);border-radius:8px;padding:12px 14px;box-shadow:0 8px 22px rgba(16,24,40,.04)}.kpi-strip small{display:block;color:var(--muted);font-size:12px;margin-bottom:5px}.kpi-strip strong{font-size:18px}
.dashboard-grid{display:grid;grid-template-columns:minmax(0,1.35fr) minmax(280px,.75fr);gap:14px;align-items:start}
.bar-chart{height:286px;border:0;border-radius:0;padding:8px 2px 0;display:flex;align-items:end;gap:10px;overflow:auto;background:linear-gradient(#fff,#fff),repeating-linear-gradient(to top,#eef2f7 0,#eef2f7 1px,transparent 1px,transparent 52px);background-blend-mode:normal}.bar-item{height:100%;min-width:42px;display:grid;grid-template-rows:18px 1fr 18px;gap:7px;text-align:center;font-size:11px;color:var(--muted)}.bar-item div{background:#eef3ff;border-radius:999px;display:flex;align-items:end;overflow:hidden}.bar-item i{display:block;width:100%;background:linear-gradient(180deg,#4d7cff,#2864ff);border-radius:999px 999px 0 0}
.checkin-evolution{min-height:220px;display:grid;align-content:start;gap:12px}.evolution-list{display:grid;gap:10px}.evolution-row{display:grid;grid-template-columns:72px 42px minmax(120px,1fr);gap:10px;align-items:center}.evolution-row span{font-size:12px;color:var(--muted);font-weight:600}.evolution-row strong{font-size:16px;color:var(--text);text-align:right}.evolution-row div{height:12px;background:#eef3ff;border-radius:999px;overflow:hidden}.evolution-row i{display:block;height:100%;background:linear-gradient(90deg,#2864ff,#5f88ff);border-radius:999px}.evolution-summary{display:flex;justify-content:space-between;gap:12px;border-top:1px solid var(--line);padding-top:12px;color:var(--muted);font-size:13px}.evolution-summary strong{color:var(--text)}
.finance-chart{height:238px;border:0;border-radius:0;padding:4px 0;display:grid;align-content:start;gap:12px;overflow:auto}.finance-row{display:grid;grid-template-columns:38px 1fr;gap:10px;align-items:center;font-size:12px;color:var(--muted)}.finance-row div{display:grid;gap:4px}.finance-row i{height:9px;border-radius:999px;display:block}.finance-row .income{background:var(--ok)}.finance-row .expense{background:var(--danger)}
.donut-card{min-height:286px;display:grid;place-items:center;gap:14px;align-content:center}.donut{width:152px;height:152px;border-radius:50%;display:grid;place-items:center;position:relative}.donut:after{content:"";position:absolute;inset:27px;background:#fff;border-radius:50%;box-shadow:inset 0 0 0 1px var(--line)}.donut span{position:relative;z-index:1;font-size:22px;font-weight:750;color:#1d2939}.donut-legend{width:100%;display:grid;gap:8px}.donut-legend div{display:grid;grid-template-columns:12px 1fr auto;gap:8px;align-items:center;font-size:12px;color:var(--muted)}.donut-legend i{width:9px;height:9px;border-radius:50%}.donut-legend .blue{background:#2864ff}.donut-legend .red{background:#ff4d61}.donut-legend .gray{background:#8a94a6}.donut-legend .pink{background:#ec4899}.donut-legend .amber{background:#f59e0b}.donut-legend b{color:#1d2939}
.ranking-list{display:grid;gap:7px}.ranking-list div{display:grid;grid-template-columns:30px 1fr auto;gap:10px;align-items:center;border:1px solid var(--line);border-radius:7px;padding:10px;background:#fff}.ranking-list span{width:24px;height:24px;border-radius:7px;display:grid;place-items:center;background:#eef3ff;color:var(--primary);font-weight:700}.ranking-list em{font-style:normal;color:var(--muted);font-weight:500;font-size:12px}

.section-toolbar{display:flex;justify-content:space-between;gap:12px;margin-bottom:12px}.search-input{max-width:460px}.report-filters{display:flex;align-items:end;gap:10px;flex-wrap:wrap}.report-filters label{display:grid;gap:6px;color:var(--muted);font-size:13px;font-weight:600}.report-filters input{border:1px solid var(--line);border-radius:4px;background:#fff;min-height:38px;padding:9px 12px}
.content-grid{display:grid;grid-template-columns:minmax(300px,380px) minmax(0,1fr);gap:14px;align-items:start}.tools-grid{display:grid;grid-template-columns:1fr;gap:14px}.config-tabs{width:max-content;margin-bottom:12px}.config-panel{display:none}.config-panel.active{display:block}.logo-preview{min-height:150px;border:1px dashed var(--line);border-radius:8px;background:#f8fafc;display:grid;place-items:center}.logo-preview span{width:92px;height:92px;border-radius:18px;background:linear-gradient(135deg,#2f6bff,#7c9dff);color:#fff;display:grid;place-items:center;font-size:40px;font-weight:750;background-size:contain;background-position:center;background-repeat:no-repeat}.logo-preview span.has-image{background-color:#fff;color:transparent}
.stack-form{display:grid;gap:12px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}.inline-form{display:flex;gap:8px;margin-bottom:12px}.inline-form input{flex:1;border:1px solid var(--line);border-radius:8px;padding:10px 12px}
.field-action{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px;align-items:center}.field-action .btn{white-space:nowrap;min-height:38px}
.table-wrap{overflow:auto;border:1px solid var(--line);border-radius:4px}table{width:100%;border-collapse:collapse;background:#fff}th,td{text-align:left;padding:11px 12px;border-bottom:1px solid var(--line);font-size:13px;vertical-align:middle}th{font-size:11px;text-transform:uppercase;color:#344054;background:#fff;letter-spacing:.02em;font-weight:600}td small{display:block;color:var(--muted);margin-top:4px}
.status{display:inline-flex;padding:4px 8px;border-radius:4px;font-size:12px;font-weight:600;background:#f0f3f6;color:var(--muted)}.status.active{background:#e8f8ef;color:#08724e}.status.overdue,.status.inactive{background:#fff0ef;color:#a73030}
.table-actions{display:flex;gap:6px;flex-wrap:wrap}.table-actions button{border:1px solid var(--line);background:#fff;border-radius:4px;min-height:30px;padding:6px 8px;font-size:12px;font-weight:600}.table-input{min-height:32px;padding:6px 8px}
.finance-table{table-layout:fixed}.finance-table th,.finance-table td{vertical-align:middle}.finance-table th:nth-child(1){width:10%}.finance-table th:nth-child(2){width:25%}.finance-table th:nth-child(3){width:22%}.finance-table th:nth-child(4){width:10%}.finance-table th:nth-child(5){width:14%}.finance-table th:nth-child(6){width:9%}.finance-table th:nth-child(7){width:10%}.finance-table td:nth-child(2),.finance-table td:nth-child(3){line-height:1.25}.finance-table .table-actions{flex-wrap:nowrap;white-space:nowrap}.finance-table .table-input{min-width:120px}.action-select{border:1px solid var(--line);background:#fff;border-radius:4px;min-height:32px;padding:6px 8px;font-size:12px;font-weight:700;max-width:92px}
.students-table-wrap{overflow:visible}.students-table{table-layout:fixed}.students-table th,.students-table td{padding:7px 8px;font-size:12px;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.students-table th{font-size:9px}.students-table th:nth-child(1){width:8%}.students-table th:nth-child(2){width:28%}.students-table th:nth-child(3){width:5%}.students-table th:nth-child(4){width:12%}.students-table th:nth-child(5){width:15%}.students-table th:nth-child(6){width:14%}.students-table th:nth-child(7){width:13%}.students-table th:nth-child(8){width:5%}.students-table .status{padding:3px 7px;font-size:11px}.students-table td.table-actions{overflow:visible;text-align:center}.action-menu-wrap{position:relative;display:inline-flex}.action-plus{width:26px;height:26px;min-height:26px;padding:0;border:1px solid var(--line);border-radius:4px;background:#fff;color:var(--primary);font-size:18px;font-weight:750;line-height:1;display:grid;place-items:center}.action-menu{display:none;position:absolute;right:0;top:30px;z-index:20;min-width:142px;background:#fff;border:1px solid var(--line);border-radius:6px;box-shadow:0 12px 30px rgba(16,24,40,.14);padding:5px}.action-menu.open{display:grid}.action-menu button{min-height:0;border:0;background:#fff;text-align:left;border-radius:4px;padding:7px 9px;font-size:12px;font-weight:600;color:var(--text)}.action-menu button:hover{background:#f3f6fb}
.pagination-bar{display:flex;align-items:center;justify-content:flex-end;gap:10px;padding:12px;border:1px solid var(--line);border-top:0;border-radius:0 0 4px 4px;background:#fff}.pagination-bar span{color:var(--muted);font-size:13px;font-weight:600}.pagination-bar button:disabled{opacity:.45;cursor:not-allowed}
.segmented{display:flex;border:1px solid var(--line);border-radius:4px;overflow:hidden}.segmented button{border:0;background:#fff;padding:8px 11px;font-weight:600}.segmented button.active{background:#f0f3f7;color:#101828}
.mini-list{display:grid;gap:8px;margin-top:12px}.mini-list div{display:flex;justify-content:space-between;align-items:center;gap:8px;border:1px solid var(--line);border-radius:8px;padding:10px}.mini-list button{border:0;background:#fff0ef;color:#a73030;font-weight:600;border-radius:7px;padding:7px 9px}.empty,.empty-line{color:var(--muted);text-align:center;padding:24px!important}

.operator-checkin{min-height:calc(100vh - 116px);display:grid;grid-template-columns:minmax(360px,560px);justify-content:center;align-content:center;gap:14px}.checkin-box{padding:34px;text-align:center;border-radius:6px;background:#fff}.checkin-box h1{font-size:clamp(42px,5vw,68px);margin:14px 0 8px;letter-spacing:0;font-weight:650}.checkin-box p{color:var(--muted);line-height:1.5}.code-form{display:grid;gap:14px;margin-top:22px}.code-form input{width:100%;font-size:44px;text-align:center;letter-spacing:10px;font-weight:650;padding:18px;border:2px solid #d7e5df;border-radius:6px;outline:0;background:#fff;box-shadow:none;transition:border-color .16s ease,box-shadow .16s ease,transform .16s ease}.code-form input:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(8,122,104,.13);transform:translateY(-1px)}.full-link{margin-top:10px;width:100%}
.operator-logout,.operator-password{display:none}.operator-mode .operator-logout,.operator-mode .operator-password{display:block;position:fixed;left:10px;z-index:12;background:var(--ink);color:#fff;border:0;border-radius:4px;min-height:28px;min-width:30px;padding:5px 8px;font-size:10px;font-weight:600;opacity:.14;transition:.18s}.operator-mode .operator-logout{bottom:10px}.operator-mode .operator-password{bottom:44px}.operator-mode .operator-logout:hover,.operator-mode .operator-logout:focus,.operator-mode .operator-password:hover,.operator-mode .operator-password:focus{opacity:.9;min-width:58px}.operator-mode .sidebar{display:none}.operator-mode.app-shell{grid-template-columns:1fr}.operator-mode .workspace{padding:0;min-height:100vh;display:grid;place-items:center}.operator-mode .workspace-top,.operator-mode #checkinHistoryPanel,.operator-mode #unitCheckinLink{display:none}.operator-mode .operator-checkin{min-height:100vh;width:100%;display:grid;place-items:center}.operator-mode .checkin-box{width:min(720px,calc(100% - 32px));padding:46px}

.modal{position:fixed;inset:0;background:rgba(15,23,42,.42);display:none;place-items:center;padding:20px;z-index:40}.modal.active{display:grid}.modal-card{width:min(860px,100%);max-height:92vh;overflow:auto;background:#fff;border:1px solid var(--line);border-radius:6px;box-shadow:0 18px 46px rgba(15,23,42,.16);padding:20px;display:grid;gap:14px}.modal-card.small{width:min(480px,100%)}.modal-head{display:flex;justify-content:space-between;align-items:center;gap:12px}.modal-head h2{margin:0;font-weight:650}.icon-close{border:1px solid var(--line);background:#fff;border-radius:4px;padding:8px 10px;font-weight:600}.modal-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.modal-section-title{font-size:12px;font-weight:700;color:#344054;text-transform:uppercase;border-top:1px solid var(--line);padding-top:14px}.modal-actions{display:flex;justify-content:flex-end;gap:10px}
.message{margin-top:12px;border-radius:4px;padding:13px;font-weight:600;animation:checkinPulse .24s ease}.message.ok{background:#e8f8ef;color:#08724e;border:1px solid #bfe8d0}.message.error{background:#fff0ef;color:#a73030;border:1px solid #f0c5c1}@keyframes checkinPulse{from{opacity:0;transform:translateY(6px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}

.topbar{height:72px;display:flex;align-items:center;justify-content:space-between;padding:0 7vw;background:#fff;border-bottom:1px solid var(--line)}.topbar nav{display:flex;gap:18px;color:var(--muted);font-weight:600}.hero{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center;padding:56px 7vw}.hero-content h1{font-size:clamp(36px,5vw,64px);line-height:1.02;margin:14px 0;font-weight:650}.hero-content p{font-size:19px;color:var(--muted);line-height:1.55}.actions{display:flex;gap:12px;flex-wrap:wrap}.preview-card,.info-grid article{background:#fff;border:1px solid var(--line);border-radius:5px;padding:22px}.metric-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.metric{background:#fff;border:1px solid var(--line);border-radius:5px;padding:18px}.fake-list{display:grid;gap:10px;margin-top:14px}.fake-list div{height:46px;background:#f0f3f6;border-radius:4px}.info-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;padding:0 7vw 50px}footer{text-align:center;color:var(--muted);padding:24px}
.center-page{min-height:100vh;display:grid;place-items:center;padding:22px;background:linear-gradient(135deg,#f7faff 0%,#eef3fb 52%,#e7edf7 100%)}
.center-page .checkin-box{width:min(342px,calc(100% - 24px));min-height:640px;padding:18px 18px 16px;text-align:left;border-radius:8px;background:#fff;position:relative;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 24px 60px rgba(16,24,40,.18)}
.center-page .checkin-box:before{content:"";position:absolute;inset:0 0 auto;height:7px;background:#111827}.checkin-brand{display:flex;align-items:center;gap:8px;color:#101828;font-size:13px;font-weight:750;margin-bottom:34px}.checkin-brand .brand-icon{width:28px;height:28px;border-radius:7px}.entry-panel{display:grid;gap:0;text-align:center}.entry-panel .badge{justify-self:center;margin-bottom:10px}.entry-panel h1{font-size:24px;line-height:1.1;margin:0 0 7px;color:#111827}.entry-panel p{font-size:12px;margin:0;color:#667085}
.center-page .code-form{gap:14px;margin-top:18px}.center-page .code-form input{height:52px;font-size:22px;letter-spacing:2px;border:1px solid #e5eaf2;border-radius:7px;background:#f8fafc;color:#101828;box-shadow:inset 0 1px 0 rgba(16,24,40,.02);padding:8px}.center-page .code-form input:focus{border-color:#2864ff;box-shadow:0 0 0 3px rgba(40,100,255,.12)}
.center-page .checkin-keypad{gap:9px}.center-page .checkin-keypad button{min-height:43px;border:0;border-radius:6px;background:linear-gradient(180deg,#202a3a,#111827);color:#fff;font-size:17px;box-shadow:0 6px 12px rgba(16,24,40,.18)}.center-page .checkin-keypad button:hover,.center-page .checkin-keypad button:focus{background:linear-gradient(180deg,#2a364a,#172033);box-shadow:0 8px 16px rgba(16,24,40,.2);transform:translateY(-1px)}.center-page .checkin-keypad .key-enter{background:#315dff;font-size:12px;text-transform:uppercase}.center-page .checkin-keypad .key-cancel{background:#111827;color:#fff;font-size:12px}
.checkin-feedback{margin:auto 0 0;border:0;border-radius:8px;min-height:420px;padding:42px 24px 18px;text-align:center;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:#fff;box-shadow:none}.checkin-feedback.ok{background:#122039;color:#fff;border:0}.checkin-feedback.error{background:#211728;color:#fff;border:0}.feedback-icon{width:68px;height:68px;border-radius:50%;display:grid;place-items:center;font-size:38px;font-weight:750;color:#fff}.checkin-feedback.ok .feedback-icon{background:#32d583}.checkin-feedback.error .feedback-icon{background:#ef4444}.checkin-feedback strong{font-size:18px;color:#45df91}.checkin-feedback.error strong{color:#ff6474}.checkin-feedback small{font-size:12px;line-height:1.55;color:#d7deea;max-width:230px}.checkin-feedback button{border:0;border-radius:999px;background:#e84d5c;color:#fff;min-height:34px;padding:0 18px;font-size:12px;font-weight:700}.checkin-feedback em{margin-top:auto;font-size:10px;font-style:normal;color:#9aa6bc}

body.center-page{height:100vh;height:100svh;min-height:0;overflow:hidden;overscroll-behavior:none;padding:10px;align-items:center}
.center-page .checkin-box{height:min(640px,calc(100svh - 20px));min-height:0;width:min(342px,calc(100vw - 20px));padding:16px;overflow:hidden}
.center-page .checkin-brand{margin-bottom:20px;flex:0 0 auto}
.center-page .entry-panel{min-height:0}
.center-page .entry-panel .badge{margin-bottom:8px}
.center-page .code-form{gap:10px;margin-top:12px}
.center-page .code-form input{height:48px;font-size:21px}
.center-page .code-form input[readonly]{caret-color:transparent;user-select:none}
.center-page .checkin-keypad{gap:8px}
.center-page .checkin-keypad button{min-height:clamp(38px,8.2svh,43px);touch-action:manipulation}
.center-page .checkin-feedback{flex:1;min-height:0;margin:0;padding:24px 18px 14px;gap:10px}
.center-page .feedback-icon{width:58px;height:58px;font-size:32px}
.center-page .checkin-feedback small{max-width:250px}

@media(max-height:620px){
  body.center-page{padding:8px}
  .center-page .checkin-box{height:calc(100svh - 16px);padding:13px}
  .center-page .checkin-brand{margin-bottom:12px;font-size:12px}
  .center-page .checkin-brand .brand-icon{width:24px;height:24px}
  .entry-panel h1{font-size:21px}
  .entry-panel p{font-size:11px}
  .center-page .code-form input{height:42px;font-size:19px}
  .center-page .checkin-keypad button{min-height:36px;font-size:16px}
  .center-page .checkin-feedback{padding:18px 14px 12px}
  .center-page .feedback-icon{width:50px;height:50px;font-size:28px}
}

@media(max-width:1100px){
  .app-shell{grid-template-columns:1fr}.sidebar{position:fixed;inset:0 auto 0 0;width:260px;z-index:30;transform:translateX(-100%);transition:.2s}.sidebar-open .sidebar{transform:translateX(0)}.icon-btn{display:inline-flex}.workspace{padding:18px}.workspace-top{margin:-18px -18px 18px;padding:0 18px}.kpi-grid,.finance-head,.kpi-strip{grid-template-columns:repeat(2,1fr)}.dashboard-grid,.content-grid,.operator-checkin,.tools-grid{grid-template-columns:1fr}
}
@media(max-width:760px){
  .login-screen{grid-template-columns:1fr}.login-visual{display:none}.workspace-top{height:auto;min-height:58px;align-items:flex-start;padding-top:12px;padding-bottom:12px}.workspace-top h1{font-size:24px}.section-toolbar,.panel-title{align-items:stretch;flex-direction:column}.search-input{max-width:none}.modal-grid,.form-row,.kpi-grid,.finance-head,.kpi-strip{grid-template-columns:1fr}.code-form input{font-size:32px;letter-spacing:5px}.hero,.info-grid{grid-template-columns:1fr;padding-left:20px;padding-right:20px}.topbar{height:auto;padding:14px 20px;align-items:flex-start;flex-direction:column}.compact-select{width:100%;min-width:0}th,td{padding:10px;font-size:13px}
}

body.center-page{
  position:fixed;
  inset:0;
  width:100%;
  height:100vh;
  height:var(--checkin-vh,100dvh);
  min-height:0;
  overflow:hidden!important;
  padding:8px;
  display:grid;
  place-items:center;
  touch-action:manipulation;
  -webkit-text-size-adjust:100%;
}
body.center-page .checkin-box{
  width:min(342px,calc(100vw - 16px));
  height:calc(var(--checkin-vh,100dvh) - 16px);
  max-height:calc(var(--checkin-vh,100dvh) - 16px);
  min-height:0;
  padding:14px;
  overflow:hidden!important;
  display:flex;
  flex-direction:column;
}
body.center-page .checkin-brand{
  margin-bottom:12px;
  flex:0 0 auto;
  font-size:12px;
  line-height:1;
}
body.center-page .checkin-brand .brand-icon{
  width:24px;
  height:24px;
}
body.center-page .entry-panel{
  min-height:0;
  display:grid;
  align-content:start;
}
body.center-page .entry-panel .badge{
  margin-bottom:7px;
  padding:4px 8px;
  font-size:11px;
}
body.center-page .entry-panel h1{
  font-size:21px;
  line-height:1.05;
  margin-bottom:5px;
}
body.center-page .entry-panel p{
  font-size:11px;
  line-height:1.25;
}
body.center-page .code-form{
  gap:8px;
  margin-top:10px;
}
body.center-page .code-form input{
  height:42px;
  min-height:0;
  padding:6px 8px;
  font-size:20px;
  line-height:1;
  letter-spacing:2px;
}
body.center-page .checkin-keypad{
  gap:7px;
}
body.center-page .checkin-keypad button{
  appearance:none;
  -webkit-appearance:none;
  width:100%;
  height:clamp(34px,7.2dvh,41px);
  min-height:0!important;
  padding:0!important;
  display:grid;
  place-items:center;
  border-radius:6px;
  font-size:16px!important;
  line-height:1!important;
  font-weight:750;
  font-family:"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;
  font-variant-numeric:tabular-nums;
  letter-spacing:0;
  text-align:center;
  transform:none!important;
}
body.center-page .checkin-keypad .key-enter,
body.center-page .checkin-keypad .key-cancel{
  font-size:12px!important;
}
body.center-page .checkin-keypad button:hover,
body.center-page .checkin-keypad button:focus{
  transform:none!important;
}
body.center-page .checkin-keypad button:active,
body.center-page .checkin-keypad button.pressed{
  transform:none!important;
}
body.center-page .checkin-feedback{
  flex:1;
  min-height:0;
  margin:0;
  padding:16px 14px 12px;
  gap:9px;
}
body.center-page .feedback-icon{
  width:48px;
  height:48px;
  font-size:27px;
}
body.center-page .checkin-feedback strong{
  font-size:16px;
}
body.center-page .checkin-feedback small{
  font-size:11px;
  line-height:1.35;
}
body.center-page .checkin-feedback button{
  min-height:30px;
  padding:0 14px;
  font-size:11px;
}
