/* ══ TOKENS ══ */
:root{
  --bl:#31c2ee;--bl2:#1da8d4;--bl3:#0e8ab3;
  --blt:rgba(49,194,238,.12);--blbd:rgba(49,194,238,.45);--blm:rgba(49,194,238,.6);
  --wbg:#050C14;--w1:#0A1525;--w2:#0F1E33;--wbr:#162944;--wmu:#4A7EA5;--wtx:#EEF6FF;
  --bg:#F0F7FC;--white:#FFFFFF;--border:#DDE8F0;--bmd:#C5D8E8;
  --tx:#0A1525;--tx2:#3A5A75;--tx3:#8AABBC;
  --red:#E53535;--am:#E58C00;--g:#1DB954;
  --xs:0 1px 2px rgba(10,21,37,.06);--sm:0 2px 6px rgba(10,21,37,.08),0 1px 2px rgba(10,21,37,.05);
  --md:0 4px 14px rgba(10,21,37,.1);--lg:0 12px 32px rgba(10,21,37,.14);
  --font:-apple-system,BlinkMacSystemFont,'Inter','Segoe UI',system-ui,sans-serif;
  --mono:ui-monospace,'SF Mono','Courier New',monospace;
  --lp:74px;--rp:74px;--th:54px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent;}
html,body{width:100%;height:100%;overflow:hidden;position:fixed;background:var(--wbg);color:var(--tx);font-family:var(--font);touch-action:manipulation;}
.screen{position:absolute;inset:0;display:none;flex-direction:column;}.screen.on{display:flex;}

