/* ============================================================
   CLINIOS ONE PREMIUM — EGYPT SALES DOSSIER
   LONGEV'AI® Clinical Intelligence — Confidential Training Platform
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,400;0,9..144,500;0,9..144,600;1,9..144,500&family=Inter:wght@400;500;600;700;800&family=IBM+Plex+Mono:wght@400;500;600&family=Noto+Kufi+Arabic:wght@400;500;600;700&family=Noto+Naskh+Arabic:wght@400;600;700&display=swap');

:root{
  --ink:#0F1614;
  --ink-soft:#1B2622;
  --emerald:#0B5D3B;
  --emerald-deep:#073D27;
  --emerald-bright:#12885E;
  --gold:#C9A961;
  --gold-soft:#DDC98B;
  --ivory:#F7F4EC;
  --cream:#EFE9D8;
  --paper:#FCFAF4;
  --red:#B23A2E;
  --red-soft:#F3E3E0;
  --line:#DFD8C2;
  --text-dim:#5C6560;
  --shadow: 0 20px 60px -20px rgba(15,22,20,.35);
  --radius: 3px;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  font-family:'Inter',-apple-system,'Segoe UI',sans-serif;
  background:var(--ivory);
  color:var(--ink);
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4{
  font-family:'Fraunces',Georgia,serif;
  font-weight:600;
  letter-spacing:-.01em;
  margin:0;
  color:var(--ink);
}
p{margin:0 0 12px; line-height:1.65;}
a{color:var(--emerald-deep);}
::selection{background:var(--gold-soft); color:var(--ink);}

.mono{font-family:'IBM Plex Mono',monospace;}
.eyebrow{
  font-family:'IBM Plex Mono',monospace;
  font-size:10.5px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--gold);
}
.eyebrow.on-ivory{color:var(--emerald-deep);}

button{font-family:inherit; cursor:pointer;}
input[type=text],input[type=password]{
  font-family:'IBM Plex Mono',monospace;
}

/* reduced motion respect */
@media (prefers-reduced-motion: reduce){
  *{animation-duration:.001ms !important; transition-duration:.001ms !important;}
}

/* focus visibility */
a:focus-visible, button:focus-visible, input:focus-visible, [tabindex]:focus-visible{
  outline:2px solid var(--gold);
  outline-offset:2px;
  border-radius:2px;
}

/* text selection */
::selection{ background:rgba(201,169,97,.32); color:var(--ink); }

/* ---------- scrollbar (webkit) ---------- */
::-webkit-scrollbar{width:9px; height:9px;}
::-webkit-scrollbar-track{background:transparent;}
::-webkit-scrollbar-thumb{background:var(--line); border-radius:6px;}
::-webkit-scrollbar-thumb:hover{background:var(--gold-soft);}
.spine::-webkit-scrollbar-thumb{background:rgba(247,244,236,.15);}
.spine::-webkit-scrollbar-thumb:hover{background:var(--gold-soft);}

/* ============================================================
   WATERMARK (dynamic, injected via JS, applies on dossier pages)
   ============================================================ */
.wm-layer{
  position:fixed; inset:0; z-index:0; pointer-events:none;
  overflow:hidden;
}
.wm-layer span{
  position:absolute;
  font-family:'IBM Plex Mono',monospace;
  font-size:13px;
  color:var(--ink);
  opacity:.035;
  white-space:nowrap;
  transform:rotate(-28deg);
}

/* ============================================================
   GATE PAGE
   ============================================================ */
.gate-body{
  background:
    radial-gradient(1100px 700px at 50% -10%, rgba(201,169,97,.14), transparent 60%),
    radial-gradient(900px 600px at 100% 110%, rgba(11,93,59,.35), transparent 55%),
    var(--ink);
  min-height:100vh;
  display:flex; align-items:center; justify-content:center;
  padding:40px 18px;
}
.gate-card{
  width:100%; max-width:560px;
  background:var(--paper);
  border-radius:4px;
  box-shadow:var(--shadow);
  border:1px solid rgba(201,169,97,.35);
  position:relative;
  overflow:hidden;
  animation:riseIn .9s cubic-bezier(.16,1,.3,1) both;
}
.gate-card::before{
  content:"";
  position:absolute; inset:0;
  border:1px solid transparent;
  margin:10px;
  border-color:rgba(201,169,97,.28);
  pointer-events:none;
}
@keyframes riseIn{
  from{opacity:0; transform:translateY(18px);}
  to{opacity:1; transform:translateY(0);}
}

.gate-head{
  text-align:center;
  padding:38px 40px 22px;
  border-bottom:1px solid var(--line);
}
.gate-logo{
  width:64px; height:64px; margin:0 auto 14px;
  display:block;
  object-fit:contain;
}
.gate-brand{
  font-family:'Fraunces',serif;
  font-size:22px;
  letter-spacing:.02em;
}
.gate-brand sup{font-size:11px;}
.gate-sub{
  font-family:'IBM Plex Mono',monospace;
  font-size:9.5px;
  letter-spacing:.28em;
  color:var(--text-dim);
  text-transform:uppercase;
  margin-top:5px;
}
.gate-title{
  margin-top:20px;
  font-size:15px;
  color:var(--ink);
}
.gate-title .stamp{
  display:inline-block;
  margin-top:8px;
  font-family:'IBM Plex Mono',monospace;
  font-size:9.5px;
  letter-spacing:.18em;
  color:#fff;
  background:var(--red);
  padding:4px 10px;
  border-radius:2px;
}

.gate-body-inner{padding:28px 40px 36px;}
.field-group{margin-bottom:18px;}
.field-label{
  display:block;
  font-family:'IBM Plex Mono',monospace;
  font-size:10px;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--text-dim);
  margin-bottom:7px;
}
.field-input{
  width:100%;
  padding:12px 14px;
  border:1px solid var(--line);
  background:#fff;
  border-radius:2px;
  font-size:14px;
  color:var(--ink);
  transition:border-color .2s, box-shadow .2s;
}
.field-input:focus{
  border-color:var(--emerald);
  box-shadow:0 0 0 3px rgba(11,93,59,.12);
  outline:none;
}

.welcome-back-hint{
  display:none;
  align-items:center; gap:6px;
  margin-top:7px;
  font-family:'IBM Plex Mono',monospace;
  font-size:10.5px; letter-spacing:.03em;
  color:var(--emerald-deep);
}
.welcome-back-hint.show{ display:flex; animation:fadeUp .3s ease both; }
.welcome-back-hint::before{ content:"✓"; font-weight:700; }

.nda-box{
  border:1px solid var(--line);
  background:#fff;
  border-radius:2px;
  padding:16px 18px;
  height:150px;
  overflow-y:auto;
  font-size:12px;
  line-height:1.7;
  color:var(--ink-soft);
}
.nda-box h5{
  font-family:'IBM Plex Mono',monospace;
  font-size:10px;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:var(--emerald-deep);
  margin:14px 0 5px;
}
.nda-box h5:first-child{margin-top:0;}
.nda-box p{margin:0 0 8px; text-align:justify;}

.nda-accept{
  display:flex; align-items:flex-start; gap:10px;
  margin-top:12px;
  font-size:12.5px;
  color:var(--ink-soft);
  cursor:pointer;
}
.nda-accept input{margin-top:3px; accent-color:var(--emerald);}

