/* ============================================================
   ClockTally — warm & friendly design system
   ============================================================ */

:root{
  --brand:#2457ff;
  --brand-2:#6d5dfc;
  --brand-ink:#1b2a6b;
  --grad:linear-gradient(135deg,#2457ff 0%,#6d5dfc 100%);
  --grad-soft:linear-gradient(135deg,#eef2ff 0%,#f3eeff 100%);

  --ink:#1d2333;
  --muted:#6b7488;
  --faint:#9aa1b2;

  --bg:#f5f6fc;
  --surface:#ffffff;
  --surface-2:#f7f8fd;
  --line:#e9eaf3;
  --line-2:#eef0f7;

  --ok:#0c8a52; --ok-bg:#e7f8ef;
  --warn:#b3631a; --warn-bg:#fff3e3;
  --danger:#c0392b; --danger-bg:#fdecea;
  --info:#2457ff; --info-bg:#eaf0ff;

  --r-sm:12px; --r:18px; --r-lg:26px; --pill:999px;
  --shadow-sm:0 2px 10px rgba(26,32,80,.05);
  --shadow:0 12px 34px rgba(26,32,80,.08);
  --shadow-lg:0 26px 70px rgba(36,55,140,.16);
  --ring:0 0 0 4px rgba(36,87,255,.16);

  --side-w:248px;
  --font:'Plus Jakarta Sans',ui-rounded,'Segoe UI',system-ui,-apple-system,BlinkMacSystemFont,sans-serif;
  --mono:'Space Mono',ui-monospace,SFMono-Regular,Menlo,monospace;
}

*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:var(--font);
  color:var(--ink);
  background:var(--bg);
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
}
a{color:var(--brand);text-decoration:none}
h1,h2,h3{letter-spacing:-.02em;line-height:1.12;margin:0 0 .4em}
h1{font-size:clamp(26px,3.2vw,40px);font-weight:800}
h2{font-size:22px;font-weight:750}
h3{font-size:17px;font-weight:700}
p{margin:0 0 1em}
p:last-child{margin-bottom:0}
small,.small{font-size:13px}
.muted{color:var(--muted)}
.faint{color:var(--faint)}
.ok{color:var(--ok);font-weight:700}
.warn{color:var(--warn);font-weight:700}
.error{color:var(--danger);font-weight:700}
hr{border:0;border-top:1px solid var(--line);margin:18px 0}
code{font-family:var(--mono);font-size:.9em}
.mono{font-family:var(--mono);font-variant-numeric:tabular-nums}

/* ---------- Buttons ---------- */
.button,button{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-family:inherit;font-size:15px;font-weight:700;
  padding:12px 20px;border-radius:var(--pill);border:0;cursor:pointer;
  background:var(--grad);color:#fff;text-decoration:none;
  box-shadow:0 8px 20px rgba(45,80,230,.24);
  transition:transform .12s ease,box-shadow .12s ease,background .12s ease;
  white-space:nowrap;
}
.button:hover,button:hover{transform:translateY(-1px);box-shadow:0 12px 26px rgba(45,80,230,.30)}
.button:active,button:active{transform:translateY(0)}
.button.secondary,button.secondary{
  background:#fff;color:var(--ink);box-shadow:none;border:1.5px solid var(--line);
}
.button.secondary:hover,button.secondary:hover{border-color:#cdd3e6;background:var(--surface-2)}
.button.ghost,button.ghost{background:transparent;color:var(--brand);box-shadow:none;border:0;padding:10px 12px}
.button.warn,button.warn{background:linear-gradient(135deg,#f59e0b,#d97706);box-shadow:0 8px 20px rgba(217,119,6,.22)}
.button.danger,button.danger{background:linear-gradient(135deg,#ef4444,#c0392b);box-shadow:0 8px 20px rgba(192,57,43,.22)}
.button.big,button.big{padding:15px 26px;font-size:16px}
.button.block,button.block{width:100%}
.button.on-grad,button.on-grad{background:#fff;color:var(--brand-ink)}
.inline{display:inline-flex}

/* ---------- Forms ---------- */
label{display:block;font-weight:650;font-size:14px;margin:16px 0 7px;color:#384055}
input,select,textarea{
  width:100%;font-family:inherit;font-size:16px;color:var(--ink);
  padding:13px 15px;border:1.5px solid var(--line);border-radius:var(--r-sm);
  background:var(--surface);transition:border-color .12s,box-shadow .12s;
}
input:focus,select:focus,textarea:focus{outline:0;border-color:var(--brand);box-shadow:var(--ring)}
/* Give the submit row breathing room from the fields above it */
form p{margin:20px 0 0}
form p.muted,form p.small,form p.faint{margin-top:10px}
form .actions{margin-top:20px}
select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' fill='none' stroke='%236b7488' stroke-width='2'%3E%3Cpath d='M5 8l5 5 5-5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:40px}

/* ---------- Cards & layout helpers ---------- */
.card{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:24px;box-shadow:var(--shadow-sm);
}
.card+.card,.grid,.stack>*+*{margin-top:0}
.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:18px;margin-top:18px}
.grid .card{margin:0}
.stack{display:grid;gap:18px}
.actions{display:flex;gap:12px;flex-wrap:wrap;align-items:center}
.center{text-align:center}

/* page header (was .hero on internal pages) */
.hero{margin:4px 0 22px}
.hero h1{margin-bottom:6px}
.hero p{color:var(--muted);font-size:16px;max-width:680px;margin:0}

/* metrics */
.metric{display:flex;flex-direction:column;gap:4px}
.metric span{color:var(--muted);font-size:13px;font-weight:600;font-family:var(--mono);letter-spacing:.04em;text-transform:uppercase}
.metric strong{font-family:var(--mono);font-size:38px;font-weight:700;letter-spacing:-.02em;color:var(--brand-ink);font-variant-numeric:tabular-nums;line-height:1}

/* pills */
.pill{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:700;border-radius:var(--pill);padding:4px 11px;line-height:1.4}
.pill.green{background:var(--ok-bg);color:var(--ok)}
.pill.amber{background:var(--warn-bg);color:var(--warn)}
.pill.red{background:var(--danger-bg);color:var(--danger)}
.pill.blue{background:var(--info-bg);color:var(--info)}
.pill.grey{background:#eef0f6;color:#5a6172}

/* flash + banner */
.flash{border-radius:var(--r);padding:13px 16px;margin:0 0 18px;font-weight:600;display:flex;gap:10px;align-items:center}
.flash::before{content:"";width:8px;height:8px;border-radius:50%;background:currentColor;flex:none;opacity:.7}
.flash.success{background:var(--ok-bg);color:var(--ok)}
.flash.error{background:var(--danger-bg);color:var(--danger)}
.flash.info{background:var(--info-bg);color:var(--info)}
.banner{border-radius:var(--r);padding:14px 18px;margin:0 0 18px;font-weight:650;
  display:flex;gap:14px;align-items:center;justify-content:space-between;flex-wrap:wrap}
.banner.warn{background:var(--warn-bg);color:var(--warn);border:1px solid #f5d9b0}
.banner.info{background:var(--info-bg);color:var(--brand-ink);border:1px solid #cfdcff}
.banner .button{padding:9px 16px;font-size:14px}

/* tables */
.table-wrap{width:100%;overflow-x:auto;border:1px solid var(--line);border-radius:var(--r);background:var(--surface);margin-top:6px}
table{width:100%;min-width:460px;border-collapse:collapse;font-variant-numeric:tabular-nums}
th,td{text-align:left;padding:13px 16px;border-bottom:1px solid var(--line-2);vertical-align:middle;font-size:14.5px}
th{background:var(--surface-2);color:#4a5163;font-weight:650;font-size:13px;text-transform:none}
tr:last-child td{border-bottom:0}
tbody tr:hover td{background:#fafbff}
td .actions{gap:8px}
td .button,td button{padding:8px 13px;font-size:13px}

/* QR card */
.qr-card{text-align:center}
.qr-render{display:inline-block;background:#fff;padding:16px;border-radius:var(--r);box-shadow:var(--shadow);max-width:100%}
.qr-render svg{width:min(260px,72vw);height:auto;display:block}
.code-link{display:block;max-width:560px;margin:0 auto;overflow-wrap:anywhere;background:var(--surface-2);
  border:1px solid var(--line);border-radius:var(--r-sm);padding:11px 14px;font-size:13px}

/* Printable card sheet (all staff / all shared codes) */
.qr-sheet{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:16px;margin-top:8px}
.qr-cardlet{border:1px solid var(--line);border-radius:16px;padding:16px;text-align:center;background:#fff;break-inside:avoid;page-break-inside:avoid}
.qr-cardlet .qr-render{display:inline-block;margin:8px auto 4px}
.qr-cardlet .qr-render svg{width:150px;height:auto}
.qc-org{font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.07em}
.qc-name{font-weight:800;font-size:17px;margin-top:6px;line-height:1.2}
.qc-sub{font-size:12px;color:var(--muted);margin-top:2px}

/* Print: show only the QR cards, drop all app chrome */
@media print{
  .side,.mobilebar,.nav-backdrop,.pub-bar,.powered,.no-print{display:none!important}
  body{background:#fff}
  .layout{display:block}
  .content,.content main,.pub-main{padding:0!important;margin:0!important;max-width:none!important}
  .card{box-shadow:none;border:1px solid #ddd;margin:0}
  .qr-card .code-link,.qr-card .actions{display:none!important}
  .qr-sheet{grid-template-columns:repeat(3,1fr);gap:8mm}
  .qr-cardlet .qr-render svg{width:44mm}
  @page{margin:12mm}
}

/* Shared-code roster — tap your name to clock in/out */
.roster-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(148px,1fr));gap:12px;margin-top:14px}
.roster-form{margin:0}
.roster-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:9px;width:100%;min-height:98px;
  padding:18px 14px;border-radius:18px;border:1.5px solid var(--line);background:#fff;color:var(--ink);
  font-family:var(--font);font-weight:700;font-size:16px;white-space:normal;text-decoration:none;cursor:pointer;
  box-shadow:var(--shadow-sm);transition:border-color .12s,box-shadow .12s,transform .1s}
.roster-btn:hover{border-color:var(--brand);box-shadow:var(--ring);transform:translateY(-1px)}
.roster-btn .rb-name{font-size:17px;line-height:1.2}
.roster-search{margin-bottom:16px;font-size:17px;padding:14px 16px}
/* Generic list filter input */
.list-search{margin-bottom:6px}

/* Initials avatar */
.avatar{display:inline-flex;align-items:center;justify-content:center;border-radius:50%;font-weight:700;flex:none;line-height:1}

/* Dashboard "who's in" list with live durations */
.in-list{display:flex;flex-direction:column}
.in-row{display:flex;align-items:center;gap:13px;padding:10px 0;border-bottom:1px solid var(--line-2)}
.in-row:last-child{border-bottom:0}
.in-meta{display:flex;flex-direction:column;line-height:1.35;min-width:0}
.in-meta strong{font-weight:700}
.in-meta .muted{font-size:13px}
.in-meta .dur{font-family:var(--mono);font-weight:700;color:var(--brand-ink)}

/* Per-org logo on the clocking screens */
.kiosk-logo{max-height:60px;max-width:200px;margin:0 0 16px;display:block;object-fit:contain}

/* Confirm modal for no-PIN tap-to-clock */
.modal-overlay{position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center;padding:20px;
  background:rgba(15,20,40,.5);opacity:0;visibility:hidden;transition:opacity .2s,visibility .2s}
.modal-overlay.show{opacity:1;visibility:visible}
.modal{background:#fff;border-radius:24px;padding:28px 24px 24px;max-width:360px;width:100%;text-align:center;
  box-shadow:var(--shadow-lg);transform:translateY(14px) scale(.97);transition:transform .2s}
.modal-overlay.show .modal{transform:none}
.modal .avatar{margin:0 auto 14px}
.modal h2{font-size:14px;font-weight:800;text-transform:uppercase;letter-spacing:.08em;margin:0 0 4px}
.modal .modal-name{font-size:24px;font-weight:800;margin:0 0 2px;letter-spacing:-.02em}
.modal-actions{display:flex;gap:12px;margin-top:24px}
.modal-actions .button{flex:1;justify-content:center;padding:15px;font-size:16px}
.modal.in h2{color:var(--ok)}
.modal.in .cm-confirm{background:linear-gradient(135deg,#16a34a,#0c8a52);box-shadow:0 8px 20px rgba(12,138,82,.28)}
.modal.out h2{color:var(--danger)}
.modal.out .cm-confirm{background:linear-gradient(135deg,#ef4444,#c0392b);box-shadow:0 8px 20px rgba(192,57,43,.26)}

/* ============================================================
   APP SHELL (logged in) — sidebar + content
   ============================================================ */
.layout{display:grid;grid-template-columns:var(--side-w) minmax(0,1fr);min-height:100vh}
.side{
  position:sticky;top:0;align-self:start;height:100vh;
  background:var(--surface);border-right:1px solid var(--line);
  padding:22px 16px;display:flex;flex-direction:column;gap:6px;
}
.side .brand{display:flex;align-items:center;gap:11px;padding:6px 8px 14px;font-weight:800;font-size:19px;letter-spacing:-.02em}
.side .brand img{width:34px;height:34px}
.org-chip{margin:0 6px 14px;padding:10px 12px;border-radius:var(--r-sm);background:var(--grad-soft);
  font-size:13px;font-weight:700;color:var(--brand-ink);display:flex;align-items:center;gap:8px}
.org-chip .dot{width:8px;height:8px;border-radius:50%;background:var(--brand);flex:none}
.nav{display:flex;flex-direction:column;gap:3px}
.nav a{display:flex;align-items:center;gap:12px;padding:11px 13px;border-radius:var(--r-sm);
  color:#4b5269;font-weight:650;font-size:15px;transition:background .12s,color .12s}
.nav a svg{width:21px;height:21px;flex:none;opacity:.85}
.nav a:hover{background:var(--surface-2);color:var(--ink)}
.nav a.active{background:var(--grad);color:#fff;box-shadow:0 8px 18px rgba(45,80,230,.26)}
.nav a.active svg{opacity:1}
.side .spacer{flex:1}
.side .foot{border-top:1px solid var(--line);padding-top:12px;margin-top:6px}
.side .foot form{margin:0}
.side .foot button{width:100%;background:transparent;color:var(--muted);box-shadow:none;justify-content:flex-start;gap:12px;padding:11px 13px;font-weight:650;font-size:15px}
.side .foot button:hover{background:var(--danger-bg);color:var(--danger);transform:none}
.side .foot svg{width:21px;height:21px}

.content{min-width:0;display:flex;flex-direction:column}
.content main{max-width:1080px;width:100%;margin:0 auto;padding:30px 30px 60px}

/* ============================================================
   PUBLIC SHELL (logged out) — top bar
   ============================================================ */
.pub-bar{position:sticky;top:0;z-index:20;background:rgba(255,255,255,.82);backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line);padding:14px 22px;display:flex;align-items:center;justify-content:space-between}
.pub-bar .brand{display:flex;align-items:center;gap:11px;font-weight:800;font-size:20px;letter-spacing:-.02em;color:var(--ink)}
.pub-bar .brand img{width:34px;height:34px}
.pub-bar nav{display:flex;gap:10px;align-items:center}
.pub-bar nav a{font-weight:650;font-size:15px;color:#4b5269;padding:9px 14px;border-radius:var(--pill)}
.pub-bar nav a.cta{background:var(--grad);color:#fff;box-shadow:0 8px 18px rgba(45,80,230,.24)}
.pub-main{max-width:480px;margin:0 auto;padding:40px 20px 60px}
/* Kiosk: staff clocking screens with no nav, just a subtle credit */
.kiosk{min-height:100vh;display:flex;flex-direction:column}
.kiosk .pub-main{flex:1;width:100%;padding-top:48px}
.powered{text-align:center;padding:18px 20px 30px}
.powered a{display:inline-flex;align-items:center;gap:8px;color:var(--faint);font-size:13px;font-weight:600;text-decoration:none}
.powered a:hover{color:var(--muted)}
.powered img{width:20px;height:20px;opacity:.85}
.pub-main.wide{max-width:1120px}
.pub-main h1{margin-bottom:14px}
.auth-head{text-align:center;margin-bottom:8px}
.auth-head .logo-chip{margin:0 auto 16px}

.logo-chip{width:62px;height:62px;border-radius:20px;background:#fff;box-shadow:var(--shadow);
  display:inline-flex;align-items:center;justify-content:center}
.logo-chip img{width:46px;height:46px}

/* ============================================================
   LANDING PAGE
   ============================================================ */
.landing-hero{position:relative;overflow:hidden;border-radius:var(--r-lg);
  background:var(--grad);color:#fff;padding:64px 40px 60px;text-align:center;box-shadow:var(--shadow-lg)}
.landing-hero::before,.landing-hero::after{content:"";position:absolute;border-radius:50%;filter:blur(50px);opacity:.55}
.landing-hero::before{width:340px;height:340px;background:#8b9bff;top:-120px;right:-80px}
.landing-hero::after{width:300px;height:300px;background:#a78bff;bottom:-130px;left:-70px}
.landing-hero>*{position:relative;z-index:1}
.landing-hero .logo-chip{margin-bottom:22px}
.landing-hero h1{font-size:clamp(34px,5.2vw,58px);font-weight:800;margin-bottom:16px}
.landing-hero p.lead{font-size:clamp(17px,2vw,20px);color:#eaefff;max-width:660px;margin:0 auto 26px}
.landing-hero .actions{justify-content:center}
.landing-hero .button.secondary{background:rgba(255,255,255,.14);color:#fff;border-color:rgba(255,255,255,.45)}
.landing-hero .button.secondary:hover{background:rgba(255,255,255,.24)}
.landing-hero .trust{margin-top:22px;color:#d6deff;font-size:14px;font-weight:600;display:flex;gap:18px;justify-content:center;flex-wrap:wrap}
.landing-hero .trust span{display:inline-flex;align-items:center;gap:7px}

/* Eyebrow — mono, tracked, with a tally mark */
.eyebrow{display:inline-flex;align-items:center;gap:11px;font-family:var(--mono);font-size:12.5px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:#dbe3ff;margin-bottom:20px}
.section-head .eyebrow{color:var(--brand);justify-content:center}

/* Five-bar tally — the signature mark */
.tally{display:inline-block;vertical-align:middle}
.tally line,.tally path{stroke:currentColor;stroke-width:2.4;stroke-linecap:round}
.eyebrow .tally{width:32px;height:19px}
.land-foot .tally{width:30px;height:18px;opacity:.55;margin-right:4px}
.trust svg{width:18px;height:18px;opacity:.9}

/* Live clock — the hero "moment": the page is literally keeping time */
.live-clock{display:inline-flex;align-items:center;gap:14px;margin:6px auto 4px;padding:12px 20px;border-radius:var(--pill);
  background:rgba(255,255,255,.13);border:1px solid rgba(255,255,255,.28);backdrop-filter:blur(6px)}
.live-clock .lc-dot{width:11px;height:11px;border-radius:50%;background:#7bf1b8;box-shadow:0 0 0 0 rgba(123,241,184,.65);animation:lc-pulse 2s infinite}
.live-clock .lc-time{font-family:var(--mono);font-weight:700;font-size:24px;letter-spacing:.04em;color:#fff;font-variant-numeric:tabular-nums}
.live-clock .lc-label{font-family:var(--mono);font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:#cdd9ff}
@keyframes lc-pulse{0%{box-shadow:0 0 0 0 rgba(123,241,184,.6)}70%{box-shadow:0 0 0 11px rgba(123,241,184,0)}100%{box-shadow:0 0 0 0 rgba(123,241,184,0)}}
@media (prefers-reduced-motion:reduce){.live-clock .lc-dot{animation:none}}
.section-head{text-align:center;max-width:640px;margin:60px auto 8px}
.section-head h2{font-size:clamp(24px,3vw,34px)}
.section-head p{color:var(--muted);font-size:16px}
.feature{padding:26px}
.feature .ic{width:50px;height:50px;border-radius:16px;background:var(--grad-soft);color:var(--brand);
  display:flex;align-items:center;justify-content:center;margin-bottom:14px}
.feature .ic svg{width:26px;height:26px}
.feature h3{margin-bottom:6px}
.feature p{color:var(--muted);margin:0;font-size:15px}
.steps{counter-reset:step}
.step{position:relative;padding:24px 24px 24px 70px}
.step::before{counter-increment:step;content:counter(step);position:absolute;left:24px;top:24px;
  width:34px;height:34px;border-radius:50%;background:var(--grad);color:#fff;font-weight:700;font-family:var(--mono);
  display:flex;align-items:center;justify-content:center;font-size:15px}
.step h3{margin-bottom:4px}
.step p{color:var(--muted);margin:0;font-size:15px}
.cta-band{margin-top:60px;text-align:center;background:var(--grad-soft);border:1px solid #e4e6fb;
  border-radius:var(--r-lg);padding:48px 30px}
.cta-band h2{margin-bottom:8px}
.cta-band p{color:var(--muted);margin-bottom:22px}
.land-foot{text-align:center;color:var(--faint);font-size:14px;margin:40px 0 0;padding:24px 0 0;border-top:1px solid var(--line)}

/* ============================================================
   RESPONSIVE — sidebar becomes a slide-out drawer on mobile
   ============================================================ */
/* Mobile chrome (hidden on desktop) */
.navcb{display:none}
.mobilebar{display:none}
.nav-backdrop{display:none}
.hamburger{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:12px;
  cursor:pointer;color:var(--ink);border:1px solid var(--line);background:#fff}
.hamburger svg{width:24px;height:24px}
.mb-brand{display:flex;align-items:center;gap:10px;font-weight:800;font-size:18px;letter-spacing:-.02em;color:var(--ink);text-decoration:none}
.mb-brand img{width:30px;height:30px}

@media (max-width:860px){
  .layout{grid-template-columns:minmax(0,1fr)}
  .content{overflow-x:clip}
  .content main{padding:76px 14px 44px}
  .mobilebar{display:flex;align-items:center;justify-content:space-between;position:fixed;top:0;left:0;right:0;z-index:60;height:62px;
    background:rgba(255,255,255,.94);backdrop-filter:blur(12px);border-bottom:1px solid var(--line);padding:10px 14px}
  .side{
    position:fixed;top:0;left:0;bottom:0;height:100%;width:266px;max-width:84vw;
    transform:translateX(-100%);transition:transform .22s ease;z-index:80;
    border-right:1px solid var(--line);box-shadow:0 22px 60px rgba(20,20,50,.22);overflow-y:auto;
  }
  .navcb:checked ~ .side{transform:none}
  .nav-backdrop{display:block;position:fixed;inset:0;background:rgba(15,20,40,.42);z-index:70;
    opacity:0;visibility:hidden;transition:opacity .2s,visibility .2s}
  .navcb:checked ~ .nav-backdrop{opacity:1;visibility:visible}
  .nav a{padding:13px 14px;font-size:16px}
  .side .foot button{font-size:16px;padding:13px 14px}
}
@media (max-width:560px){
  .card{padding:18px;border-radius:var(--r)}
  .landing-hero{padding:48px 22px 44px}
  .actions .button,.actions button{width:100%}
}
