@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&family=JetBrains+Mono:wght@400;500;600&display=swap');

:root {
    --bg:         #07080c;
    --bg-s:       #0d0f16;
    --bg-c:       #131720;
    --bg-h:       #191d28;
    --border:     #1e2332;
    --border-l:   #272d3f;
    --accent:     #4f7fff;
    --accent-d:   rgba(79,127,255,.13);
    --accent-g:   rgba(79,127,255,.22);
    --accent-2:   #7c4fff;
    --success:    #22d3a5;
    --success-d:  rgba(34,211,165,.10);
    --danger:     #ff5f6d;
    --danger-d:   rgba(255,95,109,.10);
    --warning:    #ffb347;
    --warning-d:  rgba(255,179,71,.10);
    --info:       #38bdf8;
    --info-d:     rgba(56,189,248,.10);
    --purple:     #a78bfa;
    --purple-d:   rgba(167,139,250,.10);
    --text:       #eef0f6;
    --text-s:     #7d8699;
    --text-m:     #3d4560;
    --sidebar-w:  258px;
    --top-h:      56px;
    --r:          11px;
    --r-s:        7px;
    --r-xs:       4px;
    --shadow:     0 8px 32px rgba(0,0,0,.55);
    --ui:         'Inter', system-ui, sans-serif;
    --mono:       'JetBrains Mono', 'Courier New', monospace;
}

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{font-size:14px}
body{font-family:var(--ui);background:var(--bg);color:var(--text);min-height:100vh;-webkit-font-smoothing:antialiased;line-height:1.55}
::-webkit-scrollbar{width:4px;height:4px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--border-l);border-radius:10px}

/* ── LAYOUT ── */
.app{display:flex;min-height:100vh}

/* ── SIDEBAR ── */
.sidebar{
    width:var(--sidebar-w);background:var(--bg-s);
    border-right:1px solid var(--border);
    position:fixed;top:0;left:0;height:100vh;z-index:200;
    display:flex;flex-direction:column;transition:width .22s ease;overflow:hidden
}
.sidebar.collapsed{width:60px}
.sidebar.collapsed .brand-text,.sidebar.collapsed .nav-label-txt,.sidebar.collapsed .nav-section,.sidebar.collapsed .user-info{display:none}
.sidebar.collapsed .nav-item{justify-content:center;padding:9px}

/* Logo / Brand */
.sidebar-brand{display:flex;align-items:center;gap:11px;padding:18px 15px;border-bottom:1px solid var(--border);flex-shrink:0}
.logo-mark{width:34px;height:34px;flex-shrink:0;position:relative}
.logo-mark svg{width:34px;height:34px}
.brand-name{font-size:15px;font-weight:800;letter-spacing:-.4px;color:var(--text)}
.brand-tag{font-size:9px;color:var(--text-m);font-family:var(--mono);letter-spacing:1.5px;text-transform:uppercase}

/* Nav */
.sidebar-nav{flex:1;padding:10px 8px;overflow-y:auto}
.nav-section{font-size:9px;letter-spacing:2px;text-transform:uppercase;color:var(--text-m);padding:12px 8px 4px;font-family:var(--mono)}
.nav-item{display:flex;align-items:center;gap:9px;padding:8px 10px;border-radius:var(--r-s);color:var(--text-s);text-decoration:none;font-size:13px;font-weight:500;transition:all .13s;margin-bottom:1px;white-space:nowrap}
.nav-item:hover{background:var(--bg-h);color:var(--text)}
.nav-item.active{background:var(--accent-d);color:var(--accent);font-weight:600}
.nav-icon{font-size:15px;width:18px;text-align:center;flex-shrink:0;line-height:1}
.nav-logout:hover{background:var(--danger-d);color:var(--danger)}

/* User strip */
.sidebar-user{display:flex;align-items:center;gap:10px;padding:12px 14px;border-top:1px solid var(--border);flex-shrink:0}
.user-av{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent-2));display:flex;align-items:center;justify-content:center;font-weight:700;font-size:11px;color:#fff;flex-shrink:0}
.user-name{display:block;font-size:12px;font-weight:600;color:var(--text)}
.user-role{display:block;font-size:9px;color:var(--text-m);text-transform:uppercase;letter-spacing:1px;font-family:var(--mono)}

