/* =========================================================
   وسم · WASM — Design System  ("Light Lab")
   Foundations · Components · Bilingual RTL/LTR · Motion
   ========================================================= */

/* ---------- Tokens ---------- */
:root{
  /* Color — Light Lab */
  --paper:#FBFBF9;        /* page background */
  --pure:#FFFFFF;         /* cards / surfaces */
  --ink:#11150E;          /* text / headings  */
  --green:#3D5226;        /* secondary text / status */
  --olive:#6B9A28;        /* links / highlights / numbers */
  --olive-text:#4D7A10;   /* darker olive for small text — WCAG AA on paper */
  --lime:#C4F82A;         /* accent — used sparingly */
  --line:#E9E9E2;         /* hairlines / borders */
  --line-soft:#F0F0EA;
  --ink-70:rgba(17,21,14,.70);
  --ink-60:rgba(17,21,14,.60);
  --ink-55:rgba(17,21,14,.55);
  --ink-40:rgba(17,21,14,.40);

  /* Seal theming */
  --seal-ring:var(--ink);
  --seal-tick:var(--olive);

  /* Type */
  --f-display:"Space Grotesk","IBM Plex Sans Arabic",system-ui,sans-serif;
  --f-body:"IBM Plex Sans Arabic","Space Grotesk",system-ui,sans-serif;
  --f-mono:"JetBrains Mono",ui-monospace,monospace;
  --f-kufi:"Reem Kufi","IBM Plex Sans Arabic",sans-serif;

  /* Spacing — 8pt grid */
  --s1:4px; --s2:8px; --s3:12px; --s4:16px; --s5:24px;
  --s6:32px; --s7:48px; --s8:64px; --s9:96px; --s10:128px;

  --radius:14px;
  --radius-lg:22px;
  --radius-pill:999px;

  --shadow-sm:0 1px 2px rgba(17,21,14,.04), 0 2px 8px rgba(17,21,14,.04);
  --shadow:0 4px 14px rgba(17,21,14,.06), 0 18px 40px rgba(17,21,14,.06);
  --shadow-lime:0 0 0 1px rgba(196,248,42,.35), 0 8px 40px rgba(196,248,42,.18);

  --ease:cubic-bezier(.22,.61,.36,1);
  --t-fast:.16s; --t:.28s; --t-slow:.5s;

  --container:1160px;
}

/* ---------- Reset / Base ---------- */
*,*::before,*::after{box-sizing:border-box}
html{
  -webkit-text-size-adjust:100%;
  scroll-behavior:smooth;
}
body{
  margin:0;
  background:var(--paper);
  color:var(--ink);
  font-family:var(--f-display);
  font-size:17px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:0;background:none;color:inherit}
ul{margin:0;padding:0;list-style:none}
h1,h2,h3,h4,p{margin:0}
::selection{background:var(--lime);color:var(--ink)}

