/* ==========================================================================
   janmatus.com — "Luminous / Airy minimal" (m1-airy)
   Apple-keynote / editorial minimalism. Near-white canvas everywhere, no dark
   slabs. Type does the work: large, light Albert Sans display with refined
   negative tracking; quiet uppercase labels; hairline dividers instead of
   bordered/shadowed cards. One cool teal accent; gold reduced to a hairline.
   Static, mobile-first, WCAG-AA. Self-hosted Albert Sans + Inter only.
   ========================================================================== */

/* ---- Fonts (self-hosted, variable) — COPY VERBATIM --------------------- */
@font-face{
  font-family:'Albert Sans';font-style:normal;font-weight:100 900;font-display:swap;
  src:url(/fonts/albert-sans-latin.woff2) format('woff2');
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;
}
@font-face{
  font-family:'Albert Sans';font-style:normal;font-weight:100 900;font-display:swap;
  src:url(/fonts/albert-sans-latin-ext.woff2) format('woff2');
  unicode-range:U+0104-0107,U+0118-0119,U+0141-0144,U+015A-015B,U+0179-017C;
}
@font-face{
  font-family:'Inter';font-style:normal;font-weight:100 900;font-display:swap;
  src:url(/fonts/inter-latin.woff2) format('woff2');
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;
}
@font-face{
  font-family:'Inter';font-style:normal;font-weight:100 900;font-display:swap;
  src:url(/fonts/inter-latin-ext.woff2) format('woff2');
  unicode-range:U+0104-0107,U+0118-0119,U+0141-0144,U+015A-015B,U+0179-017C;
}

/* ---- Tokens ------------------------------------------------------------- */
:root{
  /* ink scale (all AA-verified on the light surfaces below) */
  --ink:#172038;        /* primary body + display */
  --ink-2:#172038;      /* headings */
  --muted:#4f5a6b;      /* secondary body          (6.7:1 on bg) */
  --muted-2:#586273;    /* small meta              (5.0:1 on bg) */

  /* single cool accent */
  --teal:#0f7d72;       /* accent, large/decorative (4.8:1 on bg) */
  --teal-d:#0b6258;     /* links / button fills     (7.0:1 on bg) */
  --teal-dd:#084a42;    /* link/button hover */
  --teal-light:#bfe7e0; /* selection / faint wash */
  --teal-wash:#e7f2f0;  /* whisper accent surface */

  /* gold — reduced to a hairline detail only */
  --gold:#a87d1f;
  --gold-2:#C9A227;     /* legacy token (kept for award title) */

  /* near-white canvas + soft tints (no dark slabs) */
  --bg:#fbfbfa;         /* main near-white canvas */
  --bg-soft:#f3f4f2;    /* soft alternating surface */
  --bg-soft-2:#eef0ee;
  --tint:#edf0ef;       /* recognition / cta soft cool-tint */
  --tint-2:#e9eeed;

  /* hairlines */
  --line:#e3e5e2;
  --line-2:#ebeceb;
  --line-strong:#d6d9d4;

  /* legacy navy tokens kept so nothing referencing them breaks; remapped light */
  --navy:#172038; --navy-2:#1f2b4d; --navy-3:#101729;

  --maxw:1180px; --readw:720px;
  --r:14px; --r-lg:20px; --r-pill:999px;

  /* a whisper of shadow — used only on hover, never stacked */
  --shadow:0 24px 60px -28px rgba(20,28,44,.22);
  --shadow-sm:0 12px 34px -18px rgba(20,28,44,.16);
  --shadow-hair:0 1px 0 0 var(--line);

  --font-display:'Albert Sans',system-ui,-apple-system,Segoe UI,sans-serif;
  --font-body:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --ease:cubic-bezier(.22,.61,.36,1);

  /* ---- Soft-mesh ambient wash ------------------------------------------
     "Delikatny" studio-light texture for the tinted field surfaces only.
     Three light, hue-whispered blobs (cool teal, cool sky, faint warm sand).
     Every blob colour is luminance-matched to / lighter than the base tints,
     so layering them can never push body/meta text below its flat-base
     contrast — the wash only adds gentle organic glow, never a darker fill.
     Alphas stay tiny; edges are huge and feather to transparent (no hard ring). */
  --mesh-teal:198,228,220;   /* #e0f1ed — cool teal wash  */
  --mesh-sky:205,223,246;    /* #e6eff9 — cool sky wash   */
  --mesh-warm:240,228,206;   /* #f6f0e6 — faint warm sand */
}

