/* ─── tokens ─── */
:root{
  --gold:#795521;
  --gold-2:#a07434;
  --gold-soft:#c89a55;
  --crimson:#6e1010;
  --crimson-2:#8a1818;
  --espresso:#1f0d0b;
  --espresso-2:#2a1814;
  --cream:#f6efe2;
  --cream-2:#efe5d2;
  --cream-3:#e7dcc4;
  --ink:#1f0d0b;
  --muted:#6b5a4a;
  --line:#d9c9a8;
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{background:var(--cream);color:var(--ink);scroll-behavior:smooth}

/* Hide native cursor when magnifier lens is active */
body.lens-on, body.lens-on *{cursor:none !important}
/* …except when hovering interactive elements — show the hand */
body.lens-on a,
body.lens-on a *,
body.lens-on button,
body.lens-on button *,
body.lens-on .cert,
body.lens-on .cert *,
body.lens-on [role="button"],
body.lens-on [role="button"] *{cursor:pointer !important}

/* ───── Magnifier glass ───── */
#__lens{
  position:fixed;top:0;left:0;
  width:48px;height:48px;
  border-radius:50%;
  pointer-events:none;
  z-index:9999;
  overflow:hidden;
  opacity:0;
  transition:opacity .18s ease, width .25s ease, height .25s ease;
  transform:translate(-9999px,-9999px);
  background:var(--cream);
  box-shadow:
    0 0 0 3px rgba(31,13,11,.92),
    0 0 0 4px rgba(200,154,85,.85),
    0 10px 22px -6px rgba(31,13,11,.5),
    inset 0 0 0 1px rgba(255,255,255,.4);
  will-change:transform;
}
#__lens.on{opacity:1}
#__lens.hidden, #__lens-handle.hidden{opacity:0 !important}

/* glass highlight + chromatic edge */
#__lens::before{
  content:"";position:absolute;inset:0;border-radius:50%;
  background:
    radial-gradient(circle at 28% 22%, rgba(255,255,255,.55), rgba(255,255,255,0) 38%),
    radial-gradient(circle at 75% 78%, rgba(255,255,255,.18), rgba(255,255,255,0) 30%);
  pointer-events:none;z-index:3;
}
#__lens::after{
  content:"";position:absolute;inset:0;border-radius:50%;
  box-shadow:inset 0 0 30px rgba(31,13,11,.18), inset 0 0 0 2px rgba(255,255,255,.25);
  pointer-events:none;z-index:4;
}

#__lens-iframe{
  position:absolute;top:0;left:0;
  border:0;
  width:100vw;height:100vh;
  transform-origin:top left;
  pointer-events:none;
  background:var(--cream);
}

/* the handle of the magnifying glass */
#__lens-handle{
  position:fixed;top:0;left:0;
  width:46px;height:10px;
  background:linear-gradient(180deg,#3a2218,#1f0d0b 50%,#0d0604);
  border-radius:10px;
  pointer-events:none;
  z-index:9998;
  opacity:0;
  transform:translate(-9999px,-9999px);
  transition:opacity .18s ease;
  box-shadow:0 6px 14px rgba(31,13,11,.4), inset 0 1px 0 rgba(255,255,255,.15);
  transform-origin:0 50%;
}
#__lens-handle::before{
  content:"";position:absolute;left:0;top:50%;transform:translate(-30%,-50%);
  width:13px;height:13px;border-radius:50%;
  background:radial-gradient(circle at 35% 30%,#c89a55,#795521 60%,#4a3318);
  box-shadow:0 2px 6px rgba(0,0,0,.3), inset 0 1px 0 rgba(255,255,255,.3);
}
#__lens-handle.on{opacity:1}
body{
  font-family:"Tajawal","Segoe UI",sans-serif;
  font-size:17px;
  line-height:1.7;
  direction:rtl;
  text-align:right;
  -webkit-font-smoothing:antialiased;
  background-image:
    radial-gradient(1200px 600px at 80% -10%, rgba(121,85,33,.08), transparent 60%),
    radial-gradient(900px 500px at -10% 30%, rgba(110,16,16,.05), transparent 60%);
}

a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}

.serif{font-family:"Reem Kufi","Tajawal",serif;font-weight:600;letter-spacing:.01em}
.amiri{font-family:"Amiri",serif}

.shell{max-width:1240px;margin:0 auto;padding:0 28px}