/* ── MAIN ── */
.main{flex:1;margin-left:var(--sidebar-w);display:flex;flex-direction:column;min-height:100vh;transition:margin-left .22s ease}

/* Topbar */
.topbar{height:var(--top-h);background:var(--bg-s);border-bottom:1px solid var(--border);display:flex;align-items:center;gap:12px;padding:0 20px;position:sticky;top:0;z-index:100}
.toggle-btn{background:none;border:1px solid var(--border);color:var(--text-s);padding:5px 9px;border-radius:var(--r-xs);cursor:pointer;font-size:13px;transition:all .13s}
.toggle-btn:hover{background:var(--bg-h);color:var(--text)}
.topbar-title{flex:1}
.page-h{font-size:15px;font-weight:700;letter-spacing:-.3px}
.page-bc{font-size:10px;color:var(--text-m);font-family:var(--mono)}
.topbar-right{display:flex;align-items:center;gap:10px}
.top-date{font-size:10px;color:var(--text-m);font-family:var(--mono)}

/* Notif */
.notif-wrap{position:relative;cursor:pointer;padding:5px}
.notif-icon{font-size:16px}
.notif-badge{position:absolute;top:0;right:0;background:var(--danger);color:#fff;border-radius:50%;width:14px;height:14px;font-size:8px;display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-weight:600}
.notif-drop{display:none;position:absolute;top:38px;right:0;background:var(--bg-c);border:1px solid var(--border);border-radius:var(--r);width:300px;box-shadow:var(--shadow);z-index:999}
.notif-drop.open{display:block}
.notif-empty{padding:20px;text-align:center;color:var(--text-m);font-size:12px}
.notif-item{padding:11px 14px;border-bottom:1px solid var(--border);cursor:pointer;transition:background .13s}
.notif-item:hover{background:var(--bg-h)}
.notif-item strong{font-size:12px;display:block;margin-bottom:2px}
.notif-item p{font-size:11px;color:var(--text-s)}
.notif-item small{font-size:10px;color:var(--text-m);font-family:var(--mono)}

/* Content */
.content-body{padding:20px;flex:1}

/* ── CARDS ── */
.card{background:var(--bg-c);border:1px solid var(--border);border-radius:var(--r);padding:20px;margin-bottom:16px}
.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--border)}
.card-title{font-size:10px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--text-s)}

/* Stats grid */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:12px;margin-bottom:16px}
.stat{background:var(--bg-c);border:1px solid var(--border);border-radius:var(--r);padding:16px 18px;position:relative;overflow:hidden;transition:border-color .15s,transform .12s}
.stat:hover{border-color:var(--border-l);transform:translateY(-1px)}
.stat::after{content:'';position:absolute;top:0;left:0;width:100%;height:2px;background:var(--accent)}
.stat.g::after{background:var(--success)}
.stat.r::after{background:var(--danger)}
.stat.b::after{background:var(--info)}
.stat.p::after{background:var(--purple)}
.stat-lbl{font-size:9px;letter-spacing:1.5px;text-transform:uppercase;color:var(--text-m);font-family:var(--mono);margin-bottom:9px}
.stat-val{font-size:26px;font-weight:800;letter-spacing:-1px;line-height:1;margin-bottom:3px}
.stat-meta{font-size:11px;color:var(--text-s)}

/* Tables */
.table-wrap{overflow-x:auto}
table{width:100%;border-collapse:collapse;font-size:13px}
thead tr{border-bottom:1px solid var(--border)}
th{padding:8px 12px;text-align:left;font-size:9px;letter-spacing:1.5px;text-transform:uppercase;color:var(--text-m);font-family:var(--mono);font-weight:500;white-space:nowrap}
td{padding:10px 12px;border-bottom:1px solid var(--border);vertical-align:middle}
tbody tr:last-child td{border-bottom:none}
tbody tr{transition:background .1s}
tbody tr:hover td{background:var(--bg-h)}