/* ---- Reset / base ------------------------------------------------------- */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;font-family:var(--font-body);color:var(--ink);background:var(--bg);
  font-size:17px;line-height:1.72;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:hidden;
}

/* Display type: lighter Albert Sans weights, big, with refined negative tracking */
h1,h2,h3,h4{
  font-family:var(--font-display);color:var(--ink-2);line-height:1.06;
  margin:0 0 .5em;letter-spacing:-.025em;font-weight:400;text-wrap:balance;
}
h1{font-size:clamp(2.9rem,7vw,5rem);font-weight:300;letter-spacing:-.04em}
h2{font-size:clamp(1.95rem,4vw,3.1rem);font-weight:300;letter-spacing:-.032em}
h3{font-size:1.22rem;font-weight:500;letter-spacing:-.015em}
h4{font-size:1.02rem;font-weight:500;letter-spacing:-.01em}
p{margin:0 0 1.15rem}
img,svg{max-width:100%;display:block}
a{color:var(--teal-d);text-decoration:none;transition:color .18s var(--ease)}
a:hover{color:var(--teal-dd);text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:1px}
ul{margin:0;padding:0;list-style:none}
strong{font-weight:600;color:var(--ink)}
:focus-visible{outline:2.5px solid var(--teal-d);outline-offset:3px;border-radius:5px}
::selection{background:var(--teal-light);color:var(--ink-2)}

/* ---- Layout helpers ----------------------------------------------------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 26px}
/* generous, calm vertical rhythm */
.section{padding:clamp(76px,12vw,158px) 0}
.section--tight{padding:clamp(52px,8vw,96px) 0}

/* Soft-mesh wash on .bg-soft sections (Expertise on home; tight profile/contact
   sections). Base tint kept as the colour layer; three large feathered blobs
   anchored top-left + bottom-right + a faint warm mid-right. */
.bg-soft{
  background-color:var(--bg-soft);
  background-image:
    radial-gradient(78% 88% at 12% 8%,  rgba(var(--mesh-teal),.30), rgba(var(--mesh-teal),0) 60%),
    radial-gradient(86% 92% at 92% 96%, rgba(var(--mesh-sky),.26),  rgba(var(--mesh-sky),0)  62%),
    radial-gradient(70% 80% at 84% 22%, rgba(var(--mesh-warm),.18), rgba(var(--mesh-warm),0) 64%);
}

/* .bg-navy is NO LONGER dark — soft cool tint with dark text overrides */
.bg-navy{background:var(--tint);color:var(--ink)}
.bg-navy h1,.bg-navy h2,.bg-navy h3,.bg-navy h4{color:var(--ink-2)}

/* Soft-mesh wash on the Recognition band (section.bg-navy remapped light, and
   .recognition). Blobs placed top-right + bottom-left for a different sweep
   than .bg-soft — gentle page variation in the same restrained family. */
.bg-navy,
.recognition{
  background-color:var(--tint);
  background-image:
    radial-gradient(82% 90% at 90% 6%,  rgba(var(--mesh-teal),.30), rgba(var(--mesh-teal),0) 60%),
    radial-gradient(88% 96% at 6% 94%,  rgba(var(--mesh-sky),.25), rgba(var(--mesh-sky),0)  62%),
    radial-gradient(64% 72% at 34% 70%, rgba(var(--mesh-warm),.16),rgba(var(--mesh-warm),0) 66%);
}

.lede{font-size:clamp(1.18rem,1.9vw,1.42rem);color:var(--muted);max-width:42ch;line-height:1.55;font-weight:400}

/* quiet small uppercase label, hairline tick in the accent */
.eyebrow{
  display:inline-flex;align-items:center;gap:.7em;
  font-family:var(--font-body);font-weight:600;font-size:.74rem;
  text-transform:uppercase;letter-spacing:.22em;color:var(--teal-d);margin:0 0 1.5rem;
}
.eyebrow::before{content:"";width:30px;height:1px;background:var(--teal-d);display:inline-block;opacity:.85}
.bg-navy .eyebrow{color:var(--teal-d)}
.bg-navy .eyebrow::before{background:var(--teal-d)}