/* ─── paper grain ─── */
.grain::before{
  content:"";position:absolute;inset:0;pointer-events:none;opacity:.35;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.47, 0 0 0 0 0.33, 0 0 0 0 0.13, 0 0 0 0.06 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
}

/* ─── nav ─── */
.nav{
  position:sticky;top:0;z-index:30;
  backdrop-filter:saturate(140%) blur(10px);
  background:rgba(246,239,226,.78);
  border-bottom:1px solid rgba(121,85,33,.18);
}
.nav-row{display:flex;align-items:center;justify-content:space-between;height:68px}
.nav-logo{display:flex;align-items:center;gap:10px;font-family:"Reem Kufi";font-weight:700;font-size:18px;color:var(--espresso)}
.nav-logo .dot{width:8px;height:8px;background:var(--crimson);border-radius:50%}
.nav-links{display:flex;gap:26px;font-size:14.5px;color:var(--muted)}
.nav-links a{position:relative;padding:6px 0;transition:color .2s}
.nav-links a:hover{color:var(--crimson)}
.nav-links a::after{content:"";position:absolute;right:0;bottom:-3px;width:0;height:1px;background:var(--gold);transition:width .25s}
.nav-links a:hover::after{width:100%}
.nav-cta{font-size:13.5px;padding:9px 16px;border:1px solid var(--espresso);color:var(--espresso);border-radius:999px;transition:.2s}
.nav-cta:hover{background:var(--espresso);color:var(--cream)}

/* burger */
.nav-burger{
  display:none;
  width:42px;height:42px;border:0;background:transparent;
  position:relative;padding:0;
}
.nav-burger span{
  position:absolute;left:9px;right:9px;height:2px;background:var(--espresso);
  border-radius:2px;transition:transform .25s ease, opacity .2s ease, top .25s ease;
}
.nav-burger span:nth-child(1){top:14px}
.nav-burger span:nth-child(2){top:20px}
.nav-burger span:nth-child(3){top:26px}
.nav-burger.x span:nth-child(1){top:20px;transform:rotate(45deg)}
.nav-burger.x span:nth-child(2){opacity:0}
.nav-burger.x span:nth-child(3){top:20px;transform:rotate(-45deg)}

/* drawer */
.nav-drawer{
  position:fixed;inset:0;
  background:rgba(31,13,11,.55);
  backdrop-filter:blur(6px);
  opacity:0;pointer-events:none;transition:opacity .25s ease;
  z-index:25;
}
.nav-drawer.on{opacity:1;pointer-events:auto}
.nav-drawer-inner{
  position:absolute;top:68px;right:0;left:0;
  background:var(--cream);
  border-bottom:1px solid var(--line);
  padding:18px 24px 26px;
  display:flex;flex-direction:column;gap:4px;
  transform:translateY(-12px);transition:transform .25s ease;
  box-shadow:0 30px 60px -20px rgba(31,13,11,.35);
}
.nav-drawer.on .nav-drawer-inner{transform:none}
.nav-drawer-inner a{
  font-family:"Reem Kufi";font-size:17px;color:var(--espresso);
  padding:14px 4px;border-bottom:1px solid rgba(121,85,33,.12);
}
.nav-drawer-inner a:last-child{border-bottom:0}
.nav-drawer-inner .nav-cta{
  align-self:flex-start;margin-top:10px;font-size:13.5px;
}

@media (max-width:760px){
  .nav-links{display:none}
  .nav-cta--desk{display:none}
  .nav-burger{display:block}
}

/* ─── hero ─── */
.hero{position:relative;overflow:hidden;padding:90px 0 60px}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:60px;align-items:center}
.eyebrow{
  display:inline-flex;align-items:center;gap:12px;
  font-size:13px;letter-spacing:.18em;color:var(--gold);
  text-transform:uppercase;font-weight:600;
}
.eyebrow .bar{width:36px;height:1px;background:var(--gold)}
.hero h1{
  font-family:"Reem Kufi",serif;
  font-weight:600;
  font-size:clamp(44px,7vw,84px);
  line-height:1.05;
  letter-spacing:-.01em;
  color:var(--espresso);
  margin:18px 0 22px;
}
.hero h1 .red{color:var(--crimson)}
.hero h1 .gold{color:var(--gold)}
.hero-sub{font-size:19px;color:var(--muted);max-width:540px;line-height:1.75}
.hero-meta{display:flex;flex-wrap:wrap;gap:14px;margin-top:32px}
.chip{
  display:inline-flex;align-items:center;gap:8px;
  padding:8px 14px;border-radius:999px;
  background:rgba(31,13,11,.06);border:1px solid rgba(31,13,11,.1);
  font-size:13.5px;color:var(--espresso);
}
.chip .num{color:var(--crimson);font-weight:700;font-family:"Reem Kufi"}

