@font-face{font-family:'TH Sarabun New Local';src:url('/assets/fonts/THSarabunNew.ttf') format('truetype');font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:'TH Sarabun New Local';src:url('/assets/fonts/THSarabunNew%20Bold.ttf') format('truetype');font-weight:700 900;font-style:normal;font-display:swap}
@font-face{font-family:'TH Sarabun New Local';src:url('/assets/fonts/THSarabunNew%20Italic.ttf') format('truetype');font-weight:400;font-style:italic;font-display:swap}
@font-face{font-family:'TH Sarabun New Local';src:url('/assets/fonts/THSarabunNew%20BoldItalic.ttf') format('truetype');font-weight:700 900;font-style:italic;font-display:swap}
:root{
    --font-ui:"Noto Sans Thai","Prompt","Inter",system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Tahoma,sans-serif;
    --font-report:"TH Sarabun New Local","TH Sarabun New","Sarabun","Noto Sans Thai",Tahoma,sans-serif;
    --bg:#eef6f5;
    --bg2:#f8fbff;
    --card:rgba(255,255,255,.92);
    --text:#0f172a;
    --muted:#64748b;
    --line:#dbe7ea;
    --line2:#eef3f5;
    --primary:#0f766e;
    --primary2:#0ea5a4;
    --primary-dark:#0a5f59;
    --accent:#f59e0b;
    --soft:#e8f7f3;
    --soft2:#f0fdfa;
    --danger:#b42318;
    --danger-bg:#fff1f0;
    --warn:#b54708;
    --warn-bg:#fff7e6;
    --success:#087443;
    --success-bg:#ecfdf3;
    --info:#075985;
    --info-bg:#eef7ff;
    --radius:24px;
    --radius-sm:16px;
    --shadow:0 22px 70px rgba(15,23,42,.10);
    --shadow-soft:0 12px 34px rgba(15,23,42,.075);
}
*{box-sizing:border-box}
html{font-size:16px;-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{
    margin:0;
    font-family:var(--font-ui);
    color:var(--text);
    min-height:100vh;
    background:
        radial-gradient(circle at 12% 8%, rgba(14,165,164,.18), transparent 30rem),
        radial-gradient(circle at 90% 0%, rgba(245,158,11,.14), transparent 28rem),
        linear-gradient(180deg,var(--bg2) 0%,var(--bg) 100%);
}
a{color:var(--primary);text-decoration:none}
a:hover{text-decoration:none;color:var(--primary-dark)}
img,video,canvas{max-width:100%}
button,input,select,textarea{font:inherit}
.topbar{
    position:sticky;top:0;z-index:50;
    display:flex;align-items:center;justify-content:space-between;gap:18px;
    padding:14px clamp(14px,3vw,46px);
    background:rgba(255,255,255,.78);
    border-bottom:1px solid rgba(219,231,234,.85);
    backdrop-filter:blur(22px) saturate(1.25);
    -webkit-backdrop-filter:blur(22px) saturate(1.25);
}
.brand{display:flex;align-items:center;gap:13px;color:var(--text);min-width:0}
.brand:hover{color:var(--text)}
.brand-mark{
    display:grid;place-items:center;flex:0 0 auto;
    width:52px;height:52px;border-radius:18px;
    background:linear-gradient(135deg,var(--primary),var(--primary2));
    color:white;font-weight:900;letter-spacing:.02em;
    box-shadow:0 18px 38px rgba(15,118,110,.25), inset 0 1px 0 rgba(255,255,255,.35);
}
.brand-mark span{font-size:1.03rem}
.brand-text{min-width:0}.brand strong{display:block;font-size:1.04rem;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.brand small{display:block;color:var(--muted);font-size:.84rem;margin-top:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:46vw}
.main-nav{display:flex;align-items:center;gap:6px;justify-content:flex-end;flex-wrap:wrap}
.main-nav a{padding:10px 14px;border-radius:999px;color:#172033;font-weight:750;font-size:.93rem;transition:.18s ease;background:transparent}
.main-nav a:hover,.main-nav a.active{background:var(--soft);color:var(--primary);box-shadow:inset 0 0 0 1px rgba(15,118,110,.08)}
.nav-toggle{display:none;width:44px;height:44px;border:1px solid var(--line);background:white;border-radius:15px;padding:10px;box-shadow:var(--shadow-soft);cursor:pointer}
.nav-toggle span{display:block;width:100%;height:2px;background:#172033;border-radius:999px;margin:5px 0}
.page{width:min(1440px,100%);margin:0 auto;padding:26px clamp(14px,3vw,42px) 60px}
.footer{display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap;color:var(--muted);font-size:.9rem;border-top:1px solid rgba(219,231,234,.8);padding:20px clamp(16px,3vw,48px);background:rgba(255,255,255,.52)}
.card{background:var(--card);border:1px solid rgba(219,231,234,.9);border-radius:var(--radius);box-shadow:var(--shadow);padding:clamp(18px,3vw,30px);margin-bottom:22px;backdrop-filter:blur(12px)}
h1,h2,h3{line-height:1.25;margin:0 0 12px;letter-spacing:-.015em}h1{font-size:clamp(1.55rem,2.3vw,2.25rem)}h2{font-size:clamp(1.18rem,1.5vw,1.4rem)}h3{font-size:1.05rem}.muted{color:var(--muted)}.eyebrow{color:var(--primary);font-weight:900;letter-spacing:.05em;margin:0 0 8px;text-transform:uppercase}.hint{font-size:.92rem;color:var(--muted);line-height:1.7}.lead{font-size:1.08rem;line-height:1.8;color:#334155}
.hero{display:flex;align-items:center;justify-content:space-between;gap:24px;overflow:hidden;background:linear-gradient(135deg,rgba(255,255,255,.95),rgba(240,253,250,.92));position:relative}
.hero:after{content:"";position:absolute;right:-80px;top:-90px;width:260px;height:260px;border-radius:50%;background:linear-gradient(135deg,rgba(15,118,110,.16),rgba(245,158,11,.10));pointer-events:none}.hero>*{position:relative;z-index:1}
.grid{display:grid;gap:22px}.grid.two{grid-template-columns:repeat(2,minmax(0,1fr))}.grid.two.uneven{grid-template-columns:minmax(320px,.55fr) minmax(0,1fr)}
.stat-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:16px;margin-bottom:22px}.small-stats{grid-template-columns:repeat(5,minmax(0,1fr))}
.stat{display:block;color:var(--text);margin:0;transition:.18s ease}.stat:hover{transform:translateY(-2px);color:var(--text);box-shadow:0 26px 70px rgba(15,23,42,.12)}.stat span{display:block;color:var(--muted);font-size:.93rem}.stat strong{display:block;font-size:2.05rem;line-height:1;margin-top:10px;color:var(--primary);letter-spacing:-.03em}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:1px solid var(--line);background:rgba(255,255,255,.95);color:var(--text);border-radius:15px;padding:11px 16px;font-weight:850;cursor:pointer;min-height:44px;box-shadow:0 8px 20px rgba(15,23,42,.045);transition:.16s ease}.btn:hover{transform:translateY(-1px);background:#fff;color:var(--primary);box-shadow:var(--shadow-soft)}.btn.primary{background:linear-gradient(135deg,var(--primary),var(--primary2));border-color:transparent;color:white}.btn.primary:hover{color:white;background:linear-gradient(135deg,var(--primary-dark),var(--primary));box-shadow:0 16px 34px rgba(15,118,110,.22)}.btn.big{padding:15px 21px;font-size:1rem;border-radius:17px}.btn.small{padding:7px 10px;min-height:34px;font-size:.86rem;border-radius:12px}.btn.danger,.danger{border-color:#fecaca;color:var(--danger);background:#fff5f5}.btn.danger:hover{background:#ffecec;color:var(--danger)}.actions{display:flex;gap:10px;align-items:center}.actions.wrap{flex-wrap:wrap}.actions.vertical{flex-direction:column;align-items:stretch}.form-actions{display:flex;gap:10px;align-items:end;flex-wrap:wrap}.form-actions.full{grid-column:1/-1}
.auth-wrap{min-height:calc(100vh - 180px);display:grid;place-items:center}.auth-card{width:min(480px,100%)}
.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}.form-grid.single{grid-template-columns:1fr}.report-filter{grid-template-columns:repeat(4,minmax(160px,1fr))}
label{display:grid;gap:8px;font-weight:800;color:#172033}input,select,textarea{width:100%;border:1px solid #cfdbe0;border-radius:16px;padding:13px 14px;background:white;color:var(--text);outline:none;transition:.15s ease}input:focus,select:focus,textarea:focus{border-color:var(--primary);box-shadow:0 0 0 4px rgba(15,118,110,.12)}.checkline{display:flex;align-items:center;gap:10px}.checkline input{width:auto}.alert{border-radius:18px;padding:14px 16px;margin:0 0 18px;border:1px solid transparent;line-height:1.65}.alert-success{background:var(--success-bg);border-color:#a7f3d0;color:var(--success)}.alert-danger,.alert-error{background:var(--danger-bg);border-color:#fecaca;color:var(--danger)}.alert-info{background:var(--info-bg);border-color:#bae6fd;color:var(--info)}.alert-warning{background:var(--warn-bg);border-color:#fed7aa;color:var(--warn)}
.badge{display:inline-flex;align-items:center;border-radius:999px;padding:5px 11px;font-size:.82rem;font-weight:900;white-space:nowrap}.badge.ok{background:var(--success-bg);color:var(--success)}.badge.warn{background:var(--warn-bg);color:var(--warn)}.badge.bad{background:var(--danger-bg);color:var(--danger)}.muted-badge{background:#eef2f7;color:var(--muted)}
.timeline{display:grid;gap:12px}.time-row{display:grid;grid-template-columns:1fr auto auto;gap:12px;align-items:center;border:1px solid var(--line);border-radius:18px;padding:14px;background:#fff}.clean-list{padding-left:20px;line-height:1.8}.info-list{display:grid;gap:12px;margin:0}.info-list div{display:grid;grid-template-columns:150px 1fr;gap:12px;border-bottom:1px dashed var(--line);padding-bottom:10px}.info-list dt{font-weight:850}.info-list dd{margin:0;color:var(--muted)}
.table-wrap{overflow:auto;border:1px solid var(--line);border-radius:20px;background:#fff;box-shadow:0 10px 28px rgba(15,23,42,.04)}table{width:100%;border-collapse:separate;border-spacing:0;min-width:820px;background:white}th,td{padding:13px 15px;border-bottom:1px solid var(--line2);text-align:left;vertical-align:middle}th{position:sticky;top:0;background:#f8fafc;font-size:.9rem;color:#334155;white-space:nowrap;font-weight:900;z-index:1}tr:last-child td{border-bottom:0}tbody tr:hover td{background:#fbfefd}.row-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.row-actions form{margin:0}.empty{text-align:center;color:var(--muted);padding:34px!important}
.scanner-head{display:flex;justify-content:space-between;align-items:flex-start;gap:18px}.scanner-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:24px;align-items:start}.qr-video{width:100%;background:#0f172a;border-radius:22px;min-height:320px;object-fit:cover}.manual-panel{border:1px solid var(--line);border-radius:22px;padding:20px;background:#fbfdfd}.gps-box{border-radius:18px;background:#f8fafc;padding:14px;border:1px solid var(--line)}
.qr-display{text-align:center}.qr-card{display:inline-grid;gap:10px;justify-items:center;border:1px solid var(--line);border-radius:24px;background:#fff;padding:18px;margin:8px auto 18px;box-shadow:var(--shadow-soft)}.qr-card img{width:min(320px,80vw);height:auto}.qr-card.expired{opacity:.55;filter:grayscale(1)}
.face-camera-box{position:relative;overflow:hidden;border-radius:28px;aspect-ratio:4/3;background:#07111f;box-shadow:0 28px 75px rgba(15,23,42,.18), inset 0 0 0 1px rgba(255,255,255,.04)}.face-video{display:block;width:100%;height:100%;object-fit:cover;transform:scaleX(-1);background:#0f172a}.face-oval{position:absolute;left:50%;top:50%;width:min(56%,260px);height:min(72%,330px);transform:translate(-50%,-50%);border:4px solid rgba(255,255,255,.92);border-radius:50%;box-shadow:0 0 0 999px rgba(0,0,0,.18),0 0 28px rgba(255,255,255,.28);pointer-events:none}.face-guide{position:absolute;left:50%;bottom:16px;transform:translateX(-50%);padding:9px 13px;border-radius:999px;background:rgba(15,23,42,.72);color:#fff;font-weight:900;font-size:.9rem;white-space:nowrap}.camera-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-top:14px}
code{background:#f1f5f9;border:1px solid #e2e8f0;border-radius:8px;padding:2px 6px}.report-page .card.report-card,.report-card{font-family:var(--font-report);font-size:20px;line-height:1.45}.report-page .report-title{font-family:var(--font-report);font-size:30px;text-align:center;margin-bottom:4px}.report-page .report-subtitle{font-family:var(--font-report);font-size:22px;text-align:center;color:#334155;margin-bottom:16px}.report-page table{font-family:var(--font-report);font-size:19px}.report-page th{font-size:19px}.report-page .report-filter,.report-page .stat-grid,.report-page .alert,.report-page .actions{font-family:var(--font-ui);font-size:1rem}.print-only{display:none!important}
@media (max-width:1080px){.grid.two,.grid.two.uneven,.scanner-grid{grid-template-columns:1fr}.stat-grid,.small-stats{grid-template-columns:repeat(2,minmax(0,1fr))}.hero,.scanner-head{align-items:stretch;flex-direction:column}.main-nav a{padding:9px 11px}.report-filter{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width:760px){.topbar{align-items:center}.brand-mark{width:46px;height:46px;border-radius:16px}.nav-toggle{display:block;flex:0 0 auto}.main-nav{position:fixed;left:14px;right:14px;top:76px;display:grid;grid-template-columns:1fr;gap:6px;padding:12px;background:rgba(255,255,255,.96);border:1px solid var(--line);border-radius:22px;box-shadow:var(--shadow);transform:translateY(-10px);opacity:0;pointer-events:none;transition:.16s ease}.nav-open .main-nav{transform:translateY(0);opacity:1;pointer-events:auto}.main-nav a{border-radius:14px;padding:12px 14px}.page{padding-top:18px}.form-grid,.report-filter{grid-template-columns:1fr}.stat-grid,.small-stats{grid-template-columns:1fr}.time-row{grid-template-columns:1fr}.actions{align-items:stretch;flex-direction:column}.actions.wrap,.form-actions{align-items:stretch}.btn{width:100%}.table-wrap{border-radius:16px}th,td{padding:11px 12px}.face-camera-box{aspect-ratio:3/4}.face-oval{width:64%;height:62%}.face-guide{font-size:.82rem}.brand small{max-width:62vw}.footer{display:grid}}

body.modal-open{overflow:hidden}
.app-modal-overlay{position:fixed;inset:0;z-index:9999;display:grid;place-items:center;padding:18px;background:rgba(15,23,42,.52);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);animation:modalFade .14s ease-out}
.app-modal{width:min(520px,100%);display:flex;gap:16px;align-items:flex-start;background:#fff;border:1px solid rgba(255,255,255,.78);border-radius:28px;box-shadow:0 36px 110px rgba(15,23,42,.32);padding:22px;animation:modalPop .16s ease-out}
.app-modal-icon{flex:0 0 auto;width:58px;height:58px;border-radius:22px;display:grid;place-items:center;font-weight:1000;font-size:1.65rem;background:var(--info-bg);color:var(--info);box-shadow:inset 0 0 0 1px rgba(7,89,133,.10)}
.app-modal-success .app-modal-icon{background:var(--success-bg);color:var(--success)}
.app-modal-danger .app-modal-icon,.app-modal-error .app-modal-icon{background:var(--danger-bg);color:var(--danger)}
.app-modal-body{min-width:0;flex:1}.app-modal-body h2{margin:2px 0 8px;font-size:1.35rem}.app-modal-body p{margin:0;color:#334155;line-height:1.7;font-weight:650}.app-modal-details{margin-top:12px;padding:12px 14px;border-radius:16px;background:#f8fafc;color:#475569;line-height:1.75;border:1px solid var(--line)}.app-modal-actions{display:flex;justify-content:flex-end;gap:10px;flex-wrap:wrap;margin-top:18px}
@keyframes modalFade{from{opacity:0}to{opacity:1}}@keyframes modalPop{from{opacity:0;transform:translateY(10px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}
@media (max-width:560px){.app-modal{border-radius:24px;padding:18px;gap:12px}.app-modal-icon{width:48px;height:48px;border-radius:18px;font-size:1.35rem}.app-modal-actions{display:grid;grid-template-columns:1fr;width:100%}.app-modal-actions .btn{width:100%}}

@media print{
    @page{size:A4;margin:12mm}
    *{-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important}
    body{background:#fff!important;color:#000!important;font-family:var(--font-report)!important;font-size:18pt!important}
    .topbar,.footer,.btn,.actions,.form-grid,.report-filter,form:not(.printable),.alert,.stat-grid,.no-print{display:none!important}
    .print-only{display:block!important}
    .page{width:100%!important;max-width:none!important;margin:0!important;padding:0!important}
    .card{box-shadow:none!important;border:0!important;border-radius:0!important;padding:0!important;margin:0 0 8mm!important;background:#fff!important}
    h1,h2,h3,.report-title{font-family:var(--font-report)!important;color:#000!important}.report-title{font-size:28pt!important}.report-subtitle{font-size:20pt!important;color:#000!important}
    .table-wrap{overflow:visible!important;border:1px solid #000!important;border-radius:0!important;box-shadow:none!important}
    table{min-width:0!important;width:100%!important;border-collapse:collapse!important;font-family:var(--font-report)!important;font-size:16pt!important;background:#fff!important}
    th,td{border:1px solid #000!important;padding:4pt 5pt!important;color:#000!important;background:#fff!important;white-space:normal!important;vertical-align:top!important}
    th{font-size:16pt!important;font-weight:700!important;text-align:center!important}
    tr{break-inside:avoid;page-break-inside:avoid}
    .badge{border:0!important;background:#fff!important;color:#000!important;padding:0!important;font-size:15pt!important}
    a{color:#000!important}
    .qr-card{transform:none;margin:0 auto}.qr-card img{width:88mm!important}
}

.auth-extra{
    margin-top:16px;
    padding-top:14px;
    border-top:1px solid var(--line);
    display:flex;
    gap:10px;
    align-items:center;
    justify-content:space-between;
    flex-wrap:wrap;
}
.consent-line{align-items:flex-start;gap:10px}