.section-head{max-width:var(--readw)}

.skip-link{position:absolute;left:-9999px;top:0;background:var(--ink-2);color:#fff;padding:13px 20px;border-radius:0 0 10px 0;z-index:200;font-weight:600}
.skip-link:focus{left:0;text-decoration:none}

/* ---- Buttons — minimal: ink-solid primary + understated secondary ------- */
.btn{
  --bg:var(--ink-2);--fg:#fff;
  display:inline-flex;align-items:center;justify-content:center;gap:.5em;
  background:var(--bg);color:var(--fg);font-family:var(--font-body);font-weight:550;font-size:.97rem;
  letter-spacing:.005em;padding:14px 26px;border-radius:var(--r);border:1px solid transparent;cursor:pointer;
  transition:transform .2s var(--ease),background .2s var(--ease),box-shadow .2s var(--ease),border-color .2s var(--ease),color .2s var(--ease);
  min-height:48px;
}
.btn:hover{background:#101526;color:#fff;text-decoration:none;transform:translateY(-2px);box-shadow:var(--shadow-sm)}
.btn:active{transform:translateY(0);box-shadow:none}

/* secondary: understated outline / hairline */
.btn--outline{background:transparent;color:var(--ink-2);border-color:var(--line-strong)}
.btn--outline:hover{background:transparent;color:var(--ink-2);border-color:var(--ink-2);box-shadow:none;transform:translateY(-2px)}

/* ghost reused on light tints now — keep selector, recolor for light bg */
.btn--ghost{background:transparent;color:var(--teal-d);border-color:rgba(11,98,88,.35)}
.btn--ghost:hover{background:var(--teal-wash);color:var(--teal-dd);border-color:rgba(11,98,88,.5);transform:translateY(-2px);box-shadow:none}

.btn-row{display:flex;flex-wrap:wrap;gap:14px;align-items:center}

/* text/underline link — quiet, with a sliding arrow */
.link-arrow{font-weight:600;display:inline-flex;align-items:center;gap:.5em;color:var(--teal-d);
  text-decoration:underline;text-decoration-color:rgba(11,98,88,.25);text-underline-offset:5px;text-decoration-thickness:1px}
.link-arrow:hover{color:var(--teal-dd);text-decoration-color:currentColor}
.link-arrow span{transition:transform .2s var(--ease)}
.link-arrow:hover span{transform:translateX(5px)}

/* ---- Header — airy, hairline-only ------------------------------------- */
.site-header{
  position:sticky;top:0;z-index:100;background:rgba(251,251,250,.78);
  backdrop-filter:saturate(180%) blur(14px);-webkit-backdrop-filter:saturate(180%) blur(14px);
  border-bottom:1px solid var(--line);
}
.site-header .wrap{display:flex;align-items:center;justify-content:space-between;height:74px;gap:18px}
.brand{display:inline-flex;align-items:flex-end;gap:0;color:var(--ink-2);font-family:var(--font-display);font-size:1.5rem;line-height:1}
.brand:hover{text-decoration:none;color:var(--ink-2)}
.brand b{font-weight:600}
.brand .jan{font-weight:200}
.brand .dot{color:var(--gold);font-weight:600}
.brand-mark{display:inline-flex;flex-direction:column}
.brand-mark .rule{height:1px;width:36px;background:var(--gold);margin-top:5px;opacity:.9}

.nav{display:flex;align-items:center;gap:34px}
.nav a:not(.btn){color:var(--muted);font-weight:500;font-size:.95rem;letter-spacing:.005em;transition:color .18s var(--ease)}
.nav a:not(.btn):hover{color:var(--ink-2);text-decoration:none}
.nav a:not(.btn)[aria-current="page"]{color:var(--ink-2)}
.nav .btn{padding:10px 20px;min-height:0;border-radius:var(--r)}

.nav-toggle{display:none;background:none;border:0;cursor:pointer;width:44px;height:44px;align-items:center;justify-content:center;color:var(--ink-2)}
.nav-toggle svg{width:26px;height:26px}
.nav-toggle .ic-close{display:none}
.nav-toggle[aria-expanded="true"] .ic-open{display:none}
.nav-toggle[aria-expanded="true"] .ic-close{display:block}

/* ---- Hero --------------------------------------------------------------- */
.hero{padding:clamp(64px,10vw,128px) 0 clamp(64px,10vw,120px);position:relative}
.hero .wrap{display:grid;grid-template-columns:1.08fr .92fr;gap:clamp(40px,6vw,84px);align-items:center}
.hero h1{margin:.08em 0 .3em;line-height:1.0}
.hero .lede{max-width:32ch;margin-bottom:1.1rem}
.hero .subline{color:var(--muted-2);font-size:1.02rem;margin-bottom:2.1rem;max-width:44ch;line-height:1.65}
.hero .subline b{color:var(--ink);font-weight:600}

/* portrait: borderless, soft, with a single quiet accent wash + hairline tick */
.hero-figure{position:relative;justify-self:end;width:100%;max-width:460px}
.hero-figure::before{
  content:"";position:absolute;inset:auto -22px -24px 26%;width:74%;height:78%;
  background:radial-gradient(120% 120% at 70% 80%,var(--teal-wash),transparent 70%);
  opacity:.9;border-radius:var(--r-lg);z-index:0;
}
.hero-figure::after{
  content:"";position:absolute;left:-14px;top:-12px;width:40px;height:40px;
  border-left:1px solid var(--gold);border-top:1px solid var(--gold);border-radius:3px 0 0 0;z-index:2;opacity:.9;
}
.hero-figure img{
  position:relative;z-index:1;width:100%;height:auto;aspect-ratio:1/1;border-radius:var(--r-lg);
  border:1px solid var(--line);box-shadow:var(--shadow);background:#fff;
}

/* ---- Metrics — hairline-framed, airy, left-readable -------------------- */
/* Soft-mesh wash: a quiet teal glow drifting from the left, sky from the
   right, a faint warm centre-low — keeps the band alive while staying nearly
   transparent over the body canvas. Hairline frame and layout untouched. */
.metrics{border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  background-color:transparent;
  background-image:
    radial-gradient(70% 150% at 4% 50%,  rgba(var(--mesh-teal),.27), rgba(var(--mesh-teal),0) 58%),
    radial-gradient(74% 150% at 97% 48%, rgba(var(--mesh-sky),.24),  rgba(var(--mesh-sky),0)  60%),
    radial-gradient(56% 130% at 50% 108%,rgba(var(--mesh-warm),.15), rgba(var(--mesh-warm),0) 64%);
}
.metrics .wrap{display:grid;grid-template-columns:repeat(3,1fr);gap:0}
.metric{padding:clamp(36px,5vw,56px) 30px;text-align:left;border-right:1px solid var(--line)}
.metric:last-child{border-right:0}
.metric .n{font-family:var(--font-display);font-weight:300;font-size:clamp(2.6rem,4.6vw,3.7rem);color:var(--ink-2);line-height:1;letter-spacing:-.04em}
.metric .n em{font-style:normal;color:var(--teal-d);font-weight:400}
.metric .l{margin-top:14px;font-size:.78rem;text-transform:uppercase;letter-spacing:.16em;color:var(--muted-2);font-weight:600}

/* ---- Recognition (now light, soft tint) -------------------------------- */
.recognition .lede{color:var(--muted)}
.awards{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(28px,4vw,52px);margin-top:clamp(48px,6vw,72px)}
/* borderless cards: a single hairline top rule, no boxes, lift on hover */
.award{
  background:transparent;border:0;border-top:1px solid var(--line-strong);
  border-radius:0;padding:26px 0 0;transition:transform .22s var(--ease)}
.award:hover{transform:translateY(-2px)}
.award .t{color:var(--ink-2);font-family:var(--font-display);font-weight:500;font-size:1.18rem;letter-spacing:-.01em;margin-bottom:.55rem}
.award .t::before{content:"";display:block;width:22px;height:1px;background:var(--gold);margin-bottom:16px}
.award p{color:var(--muted);margin:0 0 1.2rem;font-size:1rem}
.award .src{color:var(--muted-2);font-size:.86rem;line-height:1.55;border-top:0;padding-top:0}
.award .src b{color:var(--ink-2);font-weight:600}

.brandstrip{display:flex;flex-wrap:wrap;align-items:center;gap:12px 26px;margin-top:18px;color:var(--muted-2);font-size:.9rem}
.brandstrip .co{font-family:var(--font-display);font-weight:500;font-size:1.2rem;letter-spacing:-.01em;color:var(--ink-2)}

/* ---- About — editorial 2-col, left-aligned rhythm --------------------- */
.about .wrap{display:grid;grid-template-columns:.72fr 1.28fr;gap:clamp(36px,6vw,88px);align-items:start}
.about .body{max-width:62ch}
.about .body p{color:var(--muted);font-size:1.12rem;line-height:1.7}
.about .body p:first-child{color:var(--ink);font-size:1.22rem;line-height:1.6}

/* ---- Expertise — hairline list, big quiet numbers --------------------- */
.xp-list{margin-top:clamp(40px,5vw,60px);border-top:1px solid var(--line)}
.xp{display:grid;grid-template-columns:auto 1fr;gap:clamp(24px,4vw,60px);padding:clamp(34px,4vw,48px) 0;border-bottom:1px solid var(--line);align-items:start}
.xp .no{font-family:var(--font-display);font-weight:300;font-size:1.6rem;color:var(--muted-2);letter-spacing:0;padding-top:2px;font-variant-numeric:tabular-nums}
.xp .c{display:grid;grid-template-columns:.66fr 1.34fr;gap:clamp(16px,3vw,48px);align-items:start}
.xp h3{margin:0;font-size:clamp(1.45rem,2.4vw,1.85rem);color:var(--ink-2);font-weight:400;letter-spacing:-.02em;line-height:1.12}
.xp p{margin:0;color:var(--muted);font-size:1.02rem}
.xp .tags{margin-top:18px;display:flex;flex-wrap:wrap;gap:8px}
/* tags: quiet hairline chips, not loud pills */
.xp .tag{font-size:.78rem;color:var(--muted);background:transparent;border:1px solid var(--line-strong);border-radius:var(--r-pill);padding:5px 13px;font-weight:500;transition:border-color .18s var(--ease),color .18s var(--ease)}
.xp:hover .tag{border-color:var(--line-strong)}

/* ---- CTA band — now a light, intentional close (not a dark slab) ------- */
/* Soft-mesh wash: blobs anchored bottom-left + top-right + a faint warm
   low-centre, a different arrangement again so the closing band reads as its
   own light room rather than a repeat of the sections above. */
.cta-band{background-color:var(--tint);color:var(--ink);text-align:center;position:relative;
  background-image:
    radial-gradient(80% 96% at 8% 100%, rgba(var(--mesh-teal),.30), rgba(var(--mesh-teal),0) 60%),
    radial-gradient(84% 92% at 94% 4%,  rgba(var(--mesh-sky),.26),  rgba(var(--mesh-sky),0)  62%),
    radial-gradient(60% 70% at 58% 96%, rgba(var(--mesh-warm),.18), rgba(var(--mesh-warm),0) 64%);
}
.cta-band::before{content:"";position:absolute;top:0;left:50%;transform:translateX(-50%);width:30px;height:1px;background:var(--gold)}
.cta-band h2{color:var(--ink-2);max-width:20ch;margin:0 auto .5em}
.cta-band p{color:var(--muted);max-width:50ch;margin:0 auto 2rem;font-size:1.12rem}
.cta-band .btn-row{justify-content:center}

/* ---- Footer — light, soft tint; SVG logo text recolored to dark -------- */
.site-footer{background:var(--bg-soft);color:var(--muted);padding:clamp(64px,8vw,96px) 0 32px;border-top:1px solid var(--line)}
.site-footer .grid{display:grid;grid-template-columns:1.7fr 1fr 1.3fr;gap:48px}
.site-footer .logo-svg{width:240px;max-width:72%;height:auto;margin:-16px 0 10px -2px}
/* RULE 5: the inline SVG <text> bakes in white fills — override to dark on light footer.
   The gold bar / binary keep their gold fills (untouched). The two rgba-white
   subtitle lines are nudged to a readable muted ink. */
.site-footer .logo-svg text{fill:var(--ink-2)}
.site-footer .logo-svg text[fill^="rgba(255"]{fill:var(--muted)}
.site-footer p{margin:0 0 .7rem;font-size:.96rem}
.site-footer h2{color:var(--ink-2);font-family:var(--font-body);font-weight:600;font-size:.74rem;text-transform:uppercase;letter-spacing:.18em;margin:0 0 16px}
.site-footer a{color:var(--muted)}
.site-footer a:hover{color:var(--ink-2)}
.foot-bottom{border-top:1px solid var(--line);margin-top:clamp(40px,5vw,56px);padding-top:22px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:.84rem;color:var(--muted-2)}

/* ---- Contact page ------------------------------------------------------- */
.page-hero{padding:clamp(72px,10vw,124px) 0 clamp(44px,6vw,68px)}
.page-hero .eyebrow{margin-bottom:1.3rem}
.page-hero h1{margin-bottom:.3em}
.page-hero p{font-size:clamp(1.1rem,1.8vw,1.32rem);color:var(--muted);max-width:56ch;line-height:1.6}

/* borderless contact cards: hairline top rule, lift on hover */
.contact-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,3vw,40px);margin:12px 0 44px}
.cc{background:transparent;border:0;border-top:1px solid var(--line-strong);border-radius:0;padding:24px 0 0;transition:transform .2s var(--ease)}
.cc:hover{transform:translateY(-2px);box-shadow:none}
.cc .lbl{font-size:.72rem;text-transform:uppercase;letter-spacing:.18em;color:var(--muted-2);font-weight:600}
.cc .v{font-size:1.18rem;font-weight:500;margin-top:12px;word-break:break-word;font-family:var(--font-display);letter-spacing:-.01em}
.cc .v a{color:var(--ink-2)}
.cc .v a:hover{color:var(--teal-d)}

