/* ============================================================
   DIYPassPhoto design system  ·  "the instrument that says yes"
   Palette: spruce-ink + emerald signal + cool optical white
   Type: Bricolage Grotesque (display) · Inter (body) · Spline Sans Mono (readouts)
   Motif: crop-marks (corner ticks) + a frame that goes green
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Bricolage+Grotesque:opsz,wght@12..96,500;12..96,600;12..96,700;12..96,800&family=Inter:wght@400;500;600&family=Spline+Sans+Mono:wght@400;500;600&display=swap');

:root{
  --paper:#F3F6F2; --paper-2:#E9EEE7; --card:#FBFCFA;
  --ink:#0E1A14; --ink-2:#17271F; --mist:#5A6B61; --faint:#8A988F;
  --line:#D6DDD3; --line-2:#C7D0C4;
  --go:#11A861; --go-2:#0C8E51; --go-soft:#E1F2E8; --go-line:#A9DBC0;
  --hold:#C2871F; --hold-soft:#F6ECD7;
  --stop:#CC5544; --stop-soft:#F6E1DD;
  --r:18px; --r-sm:11px;
  --sh-1:0 1px 2px rgba(14,26,20,.05), 0 10px 30px -12px rgba(14,26,20,.12);
  --sh-2:0 2px 6px rgba(14,26,20,.06), 0 24px 60px -20px rgba(14,26,20,.22);
  --ease:cubic-bezier(.2,.7,.2,1);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--paper);color:var(--ink);
  font-family:Inter,system-ui,-apple-system,sans-serif;line-height:1.55;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
.wrap{max-width:1120px;margin:0 auto;padding:0 24px}
a{color:var(--go-2);text-decoration:none}
a:hover{text-decoration:underline}
.mono{font-family:"Spline Sans Mono",ui-monospace,monospace;font-feature-settings:"tnum"}
h1,h2,h3,h4{font-family:"Bricolage Grotesque",sans-serif;margin:0;line-height:1.04;letter-spacing:-.02em;font-weight:700}

/* crop-mark eyebrow */
.eyebrow{display:inline-flex;align-items:center;gap:9px;font-family:"Spline Sans Mono",monospace;
  font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--go-2);font-weight:600}
.eyebrow::before{content:"";width:14px;height:14px;border-left:2px solid var(--go);border-top:2px solid var(--go)}

/* ---------- top bar ---------- */
header.bar{position:sticky;top:0;z-index:40;background:color-mix(in srgb,var(--paper) 86%,transparent);
  backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.bar .wrap{display:flex;align-items:center;justify-content:space-between;height:64px}
.brand{display:flex;align-items:center;gap:11px;font-family:"Bricolage Grotesque";font-weight:800;font-size:20px;letter-spacing:-.03em;color:var(--ink)}
.brand:hover{text-decoration:none}
.mark{width:30px;height:30px;border-radius:8px;border:2.5px solid var(--go);position:relative;flex:0 0 auto}
.mark::before,.mark::after{content:"";position:absolute;width:7px;height:7px;border:2px solid var(--ink)}
.mark::before{top:4px;left:4px;border-right:0;border-bottom:0}
.mark::after{bottom:4px;right:4px;border-left:0;border-top:0}
.navlinks{display:flex;gap:26px;font-size:14.5px;font-weight:500}
.navlinks a{color:var(--mist)}
.navlinks a:hover{color:var(--ink);text-decoration:none}
@media(max-width:760px){.navlinks{display:none}}

/* ---------- hero / studio ---------- */
.hero{padding:46px 0 8px}
.hero h1{font-size:clamp(34px,6vw,62px);font-weight:800;margin:16px 0 16px;max-width:15ch}
.hero h1 em{font-style:normal;color:var(--go-2)}
.hero .lede{font-size:clamp(17px,2.2vw,20px);color:var(--mist);max-width:52ch;margin:0}
.trust{display:flex;flex-wrap:wrap;gap:8px 18px;margin-top:18px;font-size:13.5px;color:var(--mist)}
.trust span{display:inline-flex;align-items:center;gap:7px}
.trust span::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--go)}

.studio{display:grid;grid-template-columns:1.05fr .95fr;gap:22px;align-items:start;margin-top:34px}
@media(max-width:900px){.studio{grid-template-columns:1fr}}

