:root{
  --ink:#141c1b;
  --ink-soft:#46524f;
  --bg:#f2f4f2;
  --card:#ffffff;
  --line:#dde3df;
  --crit:#d2232a;       /* band G red */
  --crit-soft:#fbeaea;
  --warn:#e8a000;       /* band D amber */
  --warn-soft:#fdf4e0;
  --pass:#008054;       /* band A green */
  --pass-soft:#e3f1eb;
  --disp:'Archivo',sans-serif;
  --body:'Inter',-apple-system,sans-serif;
  --mono:'IBM Plex Mono',ui-monospace,monospace;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--body);background:var(--bg);color:var(--ink);line-height:1.55;-webkit-font-smoothing:antialiased}
.wrap{max-width:880px;margin:0 auto;padding:0 20px}

/* EPC band strip — brand motif */
.bandstrip{display:flex;height:6px}
.bandstrip span{flex:1}
.bandstrip .a{background:#008054}.bandstrip .b{background:#19b459}
.bandstrip .c{background:#8dce46}.bandstrip .d{background:#ffd500}
.bandstrip .e{background:#fcaa65}.bandstrip .f{background:#ef8023}
.bandstrip .g{background:#e9153b}

nav{background:var(--ink)}
nav .inner{max-width:880px;margin:0 auto;padding:16px 20px;display:flex;align-items:center;justify-content:space-between}
.logo{font-family:var(--disp);font-weight:800;font-size:19px;color:#fff;letter-spacing:-.01em;text-decoration:none}
.logo span{color:var(--warn)}
nav .by{font-family:var(--mono);font-size:11px;color:#8fa39d;letter-spacing:.06em}

/* hero */
.hero{padding:56px 0 40px}
.hero h1{font-family:var(--disp);font-weight:800;font-size:clamp(34px,6vw,56px);letter-spacing:-.03em;line-height:.98;max-width:640px}
.hero h1 em{font-style:normal;color:var(--crit)}
.hero p.lead{font-size:17px;color:var(--ink-soft);max-width:540px;margin:18px 0 0}
.hero .steps{display:flex;gap:22px;margin-top:22px;flex-wrap:wrap}
.hero .steps div{font-family:var(--mono);font-size:12px;color:var(--ink-soft);display:flex;align-items:center;gap:8px}
.hero .steps b{font-family:var(--disp);font-size:15px;color:var(--ink)}

/* dropzone */
.drop{margin:34px 0 10px;background:var(--card);border:2px dashed #b9c4be;border-radius:16px;padding:48px 30px;text-align:center;cursor:pointer;transition:all .15s}
.drop:hover,.drop.over{border-color:var(--pass);background:var(--pass-soft)}
.drop .ico{font-size:34px;margin-bottom:10px}
.drop h2{font-family:var(--disp);font-weight:700;font-size:20px;letter-spacing:-.01em}
.drop p{font-size:14px;color:var(--ink-soft);margin-top:4px}
.drop .btn{display:inline-block;margin-top:18px;font-family:var(--mono);font-size:13px;font-weight:600;letter-spacing:.04em;background:var(--ink);color:#fff;padding:13px 26px;border-radius:10px}
.drop:hover .btn{background:var(--pass)}
.privacy{font-family:var(--mono);font-size:11.5px;color:#7d8a85;text-align:center;margin-bottom:60px}
.privacy b{color:var(--pass)}

/* progress / status panel */
.status{display:none;margin:34px 0 60px;background:var(--card);border:1px solid var(--line);border-radius:16px;padding:30px 26px;text-align:center}
.status.show{display:block}
.status .spinner{width:34px;height:34px;border:3px solid var(--line);border-top-color:var(--pass);border-radius:50%;margin:0 auto 16px;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.status h3{font-family:var(--disp);font-weight:700;font-size:18px;margin-bottom:6px}
.status p{font-size:14px;color:var(--ink-soft)}
.status.error{border-color:var(--crit);background:var(--crit-soft)}
.status.error .spinner{display:none}
.status.error h3{color:var(--crit)}
.status .retry{display:inline-block;margin-top:16px;font-family:var(--mono);font-size:13px;font-weight:600;background:var(--ink);color:#fff;padding:11px 22px;border-radius:10px;border:none;cursor:pointer}

/* example / live report */
.example-label{display:flex;align-items:center;gap:14px;margin-bottom:22px}
.example-label h2{font-family:var(--disp);font-weight:800;font-size:26px;letter-spacing:-.02em;white-space:nowrap}
.example-label .rule{height:1px;background:var(--line);flex:1}
.example-label .tag{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;background:var(--ink);color:#fff;padding:5px 10px;border-radius:5px;white-space:nowrap}

.report{background:var(--card);border:1px solid var(--line);border-radius:16px;overflow:hidden;margin-bottom:70px}
.report-head{padding:22px 26px;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;align-items:baseline}
.report-head h3{font-family:var(--disp);font-weight:700;font-size:18px}
.report-head .meta{font-family:var(--mono);font-size:11.5px;color:#7d8a85}
.report-head .actions{display:flex;gap:8px}
.report-head .dl{font-family:var(--mono);font-size:11.5px;font-weight:600;background:var(--ink);color:#fff;border:none;border-radius:8px;padding:8px 14px;cursor:pointer}
.report-head .dl:hover{background:var(--pass)}
.snapshot{padding:16px 26px;background:#fafbfa;border-bottom:1px solid var(--line);font-size:14px;color:var(--ink-soft)}
.snapshot b{color:var(--ink)}

.sect{padding:22px 26px;border-bottom:1px solid var(--line)}
.sect:last-child{border-bottom:none}
.sect-title{font-family:var(--disp);font-weight:700;font-size:15px;display:flex;align-items:center;gap:9px;margin-bottom:14px}
.count{font-family:var(--mono);font-size:11px;font-weight:600;padding:2px 9px;border-radius:100px}
.count.c{background:var(--crit-soft);color:var(--crit)}
.count.w{background:var(--warn-soft);color:#b07a00}

.finding{border:1px solid var(--line);border-left:4px solid var(--crit);border-radius:10px;padding:16px 18px;margin-bottom:12px;background:#fff}
.finding.warn{border-left-color:var(--warn)}
.finding .field{font-family:var(--disp);font-weight:700;font-size:15px;margin-bottom:7px;display:flex;justify-content:space-between;gap:10px;flex-wrap:wrap;align-items:center}
.entered{font-family:var(--mono);font-size:11.5px;background:var(--ink);color:#ffd2d4;padding:4px 10px;border-radius:6px;white-space:nowrap}
.finding.warn .entered{color:#ffe9b8}
.finding .text{font-size:14px;color:var(--ink-soft)}
.finding .text b{color:var(--ink)}
.conv{display:inline-block;margin-top:10px;font-family:var(--mono);font-size:11px;font-weight:500;color:var(--pass);background:var(--pass-soft);border:1px solid #bfdfd2;padding:4px 10px;border-radius:6px}

.evlist{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:8px 18px}
.evlist li{font-size:13.5px;color:var(--ink-soft);padding-left:24px;position:relative}
.evlist li::before{content:'📷';position:absolute;left:0;font-size:13px}
@media(max-width:560px){.evlist{grid-template-columns:1fr}}

.consistent{background:var(--pass-soft);border-radius:10px;padding:14px 18px;font-size:14px;color:#1c4f3e}
.report-foot{padding:14px 26px;background:#fafbfa;font-family:var(--mono);font-size:11px;color:#7d8a85;display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap}

.empty{font-size:14px;color:var(--ink-soft);font-style:italic}

/* trust row */
.trust{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;margin-bottom:70px}
.trust div{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:18px}
.trust h4{font-family:var(--disp);font-weight:700;font-size:14.5px;margin-bottom:5px}
.trust p{font-size:13px;color:var(--ink-soft)}

footer{background:var(--ink);color:#9bb0aa;padding:30px 0 36px;font-size:13px}
footer .inner{max-width:880px;margin:0 auto;padding:0 20px;text-align:center;line-height:1.8}
footer a{color:#fff;text-decoration:none;font-weight:600}
footer .disclaimer{font-family:var(--mono);font-size:11px;margin-top:10px;color:#7d918b}

/* print stylesheet — Download report */
@media print{
  nav,.bandstrip,.hero,.drop,.privacy,.status,.example-label,.trust,footer,.report-head .actions{display:none !important}
  body{background:#fff}
  .wrap{max-width:none;padding:0}
  .report{border:none;margin:0;box-shadow:none}
  .finding{break-inside:avoid}
}