.company-card{border:0;border-top:1px solid var(--line-strong);border-radius:0;background:transparent;padding:26px 0 0;display:grid;grid-template-columns:auto 1fr;gap:22px;align-items:start}
.company-card .lbl{font-size:.72rem;text-transform:uppercase;letter-spacing:.18em;color:var(--muted-2);font-weight:600;margin-bottom:8px}
.company-card address{font-style:normal;color:var(--ink);line-height:1.8}

/* ---- Profile page ------------------------------------------------------- */
.profile-hero .wrap{display:grid;grid-template-columns:1fr auto;gap:clamp(36px,6vw,72px);align-items:center}
.profile-hero .pf-img{width:210px;height:210px;border-radius:50%;object-fit:cover;border:1px solid var(--line);box-shadow:var(--shadow);background:#fff;justify-self:end}
.prose{max-width:var(--readw)}
.prose p{color:var(--muted);font-size:1.12rem;line-height:1.72}
.prose p:first-child{color:var(--ink);font-size:1.2rem}

.cols{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(28px,4vw,44px);margin-top:36px}
.stack{display:grid;gap:0;margin-top:clamp(32px,4vw,44px)}

/* panels: borderless, hairline-separated, generous padding (no boxes) */
.stack .panel{border-top:1px solid var(--line)}
.stack .panel:first-child{border-top:0}
.stack .panel h3{font-size:clamp(1.3rem,2vw,1.6rem);margin-bottom:.5rem;font-weight:400;letter-spacing:-.02em}
.stack .panel p{font-size:1.04rem;line-height:1.7}
.panel{border:0;border-radius:0;padding:clamp(28px,4vw,40px) 0;background:transparent}
.panel h3{color:var(--ink-2);margin-bottom:.55rem;font-weight:400}
.panel p{color:var(--muted);margin:0;font-size:1.02rem}

.role{display:flex;gap:18px;padding:22px 0;border-bottom:1px solid var(--line);align-items:baseline}
.role:last-child{border-bottom:0}
.role .ro{font-family:var(--font-display);font-weight:500;color:var(--ink-2);font-size:1.14rem;letter-spacing:-.01em}
.role .rm{color:var(--muted);font-size:.98rem}
.role .rc{margin-left:auto;color:var(--teal-d);font-weight:600;font-size:.82rem;text-transform:uppercase;letter-spacing:.1em;white-space:nowrap}

.edu{display:grid;grid-template-columns:1fr;gap:6px}
.courses{display:grid;grid-template-columns:repeat(2,1fr);gap:0 clamp(28px,4vw,56px);margin-top:22px}
.course{display:flex;justify-content:space-between;gap:16px;padding:15px 0;border-bottom:1px solid var(--line);font-size:.98rem}
.course .src{color:var(--muted-2);font-size:.84rem;white-space:nowrap}

/* ---- Reveal animation --------------------------------------------------- */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}