/* ── KEYFRAMES ── */
@keyframes blPulse{0%,100%{box-shadow:0 0 14px rgba(49,194,238,.4);}50%{box-shadow:0 0 26px rgba(49,194,238,.75),0 0 0 6px rgba(49,194,238,0);}}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes scl{0%,100%{top:4px}50%{top:calc(100% - 6px)}}
@keyframes fl{0%{opacity:.8}100%{opacity:0}}
@keyframes tup{from{opacity:0;bottom:50px}to{opacity:1;bottom:70px}}
@keyframes tilt{0%,100%{transform:rotate(-16deg)}50%{transform:rotate(16deg)}}
@keyframes cbp{from{opacity:.25}to{opacity:1}}
@keyframes fadeIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
@keyframes scanPop{from{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}
@keyframes scanSlide{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
@keyframes stSweep{from{top:4%;opacity:0}to{top:90%;opacity:.5}}
@keyframes stGrid{0%{opacity:0}40%{opacity:1}100%{opacity:.18}}
@keyframes stCorner{from{opacity:0;transform:scale(.65)}to{opacity:1;transform:scale(1)}}
@keyframes stLbl{from{opacity:.35}to{opacity:1}}
@keyframes vinGlow{0%,100%{box-shadow:0 0 0 2px rgba(49,194,238,.2),0 0 10px rgba(49,194,238,.2);}50%{box-shadow:0 0 0 4px rgba(49,194,238,.4),0 0 24px rgba(49,194,238,.5);}}
@keyframes scopePulse{0%,100%{transform:translate(0,0);}50%{transform:translate(-3px,-3px);}}
@keyframes scopeMirror{0%,100%{transform:translate(0,0);}50%{transform:translate(3px,3px);}}
@keyframes targetPulse{0%,100%{opacity:1;r:3;}50%{opacity:.5;r:5;}}

/* ══════════════════════════════════
   WELCOME — dark brand screen test
══════════════════════════════════ */
#ss{
  flex-direction:column;align-items:center;justify-content:flex-start;gap:24px;padding:28px 20px;
  background:radial-gradient(ellipse at 20% 55%,rgba(49,194,238,.08) 0%,transparent 55%),var(--wbg);
  position:relative;overflow-x:hidden;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior-y:contain;
}
#ss .w-logo,#ss .w-card{flex-shrink:0;}
/* Landscape — two column: logo left, card right — pure orientation, no height cap */
@media(orientation:landscape){
  #ss{flex-direction:row;align-items:flex-start;justify-content:center;gap:28px;padding:14px 32px;overflow-y:auto;}
  #ss .w-logo{flex-shrink:0;align-items:flex-start;justify-content:center;}
  #ss .w-card{max-width:380px;flex-shrink:0;}
  #ss .w-steps{gap:5px;margin-bottom:8px;}
  #ss .w-txt{font-size:11px;}
  #ss .w-icon{width:34px!important;height:34px!important;}
  #ss .w-name{font-size:24px;}
  #ss .w-sub{font-size:8px;}
  #ss .w-card{padding:12px 16px;}
  #ss .w-sect-lbl{margin-bottom:4px;}
  #ss .w-div{margin:2px 0 8px;}
  #ss .w-set-row{margin-bottom:7px;}
  #ss .w-cam-status{margin-bottom:6px;}
  #ss .btn-begin{padding:11px;}
}
#ss::before{content:'';position:absolute;inset:0;pointer-events:none;
  background-image:linear-gradient(rgba(49,194,238,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(49,194,238,.04) 1px,transparent 1px);
  background-size:30px 30px;}
.w-logo{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:4px;}
.w-wordmark{display:flex;align-items:center;gap:10px;}
.w-icon{width:44px;height:44px;flex-shrink:0;}
.w-name{font-size:32px;font-weight:800;letter-spacing:-.5px;color:var(--wtx);}
.w-name span{color:var(--bl);font-weight:900;}
.w-sub{font-size:9px;font-weight:700;letter-spacing:4px;text-transform:uppercase;color:var(--wmu);}
.w-card{position:relative;z-index:1;width:100%;max-width:340px;background:var(--w1);border:1px solid var(--wbr);border-radius:14px;padding:20px;}
.w-sect-lbl{font-size:9px;font-weight:800;letter-spacing:3px;text-transform:uppercase;color:var(--wmu);margin-bottom:8px;}
.w-steps{display:flex;flex-direction:column;gap:9px;margin-bottom:16px;}
.w-step{display:flex;align-items:flex-start;gap:10px;}
.w-num{width:20px;height:20px;border-radius:50%;background:var(--bl);color:#fff;font-size:10px;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px;}
.w-txt{font-size:12px;color:var(--wmu);line-height:1.5;}.w-txt b{color:var(--wtx);font-weight:700;}
.w-div{border:none;border-top:1px solid var(--wbr);margin:4px 0 14px;}
.w-set-row{display:flex;gap:7px;margin-bottom:14px;} .w-set-row .w-sel{flex:1;}
.w-sel{flex:1;background:var(--w2);border:1px solid var(--wbr);border-radius:8px;padding:9px 26px 9px 12px;color:var(--wtx);font-size:12px;font-weight:500;outline:none;cursor:pointer;-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%234A7EA5' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;}
.w-sel option{background:var(--w1);}
.w-sets-btn{background:var(--w2);border:1px solid var(--wbr);border-radius:8px;padding:9px 10px;color:var(--wmu);font-size:11px;font-weight:600;cursor:pointer;white-space:nowrap;}
.w-sets-btn:active{background:var(--wbr);}
.claim-start{display:flex;align-items:center;gap:8px;border:1px solid rgba(49,194,238,.24);background:rgba(49,194,238,.08);border-radius:8px;padding:9px 10px;margin-bottom:9px;min-height:48px;}
.claim-start.bound{border-color:rgba(29,185,84,.38);background:rgba(29,185,84,.08);}
.claim-start.offline{border-color:rgba(229,140,0,.36);background:rgba(229,140,0,.09);}
.claim-start-main{flex:1;min-width:0;}
.claim-start-title{font-size:12px;font-weight:800;color:var(--wtx);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.claim-start-meta{font-size:10px;color:var(--wmu);line-height:1.35;margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.claim-start-btn{flex-shrink:0;background:var(--w2);border:1px solid var(--wbr);border-radius:7px;color:var(--bl);font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.08em;padding:8px 9px;cursor:pointer;}
.claim-start-btn:active{background:var(--wbr);}
.offline-sets{display:none;gap:7px;margin-top:18px;padding-top:15px;border-top:1px solid var(--wbr);}
.offline-sets.on{display:grid;}
.offline-sets.on::before{content:'Pending inspection queue';margin-bottom:1px;color:var(--wmu);font-size:9px;font-weight:800;letter-spacing:2px;text-transform:uppercase;}
.offline-set{display:grid;grid-template-columns:52px 1fr auto;align-items:center;gap:8px;border:1px solid rgba(229,140,0,.34);background:rgba(229,140,0,.08);border-radius:8px;padding:7px;}
.offline-set img{width:52px;height:38px;object-fit:cover;border-radius:5px;background:#06101b;}
.offline-set-title{font-size:11px;font-weight:800;color:var(--wtx);}
.offline-set-meta{font-size:9px;color:var(--wmu);margin-top:2px;}
.offline-set-actions{display:flex;gap:5px;}
.offline-set-btn{border:1px solid rgba(229,140,0,.34);background:rgba(5,12,20,.45);color:#fbbf24;border-radius:6px;padding:6px 7px;font-size:9px;font-weight:800;text-transform:uppercase;cursor:pointer;}
.w-cam-status{display:flex;align-items:center;gap:7px;padding:8px 12px;border-radius:8px;font-size:11px;font-weight:600;border:1px solid var(--wbr);background:transparent;color:var(--wmu);margin-bottom:10px;}
.w-cam-dot{width:7px;height:7px;border-radius:50%;background:currentColor;flex-shrink:0;}
.w-cam-status.ready{color:var(--bl);border-color:var(--blbd);}
.w-cam-status.ready .w-cam-dot{animation:cbp .9s ease-in-out infinite alternate;}
.w-cam-status.denied{color:var(--red);border-color:rgba(229,53,53,.3);}
.w-err{display:none;background:rgba(229,53,53,.1);border:1px solid rgba(229,53,53,.3);border-radius:8px;padding:10px 12px;font-size:11px;color:#f87171;line-height:1.6;margin-bottom:10px;text-align:center;}
.w-err.on{display:block;}
.btn-begin{width:100%;padding:15px;background:var(--bl);border:none;border-radius:10px;color:#fff;font-size:16px;font-weight:900;letter-spacing:1px;cursor:pointer;box-shadow:0 0 24px rgba(49,194,238,.4);animation:blPulse 2.2s ease-in-out infinite;transition:transform .1s;}
.btn-begin:active{transform:scale(.97);}
.btn-begin:disabled{opacity:.35;cursor:default;animation:none;box-shadow:none;}
@media(orientation:portrait) and (max-width:500px){#ss{gap:14px;padding:20px 16px;}}

.claim-picker-overlay{position:fixed;inset:0;z-index:10000;display:flex;align-items:stretch;justify-content:center;padding:8px;background:rgba(3,10,16,.9);backdrop-filter:blur(3px);}
.claim-picker-panel{width:100%;height:100%;display:flex;flex-direction:column;border:1px solid rgba(49,194,238,.34);background:linear-gradient(180deg,rgba(10,26,43,.98),rgba(4,11,18,.98));box-shadow:0 24px 80px rgba(0,0,0,.48);overflow:hidden;}
.claim-picker-top{display:flex;justify-content:space-between;align-items:flex-start;gap:10px;padding:12px 12px 5px;}
.claim-picker-kicker,.claim-picker-meta{font-family:var(--mono);color:var(--bl);text-transform:uppercase;letter-spacing:.11em;font-size:9px;}
.claim-picker-top h2{margin:1px 0 0;font-size:22px;line-height:1;text-transform:uppercase;color:#fff;}
.claim-picker-close{width:30px;height:30px;border:1px solid rgba(49,194,238,.28);background:rgba(3,10,16,.72);color:#fff;font-size:22px;line-height:1;cursor:pointer;}
.claim-picker-copy{margin:0;padding:0 12px 8px;color:#a8c6dc;font-size:12px;line-height:1.25;}
.claim-picker-search-wrap{padding:0 12px 7px;}
.claim-picker-search{width:100%;height:36px;border:1px solid rgba(49,194,238,.3);background:rgba(3,10,16,.74);color:#fff;padding:0 10px;outline:none;font-family:var(--mono);font-size:12px;letter-spacing:.06em;}
.claim-picker-search:focus{border-color:var(--bl);box-shadow:0 0 0 3px rgba(49,194,238,.1);}
.claim-picker-meta{display:flex;justify-content:space-between;gap:8px;padding:0 12px 7px;color:var(--wmu);overflow-wrap:anywhere;}
.claim-picker-results{display:grid;gap:6px;padding:0 12px 10px;overflow-y:auto;min-height:0;}
.claim-picker-row{width:100%;display:grid;gap:3px;text-align:left;border:1px solid rgba(49,194,238,.18);background:rgba(7,19,29,.74);color:#fff;padding:8px 10px;cursor:pointer;}
.claim-picker-row:hover,.claim-picker-row:focus{border-color:var(--bl);background:rgba(49,194,238,.1);outline:none;}
.claim-picker-row-main,.claim-picker-row-foot{display:flex;justify-content:space-between;gap:12px;}
.claim-picker-owner{font-weight:800;color:#fff;}
.claim-picker-number,.claim-picker-row-foot{font-family:var(--mono);color:var(--bl);text-transform:uppercase;letter-spacing:.07em;font-size:10px;}
.claim-picker-row-sub{color:#8fb2cc;font-size:11px;overflow-wrap:anywhere;}
.claim-picker-empty{border:1px dashed rgba(49,194,238,.24);padding:12px;color:var(--wmu);font-family:var(--mono);text-transform:uppercase;letter-spacing:.08em;font-size:10px;text-align:center;}
.claim-picker-create{flex-shrink:0;display:flex;flex-direction:column;gap:7px;margin:4px 12px 12px;padding:11px 12px;border:1px solid rgba(29,185,84,.32);background:rgba(29,185,84,.06);border-radius:9px;}
.claim-picker-create-lbl{font-size:9px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--wmu);}
.claim-picker-newnum{width:100%;height:38px;border:1px solid rgba(49,194,238,.3);background:rgba(3,10,16,.74);color:#fff;padding:0 11px;outline:none;font-family:var(--mono);font-size:13px;letter-spacing:.04em;border-radius:7px;}
.claim-picker-newnum:focus{border-color:var(--bl);}
.claim-picker-create-btn{padding:11px;background:rgba(29,185,84,.16);border:1px solid rgba(29,185,84,.5);border-radius:8px;color:#34d36b;font-size:12px;font-weight:800;cursor:pointer;letter-spacing:.04em;text-transform:uppercase;}
.claim-picker-create-btn:active{background:rgba(29,185,84,.28);}
.claim-picker-skip{flex-shrink:0;margin:8px 12px 12px;padding:13px;background:rgba(49,194,238,.1);border:1px solid var(--blbd);border-radius:9px;color:var(--bl);font-size:13px;font-weight:800;cursor:pointer;letter-spacing:.02em;}
.claim-picker-skip:active{background:rgba(49,194,238,.22);}

/* Branded PWA installation guide */
.install-guide-overlay{position:fixed;inset:0;z-index:11000;display:flex;align-items:flex-end;justify-content:center;padding:12px;background:rgba(1,6,10,.82);backdrop-filter:blur(10px);opacity:0;transition:opacity .18s ease;}
.install-guide-overlay.on{opacity:1;}
.install-guide{position:relative;width:min(100%,440px);max-height:calc(100dvh - 24px);overflow:auto;padding:24px 20px 18px;border:1px solid rgba(49,194,238,.38);border-radius:24px;background:radial-gradient(circle at 85% 0,rgba(49,194,238,.14),transparent 34%),linear-gradient(180deg,#0b1d2f 0%,#050d16 100%);box-shadow:0 -10px 60px rgba(0,0,0,.65),0 0 30px rgba(49,194,238,.08);transform:translateY(24px);transition:transform .22s ease;}
.install-guide-overlay.on .install-guide{transform:translateY(0);}
.install-guide-close{position:absolute;top:14px;right:14px;width:34px;height:34px;border:1px solid rgba(49,194,238,.25);border-radius:50%;background:rgba(3,10,16,.55);color:#8fb2cc;font-size:23px;line-height:28px;cursor:pointer;}
.install-guide-brand{display:flex;align-items:center;gap:9px;margin-bottom:24px;color:#f8fafc;font-size:20px;font-weight:900;letter-spacing:-.5px;}
.install-guide-brand>span:last-child span{color:#31c2ee;}
.install-guide-mark{position:relative;width:28px;height:28px;border-left:3px solid #f8fafc;border-top:3px solid #f8fafc;border-radius:3px 0 0;}
.install-guide-mark:after{content:"";position:absolute;right:-1px;bottom:-1px;width:12px;height:12px;border-right:3px solid #f8fafc;border-bottom:3px solid #f8fafc;border-radius:0 0 3px;}
.install-guide-mark i{position:absolute;left:11px;top:11px;width:7px;height:7px;border-radius:50%;background:#31c2ee;box-shadow:0 0 12px rgba(49,194,238,.7);}
.install-guide-kicker{margin-bottom:7px;color:#31c2ee;font-family:var(--mono);font-size:10px;font-weight:800;letter-spacing:.22em;text-transform:uppercase;}
.install-guide h2{margin:0;color:#f8fafc;font-size:31px;line-height:1.02;letter-spacing:-1px;text-transform:uppercase;}
.install-guide-lead{margin:12px 0 18px;color:#8fb2cc;font-size:13px;line-height:1.55;}
.install-guide-steps{display:grid;gap:8px;}
.install-guide-step{display:grid;grid-template-columns:30px 1fr;align-items:center;gap:10px;padding:9px 11px;border:1px solid rgba(49,194,238,.16);border-radius:10px;background:rgba(3,10,16,.42);}
.install-guide-step>span{display:grid;place-items:center;width:28px;height:28px;border-radius:50%;background:rgba(49,194,238,.14);border:1px solid rgba(49,194,238,.42);color:#31c2ee;font-family:var(--mono);font-size:11px;font-weight:900;}
.install-guide-step p{margin:0;color:#b9d0e0;font-size:12px;line-height:1.35;}
.install-guide-step b{color:#fff;}
.install-guide-ready{display:flex;align-items:center;gap:10px;margin:14px 0;padding:11px 12px;border:1px solid rgba(29,185,84,.35);border-radius:10px;background:rgba(29,185,84,.08);}
.install-guide-ready>span{width:9px;height:9px;border-radius:50%;background:#32d171;box-shadow:0 0 12px rgba(50,209,113,.65);flex:none;}
.install-guide-ready b,.install-guide-ready small{display:block;}
.install-guide-ready b{color:#86efac;font-size:11px;text-transform:uppercase;letter-spacing:.08em;}
.install-guide-ready small{margin-top:2px;color:#7fa3ba;font-size:10px;line-height:1.35;}
.install-guide-done{width:100%;padding:14px;border:0;border-radius:11px;background:#31c2ee;color:#041017;font-size:13px;font-weight:900;letter-spacing:.12em;cursor:pointer;box-shadow:0 0 24px rgba(49,194,238,.28);}
.install-guide-done:active{transform:scale(.98);}
@media(min-width:600px){.install-guide-overlay{align-items:center}.install-guide{border-radius:24px;}}

/* ══════════════════════════════════
   ADMIN + EDIT — dark brand cards
══════════════════════════════════ */
#sa,#se{background:radial-gradient(ellipse at 22% 0%,rgba(49,194,238,.06) 0%,transparent 55%),var(--wbg);}
.app-bar{background:var(--w1);border-bottom:1px solid var(--wbr);padding:0 14px;display:flex;align-items:center;gap:10px;height:48px;flex-shrink:0;}
.app-bar-title{flex:1;font-size:15px;font-weight:800;color:var(--wtx);}
.btn-ghost{background:none;border:none;padding:6px 10px;font-size:13px;font-weight:600;color:var(--wmu);cursor:pointer;border-radius:6px;}
.btn-ghost:active{background:var(--w2);}
.btn-bl{background:var(--bl);color:#fff;border:none;border-radius:7px;padding:8px 14px;font-size:12px;font-weight:700;cursor:pointer;}
.btn-bl:active{background:var(--bl2);}
.admin-list{flex:1;overflow-y:auto;padding:14px;display:flex;flex-direction:column;gap:8px;}
.ac{background:var(--w1);border:1px solid var(--wbr);border-radius:10px;padding:12px 14px;display:flex;align-items:center;gap:10px;cursor:pointer;}
.ac:active{background:var(--w2);}
.ac.active-set{border-color:var(--blbd);box-shadow:0 0 0 1px var(--blbd);}
.ac-info{flex:1;min-width:0;}
.ac-name{font-size:14px;font-weight:700;color:var(--wtx);margin-bottom:2px;}
.ac-meta{font-size:11px;color:var(--wmu);}
.ac-arr{color:var(--wmu);font-size:18px;}
.ac-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:20px;font-size:9px;font-weight:700;background:var(--blt);border:1px solid var(--blbd);color:var(--bl);}
.btn-newset{width:100%;padding:13px;background:var(--w1);border:1.5px dashed var(--wbr);border-radius:10px;color:var(--bl);font-size:13px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;}
.btn-newset:active{background:var(--w2);}
#se{position:relative;}
.edit-body{flex:1;overflow-y:auto;padding:14px 14px 80px;}
.fl{display:block;font-size:9px;font-weight:800;letter-spacing:2px;text-transform:uppercase;color:var(--wmu);margin-bottom:6px;}
.name-in{width:100%;background:var(--w2);border:1px solid var(--wbr);border-radius:7px;padding:10px 12px;color:var(--wtx);font-size:15px;font-weight:700;outline:none;margin-bottom:14px;}
.name-in:focus{border-color:var(--blm);}
.name-in[readonly]{opacity:.6;cursor:default;}
.steps-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;}
.steps-lbl{font-size:11px;font-weight:700;color:var(--wtx);letter-spacing:.5px;text-transform:uppercase;}
.btn-addstep{background:var(--blt);border:1px solid var(--blbd);border-radius:6px;padding:5px 11px;color:var(--bl);font-size:10px;font-weight:700;cursor:pointer;}
.sep-lbl{font-size:9px;font-weight:600;color:var(--wmu);margin:8px 0 3px;display:block;text-transform:uppercase;letter-spacing:.5px;}
.sep-in{width:100%;background:var(--wbg);border:1px solid var(--wbr);border-radius:5px;padding:8px 9px;color:var(--wtx);font-size:12px;outline:none;}
.sep-in:focus{border-color:var(--blm);}
.sep-ta{width:100%;background:var(--wbg);border:1px solid var(--wbr);border-radius:5px;padding:8px 9px;color:var(--wtx);font-size:11px;outline:none;resize:none;line-height:1.5;height:54px;}
.sep-ta:focus{border-color:var(--blm);}
.sep-row{display:flex;gap:5px;margin-top:8px;}
.multi-tog{display:flex;align-items:center;gap:6px;cursor:pointer;font-size:11px;color:var(--wmu);margin-top:8px;}
.multi-tog input{accent-color:var(--bl);width:15px;height:15px;}
.add-form{background:rgba(49,194,238,.06);border:1px solid var(--blbd);border-radius:8px;padding:12px;margin-top:8px;display:none;}
.add-form.on{display:block;}
.edit-foot{position:absolute;bottom:0;left:0;right:0;background:var(--w1);border-top:1px solid var(--wbr);padding:10px 14px 14px;display:flex;gap:7px;}
.btn-save-set{flex:1;padding:12px;background:var(--bl);border:none;border-radius:7px;color:#fff;font-size:14px;font-weight:800;cursor:pointer;box-shadow:0 0 18px rgba(49,194,238,.35);}
.btn-save-set:active{background:var(--bl2);}
.btn-del-set{padding:12px 13px;background:rgba(229,53,53,.08);border:1px solid rgba(229,53,53,.4);border-radius:7px;color:#f87171;font-size:12px;font-weight:600;cursor:pointer;}
#drag-ghost{position:fixed;pointer-events:none;z-index:9999;opacity:.95;background:var(--w2);border:1.5px solid var(--bl);border-radius:7px;padding:9px 12px;font-size:12px;font-weight:700;color:var(--wtx);box-shadow:0 12px 32px rgba(0,0,0,.5);display:none;max-width:240px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}

/* ── shared pills / buttons used by the set builder ── */
.pill{display:inline-flex;align-items:center;gap:4px;padding:1px 7px;border-radius:20px;font-size:9px;font-weight:700;letter-spacing:.3px;vertical-align:middle;}
.pill.pa{background:var(--blt);border:1px solid var(--blbd);color:var(--bl);}
.pill.pg{background:rgba(29,185,84,.12);border:1px solid rgba(29,185,84,.4);color:var(--g);}
.btn-g{background:var(--bl);border:none;border-radius:6px;color:#fff;font-weight:700;cursor:pointer;}
.btn-g:active{background:var(--bl2);}

/* ── gear on welcome set row ── */
.w-set-gear{flex-shrink:0;width:42px;display:flex;align-items:center;justify-content:center;background:var(--w2,var(--white));border:1px solid var(--wbr,var(--border));border-radius:7px;color:var(--bl);cursor:pointer;}
.w-set-gear:active{background:var(--blt);}

/* ── checklist builder (dark) ── */
.cl-hint{font-size:10px;line-height:1.5;color:var(--wmu);margin:0 0 10px;}
.step-list{display:flex;flex-direction:column;gap:7px;}
.cr{background:var(--w1);border:1px solid var(--wbr);border-radius:8px;overflow:hidden;opacity:.5;transition:opacity .12s,border-color .12s,background .12s;}
.cr.on{opacity:1;background:var(--w1);border-color:rgba(49,194,238,.28);}
.cr.dragging{opacity:.4;}
.cr.drag-over{border-color:var(--bl);box-shadow:0 0 0 1px var(--blbd);}
.cr-row{display:flex;align-items:center;padding:9px 8px 9px 10px;gap:3px;}
.cr-chk{flex-shrink:0;width:18px;height:18px;accent-color:var(--bl);cursor:pointer;}
.cr-info{flex:1;min-width:0;cursor:pointer;padding:0 4px;}
.cr-thumb{width:36px;height:36px;object-fit:cover;border-radius:5px;border:1px solid var(--blbd);flex-shrink:0;cursor:pointer;margin-right:2px;}
.btn-cancel{padding:8px 12px;background:var(--w2);border:1px solid var(--wbr);border-radius:6px;color:var(--wmu);font-size:12px;font-weight:600;cursor:pointer;}
.btn-cancel:active{background:var(--wbr);}
.cr-name{font-size:12px;font-weight:700;color:var(--wtx);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.cr-desc{font-size:10px;color:var(--wmu);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:1px;}
.cr-arrows{display:flex;flex-direction:column;flex-shrink:0;margin-right:2px;}
.cr-arr{background:none;border:none;color:var(--wmu);font-size:9px;line-height:1;padding:3px 5px;cursor:pointer;border-radius:3px;}
.cr-arr:active{background:var(--blt);color:var(--bl);}
.cr-subs{padding:7px 10px 9px 40px;display:flex;flex-direction:column;gap:5px;border-top:1px dashed var(--wbr);background:rgba(0,0,0,.18);}
.cr-sub{display:flex;align-items:center;gap:7px;font-size:11px;font-weight:600;color:var(--wmu);cursor:pointer;}
.cr-sub input{accent-color:var(--bl);width:15px;height:15px;}
.cre{display:none;padding:2px 10px 11px 40px;border-top:1px solid var(--wbr);}
.cre.on{display:block;}
.cr-ex{display:flex;align-items:center;gap:8px;margin-top:5px;}
.cr-ex-img{width:54px;height:54px;object-fit:cover;border-radius:6px;border:1px solid var(--wbr);}
.cr-ex-none{flex:1;font-size:10px;color:var(--wmu);font-style:italic;}
.cr-ex-up{background:var(--blt);border:1px solid var(--blbd);border-radius:6px;padding:7px 12px;color:var(--bl);font-size:11px;font-weight:700;cursor:pointer;}
.cr-ex-del{background:rgba(229,53,53,.08);border:1px solid rgba(229,53,53,.4);border-radius:6px;padding:7px 9px;color:#f87171;font-size:10px;font-weight:600;cursor:pointer;}
.btn-sedit{background:none;border:1px solid var(--wbr);border-radius:5px;padding:5px 9px;color:var(--wmu);font-size:10px;font-weight:600;cursor:pointer;}
.btn-sdel{background:rgba(229,53,53,.08);border:1px solid rgba(229,53,53,.4);border-radius:5px;padding:5px 8px;color:#f87171;font-size:10px;font-weight:600;cursor:pointer;}
.dh{width:26px;display:flex;align-items:center;justify-content:center;color:var(--wmu);font-size:14px;cursor:grab;flex-shrink:0;touch-action:none;}

/* ══════════════════════════════════
   CAMERA SCREEN
══════════════════════════════════ */
#sc{background:#000;overflow:hidden;}

/* ── TOP BAR — dark glass ── */


/* ── Tray handles ── */
.tray-handle-top{
  position:absolute;top:0;left:50%;transform:translateX(-50%);
  z-index:40;cursor:pointer;padding:4px 16px 6px;
  display:none; /* shown when bar is hidden */
}
.tray-handle-top.on{display:block;}
.tray-handle-bot{
  position:absolute;bottom:6px;left:50%;transform:translateX(-50%);
  z-index:40;cursor:pointer;padding:8px 20px;
  background:rgba(5,12,20,.4);backdrop-filter:blur(8px);
  border-radius:20px;border:1px solid rgba(49,194,238,.25);
}
.tray-pip{
  width:32px;height:3px;border-radius:2px;
  background:rgba(49,194,238,.7);
}
/* Hide/show cam-bar + prog-wrap */
.cam-bar.hidden{display:none;}
.prog-wrap.bar-hidden{display:none!important;}

.cam-bar{background:rgba(5,12,20,.9);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid rgba(49,194,238,.18);padding:0 10px;display:flex;align-items:center;gap:7px;height:50px;flex-shrink:0;z-index:30;overflow:visible;}
/* VIN bar phase */
.vin-bar-phase{display:flex;align-items:center;gap:7px;flex:1;min-width:0;}
.bar-vin-lbl{font-size:9px;font-weight:800;letter-spacing:3px;text-transform:uppercase;color:var(--bl);flex-shrink:0;}
.assigned-vin{margin-left:auto;max-width:260px;min-width:0;border:1px solid rgba(49,194,238,.28);background:rgba(49,194,238,.1);border-radius:6px;padding:5px 8px;font-family:var(--mono);font-size:10px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:#c9f3ff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.vin-bar-in{flex:1;min-width:0;width:100%;background:#fff;border:2px solid rgba(49,194,238,.4);border-radius:8px;padding:8px 11px;color:#0A1525;font-family:var(--mono);font-size:14px;font-weight:800;outline:none;text-transform:uppercase;letter-spacing:2px;transition:border-color .2s,box-shadow .2s;}
.vin-bar-in:focus{border-color:var(--bl);box-shadow:0 0 0 3px rgba(49,194,238,.18);}
.vin-bar-in::placeholder{color:#9CA3AF;letter-spacing:.3px;font-weight:400;font-size:11px;text-transform:none;}
.vin-bar-in.scanned{border-color:var(--bl);animation:vinGlow 1.4s ease-in-out 3;}
.bar-sel{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.18);border-radius:6px;padding:7px 4px;color:#fff;font-size:10px;font-weight:600;outline:none;cursor:pointer;-webkit-appearance:none;appearance:none;text-align:center;flex-shrink:0;width:44px;}
.bar-go{background:var(--bl);border:none;border-radius:7px;padding:8px 12px;color:#fff;font-size:12px;font-weight:800;cursor:pointer;flex-shrink:0;white-space:nowrap;box-shadow:0 0 12px rgba(49,194,238,.4);}
.bar-go:active{background:var(--bl2);}
.bar-go:disabled{background:rgba(49,194,238,.2);box-shadow:none;cursor:not-allowed;color:rgba(255,255,255,.3);}
/* Step bar phase (guided) */
.step-bar-phase{display:none;flex:1;min-width:0;align-items:center;gap:6px;}
.vin-pill-sm{background:rgba(49,194,238,.12);border:1px solid var(--blbd);border-radius:5px;padding:4px 8px;font-family:var(--mono);font-size:9px;font-weight:700;color:var(--bl);max-width:96px;flex-shrink:0;letter-spacing:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.step-tag{flex:1;font-size:10px;font-weight:700;color:#fff;letter-spacing:.3px;text-transform:uppercase;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-align:center;cursor:pointer;padding:4px 6px;border-radius:6px;user-select:none;}
.step-tag:active{background:rgba(255,255,255,.08);}
.step-dropdown{position:fixed;top:50px;left:50%;transform:translateX(-50%);width:280px;max-height:320px;overflow-y:auto;background:var(--white);border:1px solid var(--border);border-radius:10px;box-shadow:0 8px 32px rgba(10,21,37,.25);z-index:999;display:none;}
.step-dropdown.on{display:block;}
.sdd-row{display:flex;align-items:center;gap:8px;padding:10px 14px;font-size:12px;font-weight:600;color:var(--tx);cursor:pointer;border-bottom:1px solid var(--border);}
.sdd-row:last-child{border-bottom:none;}
.sdd-row:active{background:var(--bg);}
.sdd-row.cur{background:var(--blt);color:var(--bl);font-weight:800;}
.sdd-ic{font-size:9px;width:14px;flex-shrink:0;text-align:center;color:var(--bl);}
.mode-pill{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:20px;font-size:9px;font-weight:800;letter-spacing:.5px;text-transform:uppercase;border:none;cursor:pointer;background:var(--bl);color:#fff;box-shadow:0 0 10px rgba(49,194,238,.4);white-space:nowrap;flex-shrink:0;animation:blPulse 2.5s ease-in-out infinite;}
.mode-pill.ff{background:var(--am);animation:none;box-shadow:0 0 8px rgba(229,140,0,.4);}
.mode-pill .mpd{width:5px;height:5px;border-radius:50%;background:#fff;flex-shrink:0;}
.bar-btn-v{background:none;border:1px solid rgba(255,255,255,.2);border-radius:5px;padding:4px 9px;color:rgba(255,255,255,.75);font-size:10px;font-weight:700;text-transform:uppercase;cursor:pointer;flex-shrink:0;}
.bar-btn-v:active{background:rgba(255,255,255,.1);}
/* Progress bar */
.prog-wrap{height:3px;background:rgba(49,194,238,.12);flex-shrink:0;}
.prog-fill{height:100%;background:var(--bl);width:0%;transition:width .35s ease;box-shadow:0 0 6px rgba(49,194,238,.6);}

/* ── CAMERA BODY — full screen ── */
.cam-body{flex:1;position:relative;min-height:0;overflow:hidden;background:#000;}
.cam-ctr{position:absolute;inset:0;display:flex;flex-direction:column;}
.vfw{flex:1;position:relative;background:#000;overflow:hidden;min-height:0;}
#vf{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;will-change:transform;}
#step-prev{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:none;z-index:2;}
#cam-load{position:absolute;inset:0;z-index:5;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;background:#000;}
#cam-load.gone{display:none;}
.spin{width:28px;height:28px;border:2.5px solid rgba(49,194,238,.15);border-top-color:var(--bl);border-radius:50%;animation:spin .7s linear infinite;}
.load-txt{font-size:9px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,.3);}

.vin-retry-btn{flex-shrink:0;display:inline-flex;align-items:center;gap:4px;padding:5px 11px;border-radius:16px;border:1px solid var(--blbd);background:rgba(49,194,238,.12);color:var(--bl);font-size:10px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;cursor:pointer;pointer-events:auto;}
.vin-retry-btn:active{background:rgba(49,194,238,.26);}

/* ── SCAN OVERLAY (live barcode — blue lines) ── */
.scan-ov{display:none;position:absolute;inset:0;z-index:20;background:rgba(5,12,20,.3);pointer-events:none;}
.scan-ov.on{display:block;}
.sf{position:absolute;top:28%;left:50%;transform:translateX(-50%);width:70%;height:60px;}
.sf-bd{position:absolute;inset:0;border:2px solid var(--bl);border-radius:6px;box-shadow:0 0 14px rgba(49,194,238,.35) inset;}
.sf-ln{position:absolute;left:4px;right:4px;height:2px;background:linear-gradient(90deg,transparent,var(--bl),transparent);animation:scl 1.8s ease-in-out infinite;}
.cc{position:absolute;width:13px;height:13px;border-color:var(--bl);border-style:solid;}
.cc-tl{top:-2px;left:-2px;border-width:3px 0 0 3px;border-radius:3px 0 0 0;}
.cc-tr{top:-2px;right:-2px;border-width:3px 3px 0 0;border-radius:0 3px 0 0;}
.cc-bl{bottom:-2px;left:-2px;border-width:0 0 3px 3px;border-radius:0 0 0 3px;}
.cc-br{bottom:-2px;right:-2px;border-width:0 3px 3px 0;border-radius:0 0 3px 0;}
.scan-hint{position:absolute;top:calc(28% + 70px);left:0;right:0;text-align:center;font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,.75);}

/* ── SCAN THEATER (after photo capture) ── */
.scan-theater{display:none;position:absolute;inset:0;z-index:25;pointer-events:none;}
.scan-theater.on{display:block;}
.st-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(49,194,238,.07) 1px,transparent 1px),linear-gradient(90deg,rgba(49,194,238,.07) 1px,transparent 1px);background-size:24px 24px;animation:stGrid .65s ease forwards;}
.st-line{position:absolute;left:0;right:0;height:3px;background:linear-gradient(90deg,transparent,rgba(49,194,238,.65) 20%,var(--bl) 50%,rgba(49,194,238,.65) 80%,transparent);box-shadow:0 0 10px rgba(49,194,238,.7);}
.st-l1{animation:stSweep .6s ease forwards;}
.st-l2{animation:stSweep .6s ease .12s forwards;}
.st-l3{animation:stSweep .6s ease .24s forwards;}
.st-cc{position:absolute;width:28px;height:28px;border-color:var(--bl);border-style:solid;animation:stCorner .3s ease-out forwards;}
.st-tl{top:10px;left:10px;border-width:3px 0 0 3px;border-radius:4px 0 0 0;}
.st-tr{top:10px;right:10px;border-width:3px 3px 0 0;border-radius:0 4px 0 0;}
.st-bl{bottom:10px;left:10px;border-width:0 0 3px 3px;border-radius:0 0 0 4px;}
.st-br{bottom:10px;right:10px;border-width:0 3px 3px 0;border-radius:0 0 4px 0;}
.st-lbl{position:absolute;bottom:18%;left:0;right:0;text-align:center;font-size:11px;font-weight:800;letter-spacing:4px;text-transform:uppercase;color:var(--bl);text-shadow:0 0 14px rgba(49,194,238,.8);animation:stLbl .6s ease-in-out infinite alternate;}

/* ── SCAN RESULT ── */
.scan-result{display:none;position:absolute;inset:0;z-index:26;align-items:center;justify-content:flex-start;pointer-events:none;flex-direction:column;gap:12px;background:rgba(5,12,20,.55);padding-top:14px;}
.scan-result.on{display:flex;}
.scan-result.fail-state{background:rgba(5,12,20,.35);}
/* Next button inside scan result — pointer-events on */
.scan-next-btn{pointer-events:all;background:var(--bl);border:none;border-radius:10px;padding:12px 28px;color:#fff;font-size:15px;font-weight:900;cursor:pointer;letter-spacing:.5px;box-shadow:0 0 18px rgba(49,194,238,.5);animation:blPulse 1.8s ease-in-out infinite;}
.scan-next-btn:active{background:var(--bl2);transform:scale(.97);}
/* VIN overlay card — unified entry point */
.vin-overlay-card{
  pointer-events:all;
  background:rgba(5,12,20,.88);
  border:1px solid rgba(49,194,238,.25);
  border-radius:14px;
  padding:14px 16px;
  width:96%;max-width:440px;
  display:flex;flex-direction:column;gap:10px;
  box-shadow:0 8px 32px rgba(5,12,20,.6);
  backdrop-filter:blur(8px);
}
.voc-vin-row{display:flex;align-items:center;gap:8px;}
.voc-pd-row{display:flex;align-items:center;gap:8px;}
.voc-label{font-size:9px;font-weight:800;letter-spacing:2px;text-transform:uppercase;color:rgba(49,194,238,.7);flex-shrink:0;width:28px;}
.voc-vin-in{
  flex:1;background:#fff;border:2px solid rgba(49,194,238,.4);
  border-radius:8px;padding:9px 11px;
  color:#0A1525;font-family:var(--mono);font-size:14px;font-weight:800;
  outline:none;text-transform:uppercase;letter-spacing:1px;
  transition:border-color .2s,box-shadow .2s;
}
.voc-vin-in:focus{border-color:var(--bl);box-shadow:0 0 0 3px rgba(49,194,238,.2);}
.voc-vin-in::placeholder{color:#9CA3AF;letter-spacing:.3px;font-weight:400;font-size:11px;text-transform:none;}
.voc-vin-in.empty-pulse{animation:vinGlow 1.2s ease-in-out infinite;}
.voc-vin-in.scanned{border-color:var(--bl);box-shadow:0 0 0 3px rgba(49,194,238,.2);}
.voc-next-full{width:100%;padding:14px;background:var(--bl);border:none;border-radius:10px;color:#fff;font-size:15px;font-weight:900;cursor:pointer;box-shadow:0 0 18px rgba(49,194,238,.5);animation:blPulse 1.8s ease-in-out infinite;pointer-events:all;letter-spacing:.5px;}
.voc-next-full:active{background:var(--bl2);transform:scale(.98);}
.voc-next-full:disabled{background:rgba(49,194,238,.25);box-shadow:none;animation:none;cursor:not-allowed;color:rgba(255,255,255,.4);}
.sr-check{width:68px;height:68px;border-radius:50%;background:rgba(49,194,238,.15);border:2.5px solid var(--bl);display:flex;align-items:center;justify-content:center;animation:scanPop .4s cubic-bezier(.2,.8,.3,1.2) forwards;}
.sr-vin{background:rgba(5,12,20,.9);border:1.5px solid var(--blbd);border-radius:8px;padding:10px 20px;font-family:var(--mono);font-size:16px;font-weight:900;color:#fff;letter-spacing:3px;animation:scanSlide .35s ease .2s both;box-shadow:0 0 22px rgba(49,194,238,.4);}
.sr-txt{font-size:10px;font-weight:800;letter-spacing:4px;text-transform:uppercase;color:var(--bl);animation:scanSlide .35s ease .35s both;}
.sr-hint{font-size:10px;color:rgba(255,255,255,.5);animation:scanSlide .35s ease .45s both;}
.flash{position:absolute;inset:0;background:white;opacity:0;pointer-events:none;z-index:30;}
.flash.go{animation:fl .18s ease;}
.sw-hint{position:absolute;bottom:62px;left:50%;transform:translateX(-50%);background:rgba(5,12,20,.55);border:1px solid rgba(49,194,238,.25);border-radius:6px;padding:5px 12px;font-size:9px;font-weight:600;color:rgba(255,255,255,.85);pointer-events:none;white-space:nowrap;z-index:20;opacity:0;transition:opacity .3s;}
.sw-hint.show{opacity:1;}

/* ── LEFT RAIL — light glass ── */
.cam-left{position:absolute;left:0;top:0;bottom:var(--th);width:var(--lp);z-index:10;display:block;background:transparent;overflow:hidden;}
/* ── RIGHT RAIL ── */
.cam-right{position:absolute;right:0;top:0;bottom:var(--th);width:var(--rp);z-index:10;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:11px;background:transparent;padding:12px 6px;}
/* Circle button base — solid white so visible over any camera background */
.circ{width:52px;height:52px;border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;cursor:pointer;flex-shrink:0;font-size:9px;font-weight:800;letter-spacing:.3px;text-transform:uppercase;line-height:1.2;text-align:center;transition:transform .12s;border:1px solid rgba(255,255,255,.22);background:rgba(5,12,20,.45);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);color:rgba(255,255,255,.85);box-shadow:0 2px 12px rgba(0,0,0,.35);}
.circ:active{transform:scale(.88);}
.circ svg{flex-shrink:0;}
.circ.dim{opacity:.35;}
/* Scan circle — blue accent */
.circ.bl-c{border-color:var(--blbd);background:var(--blt);color:var(--bl);}
.circ.bl-c.active{background:var(--bl);border-color:var(--bl);color:#fff;box-shadow:0 0 18px rgba(49,194,238,.6);}
/* Done circle */
.circ.done-c{border-color:rgba(29,185,84,.45);background:rgba(29,185,84,.1);color:var(--g);}
/* ── RIGHT RAIL — all buttons absolute, nothing moves ── */
.cam-right{
  position:absolute;right:0;top:0;bottom:var(--th);width:var(--rp);z-index:10;
  display:block;
  background:transparent;
}
/* Shutter pinned to center always */
.shutter{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:60px;height:60px;border-radius:50%;background:radial-gradient(circle at 38% 32%,#F87171,var(--red));
  border:3px solid rgba(229,53,53,.2);outline:4px solid rgba(229,53,53,.07);
  cursor:pointer;transition:transform .1s;box-shadow:0 4px 16px rgba(229,53,53,.38);
  flex-shrink:0;z-index:2;
}
.shutter:active{transform:translate(-50%,-50%) scale(.88);}
.shutter-ring{position:absolute;inset:6px;border-radius:50%;border:2px solid rgba(255,255,255,.32);}
.shutter.scanning{background:radial-gradient(circle at 38% 32%,#67DDF8,var(--bl));border-color:var(--blbd);outline-color:rgba(49,194,238,.14);box-shadow:0 0 22px rgba(49,194,238,.65);}
/* Skip pinned upper-center */

/* Retake replaces shutter when in use */
.retake-btn{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:60px;height:60px;border-radius:50%;background:rgba(229,53,53,.12);
  border:2px solid rgba(229,53,53,.4);display:none;flex-direction:column;
  align-items:center;justify-content:center;gap:2px;cursor:pointer;
  font-size:8px;font-weight:800;color:var(--red);text-transform:uppercase;
  transition:transform .1s;z-index:3;
}
.retake-btn:active{transform:translate(-50%,-50%) scale(.88);}
.retake-btn.on{display:flex;}
/* Review rail pinned to bottom */
#btn-review-rail{position:absolute;bottom:14px;left:50%;transform:translateX(-50%);display:none;}

/* Step info overlay — shown when in guided mode */
.step-blk.on{display:block;}
.step-num-lbl{font-size:9px;font-weight:700;color:var(--tx3);letter-spacing:.5px;text-transform:uppercase;margin-bottom:2px;}
.step-title{font-size:13px;font-weight:800;color:var(--tx);line-height:1.2;margin-bottom:2px;}
.step-desc{font-size:10px;color:var(--tx2);line-height:1.4;}
.assist-tag{display:inline-flex;align-items:center;gap:3px;font-size:8px;font-weight:700;color:var(--bl);text-transform:uppercase;letter-spacing:.3px;margin-top:4px;}
.assist-dot{width:4px;height:4px;border-radius:50%;background:var(--bl);}
/* Mode indicator — top of left rail */
.mode-blk{width:100%;padding:6px;display:flex;flex-direction:column;align-items:center;gap:3px;}
.mode-blk.on{display:flex;}
.mode-pill-rail{display:inline-flex;align-items:center;gap:3px;padding:4px 8px;border-radius:20px;font-size:8px;font-weight:800;letter-spacing:.5px;text-transform:uppercase;background:var(--bl);color:#fff;white-space:nowrap;animation:blPulse 2.5s ease-in-out infinite;}
.mode-pill-rail.ff{background:var(--am);animation:none;}
.btn-resume{background:var(--bl);border:none;border-radius:6px;padding:6px 10px;color:#fff;font-size:10px;font-weight:800;cursor:pointer;white-space:nowrap;box-shadow:0 2px 8px rgba(49,194,238,.3);}
/* Label selector — left rail bottom */
.lbl-blk{width:100%;padding:0 6px;}
.lbl-sel{width:100%;background:var(--white);border:1px solid var(--border);border-radius:6px;padding:5px 18px 5px 7px;color:var(--tx);font-size:10px;font-weight:600;outline:none;cursor:pointer;-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%238AABBC' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 6px center;box-shadow:var(--xs);}
.lbl-sel option{background:#fff;}
.cw{display:none;gap:3px;padding:0 6px;}
.cw.on{display:flex;width:100%;}
.ci{flex:1;background:var(--white);border:1.5px solid var(--blm);border-radius:5px;padding:5px 7px;color:var(--tx);font-size:10px;font-weight:600;outline:none;}
.btn-cx{background:var(--bg);border:1px solid var(--border);border-radius:5px;padding:4px 6px;color:var(--tx2);font-size:10px;cursor:pointer;}
/* VIN panel in left rail */
.vin-blk{width:100%;display:flex;flex-direction:column;align-items:center;gap:6px;padding:0 6px;}
/* Scan button overridden to circle via .circ.bl-c */
.btn-scan{width:52px!important;height:52px!important;border-radius:50%!important;border:1.5px solid var(--blbd)!important;background:var(--blt)!important;color:var(--bl)!important;display:flex!important;flex-direction:column!important;align-items:center!important;justify-content:center!important;gap:2px!important;cursor:pointer!important;font-size:8px!important;font-weight:800!important;text-transform:uppercase!important;transition:transform .12s!important;}
.btn-scan .scan-icon{display:none!important;}/* hide emoji */
.btn-scan::before{content:'';display:block;width:22px;height:17px;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='22' height='17' viewBox='0 0 26 20' fill='none' stroke='%2331c2ee' stroke-width='1.5' stroke-linecap='round'%3E%3Crect x='1' y='1' width='24' height='18' rx='2.5'/%3E%3Cline x1='5' y1='5' x2='5' y2='15'/%3E%3Cline x1='8' y1='5' x2='8' y2='15'/%3E%3Cline x1='11' y1='5' x2='11' y2='15'/%3E%3Cline x1='14' y1='5' x2='14' y2='15'/%3E%3Cline x1='17' y1='5' x2='17' y2='15'/%3E%3Cline x1='20' y1='5' x2='20' y2='15'/%3E%3C/svg%3E") center/contain no-repeat;}
.btn-scan.active{background:var(--bl)!important;border-color:var(--bl)!important;color:#fff!important;box-shadow:0 0 16px rgba(49,194,238,.55)!important;}
.btn-scan.active::before{filter:brightness(0) invert(1);}
.unsup{display:none;font-size:9px;color:var(--red);text-align:center;line-height:1.4;}
.vin-blk .btn-scan,.vin-blk .unsup{display:none!important;}
.vin-dec{display:none;position:fixed;left:82px;right:82px;bottom:62px;z-index:40;background:rgba(5,12,20,.92);border:1px solid rgba(29,185,84,.35);border-radius:10px;padding:8px 12px;backdrop-filter:blur(10px);animation:fadeIn .25s ease;}
.vin-dec.on{display:block;}
.vd-load{font-size:9px;font-weight:700;color:var(--g);display:flex;align-items:center;gap:5px;}
.vd-spin{width:9px;height:9px;border:2px solid rgba(29,185,84,.25);border-top-color:var(--g);border-radius:50%;animation:spin .6s linear infinite;flex-shrink:0;}
.vd-veh{font-size:11px;font-weight:800;color:#fff;margin-bottom:2px;}
.vd-row{font-size:9px;color:var(--wmu);line-height:1.5;}
.vd-row b{color:#fff;font-weight:600;}
.vd-skip{font-size:9px;color:var(--wmu);font-style:italic;}
/* Prod date hidden (in top bar) */
.pd{display:none!important;}
.vin-ml,.vin-mrow{display:none!important;}
/* Info float */
.info-float{position:absolute;bottom:62px;left:82px;right:82px;z-index:22;background:rgba(255,255,255,.96);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.6);border-radius:10px;padding:8px 12px;display:none;flex-direction:column;gap:3px;box-shadow:var(--md);animation:fadeIn .2s ease;}
.info-float.on{display:flex;}
.info-float-lbl{font-size:9px;font-weight:700;color:var(--tx2);letter-spacing:.5px;text-transform:uppercase;}
.info-float-in{width:100%;background:transparent;border:none;outline:none;color:var(--tx);font-size:15px;font-weight:700;}
/* Done bar — left rail bottom */
/* Pulsing blue Review button at bottom of right rail */
.btn-review-rail{
  width:52px;height:52px;border-radius:50%;
  background:rgba(5,12,20,.45);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,.22);
  color:rgba(255,255,255,.85);font-size:8px;font-weight:800;letter-spacing:.3px;text-transform:uppercase;
  display:none;flex-direction:column;align-items:center;justify-content:center;gap:2px;
  cursor:pointer;flex-shrink:0;transition:transform .12s;
  box-shadow:0 2px 12px rgba(0,0,0,.35);
}
.btn-review-rail:active{transform:scale(.88);}
/* Info blk hidden (using float) */
.info-blk{display:none!important;}
/* Thumbs strip */
.thumbs{display:none!important;}
.thumbs::-webkit-scrollbar{display:none;}
.t-empty{width:100%;text-align:center;font-size:9px;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:var(--tx3);}
.th{flex-shrink:0;width:42px;height:44px;border-radius:5px;overflow:hidden;border:1.5px solid rgba(255,255,255,.5);position:relative;}
.th img{width:100%;height:100%;object-fit:cover;display:block;}
.th-l{position:absolute;bottom:0;left:0;right:0;background:rgba(0,0,0,.6);font-size:6px;font-weight:700;text-transform:uppercase;color:#fff;text-align:center;padding:1px 2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
/* Gallery */
.gallery-btn{display:none!important;}

#g-cnt-lbl{font-size:9px;color:var(--tx2);}
.gallery-tray{position:absolute;left:0;right:0;bottom:0;z-index:38;background:rgba(5,12,20,.97);backdrop-filter:blur(12px);border-top:1px solid rgba(255,255,255,.12);border-radius:16px 16px 0 0;transform:translateY(100%);transition:transform .45s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;max-height:52%;}
.gallery-tray.open{transform:translateY(0);}
.gt-hdr{display:flex;align-items:center;padding:10px 16px;border-bottom:1px solid rgba(255,255,255,.1);flex-shrink:0;}
.gt-title{flex:1;font-size:12px;font-weight:800;color:var(--wtx);letter-spacing:.5px;}
.gt-close{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.18);border-radius:6px;padding:4px 10px;color:rgba(255,255,255,.7);font-size:11px;cursor:pointer;}
.gt-scroll{flex:1;overflow-x:auto;overflow-y:hidden;display:flex;align-items:center;gap:6px;padding:10px 12px;scrollbar-width:none;}
.gt-scroll::-webkit-scrollbar{display:none;}
.gt-th{flex-shrink:0;width:72px;height:72px;border-radius:8px;overflow:hidden;border:2px solid rgba(255,255,255,.15);position:relative;}
.gt-th img{width:100%;height:100%;object-fit:cover;display:block;}
.gt-lbl{position:absolute;bottom:0;left:0;right:0;background:rgba(0,0,0,.65);font-size:6px;font-weight:700;text-transform:uppercase;color:#fff;text-align:center;padding:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
/* Ctrl buttons in right rail — solid white */
.ctrl-btn,.btn-prev,.btn-skip,.btn-done-step{width:52px;height:52px;border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;font-size:9px;font-weight:800;letter-spacing:.3px;text-transform:uppercase;background:#ffffff;border:1.5px solid rgba(10,21,37,.12);color:var(--tx2);cursor:pointer;transition:transform .12s;flex-shrink:0;box-shadow:0 2px 8px rgba(10,21,37,.18);}
.ctrl-btn:active,.btn-prev:active,.btn-skip:active{transform:scale(.88);}
.ctrl-btn.dim,.btn-prev.dim{opacity:.3;}
.ctrl-btn.ga,.btn-done-step{border-color:rgba(29,185,84,.45);background:rgba(29,185,84,.1);color:var(--g);}
/* Portrait */
@media(orientation:portrait){
  .cam-left{position:absolute;left:0;top:0;right:0;bottom:auto;width:auto;max-height:50%;overflow-y:auto;flex-direction:row;flex-wrap:wrap;gap:8px;padding:8px;background:transparent;}
  .cam-right{position:absolute;right:0;bottom:var(--th);left:0;top:auto;width:auto;flex-direction:row;padding:8px 12px;height:auto;gap:8px;justify-content:center;background:transparent;}
  .circ,.ctrl-btn,.btn-prev,.btn-skip,.btn-done-step,.shutter,.retake-btn{flex-shrink:0;}
  .step-blk{position:static;margin:6px 8px 0;border-radius:8px;}
  .step-blk.on{display:block;}
}

/* ══════════════════════════════════
   REVIEW SCREEN
══════════════════════════════════ */
#sr{background:var(--bg);}
.rev-bar{background:var(--white);border-bottom:1px solid var(--border);padding:0 14px;display:flex;align-items:center;gap:10px;height:48px;flex-shrink:0;box-shadow:var(--xs);}
.rev-title{flex:1;font-size:15px;font-weight:800;color:var(--tx);}
.rev-vin-tag{background:var(--wbg);border:1px solid var(--blbd);border-radius:5px;padding:3px 8px;font-family:var(--mono);font-size:9px;font-weight:700;color:var(--bl);letter-spacing:1px;}
.rev-body{flex:1;overflow-y:auto;padding:12px;display:flex;flex-direction:column;gap:12px;}
@media(orientation:portrait){.rev-body{grid-template-columns:1fr;}.pgrid{grid-template-columns:1fr 1fr !important;}}
.ck{background:var(--white);border:1px solid var(--border);border-radius:10px;overflow:hidden;box-shadow:var(--xs);margin-bottom:10px;}
.ck-hdr{padding:10px 13px;display:flex;align-items:center;gap:8px;background:var(--bg);cursor:pointer;border-bottom:1px solid var(--border);}
.ck-ttl{font-size:10px;font-weight:700;color:var(--tx2);letter-spacing:.5px;text-transform:uppercase;flex:1;}
.ck-body{padding:3px 0;}
.ck-row{display:flex;align-items:center;gap:8px;padding:5px 13px;}
.ck-row.miss{cursor:pointer;}
.ck-row.miss:active{background:var(--blt);}
.ck-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0;}
.ck-dot.done{background:var(--bl);}
.ck-dot.miss{background:transparent;border:1.5px solid var(--bmd);}
.ck-nm{font-size:12px;font-weight:500;color:var(--tx);}
.ck-nm.miss{color:var(--tx3);}
.ck-take{font-size:9px;color:var(--bl);font-weight:700;margin-left:6px;white-space:nowrap;}
.pill-bl{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:20px;font-size:8px;font-weight:700;background:var(--blt);border:1px solid var(--blbd);color:var(--bl);}
.pgrid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;}
.pc{background:var(--white);border:1px solid var(--border);border-radius:7px;overflow:hidden;box-shadow:var(--xs);}
.pc img{width:100%;aspect-ratio:4/3;object-fit:cover;display:block;}
.pc-foot{padding:6px 7px;}
.pc-sel{width:100%;background:var(--bg);border:1px solid var(--border);border-radius:4px;padding:4px 18px 4px 6px;color:var(--tx);font-size:10px;font-weight:500;outline:none;cursor:pointer;-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%238AABBC' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 5px center;margin-bottom:4px;}
.pc-bot{display:flex;align-items:center;gap:3px;}
.pc-fn{font-family:var(--mono);font-size:7px;color:var(--tx3);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.btn-pdel{background:none;border:none;color:var(--red);font-size:13px;cursor:pointer;padding:0 2px;}
.no-photos{grid-column:1/-1;text-align:center;padding:24px;color:var(--tx3);font-size:12px;font-weight:600;letter-spacing:1px;text-transform:uppercase;}.notes-empty{font-size:11px;color:var(--tx3);font-style:italic;padding:4px 0;}.note-row{display:flex;align-items:flex-start;gap:10px;padding:8px 0;border-bottom:1px solid var(--br);}.note-row:last-child{border-bottom:none;}.note-step{font-size:9px;font-weight:800;letter-spacing:1px;text-transform:uppercase;color:var(--bl);flex-shrink:0;width:90px;padding-top:2px;}.note-text{flex:1;font-size:12px;color:var(--tx);line-height:1.5;}.note-time{font-size:9px;color:var(--tx3);flex-shrink:0;padding-top:2px;font-family:var(--mono);}
.rv-field{padding:6px 13px;display:flex;flex-direction:column;gap:2px;border-bottom:1px solid var(--border);}
.rv-field:last-child{border-bottom:none;}
.rv-fl{display:flex;align-items:center;gap:5px;}
.rv-lbl{font-size:9px;font-weight:600;color:var(--tx3);letter-spacing:.5px;text-transform:uppercase;}
.rv-val{font-size:12px;font-weight:600;color:var(--tx);padding-left:18px;}
.rv-empty{color:var(--am);font-style:italic;font-size:11px;}
.rv-in{margin-left:18px;background:var(--bg);border:1px solid var(--border);border-radius:5px;padding:5px 8px;color:var(--tx);font-size:12px;font-weight:500;outline:none;width:calc(100% - 18px);}
.rv-in:focus{border-color:var(--blm);background:var(--white);}
.rv-in.filled{border-color:var(--blm);}
.rv-in::placeholder{color:var(--tx3);font-style:italic;}
.rev-foot{background:var(--white);border-top:1px solid var(--border);padding:10px 14px 14px;flex-shrink:0;display:flex;flex-direction:column;gap:8px;box-shadow:0 -2px 8px rgba(10,21,37,.04);}
.btn-download-rev{width:100%;padding:13px;background:#fff;border:1.5px solid rgba(49,194,238,.45);border-radius:10px;color:var(--bl);font-size:14px;font-weight:800;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;letter-spacing:.2px;}
.btn-download-rev:active{background:rgba(49,194,238,.08);}
.btn-download-rev:disabled{background:#f8fafc;border-color:var(--border);color:var(--tx3);cursor:not-allowed;}
.btn-done-rev{width:100%;padding:14px;background:var(--bl);border:none;border-radius:10px;color:#fff;font-size:15px;font-weight:800;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;box-shadow:0 4px 14px rgba(49,194,238,.3);letter-spacing:.3px;}
.btn-done-rev:active{background:var(--bl2);}
.btn-done-rev:disabled{background:var(--border);color:var(--tx3);cursor:not-allowed;box-shadow:none;}
.btn-savezip{width:100%;padding:10px;background:none;border:1px solid var(--border);border-radius:7px;color:var(--tx2);font-size:13px;font-weight:600;cursor:pointer;}
.btn-savezip:active{background:var(--bg);}
/* Toast */
.toast{position:fixed;bottom:70px;left:50%;transform:translateX(-50%);background:var(--tx);border-radius:7px;padding:9px 16px;font-size:11px;font-weight:600;color:#fff;z-index:500;white-space:nowrap;pointer-events:none;animation:tup .2s ease;box-shadow:var(--lg);}
/* Portrait wall */
#pw{display:none;position:fixed;inset:0;z-index:600;background:rgba(5,12,20,.94);flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:32px;}
#pw.on{display:flex;}
.pw-icon{font-size:52px;animation:tilt 1.8s ease-in-out infinite;}
.pw-msg{font-size:15px;font-weight:800;color:var(--wtx);text-align:center;line-height:1.6;}
.pw-skip{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.16);border-radius:8px;padding:10px 22px;color:rgba(255,255,255,.6);font-size:12px;font-weight:600;cursor:pointer;}

/* Step counter — blue branding */
.step-counter-bl{background:rgba(49,194,238,.12);border:1px solid var(--blbd);border-radius:5px;padding:4px 9px;font-family:var(--mono);font-size:11px;font-weight:800;color:var(--bl);flex-shrink:0;letter-spacing:1px;white-space:nowrap;}
/* Step name button — clickable, obvious dropdown */
.step-tag-btn{flex:1;min-width:0;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.22);border-radius:7px;padding:5px 10px;color:#fff;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.3px;cursor:pointer;display:flex;align-items:center;gap:6px;overflow:hidden;text-align:left;}
.step-tag-btn:active{background:rgba(255,255,255,.2);}
#step-tag-name{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.step-tag-arr{font-size:8px;opacity:.6;flex-shrink:0;}
/* Step info card — auto-shows each step */
.step-blk{
  position:absolute;
  top:50%;left:calc(var(--lp) + 12px);right:calc(var(--rp) + 12px);
  transform:translateY(-50%);
  z-index:28;
  background:rgba(255,255,255,.97);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border:1px solid rgba(255,255,255,.7);border-radius:14px;
  padding:0;display:none;
  box-shadow:0 8px 32px rgba(10,21,37,.22);overflow:hidden;
  animation:fadeIn .2s ease;
}
.step-blk.on{display:block;}
.step-blk-body{padding:16px 16px 14px;}
.step-blk-footer{margin-top:12px;}
/* Got it — full width, same blue style as other action buttons */
.step-got-it{
  display:block;width:100%;
  background:var(--bl);border:none;border-radius:0 0 14px 14px;
  padding:13px;color:#fff;font-size:14px;font-weight:800;
  cursor:pointer;letter-spacing:.3px;text-align:center;
  box-shadow:none;transition:background .15s;
}
.step-got-it:active{background:var(--bl2);}
/* ? button to bring it back */
.btn-mic{width:52px;height:52px;border-radius:50%;border:1.5px solid rgba(229,53,53,.5);background:rgba(5,12,20,.45);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);color:#e53535;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;cursor:pointer;font-size:8px;font-weight:800;text-transform:uppercase;transition:all .15s;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);}
.btn-mic.recording{background:#e53535;border-color:#e53535;color:#fff;box-shadow:0 0 22px rgba(229,53,53,.8),0 0 0 3px rgba(229,53,53,.3);animation:micPulse .8s ease-in-out infinite;}
@keyframes micPulse{0%,100%{box-shadow:0 0 18px rgba(229,53,53,.6);}50%{box-shadow:0 0 28px rgba(229,53,53,.9);}}
.mic-toast{position:absolute;bottom:14px;left:var(--lp);right:var(--rp);background:rgba(4,8,11,.92);border:1px solid rgba(49,194,238,.3);border-radius:10px;padding:8px 14px;font-size:11px;font-weight:700;color:#fff;z-index:55;backdrop-filter:blur(6px);display:none;text-align:center;white-space:normal;line-height:1.5;}
.mic-toast.on{display:block;}
.btn-help{width:52px;height:52px;border-radius:50%;background:rgba(5,12,20,.45);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.22);color:rgba(255,255,255,.7);font-size:18px;font-weight:900;cursor:pointer;display:none;align-items:center;justify-content:center;box-shadow:0 2px 12px rgba(0,0,0,.35);}
.btn-help:active{background:var(--blt);}
/* Data input overlay — post-photo */
.data-overlay{display:none;position:absolute;left:calc(var(--lp) + 8px);right:calc(var(--rp) + 8px);top:14px;z-index:35;animation:fadeIn .25s ease;}
.data-overlay.on{display:block;}
.data-ov-card{background:rgba(5,12,20,.88);border:1px solid rgba(49,194,238,.25);border-radius:12px;padding:10px 12px;box-shadow:0 8px 32px rgba(5,12,20,.6);backdrop-filter:blur(8px);max-width:260px;margin:0 auto;}
.data-ov-hdr{font-size:9px;font-weight:800;letter-spacing:3px;text-transform:uppercase;color:rgba(49,194,238,.75);margin-bottom:7px;}
.data-field-row{display:flex;align-items:center;gap:6px;margin-bottom:7px;}
.data-field-lbl{font-size:8px;font-weight:800;letter-spacing:1.5px;text-transform:uppercase;color:rgba(49,194,238,.7);flex-shrink:0;width:30px;}
.data-field-in{flex:1;background:#fff;border:2px solid rgba(49,194,238,.4);border-radius:7px;padding:6px 9px;color:#0A1525;font-family:var(--mono);font-size:13px;font-weight:800;outline:none;letter-spacing:1px;transition:border-color .2s,box-shadow .2s;}
.data-field-in:focus{border-color:var(--bl);box-shadow:0 0 0 3px rgba(49,194,238,.2);}
.data-field-in.pulsing{animation:vinGlow 1.1s ease-in-out infinite;}.data-field-in::placeholder{color:#9CA3AF;letter-spacing:.3px;font-weight:400;font-size:11px;}
.data-field-sel{flex:1;background:#fff;border:2px solid rgba(49,194,238,.4);border-radius:7px;padding:6px 9px;color:#0A1525;font-family:var(--mono);font-size:13px;font-weight:700;outline:none;cursor:pointer;-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%2331c2ee' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;letter-spacing:1px;}
.data-field-sel:focus{border-color:var(--bl);box-shadow:0 0 0 3px rgba(49,194,238,.2);}
.data-ov-btns{display:flex;gap:8px;margin-top:4px;}
.data-btn-next{width:100%;padding:10px;background:var(--bl);border:none;border-radius:8px;color:#fff;font-size:13px;font-weight:900;cursor:pointer;box-shadow:0 0 14px rgba(49,194,238,.5);animation:blPulse 1.8s ease-in-out infinite;letter-spacing:.5px;margin-top:2px;}
.data-btn-next:active{background:var(--bl2);transform:scale(.98);}
/* Review grid — single column on small screens */
@media(max-width:600px){.rev-body{grid-template-columns:1fr !important;}.pgrid{grid-template-columns:1fr !important;}.pc img{aspect-ratio:16/9;}}
/* Missed photo — red pulse in review */
.ck-row.miss{cursor:pointer;transition:background .15s;}
.ck-row.miss:active{background:rgba(229,53,53,.08);}
.ck-dot.miss-red{background:rgba(229,53,53,.2);border:1.5px solid var(--red);}
.ck-nm.miss-red{color:var(--red);font-weight:700;}
.ck-take.miss-red{color:var(--red);}

/* ── EXAMPLE SLIDESHOW MODAL ── */
.ex-modal{display:none;position:fixed;inset:0;z-index:200;background:rgba(5,12,20,.88);backdrop-filter:blur(8px);flex-direction:column;align-items:center;justify-content:center;padding:16px;}
.ex-modal.on{display:flex;}
.ex-card{background:#fff;border-radius:14px;overflow:hidden;width:100%;max-width:480px;box-shadow:0 20px 60px rgba(5,12,20,.5);display:flex;flex-direction:column;max-height:88vh;}
.ex-header{background:#050C14;padding:12px 16px;display:flex;align-items:center;gap:10px;flex-shrink:0;}
.ex-step-name{flex:1;font-size:13px;font-weight:800;color:#fff;letter-spacing:.3px;}
.ex-close{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);border-radius:6px;padding:5px 12px;color:rgba(255,255,255,.75);font-size:12px;font-weight:700;cursor:pointer;}
.ex-close:active{background:rgba(255,255,255,.2);}
.ex-img-wrap{position:relative;background:#000;flex-shrink:0;}
.ex-img-wrap img{width:100%;max-height:52vh;object-fit:cover;display:block;}
/* slide counter badge */
.ex-counter{position:absolute;top:10px;right:10px;background:rgba(5,12,20,.7);border:1px solid rgba(49,194,238,.4);border-radius:20px;padding:3px 10px;font-size:10px;font-weight:700;color:var(--bl);letter-spacing:1px;}
/* prev/next arrows */
.ex-arrow{position:absolute;top:50%;transform:translateY(-50%);background:rgba(5,12,20,.55);border:1.5px solid rgba(255,255,255,.25);border-radius:50%;width:38px;height:38px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#fff;font-size:18px;transition:background .15s;}
.ex-arrow:active{background:rgba(49,194,238,.4);}
.ex-arrow-l{left:10px;}
.ex-arrow-r{right:10px;}
.ex-arrow.hidden{display:none;}
/* dots */
.ex-dots{display:flex;justify-content:center;gap:6px;padding:8px 0 4px;}
.ex-dot{width:7px;height:7px;border-radius:50%;background:rgba(49,194,238,.3);border:1.5px solid rgba(49,194,238,.5);transition:background .15s;}
.ex-dot.on{background:var(--bl);border-color:var(--bl);}
/* caption + instruction */
.ex-body{padding:12px 16px 14px;overflow-y:auto;}
.ex-caption{font-size:12px;font-weight:700;color:var(--tx);margin-bottom:6px;}
.ex-instruction{font-size:12px;color:var(--tx2);line-height:1.55;}