.hero-logo-wrap{
  position:relative;display:flex;align-items:center;justify-content:center;
  aspect-ratio:1/1;
}
.hero-logo-wrap::before{
  content:"";position:absolute;inset:8%;border-radius:50%;
  background:
    radial-gradient(closest-side, rgba(255,253,247,.95), rgba(246,239,226,.0) 70%);
  filter:blur(2px);
}
.hero-logo{position:relative;width:88%;filter:drop-shadow(0 30px 40px rgba(31,13,11,.18))}
.deco-ring{position:absolute;inset:0;border-radius:50%;border:1px dashed rgba(121,85,33,.45);animation:spin 60s linear infinite}
.deco-ring.r2{inset:6%;border-style:dotted;border-color:rgba(110,16,16,.25);animation-duration:90s;animation-direction:reverse}
@keyframes spin{to{transform:rotate(360deg)}}
.deco-tag{
  position:absolute;font-family:"Reem Kufi";font-size:12.5px;letter-spacing:.3em;color:var(--gold);
  background:var(--cream);padding:4px 10px;border:1px solid var(--line);border-radius:999px;
}
.deco-tag.t1{top:0;right:30%}
.deco-tag.t2{bottom:6%;left:8%}
.deco-tag.t3{top:42%;right:-2%}

@media (max-width:900px){
  .hero-grid{grid-template-columns:1fr;gap:30px}
  .hero{padding:50px 0 30px}
}

/* ─── section header ─── */
.sec{padding:90px 0;position:relative}
.sec-head{display:flex;align-items:end;justify-content:space-between;gap:24px;margin-bottom:48px}
.sec-head .label{font-family:"Reem Kufi";color:var(--gold);font-size:13px;letter-spacing:.25em;text-transform:uppercase}
.sec-head h2{
  font-family:"Reem Kufi";font-weight:600;
  font-size:clamp(34px,4.5vw,52px);line-height:1.1;color:var(--espresso);
  margin-top:8px;
}
.sec-head .sub{max-width:420px;color:var(--muted);font-size:15.5px;line-height:1.7}
.rule{height:1px;background:linear-gradient(to left,transparent, var(--line) 30%, var(--line) 70%, transparent);margin:0 0 18px}

/* ─── about ─── */
.about{background:var(--cream-2);position:relative;overflow:hidden}
.about-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:50px;align-items:start}
.about-body p{font-size:17.5px;color:var(--espresso);line-height:1.95;margin-bottom:14px}
.about-body p .hl{color:var(--crimson);font-weight:700;font-family:"Reem Kufi"}
.role-card{
  position:relative;
  background:linear-gradient(180deg,#fffaf0, var(--cream));
  border:1px solid var(--line);
  border-radius:18px;
  padding:34px 30px;
  box-shadow:0 20px 60px -30px rgba(31,13,11,.25);
}
.role-card::before{
  content:"";position:absolute;inset:0;border-radius:18px;pointer-events:none;
  background:repeating-linear-gradient(45deg,transparent 0 14px, rgba(121,85,33,.04) 14px 15px);
}
.role-card .stamp{
  position:absolute;top:-22px;left:24px;
  background:var(--crimson);color:var(--cream);
  padding:6px 14px;font-size:12px;letter-spacing:.2em;border-radius:999px;
  font-family:"Reem Kufi";
}
.role-card h3{font-family:"Reem Kufi";font-size:24px;color:var(--espresso);margin-bottom:6px}
.role-card .school{color:var(--gold);font-weight:600;font-size:15px;margin-bottom:18px}
.role-card ul{list-style:none;display:grid;gap:12px}
.role-card li{display:flex;gap:12px;font-size:14.5px;color:var(--muted);line-height:1.6}
.role-card li::before{content:"";flex:0 0 6px;height:6px;margin-top:10px;border-radius:50%;background:var(--gold)}

.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:60px}
.stat{
  border:1px solid var(--line);border-radius:14px;padding:24px;
  background:rgba(255,255,255,.5);
}
.stat .n{font-family:"Reem Kufi";font-size:54px;color:var(--crimson);line-height:1;letter-spacing:-.02em}
.stat .l{margin-top:8px;color:var(--muted);font-size:14px;line-height:1.5}