/* Badges */
.badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:20px;font-size:10px;font-weight:600;font-family:var(--mono);text-transform:uppercase;letter-spacing:.3px}
.badge-s{background:var(--success-d);color:var(--success)}
.badge-d{background:var(--danger-d);color:var(--danger)}
.badge-w{background:var(--warning-d);color:var(--warning)}
.badge-i{background:var(--info-d);color:var(--info)}
.badge-m{background:rgba(255,255,255,.05);color:var(--text-m)}
.badge-a{background:var(--accent-d);color:var(--accent)}
.badge-p{background:var(--purple-d);color:var(--purple)}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:5px;padding:7px 14px;border-radius:var(--r-s);font-size:13px;font-weight:600;font-family:var(--ui);cursor:pointer;border:1px solid transparent;text-decoration:none;transition:all .13s;white-space:nowrap}
.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}
.btn-primary:hover{background:#6690ff;box-shadow:0 0 0 3px var(--accent-g)}
.btn-success{background:var(--success-d);color:var(--success);border-color:rgba(34,211,165,.25)}
.btn-success:hover{background:var(--success);color:#000}
.btn-danger{background:var(--danger-d);color:var(--danger);border-color:rgba(255,95,109,.25)}
.btn-danger:hover{background:var(--danger);color:#fff}
.btn-outline{background:transparent;color:var(--text);border-color:var(--border)}
.btn-outline:hover{background:var(--bg-h);border-color:var(--border-l)}
.btn-sm{padding:4px 10px;font-size:11px;border-radius:var(--r-xs)}
.btn-lg{padding:10px 22px;font-size:14px}
.btn:disabled{opacity:.4;cursor:not-allowed}
.w-100{width:100%;justify-content:center}

/* Forms */
.form-group{margin-bottom:14px}
.form-label{display:block;font-size:10px;font-weight:600;letter-spacing:.5px;text-transform:uppercase;color:var(--text-s);margin-bottom:5px}
.form-control{width:100%;padding:8px 12px;background:var(--bg-s);border:1px solid var(--border);border-radius:var(--r-s);color:var(--text);font-family:var(--ui);font-size:13px;transition:border-color .13s,box-shadow .13s;line-height:1.4}
.form-control:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-d)}
.form-control::placeholder{color:var(--text-m)}
select.form-control{cursor:pointer}
textarea.form-control{resize:vertical;min-height:80px}
.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px}
.form-hint{font-size:11px;color:var(--text-m);margin-top:4px;font-family:var(--mono)}

/* Alerts */
.alert{padding:11px 15px;border-radius:var(--r-s);margin-bottom:14px;font-size:13px;border:1px solid}
.alert-s{background:var(--success-d);border-color:rgba(34,211,165,.25);color:var(--success)}
.alert-d{background:var(--danger-d);border-color:rgba(255,95,109,.25);color:var(--danger)}
.alert-w{background:var(--warning-d);border-color:rgba(255,179,71,.25);color:var(--warning)}
.alert-i{background:var(--info-d);border-color:rgba(56,189,248,.25);color:var(--info)}

/* Modal */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.65);backdrop-filter:blur(4px);z-index:500;align-items:center;justify-content:center}
.modal-overlay.open{display:flex !important}
.modal-box{background:var(--bg-c);border:1px solid var(--border);border-radius:var(--r);padding:24px;width:90%;max-width:560px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow);animation:minIn .17s ease}
@keyframes minIn{from{transform:translateY(-10px);opacity:0}to{transform:none;opacity:1}}
.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--border)}
.modal-close{background:none;border:none;color:var(--text-m);cursor:pointer;font-size:16px;transition:color .13s}
.modal-close:hover{color:var(--danger)}

/* Shift panel */
.shift-panel{background:var(--bg-c);border:1px solid var(--border);border-radius:var(--r);padding:28px;text-align:center;margin-bottom:16px;position:relative;overflow:hidden}
.shift-panel::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--accent),var(--accent-2))}
.shift-time{font-size:46px;font-weight:800;font-family:var(--mono);letter-spacing:-2px;line-height:1;margin-bottom:4px}
.shift-date{font-size:10px;color:var(--text-m);letter-spacing:2px;font-family:var(--mono);margin-bottom:20px;text-transform:uppercase}

