@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=Space+Mono:wght@400;700&display=swap');
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg0:#0c0a09;--bg1:#151210;--bg2:#1e1916;--bg3:#28211c;--bg4:#332a24;
  --b1:#ffffff12;--b2:#ffffff22;--b3:#ffffff38;
  --gold:#f5c842;--gd:#f5c84220;
  --peach:#ff9472;--pd:#ff947220;
  --rose:#f4607a;--rd:#f4607a20;
  --sage:#7ec8a0;--sd:#7ec8a020;
  --sky:#60c8f0;--skd:#60c8f020;
  --lav:#c4a0f5;--ld:#c4a0f520;
  --warn:#ffb700;--wd:#ffb70020;
  --ok:#00e676;--okd:#00e67620;
  --t0:#fff8f2;--t1:#e8ddd4;--t2:#9e8e82;--t3:#5a4e46;
  --r:10px;--r2:14px;
}
body{font-family:'Space Grotesk',sans-serif;font-size:14px;line-height:1.6;background:var(--bg0);color:var(--t1);-webkit-font-smoothing:antialiased;min-height:100vh}
.app{max-width:640px;margin:0 auto;padding:1.5rem 1rem 4rem}

.hdr{margin-bottom:1.5rem;padding-bottom:1.25rem;border-bottom:1px solid var(--b2);position:relative}
.hdr::before{content:'';position:absolute;top:-20px;left:-20px;right:-20px;height:2px;background:linear-gradient(90deg,transparent,var(--gold),var(--peach),transparent)}
.hdr-eye{font-family:'Space Mono',monospace;font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:.5rem}
.hdr h1{font-size:1.8rem;font-weight:700;line-height:1.1;color:var(--t0);margin-bottom:.35rem;letter-spacing:-.02em}
.hdr h1 span{color:var(--gold)}
.hdr p{font-size:12px;color:var(--t2);line-height:1.6}
.badge{display:inline-flex;align-items:center;gap:5px;background:var(--okd);border:1px solid var(--ok);border-radius:20px;padding:3px 10px;font-family:'Space Mono',monospace;font-size:10px;color:var(--ok);margin-top:.4rem}

.tips{display:grid;grid-template-columns:1fr 1fr;gap:.4rem;margin-bottom:1.1rem}
.tip{background:var(--bg2);border:1px solid var(--b1);border-radius:var(--r);padding:.6rem .85rem}
.tip b{display:block;font-family:'Space Mono',monospace;font-size:9px;text-transform:uppercase;letter-spacing:.12em;color:var(--peach);margin-bottom:2px;font-weight:400}
.tip span{font-size:12px;color:var(--t2);line-height:1.5}

.timer-row{display:flex;gap:.35rem;margin-bottom:1rem;align-items:center;flex-wrap:wrap}
.tlbl{font-family:'Space Mono',monospace;font-size:9px;text-transform:uppercase;letter-spacing:.15em;color:var(--t3);margin-right:.2rem;flex-shrink:0}
.tbtn{padding:.4rem .75rem;border-radius:20px;border:1px solid var(--b2);background:var(--bg2);font-family:'Space Mono',monospace;font-size:11px;color:var(--t2);cursor:pointer;transition:all .15s}
.tbtn:hover{border-color:var(--gold);color:var(--gold)}
.tbtn.on{background:var(--gd);border-color:var(--gold);color:var(--gold)}

