@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(--rose),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:.72;display:none}
.cam-switch{position:absolute;top:10px;right:10px;z-index:20;background:rgba(0,0,0,.55);border:1px solid rgba(255,255,255,.3);border-radius:50%;width:44px;height:44px;display:none;align-items:center;justify-content:center;cursor:pointer;font-size:20px;color:#fff}
.cam-switch.visible{display:flex}
.cam-indicator{position:absolute;top:10px;left:10px;z-index:20;background:rgba(0,0,0,.55);border:1px solid rgba(255,255,255,.2);border-radius:20px;padding:4px 10px;font-family:'Space Mono',monospace;font-size:10px;color:rgba(255,255,255,.7);display:none}
.cam-indicator.visible{display:block}
.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)}}

/* ── Skin baseline card ── */
.baseline-card{background:var(--bg1);border:1px solid var(--b2);border-radius:var(--r2);padding:1.25rem;margin-bottom:.65rem;position:relative;overflow:hidden}
.baseline-card::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--gold),transparent)}
.bc-label{font-family:'Space Mono',monospace;font-size:9px;text-transform:uppercase;letter-spacing:.15em;color:var(--t3);margin-bottom:.75rem}
.bc-swatches{display:flex;gap:.75rem;align-items:center;margin-bottom:.85rem;flex-wrap:wrap}
.bc-swatch{border-radius:10px;border:2px solid rgba(255,255,255,.15);flex-shrink:0;position:relative}
.bc-swatch-lbl{position:absolute;bottom:-20px;left:50%;transform:translateX(-50%);font-family:'Space Mono',monospace;font-size:9px;white-space:nowrap;color:var(--t3)}
.bc-meta{display:grid;grid-template-columns:repeat(3,1fr);gap:.4rem}
.bcm{background:var(--bg2);border:1px solid var(--b1);border-radius:8px;padding:.55rem .7rem;text-align:center}
.bcm-l{font-family:'Space Mono',monospace;font-size:9px;text-transform:uppercase;letter-spacing:.1em;color:var(--t3);margin-bottom:.2rem}
.bcm-v{font-family:'Space Mono',monospace;font-size:11px;font-weight:700;color:var(--t0)}

/* ── Hyperpig main card ── */
.hyperpig-card{background:var(--bg1);border:1px solid var(--b2);border-radius:var(--r2);padding:1.25rem;margin-bottom:.65rem;position:relative;overflow:hidden}
.hyperpig-card::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--rose),var(--warn),transparent)}

/* Overall severity badge */
.severity-hero{display:flex;align-items:center;gap:1rem;background:var(--bg2);border-radius:var(--r);padding:1rem 1.1rem;margin-bottom:1rem;border:1px solid var(--b1)}
.sev-swatch-pair{display:flex;gap:.5rem;align-items:center;flex-shrink:0}
.sev-arrow{font-size:1.2rem;color:var(--t3)}
.sev-info{flex:1}
.sev-title{font-size:15px;font-weight:700;color:var(--t0);margin-bottom:.2rem}
.sev-sub{font-size:12px;color:var(--t2);line-height:1.5}

/* Delta E meter */
.de-meter{margin-bottom:1rem}
.de-label{display:flex;justify-content:space-between;align-items:center;margin-bottom:.4rem}
.de-label-left{font-size:12px;font-weight:600;color:var(--t1)}
.de-val{font-family:'Space Mono',monospace;font-size:13px;font-weight:700}
.de-track{height:10px;background:var(--bg3);border-radius:5px;overflow:hidden;position:relative}
.de-fill{height:100%;border-radius:5px;transition:width 1s ease}
.de-markers{display:flex;justify-content:space-between;margin-top:.3rem}
.de-marker{font-family:'Space Mono',monospace;font-size:9px;color:var(--t3)}

/* Zone breakdown */
.zones-breakdown{margin-bottom:1rem}
.zb-title{font-size:12px;font-weight:600;color:var(--t2);margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.08em}
.zone-items{display:flex;flex-direction:column;gap:.35rem}
.zone-item{display:flex;align-items:center;gap:.65rem;background:var(--bg2);border-radius:8px;padding:.6rem .85rem;border:1px solid var(--b1)}
.zone-item.affected{border-color:var(--rose)33}
.zi-swatch{width:28px;height:28px;border-radius:6px;border:1.5px solid rgba(255,255,255,.15);flex-shrink:0}
.zi-info{flex:1;min-width:0}
.zi-name{font-size:12px;font-weight:600;color:var(--t1);margin-bottom:.1rem}
.zi-detail{font-size:11px;color:var(--t2)}
.zi-de{font-family:'Space Mono',monospace;font-size:12px;font-weight:700;flex-shrink:0}
.zi-bar{width:60px;height:4px;background:var(--bg3);border-radius:2px;flex-shrink:0;overflow:hidden}
.zi-bar-fill{height:100%;border-radius:2px}

/* Recovery timeline */
.recovery-card{background:var(--bg1);border:1px solid var(--b2);border-radius:var(--r2);padding:1.25rem;margin-bottom:.65rem;overflow:hidden;position:relative}
.recovery-card::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--sage),transparent)}
.rc-header{margin-bottom:1rem}
.rc-title{font-size:15px;font-weight:700;color:var(--t0);margin-bottom:.25rem}
.rc-sub{font-size:13px;color:var(--t2);line-height:1.6}

/* Timeline */
.timeline{position:relative;padding-left:1.5rem}
.timeline::before{content:'';position:absolute;left:6px;top:8px;bottom:8px;width:2px;background:var(--b2);border-radius:1px}
.tl-item{position:relative;margin-bottom:1rem}
.tl-item:last-child{margin-bottom:0}
.tl-dot{position:absolute;left:-1.5rem;top:4px;width:14px;height:14px;border-radius:50%;border:2px solid;display:flex;align-items:center;justify-content:center;font-size:7px;font-weight:700;background:var(--bg1)}
.tl-period{font-family:'Space Mono',monospace;font-size:10px;text-transform:uppercase;letter-spacing:.1em;margin-bottom:.25rem}
.tl-title{font-size:13px;font-weight:600;color:var(--t0);margin-bottom:.25rem}
.tl-desc{font-size:12px;color:var(--t2);line-height:1.65}
.tl-products{display:flex;flex-wrap:wrap;gap:.3rem;margin-top:.4rem}
.tl-tag{padding:2px 8px;border-radius:12px;font-family:'Space Mono',monospace;font-size:10px;border:1px solid}

/* Ingredient guide */
.ingr-card{background:var(--bg1);border:1px solid var(--b2);border-radius:var(--r2);padding:1.25rem;margin-bottom:.65rem}
.ingr-grid{display:grid;grid-template-columns:1fr 1fr;gap:.5rem;margin-top:.75rem}
.ingr-item{background:var(--bg2);border:1px solid var(--b1);border-radius:var(--r);padding:.75rem .85rem}
.ingr-name{font-size:12px;font-weight:700;color:var(--t0);margin-bottom:.2rem}
.ingr-dose{font-family:'Space Mono',monospace;font-size:10px;color:var(--gold);margin-bottom:.2rem}
.ingr-desc{font-size:11px;color:var(--t2);line-height:1.55}
.ingr-speed{font-family:'Space Mono',monospace;font-size:9px;margin-top:.3rem;padding:2px 6px;border-radius:8px;display:inline-block}

/* 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}

.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}