/* ---- Responsive --------------------------------------------------------- */
@media(max-width:920px){
  .hero .wrap{grid-template-columns:1fr;gap:44px}
  .hero-figure{justify-self:start;max-width:360px}
  .hero-figure::before{inset:auto -16px -18px 30%}
  .about .wrap{grid-template-columns:1fr;gap:24px}
  .xp .c{grid-template-columns:1fr;gap:12px}
  .site-footer .grid{grid-template-columns:1fr 1fr;gap:36px}
  .site-footer .col-brand{grid-column:1/-1}
}
@media(max-width:760px){
  /* CRITICAL: mobile nav is a fixed off-screen panel, shown via .open */
  .nav{
    position:fixed;inset:74px 0 auto 0;flex-direction:column;align-items:stretch;gap:0;
    background:var(--bg);border-bottom:1px solid var(--line);padding:10px 26px 22px;
    box-shadow:var(--shadow);transform:translateY(-130%);transition:transform .3s var(--ease);
    visibility:hidden;
  }
  .nav.open{transform:translateY(0);visibility:visible}
  .nav a:not(.btn){padding:16px 4px;border-bottom:1px solid var(--line-2);font-size:1.08rem;color:var(--ink-2)}
  .nav .btn{margin-top:16px;width:100%}
  .nav-toggle{display:inline-flex}

  .metrics .wrap{grid-template-columns:1fr}
  .metric{border-right:0;border-bottom:1px solid var(--line);padding:30px 4px;text-align:left}
  .metric:last-child{border-bottom:0}

  .awards{grid-template-columns:1fr;gap:34px}
  .contact-cards{grid-template-columns:1fr;gap:30px}
  .cols,.courses{grid-template-columns:1fr}
  .company-card{grid-template-columns:1fr;gap:14px}

  .profile-hero .wrap{grid-template-columns:1fr}
  .profile-hero .pf-img{justify-self:start;width:150px;height:150px}

  .role{flex-wrap:wrap}
  .role .rc{margin-left:0;flex-basis:100%}

  .site-footer .grid{grid-template-columns:1fr}
  .foot-bottom{flex-direction:column;gap:6px}
}