@media (max-width:900px){
  .about-grid{grid-template-columns:1fr}
  .stats{grid-template-columns:repeat(2,1fr)}
}

/* ─── courses ─── */
.courses{padding:100px 0;background:var(--espresso);color:var(--cream)}
.courses .sec-head h2{color:var(--cream)}
.courses .sec-head .label{color:var(--gold-soft)}
.courses .sec-head .sub{color:rgba(246,239,226,.7)}
.courses .rule{background:linear-gradient(to left,transparent, rgba(200,154,85,.4) 30%, rgba(200,154,85,.4) 70%, transparent)}
.course-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.course{
  position:relative;
  padding:30px 26px 28px;
  border:1px solid rgba(200,154,85,.25);
  border-radius:16px;
  background:linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,0));
  transition:.3s;
  overflow:hidden;
}
.course::before{
  content:attr(data-num);
  position:absolute;top:18px;left:22px;
  font-family:"Reem Kufi";font-size:48px;color:rgba(200,154,85,.18);line-height:1;
}
.course:hover{transform:translateY(-4px);border-color:var(--gold-soft);background:linear-gradient(180deg, rgba(200,154,85,.08), rgba(255,255,255,0))}
.course .kicker{font-size:12px;color:var(--gold-soft);letter-spacing:.22em;text-transform:uppercase;margin-bottom:18px}
.course h3{font-family:"Reem Kufi";font-size:24px;color:var(--cream);line-height:1.3;margin-bottom:14px}
.course p{font-size:14px;color:rgba(246,239,226,.65);line-height:1.7}
.course .meta{margin-top:18px;display:flex;align-items:center;gap:8px;font-size:12.5px;color:var(--gold-soft);font-family:"Reem Kufi";letter-spacing:.06em}

@media (max-width:900px){.course-grid{grid-template-columns:1fr}}

