﻿/* ============ Kiosk (visitor-facing) ============ */
.kiosk{min-height:100dvh;display:flex;flex-direction:column;align-items:center;
  padding:32px 20px 96px;max-width:760px;margin:0 auto}

/* Logo */
.logo-wrap{margin-top:24px;text-align:center;animation:fadeUp .6s var(--ease) both}
/* height-based so logos of any width/aspect-ratio show fully (object-fit:contain) */
.logo{height:84px;width:auto;max-width:280px;border-radius:20px;object-fit:contain;
  background:var(--glass);border:1px solid var(--border);padding:8px 14px;
  animation:logoIn .6s var(--ease) both;
  box-shadow:0 12px 32px rgba(15,23,42,.12)}
.logo.size-small{height:60px;max-width:220px}
.logo.size-large{height:116px;max-width:340px}
.logo-fallback{width:auto;aspect-ratio:1;padding:0;display:grid;place-items:center;
  font-family:'Plus Jakarta Sans';font-weight:800;font-size:38px;color:var(--accent)}
@keyframes logoIn{from{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}

.company-name{font-size:13px;letter-spacing:.22em;text-transform:uppercase;font-weight:600;
  color:var(--text-muted);margin:18px 0 2px}
.hero{font-family:'Plus Jakarta Sans';font-size:clamp(30px,5.5vw,46px);font-weight:700;margin:14px 0 10px;
  color:var(--text-primary);letter-spacing:-.02em;line-height:1.12}
.hero-co{color:var(--accent)}
.hero-sub{color:var(--text-muted);font-size:15.5px;max-width:430px;text-align:center;margin-bottom:8px;line-height:1.55}

/* Search bar */
.search-card{width:100%;margin-top:28px;padding:8px 8px 8px 6px}
.search-box{display:flex;gap:8px;align-items:center}
.search-box .icon{display:inline-grid;place-items:center;padding-left:10px;color:var(--text-muted)}
.search-box .icon svg{width:21px;height:21px}
.search-box input{flex:1;border:0;background:transparent;color:var(--text-primary);
  font-size:18px;padding:14px 6px;outline:none}
.search-box input::placeholder{color:#6B7280}

/* Divider */
.or-divider{display:flex;align-items:center;gap:14px;width:100%;margin:30px 0 18px;
  color:var(--text-muted);font-size:13px;letter-spacing:.12em}
.or-divider::before,.or-divider::after{content:"";flex:1;height:1px;background:var(--border)}

/* Visit type grid */
.visit-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;width:100%}
@media(min-width:720px){.visit-grid{grid-template-columns:repeat(4,1fr)}}
.visit-card{padding:24px 14px;text-align:center;cursor:pointer;border-radius:var(--r-card);
  transition:transform .2s var(--ease),box-shadow .25s,border-color .2s;position:relative;overflow:hidden}
.visit-card:hover{transform:translateY(-4px);box-shadow:0 16px 38px rgba(0,0,0,.32);
  border-color:var(--accent)}
.visit-card .visit-icon{display:inline-grid;place-items:center;width:56px;height:56px;margin:0 auto 14px;
  border-radius:16px;background:var(--accent-soft);color:var(--accent);
  transition:background .2s,color .2s,transform .2s var(--ease)}
.visit-card:hover .visit-icon{background:var(--accent);color:#fff;transform:scale(1.05)}
.visit-card .visit-icon svg{width:26px;height:26px}
.visit-card .label{font-weight:600;font-size:15px}
.visit-card .sub{font-size:12px;color:var(--text-muted);margin-top:3px}

/* Status check */
.status-check-row{margin-top:12px;display:flex;justify-content:center}
.status-card{width:100%;margin-top:20px;padding:26px;text-align:center;animation:fadeUp .4s var(--ease) both;
  border-left:3px solid var(--border)}
.status-card.status-green{border-left-color:var(--success)}
.status-card.status-amber{border-left-color:var(--warn)}
.status-card.status-red{border-left-color:var(--danger)}
.status-card .status-emoji{margin-bottom:10px;color:var(--text-muted);line-height:0}
.status-card.status-green .status-emoji{color:var(--success)}
.status-card.status-amber .status-emoji{color:var(--warn)}
.status-card.status-red .status-emoji{color:var(--danger)}
.result-meta span{display:inline-flex;align-items:center;gap:5px}
.status-card .status-title{font-family:'Plus Jakarta Sans';font-size:22px;font-weight:700;margin-bottom:6px}
.status-card .status-badge{display:inline-block;margin-top:14px;padding:8px 16px;border-radius:var(--r-pill);
  background:rgba(0,0,0,.28);border:1px solid var(--border);color:var(--accent);font-size:15px;letter-spacing:1px}

/* Search result card */
.result-card{width:100%;margin-top:22px;padding:22px;animation:fadeUp .4s var(--ease) both}
.result-head{display:flex;gap:16px;align-items:center;margin-bottom:18px}
.result-photo{width:72px;height:72px;border-radius:18px;object-fit:cover;
  border:1px solid var(--border);background:var(--glass)}
.result-photo.placeholder{display:grid;place-items:center;font-size:30px}
.result-name{font-size:22px;font-weight:700;font-family:'Plus Jakarta Sans'}
.result-meta{color:var(--text-muted);font-size:14px;margin-top:4px;display:flex;gap:14px;flex-wrap:wrap}

/* QR (inline, static) */
.qr-inline{margin:34px auto 0;display:flex;flex-direction:column;align-items:center;gap:9px;
  animation:fadeUp .5s var(--ease) both}
.qr-inline #qrCanvas{background:#fff;padding:10px;border-radius:14px;line-height:0;
  box-shadow:0 8px 26px rgba(0,0,0,.35)}
.qr-inline #qrCanvas img,.qr-inline #qrCanvas canvas{display:block;border-radius:6px}
.qr-inline .qr-label{font-size:12px;color:var(--text-muted);letter-spacing:.02em}

/* Staff links footer */
.staff-links{margin-top:34px;display:flex;align-items:center;gap:10px;justify-content:center;
  font-size:13px;color:var(--text-muted)}
.staff-links a{color:var(--text-muted);text-decoration:none;padding:6px 10px;border-radius:8px;transition:.15s}
.staff-links a:hover{color:var(--accent);background:var(--accent-soft)}

/* Install pill — keep horizontal centering on hover/active (override generic .btn transforms) */
.install-pill{position:fixed;left:50%;transform:translateX(-50%);bottom:18px;z-index:25}
.install-pill:hover{transform:translateX(-50%) translateY(-2px)}
.install-pill:active{transform:translateX(-50%) scale(.98)}

/* Form screens */
.screen{width:100%;animation:fadeUp .4s var(--ease) both}
.back-link{display:inline-flex;align-items:center;gap:6px;color:var(--text-muted);
  cursor:pointer;margin-bottom:14px;font-size:14px}
.form-card{width:100%;padding:24px}
.form-title{font-size:24px;font-family:'Plus Jakarta Sans';margin:0 0 4px}
.form-purpose-badge{margin-bottom:18px}
.form-grid{display:grid;gap:14px}
@media(min-width:720px){.form-grid.two{grid-template-columns:1fr 1fr}.form-grid .full{grid-column:1/-1}}

/* Camera */
.camera-widget{margin:6px 0 4px}
.camera-stage{position:relative;width:100%;aspect-ratio:4/3;border-radius:var(--r-card);
  overflow:hidden;background:rgba(0,0,0,.4);border:1px solid var(--border);
  display:grid;place-items:center}
.camera-stage video,.camera-stage img{width:100%;height:100%;object-fit:cover}
.camera-stage .hint{position:absolute;color:var(--text-muted);font-size:14px;padding:20px;text-align:center}
.camera-controls{display:flex;gap:10px;margin-top:12px;flex-wrap:wrap}

/* Thank-you / badge */
.tycard{width:100%;max-width:440px;margin:24px auto;padding:30px;text-align:center}
.checkmark{width:84px;height:84px;margin:0 auto 14px}
.checkmark circle{stroke:var(--success);stroke-width:4;fill:none;
  stroke-dasharray:166;stroke-dashoffset:166;animation:dash .7s var(--ease) forwards}
.checkmark path{stroke:var(--success);stroke-width:5;fill:none;stroke-linecap:round;
  stroke-dasharray:48;stroke-dashoffset:48;animation:dash .5s .5s var(--ease) forwards}
@keyframes dash{to{stroke-dashoffset:0}}
.badge{margin:22px auto;padding:22px;border-radius:18px;background:rgba(0,0,0,.3);
  border:1px dashed var(--border);max-width:330px}
.badge .vid{font-family:'JetBrains Mono';font-size:30px;color:var(--accent);letter-spacing:2px;font-weight:600}
.badge .sep{height:1px;background:var(--border);margin:14px 0}
.badge .meta{display:grid;gap:9px;text-align:left;font-size:14px}
.badge .meta div{display:flex;gap:8px;align-items:center}
.mlabel{color:var(--text-muted);min-width:74px;font-size:12px;text-transform:uppercase;letter-spacing:.04em}
.countdown{color:var(--text-muted);font-size:13px;margin-top:8px}

/* Waiting screen */
.wait-card{width:100%;max-width:460px;margin:30px auto;padding:34px;text-align:center}
.pulse-ring{width:120px;height:120px;margin:0 auto 22px;border-radius:50%;position:relative;
  display:grid;place-items:center;font-size:46px}
.pulse-ring::before,.pulse-ring::after{content:"";position:absolute;inset:0;border-radius:50%;
  border:2px solid var(--accent);animation:pulsering 2s ease-out infinite}
.pulse-ring::after{animation-delay:1s}
@keyframes pulsering{0%{transform:scale(.7);opacity:.8}100%{transform:scale(1.6);opacity:0}}
.wait-info{margin:18px auto;padding:14px 18px;border-radius:14px;background:rgba(0,0,0,.25);
  border:1px solid var(--border);font-size:14px;display:inline-block}
.dots{display:inline-flex;gap:7px;margin:14px 0}
.dots span{width:10px;height:10px;border-radius:50%;background:var(--accent);
  animation:dotpulse 1.2s ease-in-out infinite}
.dots span:nth-child(2){animation-delay:.2s}
.dots span:nth-child(3){animation-delay:.4s}
@keyframes dotpulse{0%,100%{opacity:.3;transform:scale(.8)}50%{opacity:1;transform:scale(1.2)}}
.x-mark{font-size:60px;color:var(--danger);animation:fadeUp .4s var(--ease) both}

@media print{
  body *{visibility:hidden}
  .badge,.badge *{visibility:visible}
  .badge{position:absolute;left:0;top:0;width:100%;border-color:#000;color:#000;background:#fff}
  .ambient{display:none}
}
