/* ════ رحلة اليقين — Journey of Certainty · styles ════ */
:root{
  --primary:#C0392B; --primary-dark:#A93226;
  --bg1:#071A2F; --bg2:#0E2C4A; --bg3:#143a5e;
  --gold:#E8B530; --gold-soft:#F5CC5A;
  --text:#FEF5DC; --muted:rgba(254,245,220,.72);
  --card:rgba(255,255,255,.06); --line:rgba(232,181,48,.28);
  --radius:1.4rem;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:'Tajawal','Nunito',sans-serif;
  background:
    radial-gradient(1200px 700px at 80% -10%, rgba(192,57,43,.22), transparent 60%),
    radial-gradient(1000px 600px at 0% 100%, rgba(232,181,48,.12), transparent 55%),
    linear-gradient(165deg,var(--bg1),var(--bg2) 55%,var(--bg3));
  background-attachment:fixed;
  color:var(--text); min-height:100vh;
}
html[dir="ltr"] body{font-family:'Nunito','Tajawal',sans-serif}
.lng-en{display:none}
html[dir="ltr"] .lng-ar{display:none}
html[dir="ltr"] .lng-en{display:inline}
b{color:var(--gold-soft);font-weight:800}

/* ── HEADER ── */
.hdr{position:sticky;top:0;z-index:40;display:flex;align-items:center;justify-content:space-between;gap:.8rem;padding:.85rem 1.1rem;background:rgba(7,26,47,.82);backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
.back{display:inline-flex;align-items:center;gap:.45rem;background:var(--primary);color:#fff;text-decoration:none;padding:.5rem 1rem;border-radius:2rem;font-weight:800;font-size:.9rem;box-shadow:0 6px 16px rgba(192,57,43,.35);transition:transform .2s,background .2s}
.back:hover{background:var(--primary-dark);transform:translateY(-1px)}
.hdr-badge{display:inline-flex;align-items:center;gap:.5rem;font-weight:900;font-size:1.05rem;color:var(--gold-soft)}
.hdr-badge .l{font-size:1.4rem}
/* chapter bar (multi-part journeys) */
.chapter-bar{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:.5rem .8rem;padding:.7rem 1rem;background:rgba(0,0,0,.22);border-bottom:1px solid var(--line)}
.chapter-bar .cb-label{font-weight:900;font-size:.82rem;color:var(--gold-soft)}
.cb-tabs{display:flex;gap:.45rem;flex-wrap:wrap;justify-content:center}
.cb-tab{display:inline-flex;align-items:center;gap:.35rem;text-decoration:none;font-weight:800;font-size:.82rem;color:var(--text);background:rgba(255,255,255,.06);border:1.5px solid var(--line);border-radius:2rem;padding:.42rem .9rem;transition:transform .15s,background .2s}
.cb-tab:hover{transform:translateY(-1px);background:rgba(255,255,255,.12)}
.cb-tab.active{background:var(--gold);color:#10243a;border-color:var(--gold)}
.lang{display:flex;border:1.5px solid var(--line);border-radius:2rem;overflow:hidden}
.lang button{background:transparent;border:0;color:var(--text);font-weight:800;padding:.35rem .8rem;font-size:.8rem;cursor:pointer;font-family:inherit}
.lang button.active{background:var(--gold);color:#071A2F}

/* ── INTRO ── */
.intro{max-width:920px;margin:0 auto;padding:2.2rem 1.2rem .6rem;text-align:center}
.intro h1{font-size:clamp(2rem,6vw,3rem);font-weight:900;margin:0 0 .4rem;line-height:1.12}
.intro h1 .hl{color:var(--gold-soft)}
.intro .sub{font-size:clamp(1rem,2.6vw,1.2rem);color:var(--muted);margin:0 auto;max-width:640px;line-height:1.6}
.guide{display:inline-flex;align-items:center;gap:.7rem;margin-top:1.4rem;background:var(--card);border:1px solid var(--line);border-radius:2rem;padding:.55rem .9rem .55rem .55rem;backdrop-filter:blur(8px)}
html[dir="ltr"] .guide{padding:.55rem .55rem .55rem .9rem}
.guide .who{width:44px;height:44px;border-radius:50%;background:linear-gradient(160deg,var(--gold),#caa01f);display:flex;align-items:center;justify-content:center;font-size:1.5rem;flex:0 0 auto}
.guide .say{font-weight:700;font-size:.95rem;text-align:start}

/* ── PROGRESS / CERTAINTY METER ── */
.pbar-wrap{max-width:560px;margin:1.6rem auto .4rem;padding:0 1.2rem}
.pbar-top{display:flex;justify-content:space-between;align-items:center;font-weight:800;font-size:.85rem;color:var(--muted);margin-bottom:.45rem}
.pbar-top .stars{color:var(--gold-soft)}
.pbar{position:relative;height:16px;border-radius:99px;background:rgba(255,255,255,.09);overflow:hidden;border:1px solid var(--line)}
.pbar-fill{height:100%;width:0;border-radius:99px;background:linear-gradient(90deg,#27AE60,var(--gold) 60%,var(--gold-soft));transition:width .7s cubic-bezier(.4,0,.2,1)}
.meter-label{text-align:center;font-weight:800;font-size:.8rem;color:var(--gold-soft);margin-top:.4rem;min-height:1.1em}

/* ── COLLECTIONS BAR ── */
.collections{max-width:680px;margin:1.4rem auto 0;padding:0 1.1rem;display:grid;grid-template-columns:repeat(2,1fr);gap:.8rem}
.coll-card{background:var(--card);border:1px solid var(--line);border-radius:1.1rem;padding:.9rem;text-align:center;cursor:pointer;transition:transform .15s,border-color .15s}
.coll-card:hover{transform:translateY(-2px);border-color:var(--gold)}
.coll-card .ci{font-size:1.6rem}
.coll-card .ct{font-weight:800;font-size:.9rem;margin-top:.25rem}
.coll-card .cn{font-weight:900;color:var(--gold-soft);font-size:.82rem;margin-top:.15rem}
.coll-cert{grid-column:1/-1;background:linear-gradient(160deg,rgba(232,181,48,.16),rgba(192,57,43,.12));border-color:var(--gold)}

/* ── MAP ── */
.map{position:relative;max-width:680px;margin:1.4rem auto 0;padding:1.5rem 1rem 4rem}
.road{position:absolute;top:0;bottom:0;left:50%;width:0;border-left:4px dashed rgba(232,181,48,.4);transform:translateX(-50%);z-index:0}
.station{position:relative;z-index:1;display:flex;align-items:center;gap:1rem;margin:0 0 1.5rem;width:50%}
.station.l{margin-right:auto;flex-direction:row-reverse;text-align:start;padding-left:1.2rem}
.station.r{margin-left:auto;text-align:start;padding-right:1.2rem}
html[dir="ltr"] .station.l{text-align:end}
.node{flex:0 0 auto;width:64px;height:64px;border-radius:50%;display:flex;align-items:center;justify-content:center;position:relative;font-size:1.9rem;cursor:pointer;background:var(--nc,#27AE60);box-shadow:0 0 0 4px rgba(7,26,47,1),0 0 0 6px var(--nc,#27AE60),0 10px 22px rgba(0,0,0,.45);transition:transform .2s}
.node:hover{transform:scale(1.08)}
.node .num{position:absolute;top:-8px;inset-inline-end:-8px;background:#071A2F;color:var(--gold-soft);border:2px solid var(--gold);width:24px;height:24px;border-radius:50%;font-size:.72rem;font-weight:900;display:flex;align-items:center;justify-content:center;font-family:'Nunito',sans-serif}
.node.done::after{content:'✓';position:absolute;bottom:-6px;inset-inline-start:-6px;background:var(--gold);color:#071A2F;width:24px;height:24px;border-radius:50%;font-size:.85rem;font-weight:900;display:flex;align-items:center;justify-content:center;box-shadow:0 3px 8px rgba(0,0,0,.4)}
.node.locked{background:#2a3f56;box-shadow:0 0 0 4px rgba(7,26,47,1),0 0 0 6px #2a3f56,0 8px 18px rgba(0,0,0,.4);cursor:not-allowed;filter:grayscale(.4)}
.node.locked .face{display:none}
.node.locked .lock{font-size:1.2rem}
.s-label{flex:1;min-width:0}
.s-label .t{font-weight:800;font-size:.98rem;line-height:1.3}
.s-label .t .em{margin-inline-start:.25rem}
.station.locked .s-label .t{color:var(--muted)}
.s-label .go{display:inline-block;margin-top:.3rem;font-size:.78rem;font-weight:800;color:var(--gold-soft)}
.station.locked .s-label .go{color:rgba(254,245,220,.4)}
.finish{position:relative;z-index:1;text-align:center;margin-top:.5rem}
.finish .cup{width:84px;height:84px;border-radius:50%;margin:0 auto;background:linear-gradient(160deg,#3a2f12,#241d0a);border:3px solid var(--gold);display:flex;align-items:center;justify-content:center;font-size:2.4rem;box-shadow:0 12px 30px rgba(0,0,0,.5);cursor:pointer}
.finish .ft{margin-top:.6rem;font-weight:900;color:var(--gold-soft)}

footer.foot{text-align:center;color:var(--muted);font-size:.85rem;padding:1.5rem 1rem 2.5rem}
footer.foot b{color:var(--gold-soft)}

/* ── READER OVERLAY ── */
.reader{position:fixed;inset:0;z-index:120;background:rgba(4,14,26,.55);backdrop-filter:blur(6px);display:none;overflow-y:auto}
.reader.open{display:block}
.sheet{max-width:760px;margin:0 auto;min-height:100%;background:linear-gradient(170deg,#0c243d,#0a1f36);border-inline:1px solid var(--line);display:flex;flex-direction:column}
.r-top{position:sticky;top:0;z-index:5;display:flex;align-items:center;justify-content:space-between;gap:.6rem;padding:.75rem 1rem;background:rgba(7,26,47,.92);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.r-close{background:var(--card);border:1px solid var(--line);color:var(--text);width:40px;height:40px;border-radius:50%;font-size:1.2rem;cursor:pointer;font-weight:800}
.r-count{font-weight:800;font-size:.85rem;color:var(--muted)}
.r-arrows{display:flex;gap:.4rem}
.r-arrows button{background:var(--card);border:1px solid var(--line);color:var(--text);width:40px;height:40px;border-radius:12px;font-size:1.3rem;cursor:pointer;font-weight:800}
.r-arrows button:disabled{opacity:.3;cursor:default}

.s-hero{padding:2rem 1.4rem 1.4rem;text-align:center;position:relative;overflow:hidden}
.s-hero::before{content:'';position:absolute;inset:0;background:radial-gradient(420px 220px at 50% -20%,var(--accent),transparent 70%);opacity:.4}
.s-hero .ring{position:relative;width:96px;height:96px;border-radius:50%;margin:0 auto 1rem;background:var(--accent);display:flex;align-items:center;justify-content:center;font-size:3rem;box-shadow:0 0 0 5px rgba(255,255,255,.08),0 14px 34px rgba(0,0,0,.5)}
.s-hero .kick{position:relative;font-weight:800;letter-spacing:.05em;font-size:.78rem;color:var(--gold-soft);text-transform:uppercase}
.s-hero h2{position:relative;font-size:clamp(1.5rem,4.5vw,2.1rem);font-weight:900;margin:.35rem 0 0;line-height:1.2}

.blocks{padding:.4rem 1.2rem 1.4rem;display:flex;flex-direction:column;gap:1rem}
.block{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:1.2rem}
.block h3{display:flex;align-items:center;gap:.55rem;margin:0 0 .7rem;font-size:1.05rem;font-weight:900}
.block h3 .bi{font-size:1.4rem}
.block p{margin:0;line-height:1.85;font-size:1.02rem;color:#fdf3da}
.block.wow{border-color:rgba(232,181,48,.4)}
.block.wow h3{color:var(--gold-soft)}

/* Mr Chance villain + rebuttal */
.block.chance{border-color:rgba(192,57,43,.45);background:rgba(192,57,43,.08)}
.block.chance h3{color:#FF8B7B}
.mrchance{display:flex;gap:.7rem;align-items:flex-start;background:rgba(0,0,0,.22);border:1px dashed rgba(255,139,123,.5);border-radius:1rem;padding:.8rem;margin-bottom:.9rem}
.mrchance .mc-face{flex:0 0 auto;width:46px;height:46px;border-radius:50%;background:#3a1b16;display:flex;align-items:center;justify-content:center;font-size:1.6rem}
.mrchance .mc-body .mc-name{font-weight:900;color:#FF8B7B;font-size:.82rem;margin-bottom:.2rem}
.mrchance .mc-body .mc-say{font-weight:700;line-height:1.6}
.rebut-tag{display:inline-block;font-weight:900;color:#7FE0A8;font-size:.85rem;margin-bottom:.4rem}

/* Myth-buster flip card */
.block.myth{border-color:rgba(232,181,48,.4)}
.block.myth h3{color:var(--gold-soft)}
.flip{perspective:1200px;cursor:pointer;height:175px}
@media (max-width:560px){.flip{height:205px}}
.flip-inner{position:relative;width:100%;height:100%;transition:transform .6s cubic-bezier(.4,0,.2,1);transform-style:preserve-3d}
.flip.flipped .flip-inner{transform:rotateY(180deg)}
.flip-face{position:absolute;inset:0;backface-visibility:hidden;border-radius:1rem;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:1.1rem 1.2rem;font-weight:800;font-size:1.12rem;line-height:1.65;overflow:auto}
.flip-front{background:rgba(120,28,20,.92);border:1.5px solid rgba(255,139,123,.7);color:#FFFFFF}
.flip-back{background:rgba(18,92,52,.94);border:1.5px solid rgba(46,204,113,.8);color:#FFFFFF;transform:rotateY(180deg)}
.flip-face .ft-tag{font-size:.74rem;font-weight:900;letter-spacing:.04em;opacity:.95;margin-bottom:.5rem;text-transform:uppercase}
.flip-hint{text-align:center;font-size:.78rem;color:var(--muted);margin-top:.55rem}

/* Chance Machine */
.block.machine{border-color:rgba(155,89,182,.5);background:rgba(91,75,138,.14)}
.block.machine h3{color:#C7B6F2}
.cm-stage{background:rgba(0,0,0,.25);border:1px solid rgba(199,182,242,.3);border-radius:1rem;padding:1rem .8rem;text-align:center}
.cm-tiles{display:flex;flex-wrap:wrap;gap:.4rem;justify-content:center;min-height:54px;align-items:center;margin-bottom:.7rem}
.cm-tile{width:42px;height:50px;border-radius:.55rem;background:linear-gradient(160deg,#26405e,#1a2f47);border:1px solid rgba(255,255,255,.12);display:flex;align-items:center;justify-content:center;font-weight:900;font-size:1.4rem;font-family:'Nunito',sans-serif;transition:transform .25s,background .25s}
.cm-tile.win{background:linear-gradient(160deg,#2ecc71,#27AE60);color:#04210f;animation:pop .4s}
@keyframes pop{0%{transform:scale(.6)}70%{transform:scale(1.15)}100%{transform:scale(1)}}
.cm-row{display:flex;gap:.5rem;justify-content:center;flex-wrap:wrap;align-items:center}
.cm-btn{font-family:inherit;font-weight:900;cursor:pointer;border:0;border-radius:2rem;padding:.65rem 1.3rem;font-size:.95rem;background:linear-gradient(160deg,#9B59B6,#7d439a);color:#fff;box-shadow:0 8px 20px rgba(155,89,182,.3)}
.cm-btn.solve{background:linear-gradient(160deg,var(--gold),#caa01f);color:#071A2F}
.cm-count{font-weight:800;color:#C7B6F2;font-size:.85rem;align-self:center}
.cm-verdict{margin-top:.7rem;font-weight:800;line-height:1.6;min-height:1.2em;color:#FFD7CF}
.cm-verdict.solved{color:#7FE0A8}

/* Match game */
.block.matchb{border-color:rgba(52,152,219,.45);background:rgba(41,128,185,.1)}
.block.matchb h3{color:#86C7F0}
.match-cols{display:grid;grid-template-columns:1fr 1fr;gap:.6rem}
.match-col{display:flex;flex-direction:column;gap:.5rem}
.match-item{background:rgba(0,0,0,.22);border:1.5px solid rgba(134,199,240,.35);border-radius:.7rem;padding:.65rem .6rem;font-weight:700;font-size:.9rem;cursor:pointer;text-align:center;line-height:1.4;transition:transform .12s,border-color .15s,background .15s;min-height:54px;display:flex;align-items:center;justify-content:center}
.match-item:hover{transform:translateY(-1px)}
.match-item.sel{border-color:var(--gold);background:rgba(232,181,48,.16)}
.match-item.matched{border-color:rgba(46,204,113,.6);background:rgba(46,204,113,.16);color:#CFFBE3;cursor:default;pointer-events:none}
.match-item.wrong{animation:shake .35s}
@keyframes shake{0%,100%{transform:translateX(0)}25%{transform:translateX(-6px)}75%{transform:translateX(6px)}}
.match-done{text-align:center;font-weight:800;color:#7FE0A8;margin-top:.7rem;min-height:1.2em}

/* Light of Revelation */
.block.wahy{border-color:rgba(46,204,113,.4);background:rgba(38,166,91,.08)}
.block.wahy h3{color:#7FE0A8}
.ayah{font-family:'Amiri Quran',serif;direction:rtl;text-align:center;font-size:clamp(1.5rem,4.5vw,2rem);line-height:2.2;color:#fff;margin:.4rem 0 .6rem;padding:1rem .6rem;background:rgba(0,0,0,.18);border-radius:1rem;border:1px solid rgba(46,204,113,.25)}
.ayah-ref{text-align:center;font-weight:800;color:#7FE0A8;font-size:.9rem;margin-bottom:.9rem}
.block.wahy .explain{line-height:1.85;font-size:1rem;color:#eafaf0}

/* Name of Allah reveal */
.block.name{border-color:rgba(232,181,48,.45);background:linear-gradient(160deg,rgba(232,181,48,.12),rgba(192,57,43,.08))}
.block.name h3{color:var(--gold-soft)}
.name-card{text-align:center;padding:.4rem 0 .2rem}
.name-ar{font-family:'Amiri Quran',serif;font-size:clamp(2rem,7vw,2.8rem);color:#fff;line-height:1.4}
.name-en{font-weight:900;color:var(--gold-soft);letter-spacing:.04em;margin-top:.2rem}
.name-mean{color:#fdf3da;line-height:1.7;margin-top:.5rem;font-size:.98rem}

/* Key of certainty */
.block.key{border-color:rgba(245,204,90,.5);background:rgba(232,181,48,.1)}
.block.key h3{color:var(--gold-soft)}
.key-card{display:flex;align-items:center;gap:.8rem;justify-content:center;text-align:center;padding:.4rem 0}
.key-card .ki{font-size:2.2rem}
.key-card .kt{font-weight:900;font-size:1.15rem;color:#fff;line-height:1.4}

/* dua / experiment / family */
.block.dua{border-color:rgba(127,224,168,.4);background:rgba(38,166,91,.08)}
.block.dua h3{color:#7FE0A8}
.dua-text{font-family:'Amiri Quran',serif;direction:rtl;text-align:center;font-size:clamp(1.3rem,4vw,1.7rem);line-height:2;color:#fff;background:rgba(0,0,0,.18);border-radius:1rem;padding:.9rem .6rem;border:1px solid rgba(127,224,168,.25)}
html[dir="ltr"] .dua-text{font-family:'Nunito',sans-serif;direction:ltr}
.block.exp{border-color:rgba(52,152,219,.4);background:rgba(41,128,185,.08)}
.block.exp h3{color:#86C7F0}
.block.fam{border-color:rgba(232,181,48,.35)}
.block.fam h3{color:var(--gold-soft)}

/* Journal */
.block.journal{border-color:rgba(199,182,242,.4)}
.block.journal h3{color:#C7B6F2}
.journal textarea{width:100%;min-height:80px;resize:vertical;background:rgba(0,0,0,.22);border:1px solid rgba(199,182,242,.35);border-radius:.8rem;color:var(--text);font-family:inherit;font-size:1rem;line-height:1.6;padding:.7rem .8rem}
.journal textarea:focus{outline:none;border-color:var(--gold)}
.journal .saved{font-size:.78rem;color:#7FE0A8;font-weight:800;margin-top:.35rem;min-height:1em}

/* stamp */
.r-foot{padding:.3rem 1.2rem 2.4rem;text-align:center}
.stampbtn{font-family:inherit;font-weight:900;font-size:1.05rem;cursor:pointer;background:linear-gradient(160deg,var(--gold),#caa01f);color:#071A2F;border:0;border-radius:2rem;padding:.95rem 2rem;box-shadow:0 10px 26px rgba(232,181,48,.32);transition:transform .15s}
.stampbtn:hover{transform:translateY(-2px)}
.stampbtn.done{background:rgba(46,204,113,.18);color:#7FE0A8;border:1.5px solid rgba(46,204,113,.5);box-shadow:none;cursor:default}
.r-next-hint{margin-top:.9rem;font-size:.85rem;color:var(--muted)}
.r-next-hint button{background:none;border:0;color:var(--gold-soft);font-weight:800;font-size:.9rem;cursor:pointer;font-family:inherit;text-decoration:underline}

/* ── DRAWER (collections detail) ── */
.drawer{position:fixed;inset:0;z-index:130;background:rgba(4,14,26,.65);backdrop-filter:blur(6px);display:none;overflow-y:auto}
.drawer.open{display:block}
.drawer-sheet{max-width:620px;margin:0 auto;min-height:100%;background:linear-gradient(170deg,#0c243d,#0a1f36);border-inline:1px solid var(--line)}
.dw-top{position:sticky;top:0;display:flex;align-items:center;justify-content:space-between;padding:.85rem 1.1rem;background:rgba(7,26,47,.92);border-bottom:1px solid var(--line)}
.dw-top h3{margin:0;font-weight:900;color:var(--gold-soft);font-size:1.1rem}
.dw-body{padding:1.2rem}
.sticker-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:.9rem}
.sticker{border-radius:1.1rem;padding:1.1rem .7rem;text-align:center;border:2px solid var(--sc);background:rgba(255,255,255,.04)}
.sticker.locked{opacity:.32;filter:grayscale(.7)}
.sticker .si{font-size:2.4rem}
.sticker .st{font-weight:900;font-size:.86rem;margin-top:.4rem}
.list-card{background:var(--card);border:1px solid var(--line);border-radius:1rem;padding:1rem;margin-bottom:.8rem;display:flex;gap:.8rem;align-items:flex-start}
.list-card.locked{opacity:.32}
.list-card .lci{font-size:1.8rem;flex:0 0 auto}
.list-card .lct{font-weight:900;color:var(--gold-soft)}
.list-card .lcs{font-size:.92rem;color:#fdf3da;line-height:1.6;margin-top:.2rem}
.list-card .lc-name{font-family:'Amiri Quran',serif;font-size:1.5rem;color:#fff}

/* ── CERTIFICATE ── */
.cert-overlay{position:fixed;inset:0;z-index:160;background:rgba(4,14,26,.78);backdrop-filter:blur(8px);display:none;overflow-y:auto;padding:1.2rem}
.cert-overlay.open{display:block}
.cert-tools{max-width:720px;margin:0 auto .9rem;display:flex;gap:.6rem;justify-content:center;flex-wrap:wrap}
.cert-tools input{flex:1;min-width:180px;max-width:320px;background:rgba(255,255,255,.1);border:1.5px solid var(--line);border-radius:2rem;color:#fff;font-family:inherit;font-weight:700;padding:.6rem 1rem;font-size:.95rem;text-align:center}
.cert-tools input:focus{outline:none;border-color:var(--gold)}
.cert-tools button{font-family:inherit;font-weight:900;cursor:pointer;border:0;border-radius:2rem;padding:.6rem 1.2rem;font-size:.9rem}
.cert-tools .cprint{background:linear-gradient(160deg,var(--gold),#caa01f);color:#071A2F}
.cert-tools .cclose{background:var(--card);border:1px solid var(--line);color:var(--text)}
.certificate{max-width:720px;margin:0 auto;background:radial-gradient(700px 360px at 50% 0%,#10365c,#0a2138);border:3px solid var(--gold);border-radius:1.4rem;padding:2.4rem 1.8rem;text-align:center;position:relative;box-shadow:0 18px 50px rgba(0,0,0,.5)}
.certificate::before{content:'';position:absolute;inset:10px;border:1.5px solid rgba(232,181,48,.4);border-radius:1rem;pointer-events:none}
.cert-seal{width:84px;height:84px;border-radius:50%;margin:0 auto .8rem;background:linear-gradient(160deg,var(--gold),#b8901a);display:flex;align-items:center;justify-content:center;font-size:2.6rem;box-shadow:0 8px 22px rgba(232,181,48,.4)}
.cert-kick{font-weight:900;letter-spacing:.08em;color:var(--gold-soft);text-transform:uppercase;font-size:.8rem}
.cert-title{font-size:clamp(1.6rem,5vw,2.3rem);font-weight:900;margin:.3rem 0 .2rem;color:#fff}
.cert-name{font-family:'Amiri Quran',serif;font-size:clamp(1.8rem,6vw,2.6rem);color:var(--gold-soft);margin:.8rem 0;border-bottom:2px dashed rgba(232,181,48,.5);display:inline-block;padding:0 1rem .3rem}
html[dir="ltr"] .cert-name{font-family:'Nunito',sans-serif}
.cert-statement{color:#ede2c2;line-height:1.9;max-width:540px;margin:.6rem auto 1.2rem;font-size:1.02rem}
.cert-keys{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;margin-top:1rem}
.cert-keys .ck{background:rgba(232,181,48,.14);border:1px solid var(--line);border-radius:2rem;padding:.4rem .9rem;font-weight:800;font-size:.85rem;color:var(--gold-soft)}
.cert-foot{margin-top:1.4rem;font-weight:800;color:var(--muted);font-size:.85rem}

/* confetti + toast */
#confetti{position:fixed;inset:0;pointer-events:none;z-index:200;overflow:hidden}
.cf{position:absolute;width:10px;height:14px;top:-20px;opacity:.95;animation:fall linear forwards}
@keyframes fall{to{transform:translateY(108vh) rotate(720deg);opacity:.4}}
.toast{position:fixed;left:50%;bottom:2rem;transform:translateX(-50%) translateY(140%);z-index:210;background:#071A2F;border:1.5px solid var(--gold);color:var(--text);font-weight:800;padding:.8rem 1.4rem;border-radius:2rem;box-shadow:0 14px 36px rgba(0,0,0,.5);transition:transform .4s cubic-bezier(.34,1.56,.64,1);max-width:90vw;text-align:center}
.toast.show{transform:translateX(-50%) translateY(0)}

@media (max-width:560px){
  .station{width:auto;margin:0 0 1.3rem!important;padding:0 .2rem!important}
  .station.l,.station.r{flex-direction:row;text-align:start}
  html[dir="ltr"] .station.l{text-align:start}
  .road{left:42px}
  .map{padding-inline:1rem}
}

/* ── PRINT (certificate only) ── */
@media print{
  body{background:#fff!important}
  body>*{display:none!important}
  .cert-overlay.open{display:block!important;position:static!important;background:#fff!important;padding:0!important;backdrop-filter:none!important}
  .cert-tools{display:none!important}
  .certificate{box-shadow:none!important;border-color:#b8901a!important;background:#fff!important;color:#1a1a1a!important}
  .certificate::before{border-color:#b8901a!important}
  .cert-title,.cert-statement{color:#1a1a1a!important}
  .cert-name{color:#a9801a!important}
  .cert-kick,.cert-keys .ck{color:#a9801a!important}
  .cert-seal{background:#e8b530!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}
}