/* ─── achievements ─── */
.ach-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:20px}
.ach-card{
  grid-column:span 6;
  position:relative;
  border:1px solid var(--line);
  border-radius:18px;
  padding:36px;
  background:linear-gradient(180deg,#fffbf1,#f6efe2);
  overflow:hidden;
}
.ach-card.tall{grid-column:span 6;min-height:380px}
.ach-card.wide{grid-column:span 12}
.ach-card .year{
  position:absolute;top:24px;left:30px;
  font-family:"Reem Kufi";font-size:14px;color:var(--gold);
  letter-spacing:.14em;
}
.ach-card .tag{
  display:inline-block;font-size:12px;letter-spacing:.2em;color:var(--crimson);
  font-family:"Reem Kufi";margin-bottom:14px;text-transform:uppercase
}
.ach-card h3{font-family:"Reem Kufi";font-size:28px;line-height:1.25;color:var(--espresso);margin-bottom:14px}
.ach-card p{color:var(--muted);font-size:15.5px;line-height:1.85}
.ach-card .link{
  display:inline-flex;gap:8px;align-items:center;margin-top:18px;
  color:var(--crimson);font-family:"Reem Kufi";font-size:14px;letter-spacing:.05em;
  border-bottom:1px solid var(--crimson);padding-bottom:2px;
}
.ach-card .iso{
  position:absolute;left:-30px;bottom:-30px;font-family:"Reem Kufi";
  font-size:200px;color:rgba(121,85,33,.07);line-height:.8;
}
.book-card{background:linear-gradient(180deg, var(--crimson), var(--crimson-2));color:var(--cream)}
.book-card h3,.book-card p{color:var(--cream)}
.book-card p{color:rgba(246,239,226,.85)}
.book-card .tag{color:var(--gold-soft)}
.book-card .year{color:var(--gold-soft)}
.book-card .link{color:var(--cream);border-color:rgba(246,239,226,.6)}
.book-card .iso{color:rgba(255,255,255,.08)}
.book-cover{
  position:absolute;left:30px;bottom:30px;width:140px;height:180px;
  background:linear-gradient(135deg,#fffaf0,#e7dcc4);
  border-radius:6px;
  box-shadow:0 30px 60px -20px rgba(0,0,0,.4), inset 0 0 0 1px rgba(31,13,11,.1);
  transform:rotate(-6deg);
  display:flex;flex-direction:column;justify-content:center;padding:14px;
  text-align:center;
}
.book-cover .bc-rule{height:1px;background:var(--gold);margin:8px 16px}
.book-cover .bc-t{font-family:"Reem Kufi";font-size:14px;color:var(--espresso);line-height:1.3}
.book-cover .bc-s{font-family:"Amiri";font-size:11px;color:var(--gold);margin-top:6px}

@media (max-width:900px){
  .ach-card,.ach-card.tall{grid-column:span 12;padding:28px}
  .book-cover{position:static;margin-top:24px;transform:none}
}

/* ─── certificates ─── */
.certs{background:var(--cream-2)}
.cert-strip{
  display:grid;grid-template-columns:repeat(4,1fr);gap:20px;
}
.cert{
  position:relative;border-radius:12px;overflow:hidden;
  background:#fff;border:1px solid var(--line);
  box-shadow:0 10px 30px -18px rgba(31,13,11,.3);
  transition:.3s;
  aspect-ratio:4/5.2;
}
.cert:hover{transform:translateY(-6px) rotate(-1deg);box-shadow:0 30px 60px -20px rgba(31,13,11,.4)}
.cert img{width:100%;height:100%;object-fit:cover;object-position:center}
.cert .cert-caption{
  position:absolute;inset:auto 0 0 0;
  padding:14px 16px;
  background:linear-gradient(to top, rgba(31,13,11,.92), rgba(31,13,11,0));
  color:var(--cream);
  font-family:"Reem Kufi";font-size:14px;
}
.cert .cert-caption .y{font-size:11px;color:var(--gold-soft);letter-spacing:.2em;display:block;margin-bottom:2px}

@media (max-width:900px){.cert-strip{grid-template-columns:repeat(2,1fr)}}

/* lightbox */
.lightbox{
  position:fixed;inset:0;z-index:60;background:rgba(31,13,11,.92);
  display:flex;align-items:center;justify-content:center;padding:40px;
  opacity:0;pointer-events:none;transition:.2s;
}
.lightbox.on{opacity:1;pointer-events:auto}
.lightbox img{max-width:100%;max-height:100%;border-radius:8px;box-shadow:0 40px 80px rgba(0,0,0,.5)}
.lightbox .x{
  position:absolute;top:24px;left:24px;
  width:42px;height:42px;border-radius:50%;border:1px solid rgba(246,239,226,.4);
  display:flex;align-items:center;justify-content:center;
  color:var(--cream);cursor:pointer;background:transparent;
  font-size:18px;
}

/* ─── workshop banner ─── */
.workshop{
  position:relative;overflow:hidden;
  background:
    linear-gradient(120deg, rgba(31,13,11,.85), rgba(110,16,16,.7)),
    radial-gradient(circle at 20% 50%, rgba(200,154,85,.4), transparent 50%);
  color:var(--cream);
  padding:90px 0;
}
.workshop-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.workshop h2{font-family:"Reem Kufi";font-size:clamp(34px,4.5vw,52px);line-height:1.15;margin-bottom:18px}
.workshop .quote{font-family:"Amiri";font-size:22px;line-height:1.7;color:rgba(246,239,226,.9);margin-bottom:18px}
.workshop .meta{display:flex;gap:16px;flex-wrap:wrap;color:var(--gold-soft);font-family:"Reem Kufi";font-size:13.5px;letter-spacing:.14em}
.workshop-img{position:relative;aspect-ratio:4/3;border-radius:14px;overflow:hidden;border:1px solid rgba(200,154,85,.4)}
.workshop-img img{width:100%;height:100%;object-fit:cover}
.workshop-img::after{content:"";position:absolute;inset:0;background:linear-gradient(135deg, rgba(31,13,11,.2), transparent 50%)}
@media (max-width:900px){.workshop-grid{grid-template-columns:1fr}}

/* ─── footer ─── */
.footer{background:var(--espresso);color:rgba(246,239,226,.7);padding:70px 0 30px}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;margin-bottom:50px}
.foot-grid h4{font-family:"Reem Kufi";color:var(--cream);font-size:15px;margin-bottom:16px;letter-spacing:.06em}
.foot-grid p,.foot-grid li{font-size:14px;line-height:1.9;color:rgba(246,239,226,.65)}
.foot-grid ul{list-style:none}
.foot-bottom{display:flex;align-items:center;justify-content:space-between;padding-top:24px;border-top:1px solid rgba(200,154,85,.18);font-size:12.5px;color:rgba(246,239,226,.55);font-family:"Reem Kufi";letter-spacing:.1em}
.foot-mark{display:flex;align-items:center;gap:14px}
.foot-mark img{width:46px;height:46px;object-fit:contain;filter:brightness(1.1) drop-shadow(0 0 6px rgba(200,154,85,.3))}
.foot-mark .l1{font-family:"Reem Kufi";color:var(--cream);font-size:16px}
.foot-mark .l2{font-size:12px;color:var(--gold-soft);letter-spacing:.15em}

@media (max-width:900px){
  .foot-grid{grid-template-columns:1fr}
  .foot-bottom{flex-direction:column;gap:14px;text-align:center}
}

/* utility */
.fade-in{opacity:0;transform:translateY(20px);transition:opacity .8s ease, transform .8s ease}
.fade-in.in{opacity:1;transform:none}

/* ─────────────────────────────
   Mobile polish
   ───────────────────────────── */
@media (max-width:760px){
  body{font-size:16px;line-height:1.65}
  .shell{padding:0 18px}

  /* sections */
  .sec{padding:64px 0}
  .courses{padding:72px 0}
  .workshop{padding:64px 0}
  .sec-head{flex-direction:column;align-items:flex-start;gap:14px;margin-bottom:32px}
  .sec-head .sub{font-size:14.5px}

  /* hero */
  .hero{padding:36px 0 24px}
  .hero-grid{gap:24px}
  .hero h1{font-size:clamp(38px,11vw,52px);margin:14px 0 16px;line-height:1.08}
  .hero-sub{font-size:16px;line-height:1.7}
  .hero-meta{gap:8px;margin-top:22px}
  .chip{font-size:12.5px;padding:7px 12px}
  .hero-logo-wrap{max-width:300px;margin:0 auto;width:75%}
  .deco-tag{font-size:10.5px;letter-spacing:.2em;padding:3px 8px}
  .deco-tag.t3{right:auto;left:-2%}
  .eyebrow{font-size:11.5px;letter-spacing:.15em}
  .eyebrow .bar{width:24px}

  /* about */
  .about-body p{font-size:15.5px;line-height:1.85}
  .role-card{padding:28px 22px}
  .role-card .stamp{font-size:10.5px;padding:5px 11px;top:-18px;left:18px}
  .role-card h3{font-size:21px}
  .role-card li{font-size:13.5px}
  .stats{grid-template-columns:repeat(2,1fr);gap:12px;margin-top:40px}
  .stat{padding:18px 16px}
  .stat .n{font-size:42px}
  .stat .l{font-size:13px}

  /* courses */
  .course{padding:26px 22px 24px}
  .course::before{font-size:38px;top:14px;left:18px}
  .course h3{font-size:20px}
  .course p{font-size:13.5px}

  /* achievements */
  .ach-grid{gap:14px}
  .ach-card{padding:26px 22px}
  .ach-card h3{font-size:22px}
  .ach-card p{font-size:14.5px;line-height:1.8}
  .ach-card.tall{min-height:0}
  .ach-card .year{font-size:12px;top:18px;left:22px}
  .ach-card .iso{font-size:130px;left:-10px;bottom:-20px}
  .book-card > div{max-width:none !important}
  .book-cover{
    position:static;margin-top:20px;transform:none;
    width:120px;height:160px;
  }
  .book-cover .bc-t{font-size:13px}

  /* certificates */
  .cert-strip{grid-template-columns:repeat(2,1fr);gap:12px}
  .cert{border-radius:10px}
  .cert .cert-caption{font-size:12px;padding:10px 12px}
  .cert .cert-caption .y{font-size:10px}

  /* workshop */
  .workshop-grid{gap:28px}
  .workshop h2{font-size:clamp(30px,8vw,40px)}
  .workshop .quote{font-size:17px;line-height:1.7}
  .workshop .meta{font-size:12px;gap:10px;letter-spacing:.1em}

  /* lightbox */
  .lightbox{padding:18px}
  .lightbox .x{top:14px;left:14px;width:38px;height:38px;font-size:16px}

  /* footer */
  .footer{padding:52px 0 24px}
  .foot-grid{gap:32px;margin-bottom:36px}
  .foot-mark img{width:40px;height:40px}
  .foot-mark .l1{font-size:15px}
  .foot-bottom{font-size:11.5px}
}

@media (max-width:420px){
  .hero h1{font-size:38px}
  .cert-strip{grid-template-columns:1fr}
  .stats{grid-template-columns:1fr}
  .nav-logo span:not(.dot){font-size:16px}
}

/* iOS tap-target sanity */
@media (pointer:coarse){
  .nav-drawer-inner a{padding:16px 4px}
  .chip{padding:10px 14px}
  .cert{min-height:200px}
}