/* Subtle lab grid background */
body::before{
  content:"";
  position:fixed;inset:0;z-index:-1;pointer-events:none;
  background-image:
    linear-gradient(var(--line-soft) 1px,transparent 1px),
    linear-gradient(90deg,var(--line-soft) 1px,transparent 1px);
  background-size:64px 64px;
  background-position:center;
  -webkit-mask-image:radial-gradient(120% 90% at 50% 0%,#000 35%,transparent 100%);
  mask-image:radial-gradient(120% 90% at 50% 0%,#000 35%,transparent 100%);
  opacity:.7;
}

/* ---------- Bilingual ---------- */
/* Default = English (LTR). html.ar => Arabic (RTL). */
.lang.ar{display:none}
html.ar .lang.en{display:none}
html.ar .lang.ar{display:inline}
html.ar{font-family:var(--f-body)}
html.ar body{font-size:17px;line-height:1.75}
/* Arabic display headings: medium weight reads better than heavy */
html.ar h1,html.ar h2,html.ar h3{font-family:var(--f-body);font-weight:600;letter-spacing:0}

/* mono + numbers stay LTR even inside Arabic */
.mono,.num,bdi,[dir="ltr"]{font-family:var(--f-mono);font-feature-settings:"tnum" 1}

/* ---------- Layout ---------- */
.container{width:100%;max-width:var(--container);margin-inline:auto;padding-inline:var(--s5)}
.section{padding-block:var(--s9)}
.section--tight{padding-block:var(--s8)}
.center{text-align:center}

/* ---------- Type scale ---------- */
.display{
  font-family:var(--f-display);
  font-weight:600;
  font-size:clamp(2.6rem,6.2vw,4.7rem);
  line-height:1.02;
  letter-spacing:-.02em;
}
html.ar .display{font-family:var(--f-body);line-height:1.18;letter-spacing:0;font-weight:600}
.h2{
  font-family:var(--f-display);font-weight:600;
  font-size:clamp(1.9rem,3.6vw,2.9rem);line-height:1.08;letter-spacing:-.015em;
}
html.ar .h2{line-height:1.3;letter-spacing:0}
.h3{font-family:var(--f-display);font-weight:600;font-size:clamp(1.25rem,2vw,1.55rem);line-height:1.2}
html.ar .h3{line-height:1.4}
.lead{font-size:clamp(1.05rem,1.5vw,1.25rem);color:var(--ink-70);line-height:1.6;max-width:60ch}
html.ar .lead{line-height:1.85}
.muted{color:var(--ink-60)}
.olive{color:var(--olive)}

/* ---------- Eyebrow (code-comment) — signature device ---------- */
.eyebrow{
  font-family:var(--f-mono);
  font-size:.78rem;
  letter-spacing:.04em;
  color:var(--olive-text);
  text-transform:lowercase;
  display:inline-flex;align-items:center;gap:.5ch;
}
.eyebrow::before{content:"//";color:var(--ink-40)}
html.ar .eyebrow{direction:ltr}

/* mono label / tag */
.tag{
  font-family:var(--f-mono);font-size:.72rem;letter-spacing:.06em;
  text-transform:uppercase;color:var(--green);
  border:1px solid var(--line);border-radius:var(--radius-pill);
  padding:.35em .8em;display:inline-flex;align-items:center;gap:.55ch;
  background:var(--pure);
}

/* status pill */
.status{
  display:inline-flex;align-items:center;gap:.6ch;
  font-family:var(--f-mono);font-size:.74rem;letter-spacing:.08em;text-transform:uppercase;
  color:var(--green);background:var(--pure);
  border:1px solid var(--line);border-radius:var(--radius-pill);
  padding:.4em .9em;
}
.status .dot{width:8px;height:8px;border-radius:50%;background:var(--olive);position:relative}
.status .dot::after{content:"";position:absolute;inset:-4px;border-radius:50%;border:1px solid var(--olive);
  animation:pulse 2s var(--ease) infinite}
@keyframes pulse{0%{transform:scale(.6);opacity:.9}100%{transform:scale(1.8);opacity:0}}

/* ---------- Seal ---------- */
.seal{width:40px;height:40px}
.seal .ring{stroke:var(--seal-ring);stroke-width:5;fill:none}
.seal .tick{stroke:var(--seal-tick);stroke-width:7;fill:none;stroke-linecap:round;stroke-linejoin:round}
.seal--draw .tick{stroke-dasharray:120;stroke-dashoffset:120;animation:draw 1s var(--ease) .25s forwards}
.seal--draw .ring{stroke-dasharray:270;stroke-dashoffset:270;animation:draw 1.1s var(--ease) forwards}
@keyframes draw{to{stroke-dashoffset:0}}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.6ch;
  font-family:var(--f-mono);font-size:.84rem;letter-spacing:.02em;font-weight:500;
  padding:.95em 1.5em;border-radius:var(--radius-pill);
  transition:transform var(--t-fast) var(--ease),background var(--t) var(--ease),box-shadow var(--t) var(--ease),color var(--t) var(--ease);
  white-space:nowrap;
}
html.ar .btn{font-family:var(--f-body);font-weight:600;font-size:.95rem}
.btn:active{transform:translateY(1px)}
.btn--primary{background:var(--ink);color:var(--paper)}
.btn--primary:hover{background:#000;box-shadow:var(--shadow)}
.btn--lime{background:var(--lime);color:var(--ink)}
.btn--lime:hover{box-shadow:var(--shadow-lime);transform:translateY(-1px)}
.btn--ghost{border:1px solid var(--line);color:var(--ink);background:var(--pure)}
.btn--ghost:hover{border-color:var(--ink);background:var(--paper)}
.btn .arr{transition:transform var(--t) var(--ease)}
.btn:hover .arr{transform:translateX(3px)}
html.ar .btn .arr{transform:scaleX(-1)}
html.ar .btn:hover .arr{transform:scaleX(-1) translateX(3px)}

/* link with underline grow */
.link{color:var(--olive);font-weight:500;position:relative;display:inline-flex;align-items:center;gap:.5ch}
.link::after{content:"";position:absolute;inset-inline-start:0;bottom:-2px;height:1.5px;width:100%;
  background:var(--olive);transform:scaleX(0);transform-origin:inline-start;transition:transform var(--t) var(--ease)}
.link:hover::after{transform:scaleX(1)}
.link .arr{transition:transform var(--t) var(--ease)}
.link:hover .arr{transform:translateX(3px)}
html.ar .link .arr{transform:scaleX(-1)}
html.ar .link:hover .arr{transform:scaleX(-1) translateX(3px)}

/* ---------- Navigation ---------- */
.nav{position:sticky;top:0;z-index:50;background:color-mix(in srgb,var(--paper) 82%,transparent);
  -webkit-backdrop-filter:saturate(1.4) blur(12px);backdrop-filter:saturate(1.4) blur(12px);border-bottom:1px solid transparent;transition:border-color var(--t),background var(--t)}
.nav.is-scrolled{border-color:var(--line);background:color-mix(in srgb,var(--paper) 92%,transparent)}
.nav__row{display:flex;align-items:center;gap:var(--s5);height:74px}
.brand{display:inline-flex;align-items:center;gap:.7ch}
.brand .seal{width:34px;height:34px}
.brand__word{font-family:var(--f-kufi);font-size:1.5rem;font-weight:600;color:var(--ink);line-height:1;margin-block-start:2px}
.nav__links{display:flex;align-items:center;gap:var(--s2);margin-inline-start:var(--s5)}
.nav__link{font-family:var(--f-mono);font-size:.82rem;letter-spacing:.01em;color:var(--ink-70);
  padding:.5em .8em;border-radius:var(--radius-pill);transition:color var(--t),background var(--t)}
html.ar .nav__link{font-family:var(--f-body);font-weight:500;font-size:.98rem;color:var(--green)}
.nav__link:hover{color:var(--ink);background:var(--pure)}
.nav__link.is-active{color:var(--ink);background:var(--pure)}
.nav__spacer{flex:1}
.nav__actions{display:flex;align-items:center;gap:var(--s3)}
.lang-toggle{font-family:var(--f-mono);font-size:.8rem;border:1px solid var(--line);border-radius:var(--radius-pill);
  padding:.45em .85em;color:var(--ink);transition:border-color var(--t),background var(--t)}
.lang-toggle:hover{border-color:var(--ink);background:var(--pure)}
.lang-toggle b{color:var(--olive)}

.nav__burger{display:none;width:42px;height:42px;border:1px solid var(--line);border-radius:12px;
  align-items:center;justify-content:center;background:var(--pure)}
.nav__burger span{display:block;width:18px;height:2px;background:var(--ink);position:relative}
.nav__burger span::before,.nav__burger span::after{content:"";position:absolute;inset-inline-start:0;width:18px;height:2px;background:var(--ink)}
.nav__burger span::before{top:-6px}.nav__burger span::after{top:6px}

/* ---------- Hero ---------- */
.hero{position:relative;padding-block:var(--s9) var(--s8)}
.hero__grid{display:grid;grid-template-columns:1.15fr .85fr;gap:var(--s8);align-items:center}
.hero__kicker{display:flex;align-items:center;gap:var(--s3);margin-block-end:var(--s5);flex-wrap:wrap}
.hero h1{margin-block:var(--s4) var(--s5)}
.hero .lead{margin-block-end:var(--s6)}
.hero__cta{display:flex;gap:var(--s3);flex-wrap:wrap}
.hero__seal-bg{position:absolute;inset-inline-end:-60px;top:-40px;width:340px;opacity:.05;z-index:-1}

/* Terminal / console */
.console{background:var(--ink);border-radius:var(--radius-lg);box-shadow:var(--shadow);overflow:hidden;
  border:1px solid #20251b}
.console__bar{display:flex;align-items:center;gap:.5ch;padding:var(--s3) var(--s4);border-bottom:1px solid #20251b}
.console__bar i{width:11px;height:11px;border-radius:50%;background:#2c331f;display:block}
.console__bar i:nth-child(1){background:#3a4626}
.console__title{font-family:var(--f-mono);font-size:.72rem;color:rgba(255,255,255,.4);margin-inline-start:auto;letter-spacing:.05em}
html.ar .console__title{direction:ltr}
.console__body{padding:var(--s5);font-family:var(--f-mono);font-size:.9rem;line-height:1.9;color:rgba(255,255,255,.82);direction:ltr;text-align:left;min-height:230px}
.console__line{white-space:pre-wrap}
.console__prompt{color:var(--lime)}
.console__dim{color:rgba(255,255,255,.4)}
.console__out{color:#fff}
.caret{display:inline-block;width:9px;height:1.1em;background:var(--lime);vertical-align:-2px;animation:blink 1s steps(1) infinite}
@keyframes blink{50%{opacity:0}}

/* ---------- Cards / grids ---------- */
.grid{display:grid;gap:var(--s5)}
.cols-2{grid-template-columns:repeat(2,1fr)}
.cols-3{grid-template-columns:repeat(3,1fr)}
.cols-4{grid-template-columns:repeat(4,1fr)}

.card{background:var(--pure);border:1px solid var(--line);border-radius:var(--radius-lg);padding:var(--s6);
  transition:transform var(--t) var(--ease),box-shadow var(--t) var(--ease),border-color var(--t)}
.card:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--line)}
.card__num{font-family:var(--f-mono);font-size:.8rem;color:var(--olive-text)}
.card .h3{margin-block:var(--s4) var(--s2)}
.card p{color:var(--ink-70);font-size:.97rem}
html.ar .card p{line-height:1.85}

/* capability / service icon chip */
.chip{width:46px;height:46px;border-radius:12px;background:var(--paper);border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;color:var(--olive)}
.chip svg{width:22px;height:22px;stroke:currentColor;stroke-width:1.7;fill:none}

/* section heading block */
.sec-head{max-width:62ch;margin-block-end:var(--s7)}
.sec-head .eyebrow{margin-block-end:var(--s4)}
.sec-head.center{margin-inline:auto}

/* stat */
.stat__row{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--s5);
  border-block:1px solid var(--line);padding-block:var(--s6)}
.stat__n{font-family:var(--f-mono);font-size:clamp(1.8rem,3vw,2.4rem);color:var(--ink);line-height:1}
.stat__n b{color:var(--olive);font-weight:inherit}
.stat__l{font-family:var(--f-mono);font-size:.74rem;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-60);margin-block-start:var(--s2)}
html.ar .stat__l{font-family:var(--f-body);text-transform:none;letter-spacing:0;font-size:.85rem}

/* ---------- Dark band (lime glows here) ---------- */
.band-dark{background:var(--ink);color:var(--paper);position:relative;overflow:hidden}
.band-dark::before{content:"";position:absolute;inset:0;
  background-image:linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px);
  background-size:48px 48px;-webkit-mask-image:radial-gradient(80% 80% at 70% 30%,#000,transparent);mask-image:radial-gradient(80% 80% at 70% 30%,#000,transparent)}
.band-dark .h2{color:var(--paper)}
.band-dark .lead{color:rgba(255,255,255,.7)}
.band-dark .eyebrow{color:var(--lime)}
.band-dark .eyebrow::before{color:rgba(255,255,255,.35)}
.glow-seal .ring{stroke:var(--lime);filter:drop-shadow(0 0 10px rgba(196,248,42,.5))}
.glow-seal .tick{stroke:var(--lime);filter:drop-shadow(0 0 10px rgba(196,248,42,.5))}

/* ---------- Process steps ---------- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--s5);counter-reset:step}
.step{position:relative;padding-block-start:var(--s5);border-top:2px solid var(--line)}
.step.is-on{border-top-color:var(--olive)}
.step__n{font-family:var(--f-mono);font-size:.8rem;color:var(--olive-text)}
.step .h3{font-size:1.15rem;margin-block:var(--s3) var(--s2)}
.step p{color:var(--ink-70);font-size:.93rem}

/* ---------- Work cards ---------- */
.work{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--s5)}
.work__item{border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--line);background:var(--pure);
  transition:transform var(--t) var(--ease),box-shadow var(--t) var(--ease)}
.work__item:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.work__cover{aspect-ratio:16/10;position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden}
.work__cover .label{position:absolute;inset-inline-start:var(--s4);top:var(--s4);font-family:var(--f-mono);font-size:.72rem;
  letter-spacing:.05em;background:rgba(251,251,249,.9);border:1px solid var(--line);border-radius:var(--radius-pill);padding:.3em .8em}
.work__name{font-family:var(--f-kufi);font-size:2.4rem;color:var(--ink)}
.work__meta{padding:var(--s5)}
.work__meta .h3{margin-block-end:var(--s1)}
.work__meta p{color:var(--ink-70);font-size:.95rem}
.work__tags{display:flex;gap:.5ch;flex-wrap:wrap;margin-block-start:var(--s4)}
.work__tags span{font-family:var(--f-mono);font-size:.7rem;color:var(--green);border:1px solid var(--line);border-radius:var(--radius-pill);padding:.25em .7em}
html.ar .work__tags span{font-family:var(--f-body)}

/* cover palettes */
.cv-sidra{background:linear-gradient(135deg,#F3EFE6,#E7DECB)}
.cv-sidra .work__name{color:#6B5B3E}
.cv-shifaa{background:linear-gradient(135deg,#E7F1F0,#CFE6E3)}
.cv-shifaa .work__name{color:#0D5C5C}
.cv-next{background:var(--ink);position:relative}
.cv-next .work__name{color:var(--lime);font-family:var(--f-display);font-size:1.4rem;letter-spacing:-.01em}
html.ar .cv-next .work__name{font-family:var(--f-body)}

/* ---------- Team ---------- */
.team{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--s5)}
.member{background:var(--pure);border:1px solid var(--line);border-radius:var(--radius-lg);padding:var(--s6);display:flex;gap:var(--s5);align-items:flex-start}
.member__av{width:64px;height:64px;border-radius:16px;background:var(--paper);border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;font-family:var(--f-kufi);font-size:1.6rem;color:var(--olive);flex:none}
.member__role{font-family:var(--f-mono);font-size:.74rem;text-transform:uppercase;letter-spacing:.05em;color:var(--olive-text)}
html.ar .member__role{font-family:var(--f-body);text-transform:none}
.member__name{margin-block:var(--s2) var(--s3)}
.member__links{display:flex;gap:var(--s4);flex-wrap:wrap}
.member__links a{font-family:var(--f-mono);font-size:.82rem;color:var(--green);display:inline-flex;gap:.5ch;align-items:center}
.member__links a:hover{color:var(--olive)}
.member__links bdi{font-family:var(--f-mono)}

/* ---------- Values ---------- */
.value{padding:var(--s5) 0;border-top:1px solid var(--line);display:grid;grid-template-columns:auto 1fr;gap:var(--s5);align-items:start}
.value__k{font-family:var(--f-mono);font-size:.8rem;color:var(--olive-text);padding-block-start:6px}
.value p{color:var(--ink-70)}

/* ---------- Journal ---------- */
.post{display:grid;grid-template-columns:auto 1fr auto;gap:var(--s5);align-items:center;
  padding:var(--s5) 0;border-top:1px solid var(--line);transition:padding-inline var(--t)}
.post:last-child{border-bottom:1px solid var(--line)}
.post:hover{padding-inline-start:var(--s3)}
.post__date{font-family:var(--f-mono);font-size:.78rem;color:var(--ink-60);min-width:108px}
html.ar .post__date{direction:ltr;text-align:start}
.post__title{font-family:var(--f-display);font-weight:600;font-size:1.2rem}
html.ar .post__title{font-family:var(--f-body)}
.post__cat{font-family:var(--f-mono);font-size:.72rem;color:var(--olive-text)}
.post__arr{color:var(--ink-40);transition:transform var(--t),color var(--t)}
.post:hover .post__arr{color:var(--olive);transform:translateX(4px)}
html.ar .post__arr{transform:scaleX(-1)}
html.ar .post:hover .post__arr{transform:scaleX(-1) translateX(4px)}

.empty{border:1px dashed var(--line);border-radius:var(--radius-lg);padding:var(--s8);text-align:center;background:var(--pure)}
.empty .seal{width:48px;height:48px;margin-inline:auto;margin-block-end:var(--s4);opacity:.5}

/* ---------- Contact ---------- */
.contact__grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:var(--s8);align-items:start}
.contact__channels{display:grid;gap:var(--s4)}
.channel{display:flex;gap:var(--s4);align-items:center;padding:var(--s5);background:var(--pure);border:1px solid var(--line);border-radius:var(--radius);
  transition:border-color var(--t),transform var(--t)}
.channel:hover{border-color:var(--ink);transform:translateY(-2px)}
.channel .chip{flex:none}
.channel__k{font-family:var(--f-mono);font-size:.72rem;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-60)}
html.ar .channel__k{font-family:var(--f-body);text-transform:none}
.channel__v{font-weight:500}
.channel__v bdi{font-family:var(--f-mono);font-weight:500}

.form{background:var(--pure);border:1px solid var(--line);border-radius:var(--radius-lg);padding:var(--s7)}
.field{margin-block-end:var(--s5)}
.field label{display:block;font-family:var(--f-mono);font-size:.76rem;text-transform:uppercase;letter-spacing:.05em;
  color:var(--green);margin-block-end:var(--s2)}
html.ar .field label{font-family:var(--f-body);text-transform:none;font-size:.9rem}
.field input,.field textarea,.field select{
  width:100%;padding:.85em 1em;border:1px solid var(--line);border-radius:var(--radius);background:var(--paper);
  font-family:var(--f-body);font-size:1rem;color:var(--ink);transition:border-color var(--t),box-shadow var(--t)}
.field input::placeholder,.field textarea::placeholder{color:var(--ink-40)}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--olive);
  box-shadow:0 0 0 3px rgba(107,154,40,.15)}
.field textarea{min-height:130px;resize:vertical}
.form__note{font-family:var(--f-mono);font-size:.74rem;color:var(--ink-40);margin-block-start:var(--s3)}
html.ar .form__note{font-family:var(--f-body)}

/* ---------- Footer ---------- */
.footer{background:var(--ink);color:rgba(255,255,255,.7);padding-block:var(--s8) var(--s6);position:relative;overflow:hidden}
.footer::before{content:"";position:absolute;inset:0;
  background-image:linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px);
  background-size:48px 48px;-webkit-mask-image:radial-gradient(70% 100% at 30% 0%,#000,transparent);mask-image:radial-gradient(70% 100% at 30% 0%,#000,transparent)}
.footer__grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:var(--s7);position:relative}
.footer .brand__word{color:#fff}
.footer__tag{margin-block:var(--s4) 0;max-width:34ch;color:rgba(255,255,255,.6);font-size:.95rem}
html.ar .footer__tag{line-height:1.85}
.footer__col h4{font-family:var(--f-mono);font-size:.74rem;text-transform:uppercase;letter-spacing:.06em;color:rgba(255,255,255,.45);margin-block-end:var(--s4)}
html.ar .footer__col h4{font-family:var(--f-body);text-transform:none}
.footer__col a{display:block;padding-block:.35em;color:rgba(255,255,255,.72);transition:color var(--t)}
.footer__col a:hover{color:var(--lime)}
.footer__bottom{display:flex;justify-content:space-between;gap:var(--s4);flex-wrap:wrap;align-items:center;
  margin-block-start:var(--s8);padding-block-start:var(--s5);border-top:1px solid rgba(255,255,255,.1);position:relative}
.footer__bottom .mono{font-size:.76rem;color:rgba(255,255,255,.45)}

/* ---------- Reveal animation (progressive enhancement) ---------- */
.js .reveal{opacity:0;transform:translateY(18px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.js .reveal.in{opacity:1;transform:none}
.reveal[data-d="1"]{transition-delay:.08s}
.reveal[data-d="2"]{transition-delay:.16s}
.reveal[data-d="3"]{transition-delay:.24s}

/* ---------- Responsive ---------- */
@media(max-width:980px){
  .hero__grid{grid-template-columns:1fr;gap:var(--s6)}
  .cols-4{grid-template-columns:repeat(2,1fr)}
  .steps{grid-template-columns:repeat(2,1fr)}
  .stat__row{grid-template-columns:repeat(2,1fr);gap:var(--s6)}
  .footer__grid{grid-template-columns:1fr 1fr}
  .contact__grid{grid-template-columns:1fr;gap:var(--s6)}
}
@media(max-width:760px){
  .section{padding-block:var(--s8)}
  .nav__links{display:none}
  .nav__burger{display:flex}
  .nav__links.is-open{display:flex;position:absolute;inset-inline:0;top:74px;flex-direction:column;align-items:stretch;
    background:var(--paper);border-bottom:1px solid var(--line);padding:var(--s4) var(--s5);gap:var(--s2);margin:0}
  .cols-2,.cols-3,.cols-4,.work,.team{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr}
  .footer__grid{grid-template-columns:1fr;gap:var(--s6)}
  .post{grid-template-columns:1fr auto;gap:var(--s3)}
  .post__date{order:3;grid-column:1/-1}
  .hero__seal-bg{display:none}
}

/* ---------- Reduced motion ---------- */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}
  .js .reveal{opacity:1;transform:none}
  html{scroll-behavior:auto}
}

/* ---------- Article ---------- */
.article{max-width:720px;margin-inline:auto}
.article p{color:var(--ink-70);font-size:1.05rem;line-height:1.75;margin-block-end:var(--s5)}
html.ar .article p{line-height:2}
.article h2{margin-block:var(--s7) var(--s4)}
.article h3{margin-block:var(--s6) var(--s3)}
.article blockquote{border-inline-start:3px solid var(--olive);padding-inline-start:var(--s5);margin-inline:0;margin-block:var(--s6);color:var(--ink-70);font-style:italic}
.article code{font-family:var(--f-mono);font-size:.9em;background:var(--line-soft);padding:.15em .4em;border-radius:6px}
.back-link{display:inline-flex;align-items:center;gap:.5ch;font-family:var(--f-mono);font-size:.84rem;color:var(--olive-text);margin-block-end:var(--s6)}
.back-link:hover{color:var(--ink)}
html.ar .back-link .arr{transform:scaleX(-1)}

/* ---------- Skip link ---------- */
.skip{position:absolute;top:-100%;left:var(--s4);padding:var(--s3) var(--s5);background:var(--lime);color:var(--ink);font-weight:600;border-radius:var(--radius);z-index:200;transition:top .2s}
.skip:focus{top:var(--s4)}

/* ---------- Focus visible ---------- */
:focus-visible{outline:2px solid var(--olive);outline-offset:3px;border-radius:4px}
.btn:focus-visible{outline-offset:3px}