.cam-wrap{position:relative;background:#000;border:1px solid var(--b2);border-radius:var(--r2);overflow:hidden;margin-bottom:.75rem;min-height:280px;display:flex;align-items:center;justify-content:center}
.cam-ph{text-align:center;padding:2.5rem 1.5rem}
.ph-icon{font-size:2.5rem;margin-bottom:.75rem;opacity:.22}
.cam-ph p{font-size:13px;color:var(--t3);line-height:1.6}
#videoEl{width:100%;max-height:420px;object-fit:cover;object-position:center;display:none}
#snapCanvas{width:100%;max-height:420px;object-fit:contain;display:none}
#heatCanvas{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;opacity:.7;display:none}
.sample-ov{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;display:none;align-items:center;justify-content:center}
.sample-box{width:180px;height:180px;border:2px solid rgba(245,200,66,.8);border-radius:14px;box-shadow:0 0 0 2000px rgba(0,0,0,.3);position:relative}
.sample-box::after{content:'';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:8px;height:8px;border:1.5px solid var(--gold);border-radius:50%}
.sample-lbl{position:absolute;bottom:-22px;left:50%;transform:translateX(-50%);font-family:'Space Mono',monospace;font-size:9px;color:var(--gold);white-space:nowrap}
.timer-disp{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-family:'Space Mono',monospace;font-size:5rem;font-weight:700;color:var(--gold);text-shadow:0 0 40px #f5c84244;display:none;z-index:10}

.status{background:var(--bg2);border:1px solid var(--b2);border-radius:8px;padding:.55rem 1rem;font-family:'Space Mono',monospace;font-size:11px;color:var(--t2);margin-bottom:.75rem;display:flex;align-items:center;gap:8px}
.sdot{width:7px;height:7px;border-radius:50%;background:var(--t3);flex-shrink:0;transition:all .3s}
.sdot.on{background:var(--gold);box-shadow:0 0 8px var(--gold)}
.sdot.warn{background:var(--peach);box-shadow:0 0 6px var(--peach)}
.sdot.err{background:var(--rose);box-shadow:0 0 6px var(--rose)}

.btn-row{display:flex;gap:.4rem;margin-bottom:1.5rem}
.btn{flex:1;padding:.75rem .4rem;border-radius:var(--r);font-family:'Space Grotesk',sans-serif;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center;gap:5px;border:none}
.btn-p{background:var(--gold);color:#0c0a09;box-shadow:0 0 20px #f5c84230}
.btn-p:hover{background:#fad96a}
.btn-s{background:var(--bg3);color:var(--t1);border:1px solid var(--b3)}
.btn-s:hover{background:var(--bg4);color:var(--t0)}
.btn:disabled{opacity:.3;cursor:not-allowed;box-shadow:none;pointer-events:none}

.results{display:none}
.results.show{display:block;animation:up .4s ease}
@keyframes up{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

/* Color summary card */
.color-hero{background:var(--bg1);border:1px solid var(--b2);border-radius:var(--r2);padding:1.4rem;margin-bottom:.65rem;position:relative;overflow:hidden}
.color-hero::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--gold),transparent)}
.hero-row{display:flex;gap:.85rem;align-items:flex-start;margin-bottom:1rem}
.main-swatch{width:84px;height:84px;border-radius:12px;flex-shrink:0;border:2px solid rgba(255,255,255,.15)}
.swatch-info{flex:1;min-width:0}
.s-hex{font-family:'Space Mono',monospace;font-size:1rem;font-weight:700;color:var(--t0);margin-bottom:.15rem}
.s-name{font-size:13px;font-weight:600;color:var(--t1);margin-bottom:.35rem}
.pill-row{display:flex;flex-wrap:wrap;gap:.3rem}
.pill{padding:3px 9px;border-radius:20px;font-family:'Space Mono',monospace;font-size:10px;border:1px solid;white-space:nowrap}
.pal-row{display:flex;gap:.4rem;margin-bottom:.85rem;flex-wrap:wrap}
.pal-sw{width:38px;height:38px;border-radius:7px;border:1.5px solid rgba(255,255,255,.12);flex-shrink:0}
.cgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:.4rem}
.cgi{background:var(--bg2);border:1px solid var(--b1);border-radius:8px;padding:.55rem .7rem;text-align:center}
.cgi-l{font-family:'Space Mono',monospace;font-size:9px;text-transform:uppercase;letter-spacing:.1em;color:var(--t3);margin-bottom:.2rem}
.cgi-v{font-family:'Space Mono',monospace;font-size:11px;font-weight:700;color:var(--t0)}

/* Anomaly summary — friendly */
.anom-summary-box{background:var(--bg1);border:1px solid var(--b2);border-radius:var(--r2);padding:1.4rem;margin-bottom:.65rem;position:relative;overflow:hidden}
.anom-summary-box::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--rose),var(--warn),transparent)}
.anom-overall{border-radius:10px;padding:.85rem 1.1rem;margin-bottom:1rem;font-size:14px;font-weight:600;line-height:1.5}
.anom-overall-sub{font-size:12px;font-weight:400;opacity:.85;margin-top:.2rem}