/* Camera */
.camera-box{width:320px;height:240px;background:#000;border-radius:var(--r);margin:0 auto 14px;overflow:hidden;border:1.5px solid var(--border);position:relative}
.camera-box video,.camera-box canvas{width:100%;height:100%;object-fit:cover;position:absolute;top:0;left:0}
.cam-overlay{position:absolute;inset:0;border:1.5px solid var(--accent);border-radius:var(--r);pointer-events:none;animation:camPulse 2s infinite}
.bg-indicator{position:absolute;bottom:6px;right:6px;background:rgba(79,127,255,.85);color:#fff;font-size:9px;font-family:var(--mono);padding:2px 7px;border-radius:4px;letter-spacing:1px}
@keyframes camPulse{0%,100%{border-color:var(--accent)}50%{border-color:#6690ff}}

/* Steps */
.steps{display:flex;justify-content:center;gap:16px;margin-bottom:14px;flex-wrap:wrap}
.step{display:flex;align-items:center;gap:5px;font-size:10px;color:var(--text-m);font-family:var(--mono)}
.dot{width:7px;height:7px;border-radius:50%;background:var(--border-l);transition:all .3s}
.dot.done{background:var(--success);box-shadow:0 0 5px var(--success)}
.dot.active{background:var(--accent);animation:blink .8s infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}

/* Face status */
.face-status{margin:8px auto;max-width:320px;padding:9px 14px;border-radius:var(--r-s);font-size:11px;font-family:var(--mono);text-align:left;display:none}
.face-status.checking{background:var(--info-d);border:1px solid rgba(56,189,248,.3);color:var(--info);display:block}
.face-status.pass{background:var(--success-d);border:1px solid rgba(34,211,165,.3);color:var(--success);display:block}
.face-status.fail{background:var(--danger-d);border:1px solid rgba(255,95,109,.3);color:var(--danger);display:block}

/* Login page */
.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg);background-image:radial-gradient(ellipse 60% 50% at 20% 80%,rgba(79,127,255,.06) 0%,transparent 100%),radial-gradient(ellipse 50% 40% at 80% 20%,rgba(124,79,255,.04) 0%,transparent 100%)}
.login-box{background:var(--bg-c);border:1px solid var(--border);border-radius:15px;padding:40px 36px;width:100%;max-width:420px;box-shadow:var(--shadow)}
.login-logo{text-align:center;margin-bottom:28px}
.login-logo-mark{display:flex;align-items:center;justify-content:center;margin-bottom:12px}
.login-logo-mark svg{width:52px;height:52px}
.login-title{font-size:20px;font-weight:800;margin-bottom:4px;letter-spacing:-.5px}
.login-sub{font-size:10px;color:var(--text-m);letter-spacing:2px;font-family:var(--mono);text-transform:uppercase}

/* TC checkboxes */
.tc-box{background:var(--bg-s);border:1px solid var(--border);border-radius:var(--r-s);padding:16px;max-height:280px;overflow-y:auto;font-size:13px;line-height:1.7;color:var(--text-s);margin-bottom:16px}
.tc-check{display:flex;align-items:flex-start;gap:10px;margin-bottom:10px;font-size:13px;cursor:pointer;user-select:none}
.tc-check input[type=checkbox]{width:16px;height:16px;margin-top:2px;accent-color:var(--accent);flex-shrink:0;cursor:pointer}

/* Leave bars */
.lbar-wrap{margin-bottom:12px}
.lbar-row{display:flex;justify-content:space-between;font-size:12px;margin-bottom:4px;font-weight:500}
.lbar-track{background:var(--bg-s);border-radius:5px;height:5px;overflow:hidden}
.lbar-fill{height:100%;border-radius:5px;transition:width 1.2s cubic-bezier(.4,0,.2,1)}

/* Leave calendar */
.leave-calendar{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;width:100%}
.lcal-h{text-align:center;font-size:10px;font-family:var(--mono);color:var(--text-m);padding:6px 2px;letter-spacing:.5px;text-transform:uppercase;font-weight:600}
.lcal-d{min-height:38px;display:flex;align-items:center;justify-content:center;border-radius:8px;font-size:12px;font-family:var(--mono);font-weight:500;cursor:pointer;border:1px solid transparent;transition:all .13s;position:relative;flex-direction:column;gap:2px;padding:4px 2px;color:var(--text)}
.lcal-d:hover:not(.empty):not(.wknd):not(.blocked){background:var(--bg-h);border-color:var(--border-l);transform:translateY(-1px)}
/* Weekend — subtle grey tint */
.lcal-d.wknd{background:rgba(255,255,255,.02);color:var(--text-m);cursor:default;border-color:var(--border)}
/* Today — solid blue, always visible */
.lcal-d.today{background:var(--accent) !important;color:#fff !important;font-weight:700;border-color:var(--accent) !important;box-shadow:0 2px 8px rgba(79,127,255,.4)}
/* Holiday — purple */
.lcal-d.holiday{background:rgba(167,139,250,.18);color:var(--purple);border-color:rgba(167,139,250,.45);font-weight:600}
/* Leave statuses */
.lcal-d.leave-approved{background:rgba(34,211,165,.18) !important;color:var(--success) !important;border-color:rgba(34,211,165,.5) !important;font-weight:600}
.lcal-d.leave-pending{background:rgba(255,179,71,.18) !important;color:var(--warning) !important;border-color:rgba(255,179,71,.5) !important;font-weight:600}
.lcal-d.leave-rejected{background:rgba(255,95,109,.12) !important;color:var(--danger) !important;border-color:rgba(255,95,109,.4) !important;opacity:.7}
/* Selected — cyan, always on top */
.lcal-d.selected{background:rgba(56,189,248,.2) !important;color:var(--info) !important;border-color:var(--info) !important;font-weight:700;box-shadow:0 0 0 2px rgba(56,189,248,.25)}
/* Blocked — faded */
.lcal-d.blocked{opacity:.35;cursor:not-allowed}
.lcal-d.empty{cursor:default;background:transparent;border-color:transparent}
.lcal-dot{width:5px;height:5px;border-radius:50%;background:currentColor;margin-top:1px}

/* Multi-shift badge */
.shift-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:20px;font-size:9px;font-family:var(--mono);font-weight:700;text-transform:uppercase}

/* Utility */
.mono{font-family:var(--mono)}
.text-s{color:var(--text-s)}
.text-m{color:var(--text-m)}
.text-accent{color:var(--accent)}
.text-success{color:var(--success)}
.text-danger{color:var(--danger)}
.text-warning{color:var(--warning)}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.empty-state{text-align:center;padding:36px 20px;color:var(--text-m);font-size:13px}
.divider{border:none;border-top:1px solid var(--border);margin:14px 0}

/* Responsive */
@media(max-width:900px){.grid-2,.grid-3{grid-template-columns:1fr}.stats-grid{grid-template-columns:1fr 1fr}}
@media(max-width:640px){.sidebar{transform:translateX(-100%)}.main{margin-left:0}.content-body{padding:14px}.stats-grid{grid-template-columns:1fr}.shift-time{font-size:34px}}

/* ── V1→V2 COMPATIBILITY ALIASES ─────────────────────────── */
/* Maps v1 class names used in copied modules to v2 equivalents */
.stat-card          { background:var(--bg-c);border:1px solid var(--border);border-radius:var(--r);padding:16px 18px;position:relative;overflow:hidden;transition:border-color .15s }
.stat-card::after   { content:'';position:absolute;top:0;left:0;width:100%;height:2px;background:var(--accent) }
.stat-card.green::after { background:var(--success) }
.stat-card.red::after   { background:var(--danger) }
.stat-card.blue::after  { background:var(--info) }
.stat-label { font-size:9px;letter-spacing:1.5px;text-transform:uppercase;color:var(--text-m);font-family:var(--mono);margin-bottom:9px }
.stat-value { font-size:26px;font-weight:800;letter-spacing:-1px;line-height:1;margin-bottom:3px }
.stat-meta  { font-size:11px;color:var(--text-s) }

.badge-success { background:var(--success-d);color:var(--success) }
.badge-danger  { background:var(--danger-d);color:var(--danger) }
.badge-warning { background:var(--warning-d);color:var(--warning) }
.badge-muted   { background:rgba(255,255,255,.05);color:var(--text-m) }
.badge-accent  { background:var(--accent-d);color:var(--accent) }
.badge-info    { background:var(--info-d);color:var(--info) }

.text-accent  { color:var(--accent) }
.text-success { color:var(--success) }
.text-danger  { color:var(--danger) }
.text-warning { color:var(--warning) }
.text-muted   { color:var(--text-m) }
.text-secondary { color:var(--text-s) }

:root {
  --bg-surface:   var(--bg-s);
  --bg-card:      var(--bg-c);
  --text-secondary: var(--text-s);
  --text-muted:   var(--text-m);
  --radius-sm:    var(--r-s);
  --radius-xs:    var(--r-xs);
  --font-mono:    var(--mono);
  --accent-dim:   var(--accent-d);
  --success-dim:  var(--success-d);
  --danger-dim:   var(--danger-d);
  --warning-dim:  var(--warning-d);
  --info-dim:     var(--info-d);
  --purple-dim:   var(--purple-d);
}

/* Step indicators (v1 names) */
.verification-steps { display:flex;justify-content:center;gap:16px;margin-bottom:14px;flex-wrap:wrap }
.step-indicator     { display:flex;align-items:center;gap:5px;font-size:10px;color:var(--text-m);font-family:var(--mono) }
.step-dot           { width:7px;height:7px;border-radius:50%;background:var(--border-l);transition:all .3s }
.step-dot.done      { background:var(--success);box-shadow:0 0 5px var(--success) }
.step-dot.active    { background:var(--accent);animation:blink .8s infinite }
.camera-overlay     { position:absolute;inset:0;border:1.5px solid var(--accent);border-radius:var(--r);pointer-events:none;animation:camPulse 2s infinite;z-index:3 }
.face-check-status  { margin:8px auto;max-width:320px;padding:9px 14px;border-radius:var(--r-s);font-size:11px;font-family:var(--mono);text-align:left;display:none }
.face-check-status.checking { background:var(--info-d);border:1px solid rgba(56,189,248,.3);color:var(--info);display:block }
.face-check-status.pass     { background:var(--success-d);border:1px solid rgba(34,211,165,.3);color:var(--success);display:block }
.face-check-status.fail     { background:var(--danger-d);border:1px solid rgba(255,95,109,.3);color:var(--danger);display:block }

/* Leave bars (v1 names) */
.leave-bar-wrap  { margin-bottom:12px }
.leave-bar-label { display:flex;justify-content:space-between;font-size:12px;margin-bottom:4px;font-weight:500 }
.leave-bar-track { background:var(--bg-s);border-radius:5px;height:5px;overflow:hidden }
.leave-bar-fill  { height:100%;border-radius:5px;transition:width 1.2s cubic-bezier(.4,0,.2,1) }

/* Leave calendar wrapper */
.leave-cal-wrap { width:100%; }

/* v1 modal helper class */
.modal-overlay.open { display:flex }

/* Shared layout helpers */
.mt-1 { margin-top:8px }
.mb-2 { margin-bottom:16px }
.w-100 { width:100%;justify-content:center }
.form-row { display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px }
.form-hint { font-size:11px;color:var(--text-m);margin-top:4px;font-family:var(--mono) }
.empty-state { text-align:center;padding:36px 20px;color:var(--text-m);font-size:13px }
.grid-2 { display:grid;grid-template-columns:1fr 1fr;gap:14px }
.table-wrap { overflow-x:auto }

/* ── Date input calendar icon — white ─────────────────── */
input[type="date"].form-control {
    color-scheme: white;
}
input[type="date"].form-control::-webkit-calendar-picker-indicator {
    filter: invert(1) brightness(2);
    cursor: pointer;
    opacity: .7;
}
input[type="date"].form-control::-webkit-calendar-picker-indicator:hover {
    opacity: 1;
}
/* Date input — white calendar icon and text */

input[type="date"].form-control::-webkit-calendar-picker-indicator {
    filter: invert(1) brightness(2);
    cursor: pointer;
    opacity: 0.7;
}
input[type="date"].form-control::-webkit-calendar-picker-indicator:hover {
    opacity: 1;
}
input[type="date"]::-webkit-calendar-picker-indicator {
    filter: invert(1);
    cursor: pointer;
}