@media(prefers-reduced-motion:reduce){
  *{scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none;transition:none}
  .btn,.cc,.award,.xp .tag,.link-arrow span,.hero-figure img{transition:none}
}
/* ---- Engagements logo wall (monochrome ink) ---------------------------- */
.logo-wall{display:flex;flex-wrap:wrap;align-items:center;gap:clamp(24px,4.5vw,50px);margin-top:22px}
.logo-wall img{width:auto;filter:grayscale(1) brightness(0);opacity:.45;transition:opacity .2s var(--ease)}
.logo-wall img:hover{opacity:.7}
/* per-logo heights — normalised by visible LETTER height, not bounding box */
.logo-wall .lw-pa{height:25px}
.logo-wall .lw-kp{height:48px}
.logo-wall .lw-mav{height:19px}
.logo-wall .lw-amd{height:21px}
.logo-wall .lw-xil{height:21px}
.logo-wall .lw-nokia{height:21px}
.logo-wall .co-text{font-family:var(--font-display);font-weight:600;font-size:1.18rem;letter-spacing:-.01em;color:var(--ink-2);opacity:.48;transition:opacity .2s var(--ease)}
.logo-wall .co-text:hover{opacity:.72}
@media(prefers-reduced-motion:reduce){.logo-wall img,.logo-wall .co-text{transition:none}}