/* Finding cards — friendly style */
.finding-list{display:flex;flex-direction:column;gap:.6rem;margin-bottom:1rem}
.finding-card{background:var(--bg2);border-radius:var(--r);padding:1rem 1.1rem;border:1px solid var(--b1);position:relative;overflow:hidden}
.finding-card::before{content:'';position:absolute;top:0;left:0;width:4px;height:100%}
.finding-card.ok::before{background:var(--ok)}
.finding-card.warn::before{background:var(--warn)}
.finding-card.flag::before{background:var(--rose)}
.finding-card.ok{border-color:rgba(0,230,118,.2)}
.finding-card.warn{border-color:rgba(255,183,0,.25)}
.finding-card.flag{border-color:rgba(244,96,122,.3)}
.fc-top{display:flex;align-items:center;gap:.6rem;margin-bottom:.5rem}
.fc-emoji{font-size:1.2rem;flex-shrink:0;line-height:1}
.fc-title{font-size:14px;font-weight:600;color:var(--t0);flex:1}
.fc-status{font-size:11px;font-family:'Space Mono',monospace;padding:2px 9px;border-radius:12px;border:1px solid;white-space:nowrap}
.fc-what{font-size:13px;color:var(--t1);line-height:1.7;margin-bottom:.65rem}
.fc-solution{background:var(--bg3);border-radius:8px;padding:.7rem .85rem}
.fc-sol-title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;margin-bottom:.4rem}
.fc-sol-steps{font-size:12px;color:var(--t1);line-height:1.75}
.fc-sol-steps li{margin-left:1.1rem;margin-bottom:.2rem}
.fc-sol-steps li:last-child{margin-bottom:0}

/* Heatmap box */
.hm-box{background:var(--bg2);border:1px solid var(--b1);border-radius:var(--r);padding:.75rem 1rem;margin-bottom:.5rem}
.hm-title{font-size:12px;font-weight:600;color:var(--t1);margin-bottom:.5rem}
.hm-leg{display:flex;align-items:center;gap:.5rem}
.hm-grad{flex:1;height:10px;border-radius:5px;background:linear-gradient(90deg,#00e676,#ffb700,#f4607a)}
.hm-lbl{font-family:'Space Mono',monospace;font-size:10px;color:var(--t2);white-space:nowrap}

/* Section cards */
.scard{background:var(--bg1);border:1px solid var(--b2);border-radius:var(--r2);overflow:hidden;margin-bottom:.5rem}
.scard-head{padding:.7rem 1rem;border-bottom:1px solid var(--b1);display:flex;align-items:center;gap:.6rem;background:var(--bg2)}
.scard-ico{width:26px;height:26px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0;border:1px solid var(--b2)}
.scard-ttl{font-size:13px;font-weight:600}
.scard-body{padding:1rem 1.1rem}
.ri{margin-bottom:.8rem;padding-bottom:.8rem;border-bottom:1px solid var(--b1)}
.ri:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none}
.ri-name{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;margin-bottom:.25rem}
.ri-text{font-size:13px;color:var(--t1);line-height:1.75}
.chips{display:flex;flex-wrap:wrap;gap:.3rem;margin-top:.5rem}
.chip{display:flex;align-items:center;gap:5px;padding:4px 10px;border-radius:20px;font-size:11px;font-family:'Space Mono',monospace;border:1px solid rgba(255,255,255,.12);background:var(--bg3)}
.chip-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0}
.tags{display:flex;flex-wrap:wrap;gap:.3rem;margin-top:.6rem}
.tag{padding:3px 10px;border-radius:20px;font-size:11px;font-family:'Space Mono',monospace;border:1px solid}
.disc{font-size:11px;color:var(--t3);line-height:1.7;padding:.85rem 1rem;background:var(--bg2);border:1px solid var(--b1);border-radius:8px;margin-top:.65rem;font-family:'Space Mono',monospace}