/* the signature frame around the viewfinder */
.framewrap{position:relative;padding:14px}
.framewrap::before,.framewrap::after,
.framewrap>.tick-tl,.framewrap>.tick-tr,.framewrap>.tick-bl,.framewrap>.tick-br{pointer-events:none}
.cropmark{position:absolute;width:26px;height:26px;z-index:3;transition:border-color .5s var(--ease)}
.cropmark.tl{top:0;left:0;border-left:3px solid var(--line-2);border-top:3px solid var(--line-2)}
.cropmark.tr{top:0;right:0;border-right:3px solid var(--line-2);border-top:3px solid var(--line-2)}
.cropmark.bl{bottom:0;left:0;border-left:3px solid var(--line-2);border-bottom:3px solid var(--line-2)}
.cropmark.br{bottom:0;right:0;border-right:3px solid var(--line-2);border-bottom:3px solid var(--line-2)}
.framewrap.go .cropmark{border-color:var(--go)}

.viewfinder{position:relative;background:#0B130E;border-radius:var(--r);overflow:hidden;aspect-ratio:1/1;
  display:flex;align-items:center;justify-content:center;box-shadow:var(--sh-2);
  outline:0 solid transparent;transition:box-shadow .5s var(--ease)}
.framewrap.go .viewfinder{box-shadow:0 0 0 3px var(--go), var(--sh-2)}
.viewfinder video,.viewfinder canvas.feed{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.viewfinder canvas.hud{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;z-index:2}
.vf-empty{position:relative;z-index:2;text-align:center;color:#9DB3A4;padding:30px;font-size:14px;max-width:30ch}
.vf-empty .big{display:block;font-family:"Bricolage Grotesque";font-weight:700;font-size:20px;color:#E7F0E9;margin-bottom:8px;letter-spacing:-.02em}
.vf-badge{position:absolute;top:14px;left:14px;z-index:5;font-family:"Spline Sans Mono",monospace;
  font-size:11px;font-weight:600;letter-spacing:.1em;padding:7px 12px;border-radius:999px;
  background:rgba(11,19,14,.74);color:#fff;border:1px solid rgba(255,255,255,.16);transition:background .35s}
.vf-badge.go{background:var(--go);border-color:transparent}
.vf-badge .blink{display:inline-block;width:7px;height:7px;border-radius:50%;background:currentColor;margin-right:7px;vertical-align:middle}
.framewrap.go .vf-badge .blink{animation:pulse 1.1s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}

/* gate panel */
.panel{background:var(--card);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--sh-1);overflow:hidden;display:flex;flex-direction:column}
.panel .phead{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:15px 17px;border-bottom:1px solid var(--line)}
.panel .phead .ttl{font-family:"Bricolage Grotesque";font-weight:700;font-size:15px}
select.country{font-family:Inter;font-size:13px;font-weight:600;color:var(--ink);background:var(--paper);
  border:1px solid var(--line-2);border-radius:9px;padding:8px 10px;max-width:62%}
.gates{padding:5px 8px;overflow:auto;max-height:340px}
.gate{display:flex;gap:11px;align-items:flex-start;padding:10px 9px;border-radius:10px;transition:background .35s}
.gate+.gate{border-top:1px solid var(--paper-2)}
.gate.just-passed{background:var(--go-soft)}
.dot{flex:0 0 auto;width:19px;height:19px;border-radius:50%;margin-top:1px;display:grid;place-items:center;
  font-size:11px;font-weight:700;color:#fff;transition:transform .3s var(--ease),background .3s}
.dot.pass{background:var(--go)} .dot.fail{background:var(--stop)} .dot.warn{background:var(--hold)}
.dot.manual{background:var(--faint)} .dot.idle{background:#C4CEC6}
.gate.just-passed .dot{transform:scale(1.18)}
.gate .body{flex:1;min-width:0}
.gate .glabel{display:flex;justify-content:space-between;gap:8px;font-weight:600;font-size:13.5px}
.gate .measured{font-family:"Spline Sans Mono",monospace;font-size:11px;color:var(--mist);white-space:nowrap;flex:0 0 auto}
.gate .coach{font-size:12.5px;color:var(--mist);margin-top:3px;display:none}
.gate.show-coach .coach{display:block}
.score{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 17px;border-top:1px solid var(--line);background:var(--paper)}
.score .verdict{font-family:"Bricolage Grotesque";font-weight:800;font-size:15.5px}
.score .verdict.go{color:var(--go-2)} .score .verdict.hold{color:var(--ink)}

/* controls + buttons */
.controls{display:flex;gap:11px;flex-wrap:wrap;margin-top:18px}
.btn{font-family:Inter;font-weight:600;font-size:14.5px;border-radius:12px;padding:12px 18px;
  border:1px solid var(--line-2);background:var(--card);color:var(--ink);cursor:pointer;
  display:inline-flex;align-items:center;gap:9px;transition:transform .12s,border-color .2s,background .2s}
.btn:hover{border-color:var(--mist);transform:translateY(-1px)}
.btn:active{transform:translateY(0)}
.btn.primary{background:var(--ink);border-color:var(--ink);color:#fff}
.btn.primary:hover{background:var(--ink-2)}
.btn.go{background:var(--go);border-color:var(--go);color:#fff}
.btn.go:hover{background:var(--go-2)}
.btn:disabled{opacity:.45;cursor:not-allowed;transform:none}
input[type=file]{display:none}
.hint{font-size:13px;color:var(--mist);margin-top:12px;max-width:60ch}

/* result */
.result{display:none;grid-template-columns:210px 1fr;gap:20px;align-items:start;margin-top:20px;
  background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:18px;box-shadow:var(--sh-1)}
.result.on{display:grid}
@media(max-width:560px){.result{grid-template-columns:1fr}}
.result img{width:100%;border-radius:12px;border:1px solid var(--line);background:var(--paper)}
.result .rmeta{font-family:"Spline Sans Mono",monospace;font-size:12.5px;color:var(--mist);line-height:1.7}
.result .rmeta b{color:var(--ink)}

.disclaimer{font-size:12.5px;color:var(--mist);background:var(--paper-2);border-radius:12px;padding:13px 15px;margin-top:16px}
.disclaimer b{color:var(--ink)}

/* ---------- sections ---------- */
section.block{padding:54px 0;border-top:1px solid var(--line);margin-top:54px}
h2.sec{font-size:clamp(26px,3.6vw,38px);font-weight:800;margin:12px 0 8px;max-width:18ch}
.sec-sub{color:var(--mist);max-width:58ch;font-size:16px;margin:0 0 26px}

.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
@media(max-width:820px){.steps{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.steps{grid-template-columns:1fr}}
.step{position:relative;background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:20px 18px 18px}
.step .num{font-family:"Spline Sans Mono",monospace;font-size:12px;font-weight:600;color:var(--go-2);letter-spacing:.1em}
.step h3{font-size:16.5px;font-weight:700;margin:10px 0 5px}
.step p{font-size:14px;color:var(--mist);margin:0}

.checkgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
@media(max-width:820px){.checkgrid{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.checkgrid{grid-template-columns:1fr}}
.cc{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:20px;position:relative}
.cc::before{content:"";position:absolute;top:14px;right:14px;width:14px;height:14px;border-right:2px solid var(--go-line);border-top:2px solid var(--go-line)}
.cc h3{font-size:16px;font-weight:700;margin-bottom:6px}
.cc p{font-size:13.8px;color:var(--mist);margin:0}

/* country grid */
.countries{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
@media(max-width:820px){.countries{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.countries{grid-template-columns:1fr}}
.ccard{display:flex;align-items:center;gap:14px;background:var(--card);border:1px solid var(--line);
  border-radius:var(--r);padding:16px 16px;transition:transform .14s var(--ease),border-color .2s,box-shadow .2s}
.ccard:hover{transform:translateY(-2px);border-color:var(--go-line);box-shadow:var(--sh-1);text-decoration:none}
.ccard .fl{font-size:26px;flex:0 0 auto;filter:saturate(1.1)}
.ccard .cinfo .cn{font-family:"Bricolage Grotesque";font-weight:700;font-size:15.5px;color:var(--ink);display:block}
.ccard .cinfo .cs{font-family:"Spline Sans Mono",monospace;font-size:11.5px;color:var(--mist);margin-top:3px;display:block}
.ccard .go-arrow{margin-left:auto;color:var(--faint);transition:color .2s,transform .2s}
.ccard:hover .go-arrow{color:var(--go);transform:translateX(2px)}

/* privacy band */
.privacy{display:flex;gap:16px;align-items:flex-start;background:var(--go-soft);border:1px solid var(--go-line);border-radius:var(--r);padding:22px}
.privacy .ic{flex:0 0 auto;width:38px;height:38px;border-radius:10px;background:var(--go);display:grid;place-items:center;color:#fff;font-weight:800;font-size:18px}
.privacy h3{font-size:17px;font-weight:700;margin-bottom:5px;color:var(--ink)}
.privacy p{font-size:14px;color:#2C513D;margin:0;max-width:70ch}

/* spec strip (country pages) */
.specstrip{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;margin-top:6px}
@media(max-width:620px){.specstrip{grid-template-columns:1fr 1fr}}
.specstrip .cell{background:var(--card);padding:16px}
.specstrip .k{font-family:"Spline Sans Mono",monospace;font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--mist)}
.specstrip .v{font-family:"Bricolage Grotesque";font-weight:700;font-size:19px;margin-top:5px}

/* generic lists on content pages */
.list{list-style:none;padding:0;margin:0}
.list li{position:relative;padding:9px 0 9px 26px;border-bottom:1px solid var(--line);font-size:15.5px}
.list li::before{content:"";position:absolute;left:2px;top:15px;width:9px;height:9px;border-left:2px solid var(--go);border-bottom:2px solid var(--go);transform:rotate(-45deg)}
.list.x li::before{border-color:var(--stop);transform:none;left:4px;top:14px;width:10px;height:2px;box-shadow:0 0 0 0 transparent;background:var(--stop);border:0}
.list.x li{padding-left:24px}

.faq dt{font-family:"Bricolage Grotesque";font-weight:700;font-size:16.5px;margin-top:20px}
.faq dd{margin:6px 0 0;color:var(--mist);font-size:15px}

/* blog cards */
.bloglist{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
@media(max-width:820px){.bloglist{grid-template-columns:1fr}}
.bloglist a{display:block;background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:20px}
.bloglist a:hover{border-color:var(--go-line);text-decoration:none;transform:translateY(-2px);transition:.14s}
.bloglist .k{font-family:"Spline Sans Mono",monospace;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--go-2);font-weight:600}
.bloglist h3{font-size:16px;font-weight:700;margin:8px 0 5px}
.bloglist p{font-size:13.6px;color:var(--mist);margin:0}

/* footer */
footer{border-top:1px solid var(--line);margin-top:54px;padding:38px 0 48px;color:var(--mist);font-size:13.5px}
footer .cols{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:24px}
@media(max-width:680px){footer .cols{grid-template-columns:1fr 1fr}}
footer h4{font-family:"Spline Sans Mono",monospace;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--faint);font-weight:600;margin-bottom:12px}
footer a{display:block;color:var(--mist);padding:3px 0}
footer a:hover{color:var(--ink);text-decoration:none}
footer .legal{margin-top:26px;padding-top:18px;border-top:1px solid var(--line);font-size:12.5px;color:var(--faint)}

/* breadcrumb on country pages */
.crumb{font-family:"Spline Sans Mono",monospace;font-size:12px;color:var(--mist);padding:22px 0 0}
.crumb a{color:var(--mist)}

@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}

/* ---------- national emblem (flag + animal) ---------- */
.emblem{display:inline-flex;align-items:center;gap:12px;margin-top:18px;padding:9px 9px 9px 14px;
  background:var(--card);border:1px solid var(--line);border-radius:999px;box-shadow:var(--sh-1)}
.emblem .flag{font-size:22px;line-height:1}
.emblem .sep{width:1px;height:20px;background:var(--line)}
.emblem .ani{font-size:24px;line-height:1;filter:saturate(1.1)}
.emblem .lbl{font-family:"Spline Sans Mono",monospace;font-size:11.5px;color:var(--mist);letter-spacing:.02em}
.emblem .lbl b{display:block;font-family:Inter;font-weight:600;font-size:13px;color:var(--ink);letter-spacing:0;margin-top:1px}
.ccard .fl .ani{font-size:15px;margin-left:-6px}

/* 2026 AI-rule notice (right panel top) */
.notice2026{background:#FFFBEB;border:1px solid #F5D87E;border-radius:10px;padding:11px 14px;font-size:13.5px;line-height:1.55;margin-top:-10px;margin-bottom:12px;color:#6B4F00}
.notice2026 b{color:#3D2C00}
.notice2026 a{color:#2A4D9B;font-weight:600;white-space:nowrap;margin-left:4px}

/* official requirements link (country pages) */
.official{margin:18px 0 0;font-size:14.5px}
.official a{font-weight:600}

/* requirements / rejections / faq sections (country pages) */
.reqlist,.rejlist{padding-left:20px;margin:0}
.reqlist li,.rejlist li{font-size:15.5px;line-height:1.65;padding:5px 0;border-bottom:1px solid var(--line)}
.reqlist li:last-child,.rejlist li:last-child{border-bottom:none}
.rejlist li{color:var(--mist)}
.rejlist li::marker{color:#DC2626}
.faqlist{display:flex;flex-direction:column;gap:0}
.faqitem{padding:16px 0;border-bottom:1px solid var(--line)}
.faqitem:last-child{border-bottom:none}
.faqitem h4{font-family:"Bricolage Grotesque",sans-serif;font-weight:700;font-size:16px;margin:0 0 6px;color:var(--ink)}
.faqitem p{margin:0;font-size:15px;color:var(--mist);line-height:1.65}