.gate-btn{
  width:100%;
  margin-top:22px;
  padding:14px 18px;
  background:var(--emerald-deep);
  color:#fff;
  border:none;
  border-radius:2px;
  font-size:13px;
  letter-spacing:.08em;
  text-transform:uppercase;
  font-weight:600;
  display:flex; align-items:center; justify-content:center; gap:10px;
  transition:background .2s, transform .15s;
}
.gate-btn:hover:not(:disabled){background:var(--emerald-bright);}
.gate-btn:active:not(:disabled){transform:scale(.99);}
.gate-btn:disabled{background:#C8C2AE; cursor:not-allowed;}

.gate-error{
  margin-top:12px;
  font-size:12px;
  color:var(--red);
  display:none;
  font-family:'IBM Plex Mono',monospace;
}
.gate-error.show{display:block;}

.gate-foot{
  text-align:center;
  padding:16px 20px 26px;
  font-size:10px;
  letter-spacing:.08em;
  color:var(--text-dim);
  font-family:'IBM Plex Mono',monospace;
}

/* ============================================================
   DOSSIER SHELL (post-gate)
   ============================================================ */
.shell{display:flex; min-height:100vh; position:relative; z-index:1;}

/* --- spine / sidebar --- */
.spine{
  width:308px;
  flex:none;
  background:var(--ink);
  color:var(--ivory);
  display:flex;
  flex-direction:column;
  position:sticky; top:0; height:100vh;
  overflow-y:auto;
}
.spine-head{
  padding:26px 24px 18px;
  border-bottom:1px solid rgba(247,244,236,.12);
}
.spine-brand{display:flex; align-items:center; gap:12px;}
.spine-seal{
  width:34px;height:34px;
  object-fit:contain;
  flex:none;
}
.spine-brand-text-wrap{ display:flex; flex-direction:column; }
.spine-brand-text{
  font-family:'Fraunces',serif; font-size:16px; letter-spacing:.02em; color:#fff;
  line-height:1.2;
}
.spine-brand-text sup{ font-size:9px; }
.spine-brand-tag{
  font-family:'IBM Plex Mono',monospace;
  font-size:8.5px; letter-spacing:.24em; text-transform:uppercase;
  color:var(--gold-soft);
  margin-top:4px;
}
.spine-tool-name{
  font-family:'IBM Plex Mono',monospace;
  font-size:9px; letter-spacing:.14em; text-transform:uppercase;
  color:rgba(247,244,236,.4);
  margin-top:14px;
}
.spine-trainee-row{
  margin-top:16px;
  display:flex; align-items:center; justify-content:space-between; gap:10px;
}
.spine-trainee{
  font-size:11px;
  color:rgba(247,244,236,.55);
}
.spine-trainee b{color:var(--ivory); font-weight:600;}
.logout-btn{
  flex:none;
  background:transparent;
  font-family:'IBM Plex Mono',monospace;
  font-size:8.5px; letter-spacing:.08em; text-transform:uppercase;
  color:rgba(247,244,236,.4);
  border:1px solid rgba(247,244,236,.16);
  border-radius:20px;
  padding:4px 10px;
  transition:color .2s ease, border-color .2s ease, background .2s ease;
}
.logout-btn:hover{ color:var(--red); border-color:rgba(178,58,46,.45); background:rgba(178,58,46,.08); }

.progress-wrap{padding:16px 24px 6px;}
.progress-label{
  display:flex; justify-content:space-between;
  font-family:'IBM Plex Mono',monospace;
  font-size:9.5px; letter-spacing:.1em; text-transform:uppercase;
  color:rgba(247,244,236,.55);
  margin-bottom:8px;
}
.progress-bar{
  height:5px; background:rgba(247,244,236,.14); border-radius:4px; overflow:hidden;
}
.progress-fill{
  height:100%;
  background:linear-gradient(90deg, var(--emerald-bright), var(--gold));
  width:0%;
  transition:width .5s cubic-bezier(.16,1,.3,1);
}

.spine-nav{padding:10px 14px 24px; flex:none;}

.spine-illustration{
  position:fixed; left:0; bottom:0; width:308px; height:150px;
  pointer-events:none;
  z-index:50;
  overflow:hidden;
}
.spine-illustration::before{
  content:"";
  position:absolute; inset:0;
  background:linear-gradient(0deg, rgba(15,22,20,1) 0%, rgba(15,22,20,.97) 55%, rgba(15,22,20,.5) 82%, transparent 100%);
  z-index:1;
}
.spine-illustration svg{ position:absolute; bottom:0; left:0; width:100%; height:auto; display:block; }
.spine-illustration .twinkle{ animation:twinkle 3.4s ease-in-out infinite; }
.spine-illustration .twinkle:nth-child(2n){ animation-delay:1.1s; }
.spine-illustration .twinkle:nth-child(3n){ animation-delay:2.1s; }
@keyframes twinkle{ 0%,100%{ opacity:.25; } 50%{ opacity:.9; } }
.spine-illustration .clinic-glow{ animation:clinicPulse 3s ease-in-out infinite; }
@keyframes clinicPulse{ 0%,100%{ opacity:.55; } 50%{ opacity:1; } }
.spine-nav{ padding-bottom:150px; }
.spine-foot{ position:relative; z-index:2; background:var(--ink); }
.day-label{
  font-family:'IBM Plex Mono',monospace;
  font-size:9.5px; letter-spacing:.2em; text-transform:uppercase;
  color:var(--gold-soft);
  padding:16px 10px 6px;
}
.nav-item{
  display:flex; align-items:center; gap:11px;
  width:100%; text-align:left;
  padding:10px 10px;
  border:none; background:transparent; color:rgba(247,244,236,.78);
  border-radius:4px;
  font-size:12.5px;
  font-family:'Inter',sans-serif;
  line-height:1.3;
  transition:background .2s ease, color .2s ease, transform .15s ease;
  position:relative;
}
.nav-item .num{
  font-family:'IBM Plex Mono',monospace;
  font-size:10px;
  color:var(--gold-soft);
  flex:none;
  width:16px;
}
.nav-item .dot{
  width:15px; height:15px; border-radius:50%;
  border:1.3px solid rgba(247,244,236,.35);
  flex:none;
  display:flex; align-items:center; justify-content:center;
  transition:background .25s ease, border-color .25s ease, transform .25s cubic-bezier(.34,1.56,.64,1);
}
.nav-item .dot svg{width:9px; height:9px; opacity:0; transition:opacity .2s ease .1s;}
.nav-item.done .dot{background:var(--emerald-bright); border-color:var(--emerald-bright); transform:scale(1.08);}
.nav-item.done .dot svg{opacity:1;}
.nav-item:hover{background:rgba(247,244,236,.07); color:#fff; transform:translateX(2px);}
html[dir="rtl"] .nav-item:hover{ transform:translateX(-2px); }
.nav-item.active{background:rgba(201,169,97,.16); color:#fff;}
.nav-item.active::before{
  content:"";
  position:absolute; left:-14px; top:8px; bottom:8px; width:3px;
  background:var(--gold);
  border-radius:2px;
  transition:top .2s ease, bottom .2s ease;
}

.spine-foot{
  padding:16px 24px 22px;
  border-top:1px solid rgba(247,244,236,.12);
  font-family:'IBM Plex Mono',monospace;
  font-size:9px; letter-spacing:.06em;
  color:rgba(247,244,236,.4);
  line-height:1.6;
}

/* --- main content --- */
.main{
  flex:1;
  min-width:0;
  position:relative;
  background:var(--ivory);
}
.main-inner{
  max-width:800px;
  margin:0 auto;
  padding:56px 48px 120px;
}
.module-eyebrow{display:flex; align-items:center; gap:12px; margin-bottom:14px;}
.module-eyebrow .num-badge{
  font-family:'IBM Plex Mono',monospace;
  font-size:11px; letter-spacing:.1em;
  color:var(--emerald-deep);
  border:1px solid var(--emerald-deep);
  padding:3px 9px;
  border-radius:20px;
}
.module-eyebrow .time{
  font-family:'IBM Plex Mono',monospace;
  font-size:11px; color:var(--text-dim);
}
.module-title{
  font-size:32px;
  line-height:1.12;
  margin-bottom:6px;
  animation:fadeUp .6s cubic-bezier(.16,1,.3,1) both;
}
.module-dek{
  font-size:15px;
  color:var(--text-dim);
  font-style:italic;
  font-family:'Fraunces',serif;
  margin-bottom:34px;
  padding-bottom:26px;
  border-bottom:1px solid var(--line);
}
@keyframes fadeUp{from{opacity:0; transform:translateY(10px);} to{opacity:1; transform:translateY(0);}}

.module-body h3{
  font-size:19px;
  margin:38px 0 13px;
  padding-top:2px;
  letter-spacing:-.005em;
}
.module-body h3 .n{color:var(--gold); margin-right:8px; font-family:'IBM Plex Mono',monospace; font-size:14px;}
.module-body h4{
  font-size:14px;
  margin:20px 0 8px;
  color:var(--emerald-deep);
}
.module-body p{color:var(--ink-soft); font-size:14.5px; line-height:1.72; margin-bottom:15px;}
.module-body ul, .module-body ol{padding-left:20px; margin-bottom:16px;}
.module-body li{margin-bottom:8px; font-size:14.5px; color:var(--ink-soft); line-height:1.65;}
.module-body li::marker{ color:var(--gold); }
.module-body strong{color:var(--ink); font-weight:700;}

/* say-this callout */
.say-box{
  background:#fff;
  border:1px solid var(--line);
  border-left:3px solid var(--emerald);
  border-radius:3px;
  padding:19px 24px 19px 52px;
  margin:20px 0;
  position:relative;
  box-shadow:0 2px 10px -6px rgba(15,22,20,.12);
  transition:box-shadow .25s ease, transform .25s ease;
}
.say-box:hover{ box-shadow:0 8px 22px -10px rgba(15,22,20,.2); transform:translateY(-1px); }
.say-box::after{
  content:"";
  position:absolute; left:19px; top:21px; width:20px; height:20px;
  background:var(--emerald);
  -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M21 11.5a8.38 8.38 0 0 1-.9 3.8 8.5 8.5 0 0 1-7.6 4.7 8.38 8.38 0 0 1-3.8-.9L3 21l1.9-5.7a8.38 8.38 0 0 1-.9-3.8 8.5 8.5 0 0 1 4.7-7.6 8.38 8.38 0 0 1 3.8-.9h.5a8.48 8.48 0 0 1 8 8v.5z'/%3E%3C/svg%3E") no-repeat center/contain;
  mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M21 11.5a8.38 8.38 0 0 1-.9 3.8 8.5 8.5 0 0 1-7.6 4.7 8.38 8.38 0 0 1-3.8-.9L3 21l1.9-5.7a8.38 8.38 0 0 1-.9-3.8 8.5 8.5 0 0 1 4.7-7.6 8.38 8.38 0 0 1 3.8-.9h.5a8.48 8.48 0 0 1 8 8v.5z'/%3E%3C/svg%3E") no-repeat center/contain;
  opacity:.85;
}
.say-box .tag{
  font-family:'IBM Plex Mono',monospace;
  font-size:9.5px; letter-spacing:.14em; text-transform:uppercase;
  color:var(--emerald-deep);
  margin-bottom:8px;
  display:block;
}
.say-box p{
  font-family:'Fraunces',serif;
  font-style:italic;
  font-size:15.5px;
  color:var(--ink);
  margin:0;
  line-height:1.6;
}

/* never-say / warning */
.warn-box{
  background:var(--red-soft);
  border:1px solid rgba(178,58,46,.35);
  border-left:3px solid var(--red);
  border-radius:3px;
  padding:18px 22px 18px 52px;
  margin:20px 0;
  position:relative;
  box-shadow:0 2px 10px -6px rgba(178,58,46,.15);
}
.warn-box::after{
  content:"";
  position:absolute; left:20px; top:20px; width:19px; height:19px;
  background:var(--red);
  -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M12 9v4M12 17h.01M10.3 3.9 1.8 18a2 2 0 0 0 1.7 3h17a2 2 0 0 0 1.7-3L13.7 3.9a2 2 0 0 0-3.4 0z'/%3E%3C/svg%3E") no-repeat center/contain;
  mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M12 9v4M12 17h.01M10.3 3.9 1.8 18a2 2 0 0 0 1.7 3h17a2 2 0 0 0 1.7-3L13.7 3.9a2 2 0 0 0-3.4 0z'/%3E%3C/svg%3E") no-repeat center/contain;
  opacity:.9;
}
.warn-box .tag{
  font-family:'IBM Plex Mono',monospace;
  font-size:9.5px; letter-spacing:.14em; text-transform:uppercase;
  color:var(--red);
  margin-bottom:6px;
  display:block;
}
.warn-box p, .warn-box li{color:#5c2b26; font-size:13.5px;}
.warn-box ul{margin-bottom:0;}
.warn-box li::marker{ color:var(--red); }

/* private access credential box */
.access-box{
  background:var(--ink); color:var(--ivory);
  border-radius:4px; padding:16px 20px; margin:12px 0;
  font-family:'IBM Plex Mono',monospace; font-size:12px; line-height:1.9;
  border:1px solid rgba(201,169,97,.3);
}
.access-box .lbl{ color:var(--gold-soft); letter-spacing:.1em; font-size:9.5px; text-transform:uppercase; display:block; margin-bottom:8px; }
.access-box b{ color:#fff; font-weight:600; }
.access-box .lock{ color:rgba(247,244,236,.55); }

/* info / gold callout */
.info-box{
  background:var(--cream);
  border:1px solid var(--line);
  border-left:3px solid var(--gold);
  border-radius:3px;
  padding:17px 20px 17px 52px;
  margin:20px 0;
  position:relative;
  box-shadow:0 2px 10px -6px rgba(184,146,62,.14);
}
.info-box::after{
  content:"";
  position:absolute; left:20px; top:19px; width:19px; height:19px;
  background:var(--gold);
  -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Ccircle cx='12' cy='12' r='9'/%3E%3Cpath d='M12 16v-5M12 8h.01' stroke='%23fff' stroke-width='1.6' fill='none'/%3E%3C/svg%3E") no-repeat center/contain;
  mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Ccircle cx='12' cy='12' r='9'/%3E%3C/svg%3E") no-repeat center/contain;
}
.info-box::before{
  content:"i";
  position:absolute; left:24.5px; top:19.5px; width:10px; height:18px;
  font-family:Georgia,serif; font-style:italic; font-weight:700; font-size:13px;
  color:#fff; text-align:center; line-height:19px;
  pointer-events:none;
}
.info-box .tag{
  font-family:'IBM Plex Mono',monospace;
  font-size:9.5px; letter-spacing:.14em; text-transform:uppercase;
  color:var(--gold);
  margin-bottom:6px;
  display:block;
}
.info-box p:last-child{margin-bottom:0;}
html[dir="rtl"] .say-box, html[dir="rtl"] .warn-box, html[dir="rtl"] .info-box{
  padding-left:24px; padding-right:52px;
}
html[dir="rtl"] .say-box::after, html[dir="rtl"] .warn-box::after, html[dir="rtl"] .info-box::after{ left:auto; right:20px; }
html[dir="rtl"] .info-box::before{ left:auto; right:24.5px; }

/* objection cards */
.obj-card{
  border:1px solid var(--line);
  border-radius:4px;
  margin:14px 0;
  overflow:hidden;
  background:#fff;
  transition:box-shadow .25s ease, border-color .25s ease;
}
.obj-card:hover{ box-shadow:0 6px 18px -10px rgba(15,22,20,.18); border-color:#DCD3B8; }
.obj-card.open{ box-shadow:0 8px 22px -10px rgba(15,22,20,.2); }
.obj-q{
  padding:14px 18px;
  background:var(--cream);
  font-family:'Fraunces',serif;
  font-style:italic;
  font-size:14.5px;
  display:flex; gap:10px; align-items:flex-start;
  transition:background .2s ease;
}
.obj-q .qm{color:var(--gold); font-family:'Fraunces',serif; font-size:20px; line-height:1; flex:none;}
.obj-a .tag{
  font-family:'IBM Plex Mono',monospace;
  font-size:9px; letter-spacing:.14em; text-transform:uppercase;
  color:var(--emerald-deep);
  margin-bottom:6px; display:block;
}
.obj-a p{margin:0; font-size:13.8px;}

/* stat strip */
.stat-strip{display:flex; gap:10px; margin:20px 0;}
.stat-chip{
  flex:1; background:#fff; border:1px solid var(--line); border-radius:4px;
  padding:14px 12px; text-align:center;
  transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.stat-chip:hover{ transform:translateY(-2px); box-shadow:0 8px 18px -10px rgba(15,22,20,.2); border-color:var(--gold-soft); }
.stat-chip .v{font-family:'Fraunces',serif; font-size:22px; color:var(--emerald-deep);}
.stat-chip .l{font-family:'IBM Plex Mono',monospace; font-size:8.5px; letter-spacing:.06em; text-transform:uppercase; color:var(--text-dim); margin-top:4px; line-height:1.4;}

/* table */
.dtable{width:100%; border-collapse:collapse; margin:18px 0; box-shadow:0 1px 3px rgba(15,22,20,.06);}
.dtable th{
  text-align:left; font-family:'IBM Plex Mono',monospace; font-size:9.5px;
  letter-spacing:.08em; text-transform:uppercase; color:var(--emerald-deep);
  background:var(--cream);
  border-bottom:1.5px solid var(--emerald-deep); padding:10px 12px;
}
.dtable tr{ transition:background .15s ease; }
.dtable tbody tr:hover{ background:rgba(184,146,62,.05); }
.dtable td{border-bottom:1px solid var(--line); padding:11px 12px; font-size:13.5px; vertical-align:top; color:var(--ink-soft);}
.dtable td.b{color:var(--ink); font-weight:700; white-space:nowrap;}
.dtable tbody tr:last-child td{ border-bottom:none; }

/* checklist for module completion */
.mark-done-row{
  margin-top:44px;
  padding-top:22px;
  border-top:1px solid var(--line);
  display:flex; align-items:center; justify-content:space-between;
  flex-wrap:wrap; gap:14px;
}
.mark-done-btn{
  padding:12px 22px;
  background:var(--ink);
  color:#fff;
  border:none; border-radius:3px;
  font-size:12px; letter-spacing:.06em; text-transform:uppercase; font-weight:600;
  display:flex; align-items:center; gap:9px;
  transition:background .2s ease, transform .12s ease, box-shadow .2s ease;
  box-shadow:0 2px 8px -4px rgba(15,22,20,.3);
}
.mark-done-btn:hover{background:var(--emerald-deep); box-shadow:0 6px 16px -6px rgba(11,93,59,.4); transform:translateY(-1px);}
.mark-done-btn:active{ transform:translateY(0) scale(.97); }
.mark-done-btn.is-done{background:var(--emerald-bright);}
.next-link{
  font-family:'IBM Plex Mono',monospace;
  font-size:11.5px; color:var(--emerald-deep);
  display:flex; align-items:center; gap:6px;
  text-decoration:none;
  padding:6px 2px;
  transition:gap .2s ease, color .2s ease;
}
.next-link:hover{ gap:10px; color:var(--emerald-bright); }

/* script dialogue */
.dialogue{border:1px solid var(--line); border-radius:3px; overflow:hidden; margin:16px 0;}
.dline{padding:13px 18px; font-size:13.8px; display:flex; gap:12px;}
.dline:not(:last-child){border-bottom:1px solid var(--line);}
.dline .who{
  font-family:'IBM Plex Mono',monospace; font-size:9.5px; letter-spacing:.08em; text-transform:uppercase;
  flex:none; width:74px; padding-top:2px;
}
.dline.rep{background:#fff;} .dline.rep .who{color:var(--emerald-deep);}
.dline.dir{background:var(--cream);} .dline.dir .who{color:var(--text-dim);}
.dline p{margin:0; color:var(--ink-soft);}

/* quiz */
.quiz-q{border:1px solid var(--line); border-radius:4px; padding:19px 21px; margin-bottom:16px; background:#fff; transition:box-shadow .25s ease;}
.quiz-q:hover{ box-shadow:0 4px 14px -8px rgba(15,22,20,.15); }
.quiz-q .qtext{font-family:'Fraunces',serif; font-size:15px; margin-bottom:12px;}
.quiz-opt{
  display:flex; align-items:center; gap:10px;
  padding:11px 13px; border:1px solid var(--line); border-radius:3px; margin-bottom:8px;
  cursor:pointer; font-size:13.5px; transition:border-color .18s ease, background .18s ease, transform .12s ease;
}
.quiz-opt:hover{border-color:var(--gold); background:rgba(184,146,62,.04); transform:translateX(2px);}
html[dir="rtl"] .quiz-opt:hover{ transform:translateX(-2px); }
.quiz-opt.selected{border-color:var(--emerald); background:rgba(11,93,59,.05);}
.quiz-opt.correct{border-color:var(--emerald); background:rgba(11,93,59,.09); animation:optPop .35s ease;}
.quiz-opt.wrong{border-color:var(--red); background:var(--red-soft);}
@keyframes optPop{ 0%{transform:scale(1);} 40%{transform:scale(1.015);} 100%{transform:scale(1);} }
.quiz-opt input{accent-color:var(--emerald);}
.quiz-feedback{font-size:12.5px; margin-top:8px; padding:9px 13px; border-radius:3px; display:none;}
.quiz-feedback.show{display:block; animation:fadeUp .3s ease both;}
.quiz-feedback.ok{background:rgba(11,93,59,.08); color:var(--emerald-deep);}
.quiz-feedback.bad{background:var(--red-soft); color:var(--red);}

.quiz-submit-row{text-align:center; margin-top:30px;}
.quiz-result{
  display:none;
  text-align:center; padding:34px; border:1px solid var(--gold); border-radius:5px;
  background:linear-gradient(180deg, rgba(201,169,97,.08), transparent);
  margin-top:24px;
  box-shadow:0 10px 30px -14px rgba(184,146,62,.3);
}
.quiz-result.show{display:block; animation:fadeUp .5s ease both;}
.quiz-result .score{font-family:'Fraunces',serif; font-size:42px; color:var(--emerald-deep);}

/* certificate */
.cert{
  border:2px solid var(--gold);
  padding:54px 44px;
  text-align:center;
  background:var(--paper);
  position:relative;
  margin-top:20px;
  box-shadow:0 24px 60px -24px rgba(184,146,62,.35), 0 2px 8px rgba(15,22,20,.06);
  overflow:hidden;
}
.cert::before{
  content:""; position:absolute; inset:8px; border:1px solid var(--gold-soft); pointer-events:none;
}
.cert::after{
  content:"";
  position:absolute; top:-40px; right:-40px; width:140px; height:140px;
  background:radial-gradient(circle, rgba(201,169,97,.14), transparent 70%);
  pointer-events:none;
}
.cert-eyebrow{font-family:'IBM Plex Mono',monospace; font-size:10px; letter-spacing:.24em; color:var(--gold); text-transform:uppercase; position:relative;}
.cert-title{font-family:'Fraunces',serif; font-size:27px; margin:14px 0 6px; position:relative;}
.cert-name{font-family:'Fraunces',serif; font-style:italic; font-size:31px; color:var(--emerald-deep); margin:20px 0 8px; border-bottom:1px solid var(--line); display:inline-block; padding-bottom:11px; min-width:320px; position:relative;}
.cert-sub{font-size:12.5px; color:var(--text-dim); max-width:440px; margin:10px auto 0; position:relative;}
.cert-seal{width:74px; height:74px; margin:28px auto 8px; border-radius:50%; border:1.4px solid var(--emerald-deep); display:flex; align-items:center; justify-content:center; position:relative; box-shadow:0 4px 14px -6px rgba(11,93,59,.3);}
.cert-seal::after{content:""; position:absolute; inset:6px; border-radius:50%; border:1px solid var(--gold-soft);}
.cert-date{font-family:'IBM Plex Mono',monospace; font-size:10.5px; color:var(--text-dim); margin-top:14px; position:relative;}
.print-btn{
  margin-top:24px; padding:12px 26px; background:var(--ink); color:#fff; border:none; border-radius:3px;
  font-size:11.5px; letter-spacing:.08em; text-transform:uppercase; font-weight:600;
  transition:background .2s ease, transform .12s ease;
}
.print-btn:hover{ background:var(--emerald-deep); transform:translateY(-1px); }
.print-btn:active{ transform:translateY(0) scale(.97); }
@media print{
  .spine, .print-btn, .mark-done-row, .no-print{display:none !important;}
  .main-inner{max-width:none; padding:0;}
}

/* top confidential ribbon on every module */
.confid-ribbon{
  display:flex; align-items:center; justify-content:space-between;
  gap:10px;
  padding:9px 48px;
  background:var(--ink);
  color:rgba(247,244,236,.7);
  font-family:'IBM Plex Mono',monospace;
  font-size:9.5px; letter-spacing:.12em;
  position:relative;
}
.confid-ribbon b{color:var(--gold-soft); font-weight:600;}
#readProgress{
  position:fixed; top:0; left:0; height:2.5px; width:0%;
  background:linear-gradient(90deg, var(--gold), var(--emerald-bright));
  z-index:100;
  transition:width .08s linear;
}

/* footer legal */
.legal-foot{
  margin-top:60px; padding-top:20px; border-top:1px solid var(--line);
  font-family:'IBM Plex Mono',monospace; font-size:9px; letter-spacing:.05em; color:var(--text-dim); line-height:1.8;
}

/* mobile */
@media (max-width: 900px){
  .shell{flex-direction:column;}
  .spine{position:relative; width:100%; height:auto; max-height:none;}
  .spine-illustration{ position:relative; width:100%; left:auto; right:auto; bottom:auto; }
  .spine-nav{ padding-bottom:24px; }
  .main-inner{padding:36px 20px 90px;}
  .module-title{font-size:26px;}
  .stat-strip{flex-wrap:wrap;}
  .stat-chip{min-width:calc(50% - 5px);}
  .confid-ribbon{padding:9px 20px; flex-direction:column; align-items:flex-start; gap:2px;}
}

/* mobile menu toggle */
.mobile-bar{
  display:none;
  align-items:center; justify-content:space-between;
  background:var(--ink); color:#fff; padding:14px 18px;
  position:sticky; top:0; z-index:20;
}
.mobile-bar button{background:none; border:1px solid rgba(255,255,255,.3); color:#fff; padding:7px 12px; border-radius:3px; font-size:11px;}
@media (max-width:900px){
  .mobile-bar{display:flex;}
  .spine.closed{display:none;}
}

/* ============================================================
   LANGUAGE SWITCHER + RTL (Arabic) SUPPORT
   ============================================================ */
.lang-switch{
  display:flex; gap:6px;
  margin-top:16px;
}
.lang-pill{
  flex:1;
  background:rgba(247,244,236,.08);
  border:1px solid rgba(247,244,236,.18);
  color:rgba(247,244,236,.6);
  font-family:'IBM Plex Mono',monospace;
  font-size:10px; letter-spacing:.08em;
  padding:7px 6px;
  border-radius:2px;
  text-align:center;
  transition:background .15s, color .15s, border-color .15s;
}
.lang-pill:hover{border-color:var(--gold-soft); color:#fff;}
.lang-pill.active{
  background:var(--gold);
  border-color:var(--gold);
  color:var(--ink);
  font-weight:600;
}

/* language content blocks: show only the active language */
.lang-block{display:none;}
.lang-block.lang-active{display:block;}

/* RTL mode (Arabic active) */
html[dir="rtl"] body{
  font-family:'Noto Kufi Arabic','Inter',sans-serif;
}
html[dir="rtl"] h1, html[dir="rtl"] h2, html[dir="rtl"] h3, html[dir="rtl"] h4{
  font-family:'Noto Naskh Arabic','Fraunces',serif;
}
html[dir="rtl"] .mono, html[dir="rtl"] .eyebrow, html[dir="rtl"] .module-eyebrow .num-badge,
html[dir="rtl"] .module-eyebrow .time, html[dir="rtl"] .field-label, html[dir="rtl"] .nda-accept,
html[dir="rtl"] .gate-sub, html[dir="rtl"] .spine-brand-tag, html[dir="rtl"] .progress-label,
html[dir="rtl"] .day-label, html[dir="rtl"] .nav-item .num, html[dir="rtl"] .spine-foot,
html[dir="rtl"] .legal-foot, html[dir="rtl"] .confid-ribbon, html[dir="rtl"] .obj-a .tag,
html[dir="rtl"] .say-box .tag, html[dir="rtl"] .warn-box .tag, html[dir="rtl"] .info-box .tag,
html[dir="rtl"] .dline .who, html[dir="rtl"] .cert-eyebrow, html[dir="rtl"] .cert-date{
  font-family:'IBM Plex Mono',monospace; /* keep labels/mono readable; Arabic numerals context still fine */
}
html[dir="rtl"] .module-body p, html[dir="rtl"] .module-body li,
html[dir="rtl"] .say-box p, html[dir="rtl"] .obj-q, html[dir="rtl"] .obj-a p,
html[dir="rtl"] .dline p, html[dir="rtl"] .info-box p, html[dir="rtl"] .warn-box p,
html[dir="rtl"] .warn-box li, html[dir="rtl"] .cert-sub, html[dir="rtl"] .quiz-q .qtext,
html[dir="rtl"] .quiz-opt span{
  font-family:'Noto Kufi Arabic','Inter',sans-serif;
  text-align:right;
}
html[dir="rtl"] .module-dek{font-family:'Noto Naskh Arabic','Fraunces',serif; font-style:normal;}
html[dir="rtl"] .say-box p{font-family:'Noto Naskh Arabic','Fraunces',serif; font-style:normal;}

html[dir="rtl"] .shell{flex-direction:row-reverse;}
html[dir="rtl"] .spine{direction:rtl;}
html[dir="rtl"] .spine-illustration{ left:auto; right:0; }
html[dir="rtl"] .nav-item{flex-direction:row-reverse; text-align:right;}
html[dir="rtl"] .nav-item.active::before{left:auto; right:-14px;}
html[dir="rtl"] .spine-trainee, html[dir="rtl"] .spine-foot, html[dir="rtl"] .legal-foot{text-align:right;}
html[dir="rtl"] .module-body{direction:rtl;}
html[dir="rtl"] .module-eyebrow{flex-direction:row-reverse; justify-content:flex-end;}
html[dir="rtl"] .say-box, html[dir="rtl"] .warn-box, html[dir="rtl"] .info-box{
  border-left:none; border-right:3px solid var(--emerald);
}
html[dir="rtl"] .warn-box{border-right-color:var(--red);}
html[dir="rtl"] .info-box{border-right-color:var(--gold); border-left:1px solid var(--line);}
html[dir="rtl"] .obj-q{flex-direction:row-reverse; text-align:right;}
html[dir="rtl"] .dline{flex-direction:row-reverse;}
html[dir="rtl"] .dtable th, html[dir="rtl"] .dtable td{text-align:right;}
html[dir="rtl"] .module-body ul, html[dir="rtl"] .module-body ol{padding-left:0; padding-right:20px;}
html[dir="rtl"] .quiz-opt{flex-direction:row-reverse; text-align:right;}
html[dir="rtl"] .confid-ribbon{flex-direction:row-reverse;}
html[dir="rtl"] .stat-strip{flex-direction:row-reverse;}
html[dir="rtl"] .obj-a .tag, html[dir="rtl"] .say-box .tag, html[dir="rtl"] .warn-box .tag, html[dir="rtl"] .info-box .tag{
  text-align:right; display:block;
}
html[dir="rtl"] .next-link{flex-direction:row-reverse;}
html[dir="rtl"] .mark-done-row{flex-direction:row-reverse;}
html[dir="rtl"] .wm-layer span{transform:rotate(28deg);}

/* ============================================================
   UX/UI UPGRADE PACK
   ============================================================ */

/* ---------- nav icons ---------- */
.nav-item .ico{
  flex:none; width:15px; height:15px; opacity:.7;
  display:flex; align-items:center; justify-content:center;
}
.nav-item.active .ico, .nav-item:hover .ico{ opacity:1; }
.nav-item .ico svg{ width:100%; height:100%; }

/* ---------- home/dashboard nav entry ---------- */
.spine-home-link{
  display:flex; align-items:center; gap:8px;
  padding:9px 10px; margin:0 14px 6px;
  border-radius:3px;
  font-family:'IBM Plex Mono',monospace;
  font-size:10.5px; letter-spacing:.08em; text-transform:uppercase;
  color:rgba(247,244,236,.55);
  border:1px solid rgba(247,244,236,.14);
  background:transparent;
  transition:background .15s,color .15s,border-color .15s;
}
.spine-home-link:hover{ color:#fff; border-color:var(--gold-soft); }
.spine-home-link.active{ background:rgba(201,169,97,.16); color:#fff; border-color:var(--gold); }
.spine-home-link svg{ width:13px; height:13px; flex:none; }

/* ---------- module transition ---------- */
.main-inner{ animation:none; }
.main-inner.entering{ animation:moduleIn .42s cubic-bezier(.16,1,.3,1) both; }
@keyframes moduleIn{
  from{ opacity:0; transform:translateY(14px); }
  to{ opacity:1; transform:translateY(0); }
}

/* ---------- language switcher v2 ---------- */
.lang-switch{ position:relative; background:rgba(247,244,236,.06); border-radius:5px; padding:3px; }
.lang-pill{ position:relative; z-index:2; border:none; background:transparent; }
.lang-pill.active{ box-shadow:0 2px 8px rgba(0,0,0,.25); transform:scale(1.02); }

/* ---------- countdown widget ---------- */
.countdown{
  margin:14px 24px 4px;
  padding:12px 14px;
  border:1px solid rgba(201,169,97,.3);
  border-radius:4px;
  background:linear-gradient(180deg, rgba(201,169,97,.09), transparent);
}
.countdown .cd-label{
  font-family:'IBM Plex Mono',monospace; font-size:8.5px; letter-spacing:.14em; text-transform:uppercase;
  color:var(--gold-soft); margin-bottom:6px;
}
.countdown .cd-time{
  font-family:'Fraunces',serif; font-size:19px; color:#fff; letter-spacing:.01em;
}
.countdown .cd-time .u{ font-family:'IBM Plex Mono',monospace; font-size:9px; color:rgba(247,244,236,.5); margin-right:8px; }
.countdown .cd-sub{ font-family:'IBM Plex Mono',monospace; font-size:8.5px; color:rgba(247,244,236,.4); margin-top:5px; }

/* ============================================================
   DASHBOARD — vibrant, illustrated, animated overview
   ============================================================ */
:root{
  --joy-coral:#FF6B5B;
  --joy-amber:#FFB627;
  --joy-teal:#14B8A6;
  --joy-violet:#8B5CF6;
  --joy-rose:#FB7185;
  --joy-sky:#38BDF8;
}

/* ---------- hero: illustrated Cairo scene, multicolor sky, animated figures ---------- */
.dash-hero{
  position:relative;
  display:flex; align-items:center; justify-content:space-between; gap:56px;
  padding:56px 58px;
  margin-bottom:48px;
  min-height:340px;
  border-radius:4px;
  overflow:hidden;
  flex-wrap:wrap;
  background:var(--ink);
}
.dash-hero::after{
  content:"";
  position:absolute; inset:0;
  border:1px solid rgba(201,169,97,.22);
  border-radius:4px;
  pointer-events:none;
  z-index:3;
}
.dash-hero > .hero-figures{ position:absolute; left:0; right:0; bottom:56px; height:0; z-index:0; pointer-events:none; }
.hero-figures .figure{ position:absolute; bottom:0; overflow:visible; }
.hero-figures .figure-a{ left:34%; }
.hero-figures .figure-b{ left:51%; }
html[dir="rtl"] .hero-figures .figure-a{ left:auto; right:34%; }
html[dir="rtl"] .hero-figures .figure-b{ left:auto; right:51%; }
.dash-hero .floaters{ display:none; }
.dash-hero > *{ position:relative; z-index:2; }
.dash-hero::before{
  content:"";
  position:absolute; inset:0; z-index:1;
  background:linear-gradient(100deg, rgba(15,22,20,.72) 0%, rgba(15,22,20,.5) 30%, rgba(15,22,20,.18) 50%, transparent 68%);
}
.dash-welcome h1, .dash-welcome p, .dash-welcome .eyebrow, .dash-continue{ text-shadow:0 2px 10px rgba(0,0,0,.55); }

/* animated figures — walking / gesturing motion, multi-directional */
.hero-figures .figure{ animation:figBob 2.7s ease-in-out infinite; transform-origin:50% 100%; }
.hero-figures .figure-b{ animation-delay:.3s; }
@keyframes figBob{
  0%,100%{ transform:translateY(0) rotate(0deg); }
  25%{ transform:translateY(-3px) rotate(-2deg); }
  50%{ transform:translateY(0) rotate(0deg); }
  75%{ transform:translateY(-3px) rotate(2deg); }
}
.fig-arm-l{ animation:armSwingA 1.4s ease-in-out infinite; transform-origin:0px 20px; }
.fig-leg-l{ animation:legSwingA 1.3s ease-in-out infinite; transform-origin:8px 60px; }
.fig-leg-r{ animation:legSwingB 1.3s ease-in-out infinite; transform-origin:19px 60px; }
.fig-arm-r2{ animation:armSwingB 1.4s ease-in-out infinite; transform-origin:20px 20px; }
.fig-leg-l2{ animation:legSwingB 1.5s ease-in-out infinite; transform-origin:8px 58px; }
.fig-leg-r2{ animation:legSwingA 1.5s ease-in-out infinite; transform-origin:19px 58px; }
.fig-arm-hi5-a{ animation:hi5Reach 2.6s ease-in-out infinite; transform-origin:19.5px 30px; }
.fig-arm-hi5-b{ animation:hi5Reach 2.6s ease-in-out infinite .1s; transform-origin:0.5px 30px; }
@keyframes armSwingA{ 0%,100%{ transform:rotate(-16deg); } 50%{ transform:rotate(10deg); } }
@keyframes armSwingB{ 0%,100%{ transform:rotate(16deg); } 50%{ transform:rotate(-10deg); } }
@keyframes legSwingA{ 0%,100%{ transform:rotate(10deg); } 50%{ transform:rotate(-12deg); } }
@keyframes legSwingB{ 0%,100%{ transform:rotate(-10deg); } 50%{ transform:rotate(12deg); } }
@keyframes hi5Reach{ 0%,100%{ transform:rotate(-4deg); } 50%{ transform:rotate(6deg); } }

.dash-welcome .eyebrow{ margin-bottom:16px; letter-spacing:.32em; font-size:9.5px; }
.dash-welcome h1{ font-size:38px; line-height:1.14; margin-bottom:10px; font-weight:400; letter-spacing:-.01em; }
.sparkle-row{ display:flex; gap:8px; margin-bottom:18px; }
.sparkle-row span{ width:6px; height:6px; border-radius:50%; animation:sparklePop 2.4s ease-in-out infinite; }
.sparkle-row span:nth-child(1){ background:#E0663F; animation-delay:0s; }
.sparkle-row span:nth-child(2){ background:#E0A63E; animation-delay:.15s; }
.sparkle-row span:nth-child(3){ background:#2E9E7C; animation-delay:.3s; }
.sparkle-row span:nth-child(4){ background:#7D6CC4; animation-delay:.45s; }
.sparkle-row span:nth-child(5){ background:#D4577A; animation-delay:.6s; }
@keyframes sparklePop{ 0%,100%{ transform:translateY(0) scale(1); opacity:.75; } 50%{ transform:translateY(-4px) scale(1.25); opacity:1; } }
.dash-welcome p{ font-size:14px; line-height:1.7; max-width:440px; color:rgba(247,244,236,.68); font-weight:300; }
.dash-continue{
  margin-top:28px; display:inline-flex; align-items:center; gap:12px;
  padding:15px 0;
  background:none;
  color:var(--gold-soft); border:none; border-top:1px solid rgba(201,169,97,.4); border-bottom:1px solid rgba(201,169,97,.4);
  font-size:10.5px; letter-spacing:.16em; text-transform:uppercase; font-weight:500;
  transition:color .25s, border-color .25s, gap .25s;
}
.dash-continue:hover{ color:#fff; border-color:rgba(201,169,97,.85); gap:16px; }
.dash-continue:active{ opacity:.7; }
.dash-continue svg{ transition:transform .25s; }
.dash-continue:hover svg{ transform:translateX(2px); }

.dash-ring-wrap{ flex:none; text-align:center; position:relative; z-index:2; }
.dash-ring-wrap::before{
  content:"";
  position:absolute; left:50%; top:0; transform:translateX(-50%);
  width:150px; height:150px; border-radius:50%;
  background:radial-gradient(circle, rgba(15,22,20,.72) 55%, transparent 78%);
  z-index:-1;
}
.dash-ring{ position:relative; width:128px; height:128px; }
.dash-ring svg{ width:100%; height:100%; transform:rotate(-90deg); }
.dash-ring .bg{ fill:none; stroke:rgba(255,255,255,.1); stroke-width:1; }
.dash-ring .fg{
  fill:none; stroke-width:1; stroke-linecap:butt;
  stroke:var(--gold-soft);
  transition:stroke-dashoffset 1.3s cubic-bezier(.16,1,.3,1);
}
.dash-ring .pct{ position:absolute; inset:0; display:flex; align-items:center; justify-content:center; flex-direction:column; }
.dash-ring .pct b{ font-family:'Fraunces',serif; font-size:30px; font-weight:400; color:#fff; line-height:1; }
.dash-ring .pct span{ font-family:'IBM Plex Mono',monospace; font-size:7.5px; letter-spacing:.18em; color:rgba(247,244,236,.5); text-transform:uppercase; margin-top:5px; }
.dash-ring-label{ margin-top:18px; font-family:'IBM Plex Mono',monospace; font-size:8.5px; letter-spacing:.14em; color:rgba(247,244,236,.4); text-transform:uppercase; }
.dash-hero .eyebrow.on-ivory{ color:var(--gold-soft); }
.dash-hero h1{ color:#fff; }
.dash-hero .dash-welcome p{ color:rgba(247,244,236,.68); }

/* ---------- day sections ---------- */
.dash-day{ margin-bottom:44px; }
.dash-day-title{
  display:flex; align-items:center; gap:12px;
  font-family:'IBM Plex Mono',monospace; font-size:9.5px; letter-spacing:.22em; text-transform:uppercase;
  color:var(--ink); margin-bottom:20px;
}
.dash-day-title .dot{ width:4px; height:4px; border-radius:50%; background:var(--gold); }
.dash-day-title .line{ flex:1; height:1px; background:var(--line); }

.dash-grid{ display:grid; grid-template-columns:repeat(auto-fill, minmax(210px,1fr)); gap:1px; background:var(--line); border:1px solid var(--line); }

/* ---------- cards: restrained, precise, single-accent luxury treatment ---------- */
.dash-chip{
  display:flex; align-items:center; gap:16px;
  padding:20px 20px; border:none; border-radius:0; background:#fff;
  text-align:left; transition:background .25s ease, opacity .35s ease;
  position:relative; overflow:hidden;
}
.dash-chip.entrance-pending{ opacity:0; }
.dash-chip:hover{ background:var(--paper); }
.dash-chip:hover .dc-num{ border-color:var(--gold); color:var(--gold); }
.dash-chip .dc-num{
  flex:none; width:36px; height:36px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-family:'IBM Plex Mono',monospace; font-size:11px; font-weight:700; color:#fff;
  background:var(--chip-color, var(--emerald-deep));
  box-shadow:0 3px 10px -3px var(--chip-color, var(--emerald-deep));
  transition:transform .25s cubic-bezier(.34,1.56,.64,1);
}
.dash-chip:hover .dc-num{ transform:scale(1.1) rotate(-4deg); }
.dash-chip.done .dc-num{ background:var(--emerald-deep); box-shadow:0 3px 10px -3px var(--emerald-deep); }
.dash-chip .dc-text{ font-size:12.5px; color:var(--ink); line-height:1.4; font-weight:400; font-family:'Fraunces',serif; }
.dash-chip.c0{ --chip-color:#E0663F; }
.dash-chip.c1{ --chip-color:#E0A63E; }
.dash-chip.c2{ --chip-color:#2E9E7C; }
.dash-chip.c3{ --chip-color:#7D6CC4; }
.dash-chip.c4{ --chip-color:#D4577A; }
.dash-chip.c5{ --chip-color:#3E8FBF; }
.dash-chip.done{ background:#fff; }
.dash-chip.done::after{
  content:"✓"; position:absolute; top:16px; right:18px;
  font-size:11px; font-weight:700;
  color:var(--emerald);
}

/* ---------- accordion objection cards ---------- */
.obj-card{ cursor:default; }
.obj-q{ cursor:pointer; user-select:none; position:relative; padding-right:42px; transition:background .15s; }
.obj-q:hover{ background:#F3EDD8; }
.obj-q .chev{
  position:absolute; right:16px; top:50%; transform:translateY(-50%) rotate(0deg);
  width:11px; height:11px; transition:transform .25s ease;
  flex:none;
}
.obj-card.open .obj-q .chev{ transform:translateY(-50%) rotate(180deg); }
.obj-a{
  display:grid; grid-template-rows:0fr; transition:grid-template-rows .3s ease;
}
.obj-a > div{ overflow:hidden; min-height:0; }
.obj-card.open .obj-a{ grid-template-rows:1fr; }
.obj-a-inner{ padding:0 18px; transition:padding .3s ease; }
.obj-card.open .obj-a-inner{ padding:15px 18px; }

html[dir="rtl"] .obj-q{ padding-right:18px; padding-left:42px; }
html[dir="rtl"] .obj-q .chev{ right:auto; left:16px; }

/* ---------- gate unlock overlay ---------- */
.gate-overlay{
  position:fixed; inset:0; background:var(--ink); z-index:999;
  opacity:0; pointer-events:none; transition:opacity .5s ease;
}
.gate-overlay.show{ opacity:1; pointer-events:all; }

/* ---------- confetti burst ---------- */
.confetti-piece{
  position:fixed; z-index:9999; pointer-events:none;
  border-radius:2px;
  animation:confettiFall 1.1s cubic-bezier(.25,.46,.45,.94) forwards;
}
@keyframes confettiFall{
  0%{ transform:translate(0,0) rotate(0deg); opacity:1; }
  100%{ transform:var(--confetti-end); opacity:0; }
}

/* dashboard RTL */
html[dir="rtl"] .dash-hero::before{
  background:linear-gradient(260deg, rgba(15,22,20,.72) 0%, rgba(15,22,20,.5) 30%, rgba(15,22,20,.18) 50%, transparent 68%);
}
html[dir="rtl"] .dash-hero{ flex-direction:row-reverse; }
html[dir="rtl"] .dash-chip{ text-align:right; flex-direction:row-reverse; }
html[dir="rtl"] .dash-welcome p{ text-align:right; }
html[dir="rtl"] .countdown{ text-align:right; }
html[dir="rtl"] .dash-day-title{ flex-direction:row-reverse; }

/* responsive */
@media (max-width:900px){
  .dash-hero{ flex-direction:column; align-items:flex-start; padding:28px 24px; }
  .dash-ring-wrap{ align-self:center; }
}
@media (prefers-reduced-motion: reduce){
  .dash-hero, .dash-hero .floaters span, .dash-welcome h1 .wave, .dash-chip{ animation:none !important; }
  .dash-chip{ opacity:1; transform:none; }
}

/* ============================================================
   UX/UI UPGRADE PASS
   ============================================================ */

/* ---------- content fade transition on module switch ---------- */
.main-inner{ animation: contentFade .35s ease both; }
@keyframes contentFade{ from{opacity:0; transform:translateY(6px);} to{opacity:1; transform:translateY(0);} }

/* ---------- Overview nav item (distinct from numbered modules) ---------- */
.nav-item.overview{
  margin-bottom:6px;
  background:rgba(201,169,97,.09);
  border:1px solid rgba(201,169,97,.22);
}
.nav-item.overview .num{ color:var(--gold); }
.nav-item.overview:hover{ background:rgba(201,169,97,.16); }

/* ---------- Bonus module nav accent ---------- */
.nav-item[data-target="m12"] .num{
  color:var(--gold);
  font-size:13px;
}
.nav-item[data-target="m12"]{
  border:1px dashed rgba(221,201,139,.35);
}

/* ---------- per-day progress count in sidebar ---------- */
.day-label{ display:flex; align-items:center; justify-content:space-between; }
.day-count{
  font-family:'IBM Plex Mono',monospace;
  font-size:9px; color:rgba(247,244,236,.4);
  background:rgba(247,244,236,.08);
  padding:2px 7px; border-radius:10px;
}

/* ---------- sticky position badge inside confid-ribbon ---------- */
.confid-ribbon{ position:sticky; top:0; z-index:5; }
.pos-badge{
  font-family:'IBM Plex Mono',monospace;
  font-size:9px; letter-spacing:.1em;
  color:var(--gold-soft);
  background:rgba(201,169,97,.14);
  border:1px solid rgba(201,169,97,.3);
  padding:2px 9px;
  border-radius:10px;
  margin-inline-start:10px;
}

/* ---------- copy-to-clipboard button on say-box ---------- */
.say-box{ position:relative; padding-inline-end:52px; }
html[dir="rtl"] .say-box{ padding-inline-end:22px; padding-inline-start:52px; }
.copy-btn{
  position:absolute; top:14px; inset-inline-end:14px;
  width:28px; height:28px;
  border:1px solid var(--line);
  background:#fff;
  border-radius:4px;
  display:flex; align-items:center; justify-content:center;
  color:var(--emerald-deep);
  transition:background .15s, border-color .15s, transform .1s;
}
.copy-btn:hover{ border-color:var(--emerald); background:rgba(11,93,59,.06); }
.copy-btn:active{ transform:scale(.92); }
.copy-btn.copied{ background:var(--emerald); border-color:var(--emerald); color:#fff; }
.copy-btn svg{ width:14px; height:14px; }

/* ---------- quiz answered counter + inline validation ---------- */
.quiz-progress{
  display:flex; align-items:center; gap:10px;
  font-family:'IBM Plex Mono',monospace; font-size:10.5px; color:var(--text-dim);
  margin-bottom:14px;
}
.quiz-progress-bar{ flex:1; height:4px; background:var(--line); border-radius:3px; overflow:hidden; }
.quiz-progress-fill{ height:100%; background:var(--emerald-bright); width:0%; transition:width .3s ease; }
.quiz-inline-warn{
  display:none;
  background:var(--red-soft); border:1px solid rgba(178,58,46,.3); color:var(--red);
  padding:10px 14px; border-radius:3px; font-size:12.5px; margin-bottom:14px;
}
.quiz-inline-warn.show{ display:block; }
.quiz-q.flagged{ border-color:var(--red); animation: shakeX .35s ease; }
@keyframes shakeX{ 0%,100%{transform:translateX(0);} 25%{transform:translateX(-4px);} 75%{transform:translateX(4px);} }

/* ---------- NDA scroll-to-unlock (gate page) ---------- */
.nda-box{ position:relative; }
.nda-scroll-cue{
  position:absolute; left:0; right:0; bottom:0; height:46px;
  background:linear-gradient(180deg, rgba(255,255,255,0), #fff 85%);
  display:flex; align-items:flex-end; justify-content:center;
  pointer-events:none;
  transition:opacity .25s;
  padding-bottom:4px;
}
.nda-scroll-cue span{
  font-family:'IBM Plex Mono',monospace; font-size:9px; letter-spacing:.1em; color:var(--emerald-deep);
  background:#fff; border:1px solid var(--line); border-radius:10px; padding:2px 10px;
}
.nda-scroll-cue.hidden{ opacity:0; }
.nda-accept.locked{ opacity:.45; pointer-events:none; }
.nda-accept-hint{
  font-family:'IBM Plex Mono',monospace; font-size:9.5px; color:var(--gold);
  margin-top:4px; display:block;
}

/* mobile table readability */
@media (max-width:640px){
  .dtable th, .dtable td{ font-size:12px; padding:6px 6px; }
  .dash-hero{ flex-direction:column; text-align:center; padding:26px 22px; }
  .dash-hero-text p{ margin-left:auto; margin-right:auto; }
}

/* ============================================================
   NEOM-STYLE AVATAR GUIDE — futuristic point-by-point narrator
   ============================================================ */
:root{
  --tech-glow:#6EE7F5;
  --tech-glow-soft:rgba(110,231,245,.35);
  --tech-deep:#0A1620;
}

.avatar-guide{
  position:fixed;
  right:26px; bottom:26px;
  z-index:60;
  display:flex; flex-direction:column; align-items:flex-end; gap:14px;
  direction:ltr;
}
.avatar-guide.hidden{ display:none; }

/* --- the orb --- */
.avatar-orb{
  width:58px; height:58px;
  border-radius:50%;
  background:radial-gradient(circle at 35% 30%, #12232E, var(--tech-deep) 70%);
  border:1px solid rgba(110,231,245,.4);
  display:flex; align-items:center; justify-content:center;
  cursor:pointer;
  position:relative;
  box-shadow:0 0 0 0 rgba(110,231,245,.5), 0 8px 24px -8px rgba(0,0,0,.5);
  animation:orbPulse 3.2s ease-in-out infinite;
  transition:transform .2s;
}
.avatar-orb:hover{ transform:scale(1.06); }
.avatar-orb svg{ width:30px; height:30px; position:relative; z-index:2; }
.avatar-orb .ring{
  position:absolute; inset:-6px;
  border-radius:50%;
  border:1px solid rgba(110,231,245,.25);
  animation:orbSpin 12s linear infinite;
}
.avatar-orb .ring::before{
  content:""; position:absolute; top:-2px; left:50%; width:4px; height:4px;
  margin-left:-2px; border-radius:50%; background:var(--tech-glow);
  box-shadow:0 0 8px 2px var(--tech-glow);
}
@keyframes orbPulse{
  0%,100%{ box-shadow:0 0 0 0 rgba(110,231,245,.45), 0 8px 24px -8px rgba(0,0,0,.5); }
  50%{ box-shadow:0 0 0 10px rgba(110,231,245,0), 0 8px 24px -8px rgba(0,0,0,.5); }
}
@keyframes orbSpin{ from{transform:rotate(0deg);} to{transform:rotate(360deg);} }
.avatar-orb .core{ fill:var(--tech-glow); filter:drop-shadow(0 0 6px var(--tech-glow)); }
.avatar-orb .bars rect{ fill:var(--tech-glow); opacity:.85; }

.avatar-badge-dot{
  position:absolute; top:-2px; right:-2px;
  width:14px; height:14px; border-radius:50%;
  background:var(--gold);
  border:2px solid var(--ink);
  font-family:'IBM Plex Mono',monospace; font-size:8px; color:var(--ink);
  display:flex; align-items:center; justify-content:center; line-height:1;
}

/* --- the narration panel --- */
.avatar-panel{
  width:320px;
  max-width:calc(100vw - 52px);
  background:rgba(10,22,32,.86);
  backdrop-filter:blur(16px) saturate(140%);
  -webkit-backdrop-filter:blur(16px) saturate(140%);
  border:1px solid rgba(110,231,245,.28);
  border-radius:10px;
  box-shadow:0 20px 60px -16px rgba(0,0,0,.6), 0 0 40px -12px rgba(110,231,245,.18);
  padding:0;
  overflow:hidden;
  transform-origin:bottom right;
  animation:panelIn .3s cubic-bezier(.16,1,.3,1) both;
}
.avatar-panel.hidden{ display:none; }
@keyframes panelIn{ from{opacity:0; transform:scale(.92) translateY(8px);} to{opacity:1; transform:scale(1) translateY(0);} }

.avatar-panel-head{
  display:flex; align-items:center; justify-content:space-between;
  padding:12px 14px;
  border-bottom:1px solid rgba(110,231,245,.18);
}
.avatar-name{
  display:flex; align-items:center; gap:8px;
  font-family:'IBM Plex Mono',monospace; font-size:9.5px; letter-spacing:.14em; text-transform:uppercase;
  color:var(--tech-glow);
}
.avatar-name .live-dot{
  width:6px; height:6px; border-radius:50%; background:var(--tech-glow);
  box-shadow:0 0 6px 1px var(--tech-glow);
  animation:livePulse 1.6s ease-in-out infinite;
}
@keyframes livePulse{ 0%,100%{opacity:1;} 50%{opacity:.35;} }
.avatar-close{
  width:22px; height:22px; border-radius:50%;
  background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.14);
  color:rgba(255,255,255,.6);
  display:flex; align-items:center; justify-content:center;
  font-size:13px; line-height:1;
  transition:background .15s, color .15s;
}
.avatar-close:hover{ background:rgba(255,255,255,.14); color:#fff; }

.avatar-point{
  padding:18px 16px 8px;
  font-family:'Inter',sans-serif;
  font-size:13.5px;
  line-height:1.6;
  color:rgba(247,244,236,.92);
  min-height:64px;
}
.avatar-point b{ color:var(--tech-glow); font-weight:600; }

.avatar-listen-row{ padding:0 16px 12px; }
.avatar-listen-btn{
  width:100%;
  display:flex; align-items:center; gap:9px;
  padding:9px 13px;
  background:rgba(110,231,245,.08);
  border:1px solid rgba(110,231,245,.3);
  border-radius:22px;
  color:var(--tech-glow);
  font-family:'IBM Plex Mono',monospace;
  font-size:10px; letter-spacing:.06em;
  transition:background .18s, border-color .18s;
}
.avatar-listen-btn:hover{ background:rgba(110,231,245,.16); }
.avatar-listen-btn .ico-play{ width:13px; height:13px; flex:none; }
.avatar-listen-btn .ico-stop{ width:13px; height:13px; flex:none; display:none; }
.avatar-listen-btn .listen-label{ flex:1; text-align:left; }
.avatar-listen-btn .listen-bars{ display:none; align-items:flex-end; gap:2px; height:12px; }
.avatar-listen-btn .listen-bars i{
  width:2.5px; background:var(--tech-glow); border-radius:1px;
  animation:barBounce 0.9s ease-in-out infinite;
}
.avatar-listen-btn .listen-bars i:nth-child(1){ height:5px; animation-delay:0s; }
.avatar-listen-btn .listen-bars i:nth-child(2){ height:11px; animation-delay:.15s; }
.avatar-listen-btn .listen-bars i:nth-child(3){ height:7px; animation-delay:.3s; }
.avatar-listen-btn .listen-bars i:nth-child(4){ height:10px; animation-delay:.45s; }
@keyframes barBounce{ 0%,100%{ transform:scaleY(.4); } 50%{ transform:scaleY(1); } }

.avatar-listen-btn.speaking{ background:rgba(110,231,245,.2); border-color:var(--tech-glow); }
.avatar-listen-btn.speaking .ico-play{ display:none; }
.avatar-listen-btn.speaking .ico-stop{ display:block; }
.avatar-listen-btn.speaking .listen-bars{ display:flex; }
.avatar-listen-btn.speaking .listen-label::after{ content:"Stop"; }
.avatar-listen-btn.speaking .listen-label{ font-size:0; }
.avatar-listen-btn.speaking .listen-label::after{ font-size:10px; }

.avatar-dots{
  display:flex; gap:5px; justify-content:center;
  padding:2px 16px 12px;
}
.avatar-dots span{
  width:5px; height:5px; border-radius:50%;
  background:rgba(255,255,255,.18);
  transition:background .2s, transform .2s;
}
.avatar-dots span.on{ background:var(--tech-glow); transform:scale(1.3); box-shadow:0 0 5px 1px var(--tech-glow-soft); }

.avatar-controls{
  display:flex; align-items:center; justify-content:space-between;
  padding:10px 14px 14px;
  border-top:1px solid rgba(110,231,245,.12);
}
.avatar-nav-btn{
  width:30px; height:30px; border-radius:6px;
  background:rgba(110,231,245,.08);
  border:1px solid rgba(110,231,245,.25);
  color:var(--tech-glow);
  display:flex; align-items:center; justify-content:center;
  transition:background .15s;
}
.avatar-nav-btn:hover{ background:rgba(110,231,245,.18); }
.avatar-nav-btn:disabled{ opacity:.25; pointer-events:none; }
.avatar-nav-btn svg{ width:15px; height:15px; }
.avatar-counter{
  font-family:'IBM Plex Mono',monospace; font-size:10px; letter-spacing:.08em; color:rgba(247,244,236,.5);
}
.avatar-eng-tag{
  font-family:'IBM Plex Mono',monospace; font-size:8px; letter-spacing:.1em;
  color:rgba(255,255,255,.3);
  padding:0 16px 12px;
  text-align:center;
}

@media (max-width:640px){
  .avatar-guide{ right:14px; bottom:14px; }
  .avatar-panel{ width:280px; }
}

/* ---------- ambient sidebar accent ---------- */
.spine{ position:sticky; top:0; }
.spine::after{
  content:"";
  position:absolute; top:0; right:0; bottom:0; width:1px;
  background:linear-gradient(180deg, transparent, rgba(110,231,245,.25), transparent);
  pointer-events:none;
}
.nav-item.active{ box-shadow:inset 0 0 22px -14px rgba(201,169,97,.5); }

/* ============================================================
   INTENSIVE UX/UI POLISH PASS
   ============================================================ */

/* ---------- reading progress bar ---------- */
.reading-progress{
  position:fixed; top:0; left:0; height:2.5px; width:0%;
  background:linear-gradient(90deg, var(--gold), var(--emerald-bright));
  z-index:200;
  transition:width .1s linear;
  box-shadow:0 0 8px rgba(201,169,97,.5);
}

/* ---------- scroll to top ---------- */
.scroll-top-btn{
  position:fixed; right:26px; bottom:98px; z-index:55;
  width:42px; height:42px; border-radius:50%;
  background:#fff; border:1px solid var(--line);
  color:var(--emerald-deep);
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 10px 26px -10px rgba(15,22,20,.28);
  opacity:0; transform:translateY(10px) scale(.9);
  pointer-events:none;
  transition:opacity .25s ease, transform .25s ease, border-color .2s, background .2s;
}
.scroll-top-btn.show{ opacity:1; transform:translateY(0) scale(1); pointer-events:all; }
.scroll-top-btn:hover{ background:var(--emerald-deep); color:#fff; border-color:var(--emerald-deep); }
.scroll-top-btn svg{ width:18px; height:18px; }
html[dir="rtl"] .scroll-top-btn{ right:auto; left:26px; }

/* ---------- focus-visible polish (accessibility) ---------- */
a:focus-visible, button:focus-visible, input:focus-visible, .nav-item:focus-visible,
.dash-chip:focus-visible, .obj-q:focus-visible, .lang-pill:focus-visible{
  outline:2px solid var(--gold);
  outline-offset:2px;
  border-radius:2px;
}
.avatar-orb:focus-visible{ outline:2px solid var(--tech-glow); outline-offset:3px; }

/* ---------- refined module transition ---------- */
.main-inner{ animation:contentReveal .45s cubic-bezier(.16,1,.3,1) both; }
@keyframes contentReveal{
  from{ opacity:0; transform:translateY(14px) scale(.995); }
  to{ opacity:1; transform:translateY(0) scale(1); }
}

/* ---------- certificate: elevated, celebratory ---------- */
.cert{
  border:none;
  padding:60px 48px 52px;
  text-align:center;
  background:linear-gradient(180deg, #fff 0%, var(--paper) 100%);
  position:relative;
  margin-top:20px;
  box-shadow:0 32px 70px -28px rgba(184,146,62,.4), 0 2px 8px rgba(15,22,20,.08);
  overflow:hidden;
  border-radius:6px;
}
.cert::before{
  content:"";
  position:absolute; inset:9px;
  border:1.4px solid transparent;
  background:linear-gradient(135deg, var(--gold), var(--gold-soft) 40%, var(--gold) 60%, var(--gold-soft)) border-box;
  -webkit-mask:linear-gradient(#fff 0 0) padding-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite:xor; mask-composite:exclude;
  pointer-events:none;
}
.cert::after{
  content:"";
  position:absolute; top:-60px; right:-60px; width:220px; height:220px;
  background:radial-gradient(circle, rgba(201,169,97,.18), transparent 70%);
  pointer-events:none;
}
.cert-corner{ position:absolute; width:26px; height:26px; opacity:.55; }
.cert-corner svg{ width:100%; height:100%; }
.cert-corner.tl{ top:16px; left:16px; }
.cert-corner.tr{ top:16px; right:16px; transform:scaleX(-1); }
.cert-corner.bl{ bottom:16px; left:16px; transform:scaleY(-1); }
.cert-corner.br{ bottom:16px; right:16px; transform:scale(-1,-1); }
.cert.reveal{ animation:certReveal .7s cubic-bezier(.16,1,.3,1) both; }
@keyframes certReveal{
  0%{ opacity:0; transform:scale(.92) translateY(16px); }
  60%{ opacity:1; }
  100%{ opacity:1; transform:scale(1) translateY(0); }
}
.cert-ribbon{
  display:inline-flex; align-items:center; gap:6px;
  font-family:'IBM Plex Mono',monospace; font-size:9px; letter-spacing:.18em; text-transform:uppercase;
  color:#fff; background:var(--emerald-deep);
  padding:5px 14px; border-radius:20px;
  margin-bottom:18px; position:relative;
}
.cert-title{font-family:'Fraunces',serif; font-size:29px; margin:6px 0 8px; position:relative; letter-spacing:-.01em;}
.cert-name{
  font-family:'Fraunces',serif; font-style:italic; font-size:33px; color:var(--emerald-deep);
  margin:22px 0 10px; border-bottom:1.5px solid var(--gold-soft); display:inline-block; padding-bottom:12px;
  min-width:340px; position:relative;
}
.cert-seal{
  width:82px; height:82px; margin:30px auto 8px; border-radius:50%;
  border:1.6px solid var(--emerald-deep);
  display:flex; align-items:center; justify-content:center; position:relative;
  box-shadow:0 8px 20px -8px rgba(11,93,59,.35), inset 0 0 0 5px #fff, inset 0 0 0 6px var(--gold-soft);
}
.cert-seal::after{content:"";position:absolute; inset:6px; border-radius:50%; border:1px dashed var(--gold-soft);}

/* ---------- objection cards: numbered, more refined ---------- */
.obj-card{ counter-increment:objnum; position:relative; }
.module-body:has(.obj-card){ counter-reset:objnum; }
.obj-q{ padding-left:44px; }
.obj-q::before{
  content:counter(objnum);
  position:absolute; left:14px; top:50%; transform:translateY(-50%);
  width:20px; height:20px; border-radius:50%;
  background:var(--ink); color:var(--gold-soft);
  font-family:'IBM Plex Mono',monospace; font-size:10px; font-weight:600;
  display:flex; align-items:center; justify-content:center;
}
html[dir="rtl"] .obj-q{ padding-left:18px; padding-right:44px; }
html[dir="rtl"] .obj-q::before{ left:auto; right:14px; }

/* ---------- refined link/button hover polish ---------- */
.next-link{ position:relative; }
.next-link::after{
  content:""; position:absolute; left:0; bottom:-2px; width:0; height:1px;
  background:var(--gold); transition:width .25s ease;
}
.next-link:hover::after{ width:100%; }
