/* ============================================================
   ArcanSecurity — self-hosted fonts (RGPD-friendly, no third-party request)
   Generated from Google Fonts woff2 · variable Fraunces/Hanken + static IBM Plex Mono
   ============================================================ */
@font-face{font-family:'Fraunces';font-style:italic;font-weight:400 600;font-display:swap;src:url('/assets/fonts/fraunces-400-600-italic-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;}
@font-face{font-family:'Fraunces';font-style:italic;font-weight:400 600;font-display:swap;src:url('/assets/fonts/fraunces-400-600-italic-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:'Fraunces';font-style:normal;font-weight:400 600;font-display:swap;src:url('/assets/fonts/fraunces-400-600-normal-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;}
@font-face{font-family:'Fraunces';font-style:normal;font-weight:400 600;font-display:swap;src:url('/assets/fonts/fraunces-400-600-normal-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:'Hanken Grotesk';font-style:normal;font-weight:400 700;font-display:swap;src:url('/assets/fonts/hanken-grotesk-400-700-normal-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;}
@font-face{font-family:'Hanken Grotesk';font-style:normal;font-weight:400 700;font-display:swap;src:url('/assets/fonts/hanken-grotesk-400-700-normal-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:'IBM Plex Mono';font-style:normal;font-weight:400;font-display:swap;src:url('/assets/fonts/ibm-plex-mono-400-normal-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;}
@font-face{font-family:'IBM Plex Mono';font-style:normal;font-weight:400;font-display:swap;src:url('/assets/fonts/ibm-plex-mono-400-normal-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:'IBM Plex Mono';font-style:normal;font-weight:500;font-display:swap;src:url('/assets/fonts/ibm-plex-mono-500-normal-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;}
@font-face{font-family:'IBM Plex Mono';font-style:normal;font-weight:500;font-display:swap;src:url('/assets/fonts/ibm-plex-mono-500-normal-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;}

/* ============================================================
   ArcanSecurity — shared stylesheet  ·  "l'arcane rendu clair"
   Deep-indigo canvas, amber cipher accent, tri-typeface system.
   ============================================================ */

:root{
  --bg:#0B0E17; --bg-2:#0E1220; --panel:#121626; --panel-2:#161B2E; --elev:#1B2138;
  --line:rgba(233,236,245,.09); --line-2:rgba(233,236,245,.16);
  --ink:#ECEEF5; --dim:#9AA3BC; --faint:#6E7794;
  --acc:#E8A23D; --acc-2:#F2BC6B; --acc-ink:#E8A23D;
  --acc-soft:rgba(232,162,61,.12); --acc-line:rgba(232,162,61,.34);
  --maxw:1180px; --ease:cubic-bezier(.22,.61,.36,1);
}
html[data-theme="light"]{
  --bg:#F2F4FA; --bg-2:#EAEEF6; --panel:#FFFFFF; --panel-2:#F7F9FD; --elev:#EEF1F8;
  --line:rgba(18,26,48,.10); --line-2:rgba(18,26,48,.17);
  --ink:#141A2E; --dim:#505A78; --faint:#7C86A0;
  --acc:#E8A23D; --acc-2:#CF8A22; --acc-ink:#9A6310;
  --acc-soft:rgba(232,162,61,.16); --acc-line:rgba(232,162,61,.42);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--ink);font-family:'Hanken Grotesk',system-ui,-apple-system,'Segoe UI',sans-serif;
  font-size:17px;line-height:1.65;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

body::before{content:"";position:fixed;inset:0;z-index:-2;pointer-events:none;
  background:radial-gradient(680px 480px at 88% -8%,var(--acc-soft),transparent 60%),
  radial-gradient(720px 560px at -6% 18%,rgba(96,120,210,.10),transparent 62%),var(--bg)}
body::after{content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;opacity:.5;
  background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);
  background-size:64px 64px;
  -webkit-mask-image:radial-gradient(ellipse 90% 70% at 50% 0%,#000 20%,transparent 75%);
  mask-image:radial-gradient(ellipse 90% 70% at 50% 0%,#000 20%,transparent 75%)}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}

.eyebrow{font-family:'IBM Plex Mono',ui-monospace,monospace;font-size:12.5px;font-weight:500;letter-spacing:.22em;
  text-transform:uppercase;color:var(--acc-ink);display:inline-flex;align-items:center;gap:11px}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--acc-line)}
h1,h2,h3{font-family:'Fraunces',Georgia,serif;font-weight:500;line-height:1.06;letter-spacing:-.015em;color:var(--ink)}
.lead{color:var(--dim);font-size:1.16rem;line-height:1.6;max-width:60ch}

.btn{display:inline-flex;align-items:center;gap:10px;font-family:'IBM Plex Mono',monospace;font-size:13px;font-weight:500;
  letter-spacing:.04em;padding:14px 22px;border-radius:2px;cursor:pointer;border:1px solid transparent;
  transition:transform .35s var(--ease),background .3s,border-color .3s,color .3s}
.btn .arr{transition:transform .35s var(--ease)}
.btn:hover .arr{transform:translateX(4px)}
.btn-primary{background:var(--acc);color:#0B0E17}
.btn-primary:hover{background:var(--acc-2);transform:translateY(-2px)}
.btn-ghost{border-color:var(--line-2);color:var(--ink)}
.btn-ghost:hover{border-color:var(--acc-line);color:var(--acc-ink);transform:translateY(-2px)}

/* NAV */
header{position:sticky;top:0;z-index:60;transition:background .4s,border-color .4s,backdrop-filter .4s}
header.scrolled{background:color-mix(in srgb,var(--bg) 80%,transparent);backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:74px}
.brand{display:flex;align-items:center;gap:12px;font-family:'Fraunces',serif;font-weight:600;font-size:19px;letter-spacing:.005em;color:var(--ink)}
.brand .mark{width:30px;height:30px;flex:none}
.nav-links{display:flex;align-items:center;gap:34px}
.nav-links a{font-family:'IBM Plex Mono',monospace;font-size:13px;letter-spacing:.03em;color:var(--dim);position:relative;padding:4px 0;transition:color .25s}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-2px;height:1px;width:0;background:var(--acc-ink);transition:width .3s var(--ease)}
.nav-links a:hover,.nav-links a.active{color:var(--ink)}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.nav-right{display:flex;align-items:center;gap:16px}
.lang{font-family:'IBM Plex Mono',monospace;font-size:12px;color:var(--faint);display:flex;gap:8px}
.lang a{color:var(--faint);cursor:pointer;transition:color .2s}
.lang a:hover{color:var(--ink)}
.lang a.active{color:var(--acc-ink);font-weight:500}
.icon-btn{background:none;border:1px solid var(--line-2);border-radius:2px;width:38px;height:38px;display:inline-flex;
  align-items:center;justify-content:center;cursor:pointer;color:var(--ink);transition:border-color .3s,color .3s}
.icon-btn:hover{border-color:var(--acc-line);color:var(--acc-ink)}
.icon-btn svg{width:17px;height:17px}
.theme-toggle .i-moon{display:none}
html[data-theme="light"] .theme-toggle .i-sun{display:none}
html[data-theme="light"] .theme-toggle .i-moon{display:block}
.menu-btn{display:none;flex-direction:column;gap:0}
.menu-btn span{display:block;width:18px;height:1.5px;background:currentColor;margin:3.5px auto;transition:.3s}

/* HERO (home) */
.hero{position:relative;overflow:hidden;padding:clamp(64px,11vw,128px) 0 clamp(60px,8vw,100px)}
.hero-fx{position:absolute;inset:0;z-index:0;pointer-events:none}
.hero .hero-fx{-webkit-mask-image:radial-gradient(135% 125% at 72% 46%,#000 28%,transparent 78%);
  mask-image:radial-gradient(135% 125% at 72% 46%,#000 28%,transparent 78%)}
.hero-grid{position:relative;z-index:2;display:grid;grid-template-columns:1.15fr .85fr;gap:56px;align-items:center}
.hero h1{font-size:clamp(2.6rem,6.2vw,4.5rem);margin:0}
.hero h1 .key{color:var(--acc-ink);position:relative;white-space:nowrap}
.hero h1 .key::after{content:"";position:absolute;left:0;right:0;bottom:.07em;height:2px;background:var(--acc-line)}
.hero .lead{margin-top:26px;max-width:54ch}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;margin-top:38px}
.seal-wrap{display:flex;justify-content:center;align-items:center;position:relative}
.seal{width:min(380px,80%);height:auto;overflow:visible;transition:transform .5s var(--ease);will-change:transform}
.seal .dial{transform-origin:120px 120px;animation:spin 64s linear infinite}
.seal .dial-r{transform-origin:120px 120px;animation:spin 92s linear infinite reverse}
@keyframes spin{to{transform:rotate(360deg)}}
.seal-glow{position:absolute;width:62%;aspect-ratio:1;border-radius:50%;background:radial-gradient(circle,var(--acc-soft),transparent 68%);filter:blur(8px);z-index:-1}

/* PAGE HERO (inner pages) */
.phero{position:relative;overflow:hidden;padding:clamp(72px,11vw,132px) 0 clamp(40px,6vw,64px);border-bottom:1px solid var(--line)}
.phero .hero-fx{-webkit-mask-image:radial-gradient(120% 130% at 50% 35%,#000 30%,transparent 76%);
  mask-image:radial-gradient(120% 130% at 50% 35%,#000 30%,transparent 76%)}
.phero-in{position:relative;z-index:2;max-width:880px}
.phero h1{font-size:clamp(2.4rem,5.6vw,4rem);margin:24px 0 0}
.phero .lead{margin-top:22px}

/* PAGE HERO with background photo */
.phero-photo .phero-bg{position:absolute;inset:0;z-index:0;background-image:var(--phero-img);background-size:cover;background-position:center 28%}
.phero-photo::after{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(96deg,var(--bg) 28%,color-mix(in srgb,var(--bg) 58%,transparent) 58%,color-mix(in srgb,var(--bg) 18%,transparent) 100%),
  linear-gradient(0deg,var(--bg),transparent 40%)}
.phero-photo .phero-in{z-index:2}

/* ABOUT split (consulting) */
.about-split{display:grid;grid-template-columns:1.25fr .75fr;gap:clamp(34px,5vw,64px);align-items:start}
.about-photo{margin:0;border:1px solid var(--line-2);border-radius:3px;overflow:hidden;aspect-ratio:4/5;background:var(--panel)}
.about-photo img{width:100%;height:100%;object-fit:cover;display:block}

/* STATEMENT */
.statement{border-top:1px solid var(--line);border-bottom:1px solid var(--line);text-align:center;padding:clamp(40px,6vw,64px) 0}
.statement h2{font-size:clamp(1.6rem,3.4vw,2.5rem);max-width:20ch;margin:0 auto}

/* SECTIONS */
.sec{padding:clamp(72px,10vw,124px) 0}
.sec-sm{padding:clamp(54px,7vw,86px) 0}
.sec-head{max-width:720px;margin-bottom:clamp(36px,5vw,56px)}
.sec-head h2{font-size:clamp(2rem,4.4vw,3.1rem);margin-top:20px}
.sec-head p{color:var(--dim);margin-top:18px;font-size:1.08rem;max-width:64ch}
.divider{border:0;border-top:1px solid var(--line)}

/* prose */
.prose{max-width:68ch}
.prose p{color:var(--dim);font-size:1.08rem;margin-top:16px}
.prose p:first-child{margin-top:0}
.prose p strong{color:var(--ink);font-weight:600}
.prose a{color:var(--acc-ink)}.prose a:hover{text-decoration:underline}

/* LEGAL page */
.legal{max-width:800px}
.legal .intro{font-size:1.12rem;color:var(--dim);line-height:1.7}
.legal h2{font-size:clamp(1.55rem,3.2vw,2.15rem);margin-top:56px;padding-top:8px}
.legal h2:first-of-type{margin-top:40px}
.legal h3{font-family:'Hanken Grotesk',sans-serif;font-weight:600;font-size:1.16rem;letter-spacing:0;color:var(--ink);margin-top:40px}
.legal p{color:var(--dim);margin-top:14px;line-height:1.72}
.legal ul{margin-top:12px;padding-left:20px;color:var(--dim)}
.legal li{margin-top:8px;line-height:1.6}
.legal strong{color:var(--ink);font-weight:600}
.legal a{color:var(--acc-ink);word-break:break-word}
.legal a:hover{text-decoration:underline}

/* VISION (home) */
.vision-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(36px,6vw,80px);align-items:start;margin-top:22px}
.vision-title{font-size:clamp(2rem,4.4vw,3.1rem)}
.vision-grid .body{color:var(--dim);font-size:1.1rem}

/* FEATURED SERVICE */
.feature{border:1px solid var(--line-2);border-radius:3px;background:linear-gradient(180deg,var(--panel),var(--bg-2));
  padding:clamp(28px,4vw,42px);margin-top:clamp(30px,4vw,44px);display:grid;grid-template-columns:auto 1fr auto;gap:clamp(22px,3vw,38px);
  align-items:center;position:relative;overflow:hidden;transition:border-color .4s,background .4s}
.feature:hover{border-color:var(--acc-line)}
.feature::before{content:"";position:absolute;left:0;top:0;width:3px;height:100%;background:linear-gradient(var(--acc),transparent)}
.feature .picon{width:56px;height:56px;color:var(--acc);flex:none}
.feature h3{font-size:1.55rem}
.feature p{color:var(--dim);font-size:1.04rem;margin-top:10px;max-width:62ch}
.feature .go{font-family:'IBM Plex Mono',monospace;font-size:13px;color:var(--acc-ink);letter-spacing:.04em;white-space:nowrap;
  display:inline-flex;align-items:center;gap:9px;transition:gap .3s var(--ease)}
.feature:hover .go{gap:14px}

/* CHECKLIST (à qui s'adresse) */
.checklist{display:grid;grid-template-columns:1fr 1fr;gap:14px 40px;margin-top:8px}
.check{display:flex;gap:14px;align-items:flex-start;color:var(--dim);font-size:1.02rem;line-height:1.5}
.check svg{width:20px;height:20px;flex:none;color:var(--acc-ink);margin-top:3px}
.check.key{color:var(--ink);font-weight:600}
.note-line{color:var(--dim);font-size:1.08rem;margin-top:clamp(30px,4vw,44px);max-width:74ch}
.note-line strong{color:var(--ink)}

/* SERVICE LIST CARDS (consulting services) */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.svc{border:1px solid var(--line);border-radius:3px;background:var(--panel);padding:30px 28px;transition:transform .35s var(--ease),border-color .35s,background .35s}
.svc:hover{transform:translateY(-4px);border-color:var(--acc-line);background:var(--panel-2)}
.svc .si{width:30px;height:30px;color:var(--acc);margin-bottom:18px;opacity:.9}
.svc h3{font-family:'Hanken Grotesk',sans-serif;font-weight:600;font-size:1.12rem;letter-spacing:0;color:var(--ink)}
.svc ul{list-style:none;margin-top:14px;display:flex;flex-direction:column;gap:9px}
.svc li{position:relative;padding-left:18px;color:var(--dim);font-size:.97rem;line-height:1.45}
.svc li::before{content:"";position:absolute;left:0;top:.62em;width:6px;height:6px;border:1px solid var(--acc-line);transform:rotate(45deg)}

/* NUMBERED PROCESS */
.process{display:flex;flex-direction:column;gap:0;margin-top:8px;counter-reset:step}
.pstep{display:grid;grid-template-columns:64px 1fr;gap:24px;padding:26px 0;border-top:1px solid var(--line-2);align-items:start}
.pstep:last-child{border-bottom:1px solid var(--line-2)}
.pstep .pn{font-family:'Fraunces',serif;font-size:1.9rem;color:var(--acc-ink);line-height:1}
.pstep p{color:var(--dim);font-size:1.02rem;line-height:1.55}
.pstep p strong{color:var(--ink);font-weight:600}

/* PROJECT LIST (hors normes) */
.proj-list{list-style:none;margin-top:8px;display:grid;gap:2px}
.proj-list li{display:flex;gap:16px;align-items:flex-start;padding:18px 0;border-top:1px solid var(--line);color:var(--dim);font-size:1.05rem;line-height:1.5}
.proj-list li:last-child{border-bottom:1px solid var(--line)}
.proj-list li::before{content:"";width:8px;height:8px;margin-top:.55em;flex:none;background:var(--acc);transform:rotate(45deg)}
.proj-list strong{color:var(--ink);font-weight:600}

/* METHOD */
.method-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(36px,6vw,72px);align-items:start}
.method-grid .prose p{font-size:1.06rem}
.principles{border:1px solid var(--line-2);border-radius:3px;background:linear-gradient(180deg,var(--panel),var(--bg-2));padding:32px 30px;position:relative;overflow:hidden}
.principles::before{content:"";position:absolute;left:0;top:0;width:3px;height:100%;background:linear-gradient(var(--acc),transparent)}
.principles .tag{font-family:'IBM Plex Mono',monospace;font-size:11.5px;letter-spacing:.16em;color:var(--acc-ink);text-transform:uppercase}
.principles ul{list-style:none;margin-top:18px;display:flex;flex-direction:column;gap:16px}
.principles li{font-family:'Fraunces',serif;font-size:1.25rem;line-height:1.32;color:var(--ink);padding-left:22px;position:relative}
.principles li::before{content:"";position:absolute;left:0;top:.5em;width:9px;height:9px;background:var(--acc);transform:rotate(45deg)}

/* TIMELINE (about) */
.timeline{position:relative;margin-top:10px;padding-left:34px}
.timeline::before{content:"";position:absolute;left:6px;top:6px;bottom:6px;width:1px;background:var(--line-2)}
.tl{position:relative;padding:0 0 clamp(48px,6vw,68px)}
.tl:last-child{padding-bottom:0}
.tl::before{content:"";position:absolute;left:-34px;top:4px;width:13px;height:13px;border:1px solid var(--acc);background:var(--bg);transform:rotate(45deg)}
.tl::after{content:"";position:absolute;left:-29.5px;top:8.5px;width:4px;height:4px;background:var(--acc)}
.tl .k{font-family:'IBM Plex Mono',monospace;font-size:11.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--acc-ink)}
.tl h3{font-size:clamp(1.5rem,3vw,2.05rem);margin-top:12px}
.tl .body{max-width:64ch}
.tl .body p{color:var(--dim);font-size:1.04rem;margin-top:15px}
.tl .body p:first-of-type{margin-top:16px}
.tl .body strong{color:var(--ink);font-weight:600}
.pullquote{font-family:'Fraunces',serif;font-style:italic;font-size:1.3rem;line-height:1.4;color:var(--ink);
  border-left:2px solid var(--acc);padding:6px 0 6px 22px;margin:22px 0;max-width:60ch}
.tl-list{list-style:none;margin:16px 0 0;display:flex;flex-direction:column;gap:8px}
.tl-list li{position:relative;padding-left:18px;color:var(--dim);font-size:1rem}
.tl-list li::before{content:"";position:absolute;left:0;top:.6em;width:6px;height:6px;border:1px solid var(--acc-line);transform:rotate(45deg)}

/* EXPERTISE / generic gapped cards (home) */
.exp-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;grid-auto-rows:1fr}
.exp{border:1px solid var(--line);border-radius:3px;background:var(--panel);padding:32px 28px 28px;display:flex;flex-direction:column;height:100%;
  transition:transform .35s var(--ease),border-color .35s,background .35s}
.exp:hover{transform:translateY(-4px);border-color:var(--acc-line);background:var(--panel-2)}
.exp .ei{width:30px;height:30px;color:var(--acc);margin-bottom:18px;opacity:.9}
.exp h3{font-family:'Hanken Grotesk',sans-serif;font-weight:600;font-size:1.12rem;letter-spacing:0;line-height:1.3;color:var(--ink)}
.exp p{color:var(--dim);font-size:.97rem;margin-top:11px;flex:1}
.exp p strong{color:var(--ink);font-weight:600}
.exp .go,.svc .go{font-family:'IBM Plex Mono',monospace;font-size:12px;color:var(--acc-ink);letter-spacing:.04em;
  display:inline-flex;align-items:center;gap:7px;margin-top:18px;transition:gap .3s var(--ease)}
.exp:hover .go{gap:12px}
.center-cta{display:flex;justify-content:center;margin-top:clamp(40px,6vw,56px)}

/* CLIENTS + TESTIMONIALS */
.clients{display:flex;flex-wrap:wrap;gap:14px 40px;align-items:center;justify-content:center;
  padding:32px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);margin-bottom:clamp(44px,6vw,68px)}
.clients .c{font-family:'IBM Plex Mono',monospace;font-size:14px;letter-spacing:.05em;color:var(--faint);transition:color .3s}
.clients .c:hover{color:var(--ink)}
.quotes{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;grid-auto-rows:1fr}
.quote{border:1px solid var(--line);border-radius:3px;background:var(--panel);padding:30px 28px;display:flex;flex-direction:column;height:100%}
.quote .mk{font-family:'Fraunces',serif;font-size:2.6rem;line-height:.6;color:var(--acc-line);height:24px}
.quote p{font-size:.98rem;color:var(--ink);line-height:1.62;flex:1;margin-top:10px}
.quote .who{margin-top:22px;padding-top:18px;border-top:1px solid var(--line)}
.quote .who b{display:block;font-weight:600;font-size:.95rem;color:var(--ink)}
.quote .who span{font-family:'IBM Plex Mono',monospace;font-size:11.5px;color:var(--faint);letter-spacing:.03em;display:block;margin-top:3px}
.quote .who a{color:var(--acc-ink);text-decoration:none}
.quote .who a:hover{text-decoration:underline}

/* CONTACT FORM */
.contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(40px,6vw,80px);align-items:start}
.form{display:flex;flex-direction:column;gap:18px}
.field{display:flex;flex-direction:column;gap:8px}
.field label{font-family:'IBM Plex Mono',monospace;font-size:11.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--faint)}
.field input,.field textarea{font-family:'Hanken Grotesk',sans-serif;font-size:1rem;color:var(--ink);background:var(--panel);
  border:1px solid var(--line-2);border-radius:2px;padding:13px 15px;transition:border-color .25s,background .25s;resize:vertical}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--acc-line);background:var(--panel-2)}
.field textarea{min-height:150px}
.form .btn{align-self:flex-start;margin-top:6px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}

/* CONTACT CTA */
.cta{position:relative;text-align:center;padding:clamp(80px,11vw,128px) 0;overflow:hidden}
.cta::before{content:"";position:absolute;inset:0;z-index:-1;background:radial-gradient(560px 320px at 50% 0%,var(--acc-soft),transparent 62%)}
.cta h2{font-size:clamp(2.1rem,5vw,3.4rem);max-width:18ch;margin:22px auto 0}
.cta p{color:var(--dim);max-width:48ch;margin:20px auto 0;font-size:1.08rem}
.cta .btn{margin-top:36px}

/* FOOTER */
footer{border-top:1px solid var(--line);padding:56px 0 36px}
.foot-top{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:24px;padding-bottom:36px;border-bottom:1px solid var(--line)}
.foot-nav{display:flex;flex-wrap:wrap;gap:28px}
.foot-nav a{font-family:'IBM Plex Mono',monospace;font-size:13px;color:var(--dim);letter-spacing:.03em;transition:color .25s}
.foot-nav a:hover{color:var(--acc-ink)}
.foot-bottom{padding-top:26px;font-family:'IBM Plex Mono',monospace;font-size:12px;color:var(--faint);letter-spacing:.03em;text-align:center}
.foot-bottom a{color:var(--faint)}.foot-bottom a:hover{color:var(--acc-ink)}

/* REVEAL */
[data-reveal]{opacity:0;transform:translateY(22px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
[data-reveal].in{opacity:1;transform:none}

/* THEME-SWITCH transition */
html.theming, html.theming *:not(.hero-fx){
  transition:background-color .45s ease,border-color .45s ease,color .45s ease,fill .45s ease,stroke .45s ease !important;
}

/* RESPONSIVE */
@media(max-width:920px){
  .hero-grid{grid-template-columns:1fr;gap:8px}
  .hero .hero-fx{-webkit-mask-image:radial-gradient(140% 120% at 50% 30%,#000 26%,transparent 80%);mask-image:radial-gradient(140% 120% at 50% 30%,#000 26%,transparent 80%)}
  .seal-wrap{order:-1;margin-bottom:8px}.seal{width:min(260px,62%)}
  .vision-grid,.method-grid,.contact-grid{grid-template-columns:1fr;gap:24px}
  .about-split{grid-template-columns:1fr;gap:26px}
  .about-photo{aspect-ratio:16/11;max-width:560px}
  .phero-photo::after{background:linear-gradient(180deg,color-mix(in srgb,var(--bg) 42%,transparent),var(--bg) 82%),linear-gradient(96deg,var(--bg),transparent 72%)}
  .feature{grid-template-columns:1fr;text-align:left;gap:18px}
  .checklist{grid-template-columns:1fr;gap:12px}
  .svc-grid,.exp-grid{grid-template-columns:1fr 1fr}
  .quotes{grid-template-columns:1fr 1fr}
  .nav-links,.lang{display:none}.menu-btn{display:flex}
  .nav-right .btn-primary{display:none}  /* "Contact" is in the hamburger menu on mobile */
  .nav-links.open{display:flex;position:absolute;top:74px;left:0;right:0;flex-direction:column;gap:0;
    background:color-mix(in srgb,var(--bg) 97%,transparent);backdrop-filter:blur(14px);border-bottom:1px solid var(--line);padding:8px 28px 20px}
  .nav-links.open a{padding:14px 0;border-bottom:1px solid var(--line);font-size:15px}
}
@media(max-width:560px){
  body{font-size:16px}
  .svc-grid,.exp-grid{grid-template-columns:1fr;grid-auto-rows:auto}
  .quotes{grid-template-columns:1fr;grid-auto-rows:auto}
  .form-row{grid-template-columns:1fr}
  .pstep{grid-template-columns:44px 1fr;gap:16px}
  .foot-top{flex-direction:column;align-items:flex-start}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;scroll-behavior:auto!important}
  [data-reveal]{opacity:1;transform:none;transition:none}
  .seal .dial,.seal .dial-r{animation:none!important}
}
:focus-visible{outline:2px solid var(--acc);outline-offset:3px;border-radius:2px}
::selection{background:var(--acc);color:#0B0E17}

/* SKIP LINK (a11y) */
.skip-link{position:absolute;left:-9999px;top:0;z-index:200;background:var(--acc);color:#0B0E17;
  font-family:'IBM Plex Mono',monospace;font-size:13px;padding:10px 16px;border-radius:2px}
.skip-link:focus{left:12px;top:12px}

/* CONTACT FORM — status banner, consent, honeypot, reCAPTCHA */
.form-note{font-family:'Hanken Grotesk',sans-serif;font-size:.98rem;line-height:1.5;padding:14px 16px;border-radius:3px;border:1px solid var(--line-2)}
.form-note.ok{color:var(--ink);border-color:var(--acc-line);background:var(--acc-soft)}
.form-note.err{color:var(--ink);border-color:rgba(220,90,90,.55);background:rgba(220,90,90,.10)}
.field.consent{flex-direction:row;align-items:flex-start;gap:11px}
.field.consent input{margin-top:3px;width:16px;height:16px;flex:none;accent-color:var(--acc)}
.field.consent label{font-family:'Hanken Grotesk',sans-serif;font-size:.92rem;letter-spacing:0;text-transform:none;color:var(--dim);line-height:1.5}
.field.consent a{color:var(--acc-ink)}.field.consent a:hover{text-decoration:underline}
.field-hp{position:absolute!important;left:-9999px!important;width:1px;height:1px;overflow:hidden}
.g-recaptcha{margin-top:2px}
.form .btn[disabled]{opacity:.6;cursor:progress}
