/* =========================================================================
   Bjorn Laku — personal site
   Design: modern executive. Hanken Grotesk (display + body)
   + JetBrains Mono (interface data). Palette derived from the Cashbook brand.
   ========================================================================= */

/* ---------- Fonts (self-hosted, fast and modern) ---------- */
@font-face{
  font-family:"Hanken Grotesk";
  src:url("./fonts/hanken-regular.woff2") format("woff2");
  font-weight:400;font-style:normal;font-display:swap;
}
@font-face{
  font-family:"Hanken Grotesk";
  src:url("./fonts/hanken-semibold.woff2") format("woff2");
  font-weight:600 900;font-style:normal;font-display:swap;
}
@font-face{
  font-family:"JetBrains Mono";
  src:url("./fonts/jetbrains-medium.woff2") format("woff2");
  font-weight:500 700;font-style:normal;font-display:swap;
}

/* ---------- Tokens ---------- */
:root{
  --ink:#0A1A2F;        --ink-2:#0F2438;      --ink-3:#16314A;
  --azure:#0E76D6;      --azure-bright:#1B86EE;--sky:#5BA4F0;
  --porcelain:#F2F5F9;  --paper:#FBFCFE;      --cloud:#EAF1F8;
  --slate:#51617A;      --slate-deep:#33425A; --slate-soft:#6B7C92;
  --platinum:#DCE3EC;   --platinum-2:#E7ECF3;
  --on-dark:#E9F0F8;    --on-dark-mut:#9DB1C8;
  --hair:#E2E8F0;       --hair-dark:rgba(255,255,255,.12);

  --serif:"Hanken Grotesk", "Avenir Next", "Segoe UI Variable Display", system-ui, sans-serif;
  --sans:"Hanken Grotesk", "Avenir Next", "Segoe UI Variable Text", system-ui, -apple-system, sans-serif;
  --mono:"JetBrains Mono", "SFMono-Regular", Consolas, monospace;

  --maxw:1180px;
  --pad:clamp(20px, 5.2vw, 60px);
  --sect:clamp(74px, 11vw, 156px);
  --r:14px;     --r-sm:10px;     --r-lg:22px;

  --shadow-s:0 1px 2px rgba(10,26,47,.05), 0 2px 8px rgba(10,26,47,.05);
  --shadow-m:0 14px 40px -18px rgba(10,26,47,.30), 0 6px 16px -10px rgba(10,26,47,.18);
  --shadow-l:0 40px 90px -40px rgba(10,26,47,.45), 0 18px 40px -28px rgba(10,26,47,.30);

  --ease:cubic-bezier(.22,.61,.27,1);
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--sans);
  font-size:clamp(1rem, .965rem + .18vw, 1.07rem);
  line-height:1.64;
  color:var(--slate-deep);
  background:var(--porcelain);
  font-weight:400;
  letter-spacing:-.006em;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}

body,button,input,textarea{font-variant-numeric:proportional-nums;font-feature-settings:"kern" 1,"liga" 1,"calt" 1;}
.eyebrow,.cred-card__kicker,.product__badge,.field label,.foot__col h4,.local-time,.copy-email__address{font-variant-numeric:tabular-nums;font-feature-settings:"tnum" 1,"zero" 1;}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}
::selection{background:var(--azure);color:#fff}

/* ---------- Layout helpers ---------- */
.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--pad)}
.section{padding-block:var(--sect)}
.eyebrow{
  font-family:var(--mono);font-size:.66rem;font-weight:650;
  letter-spacing:.17em;text-transform:uppercase;color:var(--azure);
  display:inline-flex;align-items:center;gap:.6em;
}
.eyebrow::before{
  content:"";width:18px;height:11px;flex:none;
  background:var(--azure);
  -webkit-mask:var(--chev) center/contain no-repeat; mask:var(--chev) center/contain no-repeat;
}
.eyebrow--plain::before{display:none}
.eyebrow--light{color:var(--sky)}
.eyebrow--light::before{background:var(--sky)}

h1,h2,h3,h4{
  font-family:var(--serif);font-weight:700;line-height:.98;
  letter-spacing:-.045em;color:var(--ink);
  text-wrap:balance;
}
.h2{font-size:clamp(2.1rem, 1.25rem + 3.7vw, 3.7rem);line-height:.98;letter-spacing:-.052em;font-weight:760}
.lead{font-size:clamp(1.12rem, 1.02rem + .62vw, 1.42rem);line-height:1.5;color:var(--slate);font-weight:400;letter-spacing:-.014em}

/* chevron mask used across the site */
:root{--chev:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 60 36'%3E%3Cpath d='M2 2 L34 18 L2 34 Z M26 2 L58 18 L26 34 Z'/%3E%3C/svg%3E")}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.55em;
  font-family:var(--sans);font-weight:700;font-size:.93rem;letter-spacing:-.01em;
  padding:.82em 1.45em;border-radius:999px;
  transition:transform .25s var(--ease), box-shadow .25s var(--ease), background .25s var(--ease), color .25s var(--ease);
  will-change:transform;
}
.btn .arr{transition:transform .3s var(--ease)}
.btn:hover .arr{transform:translateX(4px)}
.btn--primary{background:var(--azure);color:#fff;box-shadow:0 8px 20px -8px rgba(14,118,214,.6)}
.btn--primary:hover{background:var(--azure-bright);transform:translateY(-2px);box-shadow:0 14px 30px -10px rgba(14,118,214,.65)}
.btn--ghost{background:transparent;color:var(--ink);box-shadow:inset 0 0 0 1.4px var(--platinum)}
.btn--ghost:hover{box-shadow:inset 0 0 0 1.4px var(--azure);color:var(--azure);transform:translateY(-2px)}
.btn--on-dark{background:#fff;color:var(--ink)}
.btn--on-dark:hover{transform:translateY(-2px);box-shadow:0 16px 34px -14px rgba(0,0,0,.6)}
.btn--ghost-dark{box-shadow:inset 0 0 0 1.4px var(--hair-dark);color:var(--on-dark)}
.btn--ghost-dark:hover{box-shadow:inset 0 0 0 1.4px var(--sky);color:#fff;transform:translateY(-2px)}

/* animated underline link */
.ulink{position:relative;color:var(--azure);font-weight:500}
.ulink::after{content:"";position:absolute;left:0;bottom:-2px;height:1.5px;width:100%;
  background:currentColor;transform:scaleX(0);transform-origin:right;transition:transform .35s var(--ease)}
.ulink:hover::after{transform:scaleX(1);transform-origin:left}

:focus-visible{outline:2.5px solid var(--azure);outline-offset:3px;border-radius:3px}

/* =========================================================================
   Scroll progress + Nav
   ========================================================================= */
.progress{position:fixed;top:0;left:0;height:2.5px;width:100%;z-index:120;
  background:linear-gradient(90deg,var(--azure),var(--sky));
  transform:scaleX(0);transform-origin:left;transition:transform .1s linear}

.nav{position:fixed;top:0;left:0;width:100%;z-index:100;
  transform:translateY(-100%);transition:transform .5s var(--ease), background .4s ease, box-shadow .4s ease;}
.nav.show{transform:translateY(0)}
.nav.solid{background:rgba(242,245,249,.82);backdrop-filter:saturate(180%) blur(14px);
  -webkit-backdrop-filter:saturate(180%) blur(14px);box-shadow:0 1px 0 var(--hair), 0 6px 24px -18px rgba(10,26,47,.4)}
.nav__inner{max-width:var(--maxw);margin-inline:auto;padding:.85rem var(--pad);
  display:flex;align-items:center;justify-content:space-between;gap:1rem}
.brand{display:inline-flex;align-items:center;gap:0;font-family:var(--serif);font-weight:760;letter-spacing:-.035em;
  font-weight:600;font-size:1.18rem;color:var(--ink);letter-spacing:-.01em}
.brand .dot{color:var(--azure)}
.brand__mark{display:inline-block;width:22px;height:14px;flex:none;margin-right:.55ch;
  background:var(--azure);-webkit-mask:var(--chev) center/contain no-repeat;mask:var(--chev) center/contain no-repeat}
.nav__links{display:flex;align-items:center;gap:1.9rem}
.nav__links a{font-size:.88rem;font-weight:650;letter-spacing:-.012em;color:var(--slate-deep);position:relative;transition:color .25s}
.nav__links a::after{content:"";position:absolute;left:0;bottom:-5px;height:1.5px;width:100%;background:var(--azure);
  transform:scaleX(0);transform-origin:right;transition:transform .3s var(--ease)}
.nav__links a:hover{color:var(--ink)}
.nav__links a:hover::after{transform:scaleX(1);transform-origin:left}
.nav__right{display:flex;align-items:center;gap:1.1rem}
.nav__cta{font-size:.86rem;padding:.6em 1.2em}
.nav__toggle{display:none}

/* mobile drawer */
.drawer{position:fixed;inset:0;z-index:110;background:rgba(10,26,47,.55);
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  opacity:0;visibility:hidden;transition:opacity .35s ease, visibility .35s}
.drawer.open{opacity:1;visibility:visible}
.drawer__panel{position:absolute;top:0;right:0;height:100%;width:min(86%,360px);
  background:var(--ink);color:var(--on-dark);padding:5.5rem 2rem 2rem;
  transform:translateX(100%);transition:transform .42s var(--ease);
  display:flex;flex-direction:column;gap:.4rem}
.drawer.open .drawer__panel{transform:none}
.drawer__panel a{font-family:var(--serif);font-size:1.5rem;color:var(--on-dark);padding:.55rem 0;
  border-bottom:1px solid var(--hair-dark);transition:color .2s, padding-left .25s}
.drawer__panel a:hover{color:var(--sky);padding-left:.4rem}
.drawer__meta{margin-top:auto;font-family:var(--mono);font-size:.72rem;color:var(--on-dark-mut);line-height:1.9;letter-spacing:.02em}
.drawer__close{position:absolute;top:1.5rem;right:1.6rem;width:42px;height:42px;border-radius:50%;
  box-shadow:inset 0 0 0 1px var(--hair-dark);display:grid;place-items:center;color:var(--on-dark)}
.burger{width:46px;height:46px;border-radius:50%;display:grid;place-items:center;
  box-shadow:inset 0 0 0 1.3px var(--platinum);transition:box-shadow .25s}
.burger:hover{box-shadow:inset 0 0 0 1.3px var(--azure)}
.burger span{display:block;width:18px;height:1.6px;background:var(--ink);position:relative}
.burger span::before,.burger span::after{content:"";position:absolute;left:0;width:18px;height:1.6px;background:var(--ink)}
.burger span::before{top:-5px}.burger span::after{top:5px}

/* =========================================================================
   HERO
   ========================================================================= */
.hero{position:relative;padding-top:clamp(110px,16vh,168px);padding-bottom:clamp(60px,9vw,110px);overflow:hidden}
.hero::before{ /* cool radial wash */
  content:"";position:absolute;inset:0;z-index:0;pointer-events:none;
  background:
    radial-gradient(120% 80% at 88% 6%, rgba(91,164,240,.16), transparent 55%),
    radial-gradient(90% 70% at 0% 100%, rgba(14,118,214,.07), transparent 60%);
}
.hero__grid{position:relative;z-index:1;display:grid;
  grid-template-columns:minmax(0,1.18fr) minmax(0,.92fr);gap:clamp(2rem,5vw,5.5rem);align-items:center}
.hero__eyebrow{margin-bottom:1.5rem}
.hero__name{font-size:clamp(3.3rem, 1.6rem + 8.4vw, 7.2rem);line-height:.92;letter-spacing:-.028em;font-weight:800;
  color:var(--ink)}
.hero__name .sur{display:block;color:var(--azure);
  font-style:normal;font-weight:800}
.hero__role{margin-top:1.4rem;font-family:var(--mono);font-size:.82rem;font-weight:500;letter-spacing:.16em;
  text-transform:uppercase;color:var(--slate);display:flex;flex-wrap:wrap;gap:.55em 1em;align-items:center}
.hero__role .sep{width:5px;height:5px;border-radius:50%;background:var(--azure)}
.hero__intro{margin-top:1.7rem;max-width:34ch;font-size:clamp(1.08rem,1rem+.5vw,1.32rem);
  line-height:1.55;color:var(--slate)}
.hero__cta-row{margin-top:2.3rem;display:flex;flex-wrap:wrap;gap:.85rem}
.hero__facts{margin-top:2.6rem;display:flex;flex-wrap:wrap;gap:.6rem .65rem}
.fact{font-family:var(--mono);font-size:.72rem;letter-spacing:.04em;color:var(--slate-deep);
  background:var(--paper);box-shadow:inset 0 0 0 1px var(--platinum);
  padding:.5em .85em;border-radius:8px;display:inline-flex;align-items:center;gap:.5em}
.fact b{color:var(--azure);font-weight:700}

/* portrait */
.hero__media{position:relative;justify-self:center;width:100%;max-width:430px}
.portrait{position:relative;z-index:2;border-radius:var(--r-lg);overflow:hidden;
  box-shadow:var(--shadow-l);background:var(--ink-2);
  aspect-ratio:4/4.55}
.portrait img{width:100%;height:100%;object-fit:cover;object-position:50% 22%}
.portrait::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 62%, rgba(10,26,47,.18));pointer-events:none}
.portrait__tag{position:absolute;left:0;bottom:0;z-index:3;margin:14px;
  font-family:var(--mono);font-size:.66rem;letter-spacing:.12em;text-transform:uppercase;color:#fff;
  background:rgba(10,26,47,.5);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  padding:.5em .8em;border-radius:7px;display:inline-flex;align-items:center;gap:.55em}
.portrait__tag i{width:6px;height:6px;border-radius:50%;background:var(--sky);box-shadow:0 0 0 3px rgba(91,164,240,.25)}
/* chevron watermark behind portrait */
.hero__chev{position:absolute;z-index:1;right:-7%;top:-9%;width:62%;color:var(--azure);opacity:.14;
  filter:drop-shadow(0 20px 40px rgba(14,118,214,.25))}
.hero__plate{position:absolute;z-index:1;left:-7%;bottom:-7%;width:46%;aspect-ratio:1;border-radius:18px;
  background:linear-gradient(150deg,var(--azure),var(--sky));opacity:.10}
.scrollcue{position:relative;z-index:1;margin-top:clamp(3rem,6vw,4.5rem);
  display:inline-flex;align-items:center;gap:.7em;font-family:var(--mono);font-size:.7rem;
  letter-spacing:.18em;text-transform:uppercase;color:var(--slate-soft)}
.scrollcue .line{width:46px;height:1px;background:var(--platinum);position:relative;overflow:hidden}
.scrollcue .line::after{content:"";position:absolute;inset:0;width:40%;background:var(--azure);
  animation:slide 2.4s var(--ease) infinite}
@keyframes slide{0%{transform:translateX(-120%)}60%,100%{transform:translateX(320%)}}

/* =========================================================================
   STATEMENT (thesis)
   ========================================================================= */
.statement{background:var(--paper);border-block:1px solid var(--hair)}
.statement .wrap{display:grid;grid-template-columns:auto 1fr;gap:clamp(1.5rem,4vw,4rem);align-items:start}
.statement__q{font-family:var(--serif);font-size:clamp(2rem,1.2rem+3.6vw,3.55rem);line-height:1.16;
  letter-spacing:-.052em;color:var(--ink);font-weight:760;max-width:18ch}
.statement__q em{font-style:normal;color:var(--azure);font-weight:750}
.statement__side{font-family:var(--mono);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--slate-soft);writing-mode:vertical-rl;transform:rotate(180deg);white-space:nowrap;padding-top:.4rem}

/* =========================================================================
   PROFILE
   ========================================================================= */
.profile__grid{display:grid;grid-template-columns:minmax(0,.5fr) minmax(0,1fr);gap:clamp(2rem,6vw,5rem)}
.profile__aside{position:sticky;top:120px;align-self:start}
.profile__aside h2{font-size:clamp(2rem,1.3rem+3vw,3.2rem);margin-top:1.1rem;letter-spacing:-.052em;font-weight:760}
.profile__signoff{margin-top:1.8rem;display:flex;align-items:center;gap:.9rem}
.profile__avatar{width:52px;height:52px;border-radius:50%;object-fit:cover;object-position:50% 20%;
  box-shadow:0 0 0 1px var(--platinum)}
.profile__signoff .nm{font-family:var(--serif);font-size:1.05rem;color:var(--ink);font-weight:720;line-height:1.15;letter-spacing:-.03em}
.profile__signoff .rl{font-family:var(--mono);font-size:.68rem;letter-spacing:.08em;text-transform:uppercase;color:var(--slate-soft)}
.prose p{margin-bottom:1.15rem;color:var(--slate-deep);max-width:64ch}
.prose p.dropcap::first-letter{font-family:var(--serif);float:left;font-size:3.5em;line-height:.78;
  font-weight:800;padding:.04em .12em 0 0;color:var(--azure)}
.prose p:last-child{margin-bottom:0}
.prose strong{color:var(--ink);font-weight:600}
.pull{margin:1.7rem 0;padding-left:1.3rem;border-left:2.5px solid var(--azure);
  font-family:var(--serif);font-style:normal;font-size:1.22rem;font-weight:650;line-height:1.38;letter-spacing:-.025em;color:var(--ink);max-width:40ch}

/* =========================================================================
   EXPERTISE
   ========================================================================= */
.exp__head{display:grid;grid-template-columns:1fr auto;gap:1.5rem;align-items:end;margin-bottom:clamp(2.2rem,5vw,3.6rem)}
.exp__head p{max-width:42ch;color:var(--slate);margin-top:1rem}
.exp__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;
  border-top:1px solid var(--hair)}
.exp__item{padding:1.8rem 1.6rem 2rem;border-bottom:1px solid var(--hair);
  border-right:1px solid var(--hair);position:relative;transition:background .3s ease}
.exp__item:nth-child(3n){border-right:none}
.exp__item::before{content:"";position:absolute;left:0;top:-1px;height:2px;width:0;background:var(--azure);transition:width .4s var(--ease)}
.exp__item:hover{background:var(--paper)}
.exp__item:hover::before{width:100%}
.exp__no{font-family:var(--mono);font-size:.72rem;color:var(--azure);letter-spacing:.06em}
.exp__term{font-family:var(--serif);font-size:1.35rem;font-weight:720;letter-spacing:-.035em;color:var(--ink);margin:.7rem 0 .55rem;line-height:1.1}
.exp__desc{font-size:.95rem;color:var(--slate);line-height:1.55}

/* =========================================================================
   SECTORS / BACKGROUND
   ========================================================================= */
.sectors{background:var(--paper);border-block:1px solid var(--hair)}
.sectors__head{max-width:60ch;margin-bottom:clamp(2.2rem,5vw,3.4rem)}
.sectors__head h2{margin-top:1rem}
.sectors__head p{margin-top:1.2rem;color:var(--slate);font-size:1.08rem}
.sect-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.1rem}
.scard{background:var(--porcelain);border:1px solid var(--hair);border-radius:var(--r);
  padding:1.5rem 1.4rem 1.6rem;transition:transform .3s var(--ease), box-shadow .3s var(--ease), border-color .3s}
.scard:hover{transform:translateY(-4px);box-shadow:var(--shadow-m);border-color:transparent}
.scard__ic{width:42px;height:42px;border-radius:11px;display:grid;place-items:center;margin-bottom:1rem;
  background:linear-gradient(150deg,rgba(14,118,214,.12),rgba(91,164,240,.12));color:var(--azure)}
.scard__ic svg{width:21px;height:21px}
.scard h3{font-family:var(--serif);font-size:1.14rem;font-weight:720;letter-spacing:-.03em;color:var(--ink);margin-bottom:.4rem;line-height:1.15}
.scard p{font-size:.9rem;color:var(--slate);line-height:1.5}


/* =========================================================================
   CREDENTIALS & COMMUNITY
   ========================================================================= */
.credentials{background:var(--porcelain)}
.cred__head{display:grid;grid-template-columns:minmax(0,1fr) minmax(280px,.68fr);
  gap:clamp(1.5rem,5vw,4.5rem);align-items:end;margin-bottom:clamp(2.2rem,5vw,3.6rem)}
.cred__head h2{margin-top:1rem;max-width:15ch}
.cred__head p{color:var(--slate);max-width:48ch}
.cred__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
.cred-card{background:#fff;border:1px solid var(--hair);border-radius:var(--r-lg);
  padding:clamp(1.35rem,2.6vw,2rem);box-shadow:var(--shadow-s);position:relative;overflow:hidden}
.cred-card::before{content:"";position:absolute;inset:0 auto auto 0;width:100%;height:3px;
  background:linear-gradient(90deg,var(--azure),var(--sky));opacity:.9}
.cred-card--accent{background:var(--ink);border-color:transparent;color:var(--on-dark)}
.cred-card--accent::before{height:4px}
.cred-card__kicker{display:block;font-family:var(--mono);font-size:.64rem;font-weight:650;
  letter-spacing:.13em;text-transform:uppercase;color:var(--azure);margin-bottom:.9rem}
.cred-card--accent .cred-card__kicker{color:var(--sky)}
.cred-card h3{font-family:var(--serif);font-size:1.42rem;font-weight:740;letter-spacing:-.04em;line-height:1.12;color:var(--ink);margin-bottom:.7rem}
.cred-card--accent h3{color:#fff}
.cred-card > p{font-size:.94rem;color:var(--slate);line-height:1.55;margin-bottom:1rem}
.cred-list{list-style:none;display:grid;gap:.58rem;margin-top:1rem}
.cred-list li{position:relative;padding-left:1.15rem;color:var(--slate-deep);font-size:.91rem;line-height:1.4}
.cred-list li::before{content:"";position:absolute;left:0;top:.6em;width:6px;height:6px;border-radius:50%;background:var(--azure)}
.role-line{padding:1rem 0;border-top:1px solid var(--hair-dark)}
.role-line:first-of-type{border-top:none;padding-top:.35rem}
.role-line strong{display:block;color:#fff;font-size:.96rem;line-height:1.3}
.role-line span{display:block;color:var(--on-dark-mut);font-family:var(--mono);font-size:.68rem;line-height:1.55;margin-top:.25rem}
.languages{margin-top:1rem;background:var(--paper);border:1px solid var(--hair);border-radius:var(--r);
  display:grid;grid-template-columns:1.15fr repeat(3,1fr);overflow:hidden}
.languages__label,.language{padding:1rem 1.2rem}
.languages__label{font-family:var(--mono);font-size:.68rem;font-weight:650;letter-spacing:.15em;
  text-transform:uppercase;color:var(--azure);display:flex;align-items:center}
.language{border-left:1px solid var(--hair)}
.language strong{display:block;color:var(--ink);font-family:var(--serif);font-size:1.05rem;line-height:1.2}
.language span{display:block;color:var(--slate-soft);font-size:.78rem;margin-top:.2rem}

/* =========================================================================
   CASHBOOK (dark)
   ========================================================================= */
.cashbook{position:relative;background:var(--ink);color:var(--on-dark);overflow:hidden}
.cashbook::before{content:"";position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(80% 60% at 85% 0%, rgba(14,118,214,.22), transparent 55%),
    radial-gradient(60% 60% at 0% 100%, rgba(91,164,240,.10), transparent 55%)}
.cashbook__chev{position:absolute;right:-4%;bottom:-12%;width:34%;color:#fff;opacity:.04;z-index:0}
.cashbook .wrap{position:relative;z-index:1}
.cb__grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:clamp(2.5rem,6vw,5rem);align-items:center}
.cb__eyebrow{margin-bottom:1.6rem}
.cb h2{color:#fff;font-size:clamp(2rem,1.3rem+3vw,3.3rem)}
.cb__chip{display:flex;width:fit-content;background:#fff;border-radius:12px;padding:.95rem 1.3rem;margin-bottom:1.9rem;
  box-shadow:0 18px 40px -22px rgba(0,0,0,.7)}
.cb__chip img{height:34px;width:auto}
.cb p{color:var(--on-dark-mut);max-width:52ch;margin-bottom:1.2rem}
.cb p strong{color:#fff;font-weight:600}
.cb__role{display:inline-flex;align-items:center;gap:.6em;font-family:var(--mono);font-size:.72rem;
  letter-spacing:.12em;text-transform:uppercase;color:var(--sky);margin-bottom:1.4rem}
.cb__role i{width:6px;height:6px;border-radius:50%;background:var(--sky)}
.cb__products{display:grid;gap:1rem}
.product{background:rgba(255,255,255,.045);border:1px solid var(--hair-dark);border-radius:var(--r);
  padding:1.4rem 1.5rem;transition:background .3s, border-color .3s, transform .3s var(--ease)}
.product:hover{background:rgba(255,255,255,.07);border-color:rgba(91,164,240,.4);transform:translateY(-3px)}
.product__top{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:.5rem}
.product h3{font-family:var(--serif);color:#fff;font-size:1.3rem;font-weight:730;letter-spacing:-.035em}
.product__badge{font-family:var(--mono);font-size:.64rem;letter-spacing:.1em;text-transform:uppercase;
  color:var(--sky);background:rgba(91,164,240,.12);padding:.4em .7em;border-radius:6px;white-space:nowrap}
.product p{color:var(--on-dark-mut);font-size:.95rem;margin-bottom:0;line-height:1.55}
.cb__cta{margin-top:1.9rem;display:flex;flex-wrap:wrap;gap:.85rem;align-items:center}
.cb__note{font-family:var(--mono);font-size:.68rem;color:var(--on-dark-mut);letter-spacing:.04em}

/* =========================================================================
   CONTACT
   ========================================================================= */
.contact__grid{display:grid;grid-template-columns:minmax(0,.92fr) minmax(0,1.08fr);gap:clamp(2.5rem,6vw,5rem)}
.contact__head h2{margin-top:1rem}
.contact__head p{margin-top:1.2rem;color:var(--slate);max-width:38ch;font-size:1.08rem}
.contact__methods{margin-top:2.2rem;display:flex;flex-direction:column;gap:.2rem}
.cmethod{display:flex;align-items:center;gap:1.1rem;padding:1.05rem .2rem;border-bottom:1px solid var(--hair);
  transition:padding-left .3s var(--ease)}
.cmethod:hover{padding-left:.5rem}
.cmethod__ic{width:44px;height:44px;flex:none;border-radius:12px;display:grid;place-items:center;
  background:var(--cloud);color:var(--azure);transition:background .3s, color .3s}
.cmethod:hover .cmethod__ic{background:var(--azure);color:#fff}
.cmethod__ic svg{width:20px;height:20px}
.cmethod .lbl{display:block;margin-bottom:2px;font-family:var(--mono);font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;color:var(--slate-soft)}
.cmethod .val{display:block;font-size:1.04rem;color:var(--ink);font-weight:500;line-height:1.25}
.cmethod .arr2{margin-left:auto;color:var(--platinum);transition:color .3s, transform .3s var(--ease)}
.cmethod:hover .arr2{color:var(--azure);transform:translateX(3px)}

/* form */
.formcard{background:var(--paper);border:1px solid var(--hair);border-radius:var(--r-lg);
  padding:clamp(1.6rem,3vw,2.4rem);box-shadow:var(--shadow-m)}
.formcard h3{font-family:var(--serif);font-size:1.48rem;font-weight:740;letter-spacing:-.04em;color:var(--ink);margin-bottom:.4rem}
.formcard .sub{font-size:.95rem;color:var(--slate);margin-bottom:1.6rem}
.field{margin-bottom:1.05rem}
.field label{display:block;font-family:var(--mono);font-size:.64rem;letter-spacing:.12em;text-transform:uppercase;
  color:var(--slate-soft);margin-bottom:.5rem}
.field input,.field textarea{width:100%;font-family:var(--sans);font-size:1rem;color:var(--ink);
  background:var(--porcelain);border:1.4px solid var(--platinum);border-radius:var(--r-sm);
  padding:.82em .95em;transition:border-color .25s, background .25s, box-shadow .25s}
.field textarea{resize:vertical;min-height:118px}
.field input::placeholder,.field textarea::placeholder{color:#9aa8ba}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--azure);background:#fff;
  box-shadow:0 0 0 4px rgba(14,118,214,.1)}
.field-2{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.form-foot{display:flex;align-items:center;gap:1rem;margin-top:.4rem;flex-wrap:wrap}
.form-foot .btn{flex:none}
.form-note{font-size:.82rem;color:var(--slate-soft);line-height:1.4}
.hp{position:absolute;left:-9999px;opacity:0}
.form-ok{display:none;text-align:center;padding:1.5rem 0}
.form-ok.show{display:block}
.form-ok .tick{width:60px;height:60px;border-radius:50%;margin:0 auto 1.1rem;display:grid;place-items:center;
  background:rgba(72,209,138,.14);color:#1f9d5f}
.form-ok h3{margin-bottom:.4rem}
.form-ok p{color:var(--slate);font-size:.96rem}

/* =========================================================================
   FOOTER
   ========================================================================= */
.foot{background:var(--ink);color:var(--on-dark);padding-block:clamp(3.2rem,6vw,4.6rem) 2rem}
.foot__top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:2.5rem;padding-bottom:2.8rem;
  border-bottom:1px solid var(--hair-dark)}
.foot__brand .brand{color:#fff;font-size:1.4rem}
.foot__brand p{margin-top:1rem;color:var(--on-dark-mut);max-width:34ch;font-size:.96rem}
.foot__soc{margin-top:1.5rem;display:flex;gap:.6rem}
.foot__soc a{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;color:var(--on-dark);
  box-shadow:inset 0 0 0 1px var(--hair-dark);transition:background .25s, color .25s, transform .25s, box-shadow .25s}
.foot__soc a:hover{background:var(--azure);color:#fff;transform:translateY(-3px);box-shadow:none}
.foot__soc svg{width:18px;height:18px}
.foot__col h4{font-family:var(--mono);font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--on-dark-mut);font-weight:600;margin-bottom:1.1rem}
.foot__col a{display:block;color:var(--on-dark);font-size:.96rem;padding:.32rem 0;transition:color .2s, padding-left .25s}
.foot__col a:hover{color:var(--sky);padding-left:.3rem}
.foot__bottom{display:flex;flex-wrap:wrap;justify-content:space-between;gap:1rem;padding-top:1.8rem;
  font-family:var(--mono);font-size:.72rem;color:var(--on-dark-mut);letter-spacing:.02em;line-height:1.7}
.foot__bottom a{color:var(--on-dark-mut)}
.foot__bottom a:hover{color:var(--sky)}

/* =========================================================================
   Reveal animation
   ========================================================================= */
.rv{opacity:0;transform:translateY(22px);transition:opacity .8s var(--ease), transform .8s var(--ease)}
.rv.in{opacity:1;transform:none}
.rv-d1{transition-delay:.08s}.rv-d2{transition-delay:.16s}.rv-d3{transition-delay:.24s}
.rv-d4{transition-delay:.32s}.rv-d5{transition-delay:.4s}

/* hero load sequence */
.hero .anim{opacity:0;transform:translateY(26px)}
.hero.ready .anim{opacity:1;transform:none;transition:opacity .9s var(--ease), transform .9s var(--ease)}
.hero.ready .a1{transition-delay:.05s}.hero.ready .a2{transition-delay:.16s}
.hero.ready .a3{transition-delay:.27s}.hero.ready .a4{transition-delay:.38s}
.hero.ready .a5{transition-delay:.49s}.hero.ready .a6{transition-delay:.6s}
.hero__media.anim{transform:translateY(26px) scale(.985)}
.hero.ready .hero__media.anim{transform:none}

/* =========================================================================
   Responsive
   ========================================================================= */
@media (max-width:1000px){
  .nav__links{display:none}
  .nav__toggle{display:grid}
  .nav__cta{display:none}
  .hero__grid{grid-template-columns:1fr;gap:2.6rem}
  .hero__media{order:-1;max-width:330px}
  .hero__name{font-size:clamp(3rem,11vw,5.2rem)}
  .profile__grid{grid-template-columns:1fr;gap:2.2rem}
  .profile__aside{position:static}
  .exp__grid{grid-template-columns:repeat(2,1fr)}
  .exp__item:nth-child(3n){border-right:1px solid var(--hair)}
  .exp__item:nth-child(2n){border-right:none}
  .sect-grid{grid-template-columns:repeat(2,1fr)}
  .cred__grid{grid-template-columns:1fr 1fr}
  .cred-card--accent{grid-column:1/-1}
  .languages{grid-template-columns:1fr 1fr}
  .languages__label{grid-column:1/-1;border-bottom:1px solid var(--hair)}
  .language:nth-child(2){border-left:none}
  .language:nth-child(4){border-top:1px solid var(--hair)}
  .cb__grid{grid-template-columns:1fr;gap:2.4rem}
  .contact__grid{grid-template-columns:1fr;gap:2.4rem}
  .foot__top{grid-template-columns:1fr 1fr}
  .foot__brand{grid-column:1/-1}
}
@media (max-width:600px){
  .statement .wrap{grid-template-columns:1fr}
  .statement__side{writing-mode:horizontal-tb;transform:none;padding-top:0;order:-1}
  .exp__grid{grid-template-columns:1fr}
  .exp__item{border-right:none !important}
  .sect-grid{grid-template-columns:1fr}
  .cred__head{grid-template-columns:1fr}
  .cred__grid{grid-template-columns:1fr}
  .cred-card--accent{grid-column:auto}
  .languages{grid-template-columns:1fr}
  .languages__label{grid-column:auto}
  .language{border-left:none;border-top:1px solid var(--hair)}
  .field-2{grid-template-columns:1fr}
  .exp__head{grid-template-columns:1fr}
  .hero__role{font-size:.74rem}
  .foot__top{grid-template-columns:1fr}
  .foot__bottom{flex-direction:column}
}

/* =========================================================================
   Reduced motion
   ========================================================================= */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation:none !important;transition-duration:.01ms !important;scroll-behavior:auto !important}
  .rv,.hero .anim{opacity:1 !important;transform:none !important}
  .scrollcue .line::after{display:none}
}

/* =========================================================================
   Premium visual refresh — 2026
   A high-fidelity executive interface with richer depth, stronger hierarchy,
   modern glass surfaces and carefully tuned responsive behaviour.
   ========================================================================= */
:root{
  --ink:#071426;
  --ink-2:#0B1E34;
  --ink-3:#12314E;
  --azure:#0877E8;
  --azure-bright:#2396FF;
  --sky:#7FC0FF;
  --porcelain:#F3F6FA;
  --paper:#FFFFFF;
  --cloud:#EAF3FC;
  --slate:#53657C;
  --slate-deep:#2E4058;
  --slate-soft:#73849A;
  --platinum:#D9E3EE;
  --platinum-2:#EAF0F6;
  --hair:rgba(18,49,78,.11);
  --hair-dark:rgba(255,255,255,.13);
  --maxw:1240px;
  --r:20px;
  --r-sm:13px;
  --r-lg:30px;
  --shadow-s:0 1px 2px rgba(7,20,38,.04),0 10px 30px -24px rgba(7,20,38,.22);
  --shadow-m:0 24px 70px -38px rgba(7,20,38,.38),0 8px 24px -18px rgba(7,20,38,.22);
  --shadow-l:0 50px 120px -52px rgba(0,0,0,.65),0 22px 58px -36px rgba(8,119,232,.55);
}

html{scroll-padding-top:110px}
body{
  background:
    radial-gradient(1000px 500px at 5% 18%,rgba(35,150,255,.055),transparent 60%),
    radial-gradient(800px 520px at 94% 47%,rgba(8,119,232,.045),transparent 65%),
    var(--porcelain);
}
body::before{
  content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;opacity:.22;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180' viewBox='0 0 180 180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.055'/%3E%3C/svg%3E");
}
.skip-link{position:fixed;left:1rem;top:1rem;z-index:999;padding:.7rem 1rem;border-radius:999px;background:#fff;color:var(--ink);font-weight:700;transform:translateY(-180%);transition:transform .2s;box-shadow:var(--shadow-m)}
.skip-link:focus{transform:none}
.wrap{width:100%}
.section{position:relative}
.h2{font-size:clamp(2.2rem,1.25rem + 3.8vw,4.15rem);letter-spacing:-.035em}
.eyebrow{letter-spacing:.2em;font-size:.67rem}

/* Premium floating navigation */
.nav{top:14px;transform:none!important;padding-inline:clamp(12px,2vw,24px);pointer-events:none}
.nav__inner{
  pointer-events:auto;max-width:1220px;padding:.68rem .72rem .68rem 1.05rem;border-radius:20px;
  background:rgba(255,255,255,.74);border:1px solid rgba(255,255,255,.72);
  backdrop-filter:blur(22px) saturate(175%);-webkit-backdrop-filter:blur(22px) saturate(175%);
  box-shadow:0 16px 50px -30px rgba(7,20,38,.55),inset 0 1px 0 rgba(255,255,255,.72);
  transition:background .35s,border-color .35s,box-shadow .35s,transform .35s var(--ease)
}
.nav.solid{background:transparent;box-shadow:none;backdrop-filter:none;-webkit-backdrop-filter:none}
.nav.solid .nav__inner{background:rgba(255,255,255,.9);border-color:rgba(217,227,238,.9);box-shadow:0 18px 55px -32px rgba(7,20,38,.55)}
.nav__inner:hover{transform:translateY(-1px)}
.brand{font-size:1.22rem;white-space:nowrap}
.brand__mark{width:24px;height:15px}
.nav__links{gap:clamp(1rem,2vw,1.8rem)}
.nav__links a{font-size:.86rem;font-weight:600;color:#40536a}
.nav__links a.active{color:var(--azure)}
.nav__links a.active::after{transform:scaleX(1);transform-origin:left}
.nav__cta{padding:.72em 1.3em;box-shadow:0 10px 25px -12px rgba(8,119,232,.7)}

/* Elevated button system */
.btn{min-height:47px;padding:.8em 1.45em;position:relative;overflow:hidden;border:1px solid transparent}
.btn::before{content:"";position:absolute;inset:-2px;transform:translateX(-120%) skewX(-20deg);width:45%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.34),transparent);transition:transform .65s var(--ease);pointer-events:none}
.btn:hover::before{transform:translateX(330%) skewX(-20deg)}
.btn--primary{background:linear-gradient(135deg,#0877E8,#2396FF);border-color:rgba(255,255,255,.15);box-shadow:0 14px 32px -14px rgba(8,119,232,.75),inset 0 1px 0 rgba(255,255,255,.22)}
.btn--ghost{background:rgba(255,255,255,.07);color:#fff;box-shadow:inset 0 0 0 1px rgba(255,255,255,.19);backdrop-filter:blur(12px)}
.btn--ghost:hover{color:#fff;box-shadow:inset 0 0 0 1px rgba(127,192,255,.7);background:rgba(255,255,255,.1)}

/* Hero: immersive executive canvas */
.hero{
  min-height:min(900px,100svh);display:flex;align-items:center;padding-top:clamp(125px,16vh,172px);padding-bottom:clamp(76px,10vw,120px);
  color:var(--on-dark);background:linear-gradient(132deg,#061220 0%,#0A1C31 46%,#0C2743 100%);isolation:isolate
}
.hero::before{
  background:
    radial-gradient(60% 85% at 82% 14%,rgba(35,150,255,.25),transparent 62%),
    radial-gradient(52% 80% at -4% 98%,rgba(8,119,232,.21),transparent 66%),
    linear-gradient(110deg,rgba(255,255,255,.025),transparent 45%);
}
.hero::after{content:"";position:absolute;inset:auto 0 0;height:160px;background:linear-gradient(to bottom,transparent,rgba(3,10,20,.16));pointer-events:none}
.hero__ambient{position:absolute;inset:0;z-index:0;overflow:hidden;pointer-events:none}
.hero__ambient span{position:absolute;border-radius:50%;filter:blur(2px);opacity:.8;animation:ambientFloat 15s ease-in-out infinite alternate}
.hero__ambient span:nth-child(1){width:280px;height:280px;right:10%;top:11%;background:radial-gradient(circle,rgba(55,164,255,.16),transparent 69%)}
.hero__ambient span:nth-child(2){width:440px;height:440px;left:-15%;bottom:-35%;background:radial-gradient(circle,rgba(8,119,232,.16),transparent 70%);animation-delay:-4s}
.hero__ambient span:nth-child(3){width:180px;height:180px;left:44%;top:4%;background:radial-gradient(circle,rgba(127,192,255,.08),transparent 70%);animation-delay:-8s}
@keyframes ambientFloat{to{transform:translate3d(22px,-18px,0) scale(1.08)}}
.hero__gridlines{position:absolute;inset:0;z-index:0;pointer-events:none;opacity:.2;background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);background-size:72px 72px;mask-image:linear-gradient(to bottom,black,transparent 88%)}
.hero__grid{grid-template-columns:minmax(0,1.12fr) minmax(390px,.88fr);gap:clamp(3rem,6vw,7rem)}
.hero__lead{position:relative;z-index:3}
.hero__eyebrow{color:var(--sky);margin-bottom:1.8rem}
.hero__eyebrow::before{background:var(--sky)}
.hero__name{font-size:clamp(4.2rem,2.2rem + 8.5vw,8.5rem);line-height:.83;letter-spacing:-.06em;color:#fff;text-shadow:0 8px 35px rgba(0,0,0,.18)}
.hero__name .sur{display:block;background:linear-gradient(100deg,#fff 5%,#87C9FF 55%,#2B9CFF 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;font-style:normal;padding-right:.08em}
.hero__role{margin-top:1.7rem;color:#B5C5D7;font-size:.76rem;letter-spacing:.13em}
.hero__role .sep{background:#3B9EF8;box-shadow:0 0 0 4px rgba(59,158,248,.11)}
.hero__intro{color:#B9C9D9;max-width:38ch;font-size:clamp(1.12rem,1.02rem + .55vw,1.38rem);line-height:1.55}
.hero__cta-row{margin-top:2.35rem}
.hero__facts{margin-top:2.8rem;gap:.7rem}
.fact{background:rgba(255,255,255,.055);color:#CAD7E5;box-shadow:inset 0 0 0 1px rgba(255,255,255,.12);border-radius:999px;padding:.64em 1em;backdrop-filter:blur(12px)}
.fact b{color:#8AC9FF}
.hero__media{max-width:475px;perspective:1200px;filter:drop-shadow(0 40px 60px rgba(0,0,0,.28))}
.portrait{border-radius:34px;aspect-ratio:4/4.55;border:1px solid rgba(255,255,255,.16);box-shadow:0 50px 120px -52px rgba(0,0,0,.85),0 0 0 10px rgba(255,255,255,.025),0 0 90px rgba(35,150,255,.16);transition:transform .25s ease-out,box-shadow .3s;transform-style:preserve-3d}
.portrait:hover{box-shadow:0 62px 130px -52px rgba(0,0,0,.9),0 0 0 10px rgba(255,255,255,.035),0 0 110px rgba(35,150,255,.22)}
.portrait img{filter:saturate(.94) contrast(1.035)}
.portrait::before{content:"";position:absolute;inset:0;z-index:2;background:linear-gradient(115deg,rgba(255,255,255,.12),transparent 22%,transparent 72%,rgba(8,119,232,.14));pointer-events:none}
.portrait__tag{margin:18px;padding:.62em .95em;border:1px solid rgba(255,255,255,.12);background:rgba(5,16,29,.58);border-radius:999px}
.hero__chev{right:-13%;top:-10%;width:68%;opacity:.2;filter:drop-shadow(0 28px 60px rgba(8,119,232,.4))}
.hero__plate{left:-11%;bottom:-8%;width:58%;border-radius:32px;opacity:.14;filter:blur(.2px)}
.hero__float{position:absolute;z-index:5;display:flex;align-items:center;gap:.75rem;border:1px solid rgba(255,255,255,.15);background:rgba(8,25,43,.66);backdrop-filter:blur(18px) saturate(140%);-webkit-backdrop-filter:blur(18px) saturate(140%);box-shadow:0 20px 55px -28px rgba(0,0,0,.8),inset 0 1px 0 rgba(255,255,255,.08);color:#fff}
.hero__float--top{top:9%;left:-15%;padding:.85rem 1rem;border-radius:16px;display:block;min-width:190px}
.hero__float--top strong{display:block;font-size:.9rem;line-height:1.2}
.hero__float-kicker{display:block;font-family:var(--mono);font-size:.58rem;letter-spacing:.14em;text-transform:uppercase;color:var(--sky);margin-bottom:.25rem}
.hero__float--bottom{right:-9%;bottom:12%;padding:.78rem 1rem;border-radius:999px;font-family:var(--mono);font-size:.62rem;letter-spacing:.06em;text-transform:uppercase;color:#C9D8E6;white-space:nowrap}
.hero__pulse{width:8px;height:8px;border-radius:50%;background:#57D69C;box-shadow:0 0 0 0 rgba(87,214,156,.55);animation:pulseModern 2.2s infinite}
@keyframes pulseModern{70%{box-shadow:0 0 0 9px rgba(87,214,156,0)}}
.scrollcue{color:#91A6BB;margin-top:clamp(3rem,6vw,5rem)}
.scrollcue .line{background:rgba(255,255,255,.16)}

/* Statement card */
.statement{padding-block:clamp(68px,8vw,110px);border:0;background:transparent}
.statement .wrap{position:relative;padding-block:clamp(2.4rem,5vw,4.4rem);padding-right:clamp(2rem,6vw,6rem);border:1px solid rgba(255,255,255,.8);border-radius:36px;background:linear-gradient(135deg,rgba(255,255,255,.93),rgba(244,248,252,.84));box-shadow:0 35px 100px -60px rgba(7,20,38,.45),inset 0 1px 0 #fff;overflow:hidden}
.statement .wrap::after{content:"";position:absolute;width:260px;height:260px;right:-80px;top:-110px;border-radius:50%;background:radial-gradient(circle,rgba(35,150,255,.15),transparent 66%)}
.statement__q{font-size:clamp(2.15rem,1.25rem + 3.5vw,4rem);max-width:20ch;letter-spacing:-.035em;position:relative;z-index:1}
.statement__side{position:relative;z-index:1}

/* Profile: editorial with premium sticky panel */
.profile{padding-top:clamp(60px,8vw,110px)}
.profile__grid{grid-template-columns:minmax(290px,.46fr) minmax(0,1fr);gap:clamp(3rem,7vw,7rem)}
.profile__aside{top:118px;padding:2rem;border-radius:26px;background:linear-gradient(145deg,#fff,rgba(245,249,253,.9));border:1px solid rgba(255,255,255,.85);box-shadow:var(--shadow-m)}
.profile__aside::after{content:"";display:block;width:78px;height:5px;border-radius:99px;margin-top:2rem;background:linear-gradient(90deg,var(--azure),var(--sky))}
.profile__avatar{width:60px;height:60px;box-shadow:0 0 0 5px #fff,0 14px 30px -18px rgba(7,20,38,.45)}
.profile__body{padding-top:.35rem}
.prose p{font-size:1.045rem;line-height:1.78;margin-bottom:1.35rem}
.prose p.dropcap::first-letter{font-size:4.2em;line-height:.72;padding-right:.1em;background:linear-gradient(150deg,var(--azure),var(--sky));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.pull{margin:2rem 0;padding:1.5rem 1.7rem;border:0;border-radius:20px;background:linear-gradient(135deg,rgba(8,119,232,.08),rgba(127,192,255,.06));box-shadow:inset 3px 0 0 var(--azure);font-size:1.45rem;max-width:46ch}

/* Bento expertise cards with cursor spotlight */
.expertise{background:linear-gradient(180deg,transparent,rgba(255,255,255,.65),transparent)}
.exp__grid{gap:1rem;border:0}
.exp__item{min-height:220px;padding:2rem;border:1px solid var(--hair);border-radius:24px;background:rgba(255,255,255,.78);box-shadow:var(--shadow-s);overflow:hidden;isolation:isolate;transition:transform .35s var(--ease),box-shadow .35s,border-color .35s}
.exp__item:nth-child(1),.exp__item:nth-child(6){background:linear-gradient(145deg,#fff,rgba(230,243,255,.8))}
.exp__item:nth-child(3){background:linear-gradient(145deg,var(--ink-2),#113453);border-color:rgba(255,255,255,.08)}
.exp__item:nth-child(3) .exp__term{color:#fff}.exp__item:nth-child(3) .exp__desc{color:#AFC2D5}.exp__item:nth-child(3) .brand__mark{background:var(--sky)!important}
.exp__item::before{inset:auto 0 0;height:4px;width:100%;transform:scaleX(0);transform-origin:left;background:linear-gradient(90deg,var(--azure),var(--sky));transition:transform .45s var(--ease)}
.exp__item::after,.scard::after,.cred-card::after,.product::after,.formcard::after{content:"";position:absolute;inset:0;z-index:-1;pointer-events:none;opacity:0;background:radial-gradient(320px circle at var(--mx,50%) var(--my,50%),rgba(35,150,255,.12),transparent 60%);transition:opacity .3s}
.exp__item:hover{transform:translateY(-7px);box-shadow:0 28px 70px -38px rgba(7,20,38,.42);border-color:rgba(8,119,232,.22)}
.exp__item:hover::before{transform:scaleX(1)}
.exp__item:hover::after,.scard:hover::after,.cred-card:hover::after,.product:hover::after,.formcard:hover::after{opacity:1}
.exp__term{font-size:1.55rem;margin-top:1.2rem}
.exp__desc{font-size:.98rem}

/* Sector cards */
.sectors{background:linear-gradient(180deg,#F7FAFD,#EEF4F9);border-block:1px solid rgba(18,49,78,.08)}
.sect-grid{gap:1rem}
.scard{position:relative;isolation:isolate;overflow:hidden;min-height:230px;padding:1.7rem;border-radius:24px;background:rgba(255,255,255,.82);box-shadow:var(--shadow-s)}
.scard:hover{transform:translateY(-8px);box-shadow:0 30px 70px -40px rgba(7,20,38,.45);border-color:rgba(8,119,232,.18)}
.scard__ic{width:48px;height:48px;border-radius:15px;background:linear-gradient(145deg,rgba(8,119,232,.14),rgba(127,192,255,.08));box-shadow:inset 0 0 0 1px rgba(8,119,232,.08)}
.scard h3{font-size:1.28rem;margin-top:1.45rem}

/* Credentials cards */
.credentials{background:transparent}
.cred__grid{gap:1.15rem}
.cred-card{isolation:isolate;min-height:100%;padding:2.15rem;border-radius:27px;box-shadow:var(--shadow-m);transition:transform .35s var(--ease),box-shadow .35s,border-color .35s}
.cred-card:hover{transform:translateY(-7px);box-shadow:0 34px 80px -40px rgba(7,20,38,.48);border-color:rgba(8,119,232,.18)}
.cred-card::before{height:5px;background:linear-gradient(90deg,var(--azure),#62B5FF)}
.cred-card--accent{background:linear-gradient(145deg,#071426,#123452)}
.cred-card--accent::after{background:radial-gradient(360px circle at var(--mx,50%) var(--my,50%),rgba(127,192,255,.14),transparent 58%)}
.cred-card h3{font-size:1.62rem}
.cred-list{gap:.75rem}
.cred-list li::before{box-shadow:0 0 0 4px rgba(8,119,232,.1)}

/* Cashbook section: cinematic dark panel */
.cashbook{margin-inline:clamp(10px,2vw,24px);border-radius:clamp(26px,4vw,48px);background:linear-gradient(135deg,#061220 0%,#0A213A 52%,#0C3155 100%);box-shadow:0 55px 120px -65px rgba(7,20,38,.8)}
.cashbook::before{background:radial-gradient(70% 90% at 95% 5%,rgba(35,150,255,.28),transparent 60%),radial-gradient(70% 80% at 0% 100%,rgba(8,119,232,.16),transparent 62%),linear-gradient(90deg,rgba(255,255,255,.02),transparent)}
.cashbook::after{content:"";position:absolute;inset:0;pointer-events:none;opacity:.24;background-image:linear-gradient(rgba(255,255,255,.045) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.045) 1px,transparent 1px);background-size:64px 64px;mask-image:linear-gradient(90deg,transparent,black)}
.cb__chip{padding:1rem 1.45rem;border-radius:16px;box-shadow:0 22px 48px -24px rgba(0,0,0,.82)}
.product{position:relative;isolation:isolate;overflow:hidden;padding:1.7rem;border-radius:22px;background:rgba(255,255,255,.055);box-shadow:inset 0 1px 0 rgba(255,255,255,.04)}
.product:hover{transform:translateY(-6px);background:rgba(255,255,255,.085);border-color:rgba(127,192,255,.42)}
.product h3{font-size:1.48rem}
.product__badge{border:1px solid rgba(127,192,255,.16);background:rgba(127,192,255,.1);border-radius:999px;padding:.5em .75em}

/* Contact: refined conversion panel */
.contact{padding-bottom:clamp(84px,11vw,150px)}
.contact__grid{align-items:stretch}
.contact__head,.formcard{height:100%}
.contact__methods{border-radius:24px;overflow:hidden;border:1px solid var(--hair);background:rgba(255,255,255,.72);box-shadow:var(--shadow-s);padding:.3rem 1.2rem}
.cmethod{padding:1.18rem .2rem}
.cmethod__ic{width:48px;height:48px;border-radius:15px;background:linear-gradient(145deg,#EAF4FE,#F8FBFF);box-shadow:inset 0 0 0 1px rgba(8,119,232,.08)}
.formcard{position:relative;isolation:isolate;overflow:hidden;border-radius:30px;padding:clamp(1.8rem,3.8vw,2.8rem);background:linear-gradient(145deg,rgba(255,255,255,.98),rgba(245,249,253,.94));border:1px solid rgba(255,255,255,.9);box-shadow:0 40px 100px -55px rgba(7,20,38,.52),inset 0 1px 0 #fff;transition:transform .35s var(--ease),box-shadow .35s}
.formcard:hover{transform:translateY(-3px);box-shadow:0 48px 110px -55px rgba(7,20,38,.58),inset 0 1px 0 #fff}
.field input,.field textarea{border-radius:15px;padding:.94em 1em;background:rgba(255,255,255,.7);border-color:#D7E2ED}
.field input:hover,.field textarea:hover{border-color:#B8CDE1}
.field textarea{min-height:138px}

/* Footer */
.foot{position:relative;background:linear-gradient(135deg,#061220,#0A2037);overflow:hidden}
.foot::before{content:"";position:absolute;width:620px;height:620px;right:-250px;top:-350px;border-radius:50%;background:radial-gradient(circle,rgba(35,150,255,.14),transparent 68%);pointer-events:none}
.foot .wrap{position:relative;z-index:1}
.foot__soc a{background:rgba(255,255,255,.035);box-shadow:inset 0 0 0 1px rgba(255,255,255,.13)}
.foot__col a{width:fit-content}

/* Modern drawer */
.drawer{background:rgba(3,10,20,.62);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px)}
.drawer__panel{width:min(92%,420px);padding:6.5rem 2.2rem 2.2rem;background:linear-gradient(155deg,#071426,#0B2A49);box-shadow:-35px 0 90px -45px rgba(0,0,0,.75)}
.drawer__panel::before{content:"";position:absolute;inset:0;pointer-events:none;background:radial-gradient(350px 350px at 100% 0%,rgba(35,150,255,.2),transparent 65%)}
.drawer__panel a{position:relative;z-index:1;font-size:clamp(1.55rem,5vw,2rem);padding:.72rem 0;border-color:rgba(255,255,255,.1)}
.drawer__meta{position:relative;z-index:1;padding:1rem 1.1rem;border-radius:16px;border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.035)}
.drawer__close{z-index:2;background:rgba(255,255,255,.04)}

/* Smooth modern scrollbar */
@media (min-width:800px){
  *{scrollbar-width:thin;scrollbar-color:#9AB8D4 transparent}
  ::-webkit-scrollbar{width:10px}
  ::-webkit-scrollbar-track{background:transparent}
  ::-webkit-scrollbar-thumb{background:#A8BED3;border:3px solid transparent;background-clip:padding-box;border-radius:99px}
}

/* Responsive refinements */
@media (max-width:1120px){
  .hero__grid{grid-template-columns:minmax(0,1.05fr) minmax(340px,.95fr);gap:3rem}
  .hero__float--top{left:-8%}.hero__float--bottom{right:-4%}
  .nav__links{gap:1rem}
}
@media (max-width:1000px){
  .nav{top:10px;padding-inline:10px}
  .nav__inner{border-radius:18px;padding:.62rem .7rem .62rem .9rem}
  .hero{min-height:auto;padding-top:125px}
  .hero__grid{grid-template-columns:1fr;gap:3rem}
  .hero__media{order:0;max-width:390px;margin-top:1rem}
  .hero__lead{text-align:center}
  .hero__eyebrow{justify-content:center}
  .hero__role,.hero__cta-row,.hero__facts{justify-content:center}
  .hero__intro{margin-inline:auto}
  .hero__name{font-size:clamp(4.3rem,17vw,7.5rem)}
  .hero__float--top{left:-14%;top:12%}
  .hero__float--bottom{right:-10%}
  .scrollcue{display:none}
  .profile__aside{position:static}
  .cashbook{margin-inline:10px}
}
@media (max-width:720px){
  :root{--pad:20px;--sect:clamp(68px,18vw,96px)}
  .nav__inner{min-height:60px}
  .brand{font-size:1.08rem}
  .burger{width:43px;height:43px}
  .hero{padding-top:118px;padding-bottom:80px}
  .hero__gridlines{background-size:48px 48px}
  .hero__name{font-size:clamp(4rem,22vw,6.2rem)}
  .hero__role{gap:.5em .75em;justify-content:center;line-height:1.6}
  .hero__role .sep:nth-of-type(2){display:none}
  .hero__intro{font-size:1.08rem}
  .hero__cta-row{display:grid;grid-template-columns:1fr;width:100%;max-width:360px;margin-inline:auto;margin-top:2rem}
  .hero__cta-row .btn{justify-content:center}
  .hero__facts{gap:.55rem}
  .fact{font-size:.64rem}
  .hero__media{max-width:min(86vw,360px)}
  .hero__float--top{left:-7%;top:7%;min-width:165px;padding:.7rem .8rem}
  .hero__float--bottom{right:-6%;bottom:9%;font-size:.55rem;padding:.66rem .78rem}
  .statement{padding-block:50px}
  .statement .wrap{border-radius:26px;padding:2rem 1.5rem;display:block}
  .statement__side{writing-mode:horizontal-tb;transform:none;display:block;margin-bottom:1.2rem}
  .statement__q{font-size:clamp(2rem,9vw,3rem)}
  .profile__grid{gap:2rem}
  .profile__aside{padding:1.5rem;border-radius:22px}
  .exp__grid{gap:.8rem}
  .exp__item{min-height:0;padding:1.55rem;border-radius:20px}
  .sect-grid{gap:.8rem}
  .scard{min-height:0;padding:1.5rem;border-radius:20px}
  .cred-card{padding:1.6rem;border-radius:22px}
  .cashbook{border-radius:28px}
  .product{padding:1.4rem;border-radius:18px}
  .product__top{align-items:flex-start}
  .product__badge{font-size:.56rem}
  .contact__methods{padding:.2rem .9rem;border-radius:20px}
  .cmethod{gap:.8rem}
  .cmethod__ic{width:44px;height:44px}
  .cmethod .val{font-size:.92rem;overflow-wrap:anywhere}
  .formcard{border-radius:24px;padding:1.5rem}
}
@media (max-width:430px){
  .hero__float--top{left:-2%;top:4%;transform:scale(.9);transform-origin:left top}
  .hero__float--bottom{right:-2%;bottom:5%;transform:scale(.9);transform-origin:right bottom}
  .hero__facts{display:grid;grid-template-columns:1fr 1fr;width:100%;max-width:340px;margin-inline:auto;margin-top:2rem}
  .fact{justify-content:center;text-align:center}
  .fact:last-child{grid-column:1/-1}
  .hero__media{max-width:330px}
  .portrait{border-radius:28px}
  .foot__top{gap:2rem}
}
@media (hover:none){
  .exp__item:hover,.scard:hover,.cred-card:hover,.product:hover,.formcard:hover,.portrait:hover{transform:none}
  .btn:hover::before{display:none}
}
@media (prefers-reduced-motion:reduce){
  .hero__ambient span,.hero__pulse{animation:none!important}
  .portrait{transform:none!important}
}

/* Desktop uses the full navigation; the menu trigger is reserved for tablets and phones. */
@media (min-width:1001px){.nav__toggle{display:none!important}}

/* Final responsive safeguards */
html,body{max-width:100%;overflow-x:hidden}
@supports (overflow:clip){html,body{overflow-x:clip}}
.drawer{overflow:hidden}
@media (max-width:1000px){.profile__grid{grid-template-columns:1fr}}

/* =========================================================================
   DESIGN REFINEMENT V3 — cinematic navigation, section rhythm and bento UX
   ========================================================================= */

/* Dark glass navigation over the hero, light glass after scrolling */
.nav:not(.solid) .nav__inner{
  background:rgba(4,15,28,.58);
  border-color:rgba(255,255,255,.13);
  box-shadow:0 20px 60px -34px rgba(0,0,0,.9),inset 0 1px 0 rgba(255,255,255,.08);
}
.nav:not(.solid) .brand,
.nav:not(.solid) .nav__links a{color:rgba(238,246,255,.82)}
.nav:not(.solid) .brand:hover,
.nav:not(.solid) .nav__links a:hover,
.nav:not(.solid) .nav__links a.active{color:#fff}
.nav:not(.solid) .nav__links a::after{background:var(--sky)}
.nav:not(.solid) .brand__mark{background:#59B4FF;filter:drop-shadow(0 0 10px rgba(69,170,255,.45))}
.nav:not(.solid) .burger{box-shadow:inset 0 0 0 1.2px rgba(255,255,255,.2)}
.nav:not(.solid) .burger span,
.nav:not(.solid) .burger span::before,
.nav:not(.solid) .burger span::after{background:#fff}
.nav.solid .brand__mark{filter:none}

/* A precise top highlight makes the glass bar feel machined rather than generic */
.nav__inner::before{
  content:"";position:absolute;left:8%;right:8%;top:-1px;height:1px;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.82),transparent);
  opacity:.55;pointer-events:none
}
.nav__inner{position:relative}

/* Capability ticker creates a confident transition out of the hero */
.capability-strip{
  position:relative;z-index:4;overflow:hidden;background:#071729;color:#B9CBE0;
  border-top:1px solid rgba(255,255,255,.08);border-bottom:1px solid rgba(255,255,255,.08)
}
.capability-strip::before,.capability-strip::after{
  content:"";position:absolute;z-index:2;top:0;bottom:0;width:min(12vw,150px);pointer-events:none
}
.capability-strip::before{left:0;background:linear-gradient(90deg,#071729,transparent)}
.capability-strip::after{right:0;background:linear-gradient(-90deg,#071729,transparent)}
.capability-track{display:flex;width:max-content;animation:capabilityMove 32s linear infinite}
.capability-group{display:flex;align-items:center;gap:1.4rem;padding:1rem .7rem;white-space:nowrap}
.capability-group span{
  font-family:var(--mono);font-size:.66rem;font-weight:650;letter-spacing:.17em;text-transform:uppercase
}
.capability-group i{width:5px;height:5px;border-radius:50%;background:#3EA8FF;box-shadow:0 0 0 5px rgba(62,168,255,.08)}
@keyframes capabilityMove{to{transform:translateX(-50%)}}
.capability-strip:hover .capability-track{animation-play-state:paused}

/* Editorial section indices add structure without inventing content */
.section[data-index]::before{
  content:attr(data-index);position:absolute;right:max(var(--pad),calc((100vw - var(--maxw))/2 + var(--pad)));
  top:clamp(38px,6vw,82px);z-index:0;font-family:var(--serif);font-style:normal;font-weight:800;font-size:clamp(5rem,11vw,10rem);
  line-height:.8;letter-spacing:-.06em;color:rgba(8,119,232,.045);pointer-events:none;user-select:none
}
.section[data-index]>.wrap{position:relative;z-index:1}
.cashbook[data-index]::before{color:rgba(255,255,255,.045);top:clamp(34px,5vw,64px)}
.contact[data-index]::before{color:rgba(8,119,232,.04)}

/* Desktop section dock — subtle until used */
.section-dock{
  position:fixed;z-index:85;right:18px;top:50%;transform:translateY(-50%);
  display:flex;flex-direction:column;align-items:flex-end;gap:.7rem;padding:.85rem .65rem;
  border:1px solid rgba(255,255,255,.12);border-radius:999px;background:rgba(5,18,32,.54);
  backdrop-filter:blur(18px) saturate(145%);-webkit-backdrop-filter:blur(18px) saturate(145%);
  box-shadow:0 24px 60px -36px rgba(0,0,0,.8);transition:background .3s,border-color .3s
}
.section-dock a{position:relative;display:flex;align-items:center;justify-content:flex-end;width:10px;height:10px}
.section-dock a::after{content:"";width:5px;height:5px;border-radius:50%;background:rgba(255,255,255,.42);transition:.3s var(--ease)}
.section-dock a span{
  position:absolute;right:18px;padding:.38rem .6rem;border-radius:8px;background:#071729;color:#DCE9F6;
  font-family:var(--mono);font-size:.56rem;letter-spacing:.1em;text-transform:uppercase;white-space:nowrap;
  opacity:0;transform:translateX(8px);pointer-events:none;transition:.25s var(--ease);box-shadow:0 12px 28px -16px rgba(0,0,0,.8)
}
.section-dock a:hover span,.section-dock a:focus-visible span{opacity:1;transform:none}
.section-dock a:hover::after{background:#fff;transform:scale(1.35)}
.section-dock a.active::after{height:22px;border-radius:999px;background:linear-gradient(#64C1FF,#168BEE);box-shadow:0 0 18px rgba(41,158,255,.45)}

/* Hero gets a quiet personal monogram and cleaner optical depth */
.hero__media::before{
  content:"BL";position:absolute;z-index:0;right:-18%;bottom:-4%;font-family:var(--serif);font-style:normal;font-weight:800;
  font-size:clamp(8rem,15vw,13rem);line-height:.8;letter-spacing:-.12em;color:rgba(255,255,255,.028);
  pointer-events:none;user-select:none
}
.hero__media::after{
  content:"";position:absolute;z-index:0;inset:10% -13% -10% 13%;border-radius:42px;
  border:1px solid rgba(83,176,255,.14);transform:rotate(3deg);pointer-events:none
}
.portrait{z-index:2}
.hero__plate{z-index:1}
.hero__float{z-index:4}
.hero__name{position:relative}
.hero__name::after{
  content:"";position:absolute;left:.02em;bottom:-.12em;width:clamp(70px,9vw,125px);height:4px;border-radius:999px;
  background:linear-gradient(90deg,#168BEE,#8BD1FF,transparent);opacity:.85
}

/* Statement becomes a sharper editorial interlude */
.statement .wrap::before{
  content:"“";position:absolute;left:clamp(1.4rem,4vw,3.6rem);top:-.12em;font-family:var(--serif);font-size:clamp(8rem,18vw,14rem);
  line-height:1;color:rgba(8,119,232,.055);pointer-events:none
}
.statement__q{padding-left:clamp(0px,3vw,2.4rem)}
.statement .wrap{transition:transform .45s var(--ease),box-shadow .45s var(--ease)}
.statement .wrap:hover{transform:translateY(-4px);box-shadow:0 45px 110px -60px rgba(7,20,38,.52),inset 0 1px 0 #fff}

/* Expertise becomes a real bento composition */
.exp__grid{
  grid-template-columns:repeat(12,minmax(0,1fr));gap:1rem;border-top:0;counter-reset:expertise
}
.exp__item{grid-column:span 4;border:1px solid var(--hair)!important}
.exp__item:nth-child(1),.exp__item:nth-child(6){grid-column:span 6;min-height:245px}
.exp__item:nth-child(2),.exp__item:nth-child(3),.exp__item:nth-child(4),.exp__item:nth-child(5){min-height:225px}
.exp__index{
  position:absolute;right:1.35rem;top:1.25rem;font-family:var(--mono);font-size:.62rem;letter-spacing:.12em;
  color:rgba(52,79,105,.42);transition:color .3s
}
.exp__item:nth-child(3) .exp__index{color:rgba(255,255,255,.36)}
.exp__item:hover .exp__index{color:var(--azure)}
.exp__item:nth-child(3):hover .exp__index{color:var(--sky)}
.exp__item .brand__mark{transition:transform .35s var(--ease),filter .35s}
.exp__item:hover .brand__mark{transform:translateX(4px);filter:drop-shadow(0 5px 8px rgba(8,119,232,.24))}

/* More deliberate visual rhythm in sector and credential collections */
.scard:nth-child(even){transform:translateY(18px)}
.scard:nth-child(even):hover{transform:translateY(10px)}
.sect-grid{padding-bottom:18px}
.cred-card:nth-child(2){transform:translateY(18px)}
.cred-card:nth-child(2):hover{transform:translateY(11px)}
.cred__grid{padding-bottom:18px}

/* Stronger contact composition with a shared visual datum */
.contact__grid{position:relative}
.contact__grid::before{
  content:"";position:absolute;left:calc(46% + clamp(1.25rem,3vw,2.5rem));top:2rem;bottom:2rem;width:1px;
  background:linear-gradient(transparent,rgba(8,119,232,.17),transparent);pointer-events:none
}
.contact__head{display:flex;flex-direction:column}
.contact__methods{margin-top:auto}
.formcard::before{
  content:"";position:absolute;right:-100px;top:-100px;width:230px;height:230px;border-radius:50%;
  background:radial-gradient(circle,rgba(35,150,255,.12),transparent 68%);pointer-events:none
}
.formcard h3{font-size:clamp(1.65rem,2.2vw,2rem)}

/* Footer gains a clean return affordance */
.foot__toplink{
  display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-top:1.5rem;padding:1rem 0;
  border-bottom:1px solid var(--hair-dark);font-family:var(--mono);font-size:.65rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--on-dark-mut);transition:color .25s
}
.foot__toplink svg{transition:transform .3s var(--ease)}
.foot__toplink:hover{color:#fff}
.foot__toplink:hover svg{transform:translateY(-4px)}

/* Responsive tuning for the richer layout */
@media (max-width:1320px){.section-dock{display:none}}
@media (max-width:1000px){
  .nav:not(.solid) .nav__inner{background:rgba(4,15,28,.72)}
  .exp__item,.exp__item:nth-child(1),.exp__item:nth-child(6){grid-column:span 6;min-height:220px}
  .contact__grid::before{display:none}
  .scard:nth-child(even),.scard:nth-child(even):hover,.cred-card:nth-child(2),.cred-card:nth-child(2):hover{transform:none}
  .section[data-index]::before{right:var(--pad);font-size:7rem}
}
@media (max-width:720px){
  .capability-group{gap:1rem;padding:.85rem .55rem}
  .capability-group span{font-size:.58rem;letter-spacing:.14em}
  .capability-group i{width:4px;height:4px}
  .section[data-index]::before{top:34px;font-size:5.2rem;opacity:.8}
  .hero__media::after{inset:10% -5% -7% 12%;border-radius:30px}
  .hero__media::before{right:-8%;font-size:8rem}
  .hero__name::after{height:3px;bottom:-.1em}
  .statement__q{padding-left:0}
  .exp__grid{grid-template-columns:1fr}
  .exp__item,.exp__item:nth-child(1),.exp__item:nth-child(6){grid-column:auto;min-height:0}
  .exp__index{right:1rem;top:1rem}
  .sect-grid{padding-bottom:0}
  .cred__grid{padding-bottom:0}
  .foot__toplink{margin-top:1rem}
}
@media (prefers-reduced-motion:reduce){
  .capability-track{animation:none;transform:none}
  .statement .wrap:hover{transform:none}
}

/* =========================================================================
   DESIGN REFINEMENT V4 — calmer hierarchy, stronger usability, better mobile
   ========================================================================= */

/* Keep the primary navigation discoverable from the first frame. */
.nav{transform:none!important;top:14px;padding-inline:14px}
.nav__inner{
  max-width:min(1220px,calc(100vw - 28px));
  border:1px solid rgba(255,255,255,.12);
  border-radius:22px;
  padding:.72rem .78rem .72rem 1.08rem;
  transition:background .35s,border-color .35s,box-shadow .35s,transform .35s;
}
.nav.solid .nav__inner{
  background:rgba(248,251,254,.88);
  border-color:rgba(175,194,213,.52);
  box-shadow:0 20px 52px -32px rgba(7,20,38,.46),inset 0 1px 0 rgba(255,255,255,.95);
}
.nav.solid{background:transparent;box-shadow:none;backdrop-filter:none;-webkit-backdrop-filter:none}
.nav__context{display:none;font-family:var(--mono);font-size:.61rem;letter-spacing:.11em;text-transform:uppercase;color:var(--slate-soft);white-space:nowrap}

/* Static capability rail: more readable and less distracting than an endless marquee. */
.capability-strip{background:#071729}
.capability-track{width:100%;animation:none;display:block}
.capability-group{width:min(1180px,100%);margin-inline:auto;padding:1.05rem var(--pad);justify-content:space-between;gap:1.1rem}
.capability-group[aria-hidden="true"]{display:none}
.capability-group b{
  font-family:var(--mono);font-size:.61rem;letter-spacing:.17em;text-transform:uppercase;color:#63B9FF;
  padding:.42rem .7rem;border:1px solid rgba(99,185,255,.22);border-radius:999px;font-weight:650;
}
.capability-group span{color:#C8D7E7}
.capability-strip::before,.capability-strip::after{display:none}

/* More deliberate section anchoring and rhythm. */
section[id]{scroll-margin-top:108px}
.section{position:relative}
.section>.wrap{container-type:inline-size}

/* Hero polish: stronger composition without adding visual noise. */
.hero{min-height:min(940px,100svh);display:flex;align-items:center;padding-top:132px;padding-bottom:72px}
.hero .wrap{width:100%}
.hero__grid{align-items:center}
.hero__intro{max-width:36ch}
.hero__cta-row .btn{min-height:52px}
.hero__media{isolation:isolate}
.hero__media::after{box-shadow:0 26px 80px -50px rgba(21,143,241,.62)}
.hero__float{pointer-events:none}
.hero__facts{position:relative}
.hero__facts::before{
  content:"At a glance";font-family:var(--mono);font-size:.58rem;letter-spacing:.14em;text-transform:uppercase;
  color:#7890A8;display:flex;align-items:center;margin-right:.15rem;
}

/* Working approach: a concise bridge between biography and capabilities. */
.approach{padding-block:clamp(54px,7vw,92px);background:#08192C;color:var(--on-dark);position:relative;overflow:hidden}
.approach::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(520px 420px at 8% 20%,rgba(28,145,238,.16),transparent 70%),
             radial-gradient(480px 360px at 94% 80%,rgba(100,193,255,.08),transparent 72%);
}
.approach__grid{position:relative;z-index:1;display:grid;grid-template-columns:minmax(250px,.62fr) minmax(0,1.38fr);gap:clamp(2rem,6vw,6rem);align-items:start}
.approach__intro{position:sticky;top:118px}
.approach__intro .eyebrow{color:#72C0FF}
.approach__intro h2{color:#fff;font-size:clamp(2.25rem,1.45rem + 3.4vw,4rem);margin-top:1rem;max-width:8ch;letter-spacing:-.035em}
.approach__items{border-top:1px solid rgba(255,255,255,.12)}
.approach__item{display:grid;grid-template-columns:52px 1fr;gap:1rem;padding:1.45rem 0;border-bottom:1px solid rgba(255,255,255,.12);transition:padding-left .3s var(--ease),background .3s}
.approach__item:hover{padding-left:.7rem}
.approach__item>span{font-family:var(--mono);font-size:.65rem;letter-spacing:.14em;color:#64B9FF;padding-top:.32rem}
.approach__item h3{font-family:var(--serif);font-size:1.34rem;color:#fff;margin-bottom:.35rem}
.approach__item p{color:#AFC2D6;line-height:1.55;max-width:52ch;font-size:.95rem}

/* Expertise cards read better when the heading and body align on a clear baseline. */
.exp__item{display:flex;flex-direction:column}
.exp__item .brand__mark{margin-bottom:auto}
.exp__term{margin-top:2rem}
.exp__desc{max-width:34ch}

/* Background cards become a connected experience path rather than four isolated tiles. */
.sect-grid{position:relative}
.sect-grid::before{content:"";position:absolute;left:7%;right:7%;top:44px;height:1px;background:linear-gradient(90deg,transparent,#B9D2E8 10%,#B9D2E8 90%,transparent);z-index:0}
.scard{z-index:1}
.scard__ic{position:relative}
.scard__ic::after{content:"";position:absolute;inset:-7px;border-radius:20px;border:1px solid rgba(14,118,214,.11)}

/* Products behave unmistakably like links. */
.product{padding-right:4.4rem}
.product__arrow{
  position:absolute;right:1.35rem;bottom:1.35rem;width:38px;height:38px;border-radius:50%;display:grid;place-items:center;
  color:#A9C9E7;border:1px solid rgba(255,255,255,.14);background:rgba(255,255,255,.035);
  font-size:1rem;transition:transform .3s var(--ease),background .3s,color .3s,border-color .3s;
}
.product:hover .product__arrow{transform:translate(3px,-3px);background:#fff;color:var(--ink);border-color:#fff}

/* Contact is now an equal, coherent two-panel system with clearer field feedback. */
.contact__grid{grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:1.25rem}
.contact__head{
  padding:clamp(1.8rem,3vw,2.8rem);border-radius:30px;background:linear-gradient(145deg,#07182A,#0C3153);
  color:var(--on-dark);box-shadow:0 42px 100px -58px rgba(7,20,38,.7);position:relative;overflow:hidden;
}
.contact__head::before{content:"";position:absolute;width:300px;height:300px;right:-120px;top:-130px;border-radius:50%;background:radial-gradient(circle,rgba(55,164,255,.2),transparent 68%)}
.contact__head>div,.contact__methods{position:relative;z-index:1}
.contact__head .eyebrow{color:#72C0FF}
.contact__head .eyebrow::before{background:#72C0FF}
.contact__head h2{color:#fff}
.contact__head>div>p{color:#B5C6D8}
.contact__methods{background:rgba(255,255,255,.045);border-color:rgba(255,255,255,.11);box-shadow:inset 0 1px 0 rgba(255,255,255,.04)}
.cmethod{border-color:rgba(255,255,255,.1)}
.cmethod__ic{background:rgba(255,255,255,.07);color:#78C4FF;box-shadow:inset 0 0 0 1px rgba(255,255,255,.08)}
.cmethod:hover .cmethod__ic{background:#198BE8;color:#fff}
.cmethod .lbl{color:#7F99B2}
.cmethod .val{color:#F3F8FC}
.cmethod .arr2{color:rgba(255,255,255,.22)}
.local-time{display:block;font-family:var(--mono);font-size:.61rem;letter-spacing:.08em;color:#76BDF4;margin-top:.28rem}
.formcard{display:flex;flex-direction:column;justify-content:center}
.field-meta{display:flex;justify-content:space-between;gap:1rem;margin-top:.45rem;font-size:.73rem;color:var(--slate-soft)}
.field-meta span:last-child{font-family:var(--mono);white-space:nowrap}
.form-status{min-height:1.35em;font-size:.82rem;color:var(--slate-soft);margin-top:-.2rem;margin-bottom:.4rem}
.form-status.is-error{color:#B33B3B}
.form-status.is-success{color:#167A50}

/* Drawer: clear navigation first, contact actions second. */
.drawer__actions{position:relative;z-index:1;display:grid;grid-template-columns:1fr;gap:.65rem;margin-top:auto;margin-bottom:.8rem}
.drawer__panel .drawer__action{
  display:flex;align-items:center;justify-content:flex-start;gap:.75rem;padding:.85rem 1rem;border:1px solid rgba(255,255,255,.12);
  border-radius:14px;background:rgba(255,255,255,.045);font-family:var(--sans);font-size:.9rem;font-weight:600;
}
.drawer__action svg{width:19px;height:19px;color:#76C2FF;flex:none}
.drawer__panel .drawer__action:hover{padding-left:1rem;background:rgba(255,255,255,.075)}
.drawer__meta{margin-top:0}

/* Mobile quick-action dock: useful, thumb-friendly and hidden near the contact section. */
.mobile-actions{display:none}

/* Better keyboard affordance on cards and links. */
.product:focus-visible,.cmethod:focus-visible,.scard:focus-within,.exp__item:focus-within{outline:3px solid rgba(14,118,214,.5);outline-offset:4px}

@media (max-width:1120px){
  .capability-group{justify-content:flex-start;overflow-x:auto;scrollbar-width:none}
  .capability-group::-webkit-scrollbar{display:none}
  .capability-group span,.capability-group i,.capability-group b{flex:none}
}

@media (max-width:1000px){
  .nav{top:10px;padding-inline:10px}
  .nav__context{display:inline-flex;margin-left:auto}
  .nav__cta{display:none}
  .nav__right{gap:.65rem}
  .hero{min-height:auto;padding-top:126px}
  .approach__grid{grid-template-columns:1fr;gap:1.5rem}
  .approach__intro{position:static}
  .approach__intro h2{max-width:none}
  .sect-grid::before{display:none}
  .contact__grid{grid-template-columns:1fr}
  .contact__head,.formcard{min-height:auto}
}

@media (max-width:720px){
  body{padding-bottom:78px}
  .nav__context{max-width:106px;overflow:hidden;text-overflow:ellipsis}
  .capability-group{padding:.82rem 18px;gap:.85rem}
  .capability-group b{font-size:.53rem}
  .hero__facts::before{width:100%;justify-content:center;margin:0 0 .25rem}
  .approach{padding-block:60px}
  .approach__item{grid-template-columns:40px 1fr;padding:1.2rem 0}
  .approach__item:hover{padding-left:0}
  .approach__item h3{font-size:1.2rem}
  .contact__head{padding:1.55rem;border-radius:24px}
  .contact__methods{margin-top:1.7rem}
  .formcard{padding:1.55rem}
  .field-meta{font-size:.68rem}
  .mobile-actions{
    position:fixed;z-index:95;left:10px;right:10px;bottom:10px;height:62px;padding:6px;display:grid;grid-template-columns:1fr 1.25fr 1fr;
    gap:5px;border:1px solid rgba(255,255,255,.14);border-radius:19px;background:rgba(6,20,35,.88);
    backdrop-filter:blur(18px) saturate(150%);-webkit-backdrop-filter:blur(18px) saturate(150%);
    box-shadow:0 22px 55px -25px rgba(0,0,0,.72);transition:opacity .3s,transform .3s,visibility .3s;
  }
  .mobile-actions.is-hidden{opacity:0;visibility:hidden;transform:translateY(20px)}
  .mobile-actions a{display:flex;align-items:center;justify-content:center;gap:.4rem;border-radius:13px;color:#C8D7E6;font-size:.72rem;font-weight:650}
  .mobile-actions a svg{width:17px;height:17px}
  .mobile-actions__primary{background:linear-gradient(135deg,#0F7AD5,#269AF2);color:#fff!important;box-shadow:0 9px 22px -12px rgba(35,150,255,.8)}
  .foot{padding-bottom:88px}
}

@media (max-width:430px){
  .nav__context{display:none}
  .approach__item p{font-size:.9rem}
  .mobile-actions{grid-template-columns:1fr 1.2fr 1fr}
  .mobile-actions a{font-size:.67rem}
}

@media (prefers-reduced-motion:reduce){
  .approach__item,.product__arrow,.mobile-actions{transition:none}
}

/* =========================================================================
   V5 — premium interaction and hierarchy pass
   ========================================================================= */
:root{
  --surface-glass:rgba(255,255,255,.82);
  --ring:0 0 0 1px rgba(14,118,214,.16),0 22px 70px -48px rgba(10,26,47,.58);
}

/* Perceived performance and stable anchor behaviour. */
.section,.approach,.cashbook,.contact,.snapshot{content-visibility:auto;contain-intrinsic-size:800px}
.hero{content-visibility:visible}

/* Navigation: a clearer active state, direct-call utility and integrated progress. */
.nav{--page-progress:0}
.nav__inner{overflow:hidden}
.nav__progress{position:absolute;left:18px;right:18px;bottom:0;height:2px;transform-origin:left;transform:scaleX(var(--page-progress));background:linear-gradient(90deg,#2AA2FF,#74C8FF);opacity:.72;transition:opacity .25s}
.nav:not(.solid) .nav__progress{opacity:.35}
.nav__links a{padding:.52rem .15rem;border-radius:999px}
.nav__links a.active{color:var(--azure);font-weight:650}
.nav:not(.solid) .nav__links a.active{color:#fff}
.nav__links a.active::after{transform:scaleX(1);transform-origin:left}
.nav__phone{display:inline-flex;align-items:center;gap:.48rem;padding:.55rem .75rem;border-radius:999px;color:var(--slate-deep);font-size:.78rem;font-weight:650;white-space:nowrap;transition:.25s var(--ease)}
.nav__phone svg{width:17px;height:17px;color:var(--azure)}
.nav__phone:hover{background:rgba(14,118,214,.08);color:var(--ink)}
.nav:not(.solid) .nav__phone{color:#D8E8F7;background:rgba(255,255,255,.045)}
.nav:not(.solid) .nav__phone svg{color:#6CC1FF}
.nav:not(.solid) .nav__phone:hover{background:rgba(255,255,255,.1);color:#fff}

/* Hero: more dimensional portrait, quieter copy rhythm and premium fact chips. */
.hero__lead{position:relative}
.hero__lead::before{content:"";position:absolute;width:130px;height:130px;left:-80px;top:34%;border-radius:50%;background:radial-gradient(circle,rgba(45,155,245,.12),transparent 68%);pointer-events:none}
.hero__intro{font-size:clamp(1.08rem,1rem + .45vw,1.27rem);line-height:1.62}
.hero__facts{gap:.55rem}
.fact{min-height:34px;display:inline-flex;align-items:center;padding:.5rem .78rem;background:rgba(255,255,255,.045);border-color:rgba(255,255,255,.14);box-shadow:inset 0 1px 0 rgba(255,255,255,.04)}
.portrait{box-shadow:0 50px 120px -58px rgba(0,0,0,.8),0 0 0 1px rgba(255,255,255,.12)}
.portrait::after{content:"";position:absolute;inset:0;border-radius:inherit;box-shadow:inset 0 0 0 1px rgba(255,255,255,.12),inset 0 -90px 100px -90px rgba(2,11,20,.72);pointer-events:none}
.hero__float{box-shadow:0 22px 54px -30px rgba(0,0,0,.72),inset 0 1px 0 rgba(255,255,255,.11)}

/* Executive snapshot: a fast-scanning bridge between the hero and biography. */
.snapshot{position:relative;padding:0 0 clamp(54px,7vw,92px);background:var(--porcelain)}
.snapshot__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0}
.snapshot__item{position:relative;padding:1.45rem 1.5rem 1.55rem;background:rgba(255,255,255,.7);border:1px solid var(--hair);border-right:0;box-shadow:0 18px 55px -48px rgba(10,26,47,.55);overflow:hidden}
.snapshot__item:first-child{border-radius:22px 0 0 22px}
.snapshot__item:last-child{border-right:1px solid var(--hair);border-radius:0 22px 22px 0}
.snapshot__item::before{content:"";position:absolute;left:0;right:0;top:0;height:2px;background:linear-gradient(90deg,var(--azure),var(--sky));transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease)}
.snapshot__item:hover::before{transform:scaleX(1)}
.snapshot__label{display:block;font-family:var(--mono);font-size:.6rem;letter-spacing:.15em;text-transform:uppercase;color:var(--azure);margin-bottom:.65rem}
.snapshot__item strong{display:block;font-family:var(--serif);font-size:clamp(1.18rem,1rem + .5vw,1.45rem);line-height:1.08;color:var(--ink);font-weight:740;letter-spacing:-.04em}
.snapshot__item small{display:block;margin-top:.38rem;font-size:.83rem;color:var(--slate-soft)}

/* Profile side panel: turn empty space into a useful executive summary. */
.profile__summary{margin-top:1.65rem;border:1px solid var(--hair);border-radius:18px;background:rgba(255,255,255,.68);overflow:hidden;box-shadow:0 20px 55px -48px rgba(10,26,47,.52)}
.profile__summary>div{padding:1rem 1.1rem;border-top:1px solid var(--hair)}
.profile__summary>div:first-child{border-top:0}
.profile__summary span{display:block;font-family:var(--mono);font-size:.58rem;letter-spacing:.12em;text-transform:uppercase;color:var(--azure);margin-bottom:.28rem}
.profile__summary strong{display:block;font-size:.91rem;color:var(--ink);line-height:1.35;font-weight:620}
.profile__body{position:relative}
.profile__body::before{content:"";position:absolute;left:-2rem;top:.15rem;bottom:.15rem;width:1px;background:linear-gradient(transparent,var(--platinum) 8%,var(--platinum) 92%,transparent)}

/* Cards: more precise hover depth and a softer material treatment. */
.exp__item,.scard,.cred-card{isolation:isolate;transition:transform .35s var(--ease),box-shadow .35s var(--ease),border-color .35s var(--ease),background .35s var(--ease)}
.exp__item::after,.scard::after,.cred-card::after{content:"";position:absolute;inset:0;z-index:-1;pointer-events:none;background:radial-gradient(260px circle at var(--mx,50%) var(--my,50%),rgba(36,151,239,.09),transparent 65%);opacity:0;transition:opacity .3s}
.exp__item:hover::after,.scard:hover::after,.cred-card:hover::after{opacity:1}
.exp__item:hover,.scard:hover,.cred-card:hover{transform:translateY(-5px);border-color:rgba(14,118,214,.28);box-shadow:0 28px 70px -48px rgba(10,26,47,.6)}

/* Contact: a genuinely useful copy action and stronger form hierarchy. */
.copy-email{position:relative;z-index:1;margin-top:1rem;width:100%;display:flex;align-items:center;gap:.85rem;padding:.92rem 1rem;border:1px dashed rgba(117,196,255,.3);border-radius:15px;background:rgba(255,255,255,.035);color:#fff;text-align:left;transition:.25s var(--ease)}
.copy-email:hover{background:rgba(255,255,255,.075);border-style:solid;transform:translateY(-2px)}
.copy-email__icon{width:38px;height:38px;border-radius:11px;display:grid;place-items:center;background:rgba(100,193,255,.1);color:#78C4FF;flex:none}
.copy-email__icon svg{width:19px;height:19px}
.copy-email strong{display:block;font-size:.86rem;line-height:1.2}
.copy-email small{display:block;margin-top:.22rem;font-family:var(--mono);font-size:.62rem;letter-spacing:.03em;color:#8FA8C0}
.copy-email.copied{border-color:rgba(74,214,154,.48);background:rgba(41,168,114,.1)}
.copy-email.copied .copy-email__icon{background:rgba(74,214,154,.16);color:#72DDAA}
.formcard{background:linear-gradient(145deg,rgba(255,255,255,.96),rgba(247,250,253,.92));box-shadow:0 42px 100px -62px rgba(7,20,38,.62),inset 0 1px 0 #fff}
.field input,.field textarea{transition:border-color .2s,box-shadow .2s,background .2s,transform .2s}
.field input:hover,.field textarea:hover{border-color:#C6D7E7}
.field input:focus,.field textarea:focus{transform:translateY(-1px)}
.form-foot .btn{min-width:160px;justify-content:center}

/* Full-screen drawer with clearer hierarchy and numbered navigation. */
.drawer__panel{width:min(90%,420px);padding:1.5rem 1.5rem max(1.5rem,env(safe-area-inset-bottom));gap:0}
.drawer__brand{display:flex;align-items:center;gap:.75rem;padding:.3rem 3.5rem 1.25rem 0;border-bottom:1px solid var(--hair-dark)}
.drawer__brand .brand__mark{margin:0;background:#65BCFF;width:25px;height:16px}
.drawer__brand strong{display:block;font-family:var(--serif);font-size:1.15rem;color:#fff;font-weight:740;letter-spacing:-.035em}
.drawer__brand small{display:block;margin-top:.15rem;font-family:var(--mono);font-size:.58rem;letter-spacing:.08em;text-transform:uppercase;color:#829CB6}
.drawer__nav{padding:1.2rem 0 .75rem}
.drawer__panel .drawer__nav a{display:grid;grid-template-columns:34px 1fr;align-items:center;font-size:1.42rem;padding:.68rem 0}
.drawer__nav a::before{content:attr(data-no);font-family:var(--mono);font-size:.56rem;letter-spacing:.1em;color:#5BAFF2}
.drawer__panel .drawer__nav a:hover{padding-left:.35rem}
.drawer__actions{margin-top:auto}

/* Floating return control: unobtrusive until it is useful. */
.floating-top{position:fixed;z-index:92;right:22px;bottom:22px;width:48px;height:48px;border-radius:50%;display:grid;place-items:center;color:#fff;background:rgba(7,24,42,.88);border:1px solid rgba(255,255,255,.14);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);box-shadow:0 18px 45px -22px rgba(0,0,0,.72);opacity:0;visibility:hidden;transform:translateY(12px);transition:.3s var(--ease)}
.floating-top svg{width:20px;height:20px}
.floating-top.show{opacity:1;visibility:visible;transform:none}
.floating-top:hover{background:var(--azure);transform:translateY(-3px)}

/* Footer and global detail polish. */
.foot__toplink{transition:transform .25s var(--ease),background .25s}
.foot__toplink:hover{transform:translateY(-3px)}
::-webkit-scrollbar{width:11px}
::-webkit-scrollbar-track{background:#E9EFF5}
::-webkit-scrollbar-thumb{background:linear-gradient(#7FAED8,#2F8DDE);border:3px solid #E9EFF5;border-radius:999px}

@media (max-width:1180px){
  .nav__phone span{display:none}
  .nav__phone{width:42px;height:42px;justify-content:center;padding:0}
}
@media (max-width:1000px){
  .nav__phone{display:none}
  .snapshot__grid{grid-template-columns:repeat(2,1fr);gap:1px;background:var(--hair);border:1px solid var(--hair);border-radius:22px;overflow:hidden}
  .snapshot__item{border:0!important;border-radius:0!important}
  .profile__body::before{display:none}
}
@media (max-width:720px){
  .snapshot{padding-bottom:54px}
  .snapshot__grid{grid-template-columns:1fr}
  .snapshot__item{padding:1.15rem 1.2rem}
  .snapshot__item strong{font-size:1.18rem}
  .hero__facts{justify-content:flex-start}
  .hero__facts::before{justify-content:flex-start}
  .floating-top{display:none}
  .drawer__panel{width:100%}
  .copy-email{margin-top:.85rem}
}
@media (max-width:430px){
  .hero__cta-row{display:grid;grid-template-columns:1fr}
  .hero__cta-row .btn{width:100%;justify-content:center}
  .fact{font-size:.67rem}
}
@media (prefers-reduced-motion:reduce){
  .snapshot__item::before,.copy-email,.floating-top,.exp__item,.scard,.cred-card{transition:none}
}

/* Keep the two hero actions perfectly aligned. */
.hero__cta-row .btn{
  box-sizing:border-box;
  height:52px;
  min-height:52px;
  padding-top:0;
  padding-bottom:0;
  align-items:center;
  justify-content:center;
  white-space:nowrap;
}


/* =========================================================================
   V6 — adaptive appearance, mobile-first reading flow and refined UX
   ========================================================================= */
:root{--theme-transition:background-color .32s ease,color .32s ease,border-color .32s ease,box-shadow .32s ease}
html{scroll-padding-top:104px}
body,.statement,.snapshot,.profile,.expertise,.sectors,.credentials,.contact,.approach,.nav__inner,.profile__aside,.profile__summary,.exp__item,.scard,.cred-card,.formcard,.snapshot__item,.contact__methods,.field input,.field textarea{transition:var(--theme-transition)}

/* Appearance controls */
.theme-toggle{width:40px;height:40px;display:grid;place-items:center;border-radius:999px;color:var(--slate-deep);background:rgba(255,255,255,.58);box-shadow:inset 0 0 0 1px var(--hair);transition:transform .22s var(--ease),background .22s,color .22s,box-shadow .22s;flex:none}
.theme-toggle:hover{transform:translateY(-2px);color:var(--azure);box-shadow:inset 0 0 0 1px rgba(14,118,214,.28),0 12px 26px -18px rgba(7,20,38,.55)}
.theme-toggle svg{grid-area:1/1;width:18px;height:18px;transition:opacity .22s,transform .28s var(--ease)}
.theme-toggle__moon{opacity:0;transform:rotate(-22deg) scale(.7)}
html[data-theme="dark"] .theme-toggle__sun,html[data-theme="dark"] .drawer__theme .theme-toggle__sun{opacity:0;transform:rotate(30deg) scale(.7)}
html[data-theme="dark"] .theme-toggle__moon,html[data-theme="dark"] .drawer__theme .theme-toggle__moon{opacity:1;transform:none}
.nav:not(.solid) .theme-toggle{color:#DCEAF6;background:rgba(255,255,255,.05);box-shadow:inset 0 0 0 1px rgba(255,255,255,.13)}
.nav:not(.solid) .theme-toggle:hover{background:rgba(255,255,255,.1);color:#fff}
.drawer__theme{display:grid;grid-template-columns:38px 1fr 42px;align-items:center;gap:.8rem;width:100%;margin:.85rem 0 .2rem;padding:.78rem .85rem;border:1px solid var(--hair-dark);border-radius:16px;background:rgba(255,255,255,.035);color:#fff;text-align:left}
.drawer__theme-icon{width:38px;height:38px;border-radius:12px;background:rgba(101,188,255,.09);display:grid;place-items:center;color:#70C2FF}
.drawer__theme-icon svg{grid-area:1/1;width:18px;height:18px;transition:opacity .22s,transform .28s var(--ease)}
.drawer__theme strong{display:block;font-size:.84rem;font-family:var(--sans)}
.drawer__theme small{display:block;margin-top:.12rem;color:#8DA4BA;font-size:.66rem;font-family:var(--mono)}
.drawer__theme-switch{width:42px;height:24px;padding:3px;border-radius:999px;background:rgba(255,255,255,.12);box-shadow:inset 0 0 0 1px rgba(255,255,255,.08)}
.drawer__theme-switch i{display:block;width:18px;height:18px;border-radius:50%;background:#fff;box-shadow:0 4px 10px rgba(0,0,0,.28);transition:transform .28s var(--ease),background .28s}
html[data-theme="dark"] .drawer__theme-switch{background:rgba(42,162,255,.35)}
html[data-theme="dark"] .drawer__theme-switch i{transform:translateX(18px);background:#8FD0FF}

/* The solid navigation becomes more compact and precise after the first scroll. */
.nav.solid .nav__inner{padding-top:.54rem;padding-bottom:.54rem;min-height:58px}
.nav__inner{transition:padding .32s var(--ease),min-height .32s var(--ease),background .32s,border-color .32s,box-shadow .32s}

/* Mobile portrait is placed where identity matters most, rather than after the entire hero copy. */
.hero__mobile-portrait{display:none}

/* Mobile profile disclosure keeps the long biography readable without removing indexed content. */
.profile__toggle{display:none}

/* Better field feedback, without replacing native validation. */
.field{position:relative}
.field.is-valid input,.field.is-valid textarea{border-color:rgba(34,168,113,.58);box-shadow:0 0 0 3px rgba(34,168,113,.08)}
.field.is-invalid input,.field.is-invalid textarea{border-color:rgba(218,74,74,.62);box-shadow:0 0 0 3px rgba(218,74,74,.08)}
.field.is-valid::after{content:"✓";position:absolute;right:13px;top:39px;width:20px;height:20px;border-radius:50%;display:grid;place-items:center;background:#E4F7EF;color:#16855B;font-size:.68rem;font-weight:800;pointer-events:none}
.field:has(textarea).is-valid::after{top:39px}

/* Theme: lower-page dark mode retains the blue editorial identity instead of simply inverting colours. */
html[data-theme="dark"]{color-scheme:dark;--porcelain:#07111F;--paper:#0B192A;--cloud:#0E2238;--slate:#A8B8CA;--slate-deep:#D5E1EC;--slate-soft:#879AAF;--platinum:#20364D;--platinum-2:#14283D;--hair:rgba(255,255,255,.105);--shadow-s:0 1px 2px rgba(0,0,0,.22),0 8px 28px -22px rgba(0,0,0,.8);--shadow-m:0 24px 64px -40px rgba(0,0,0,.82);--shadow-l:0 46px 100px -56px rgba(0,0,0,.92)}
html[data-theme="dark"] body{background:#07111F;color:#B9C8D7}
html[data-theme="dark"] h1,html[data-theme="dark"] h2,html[data-theme="dark"] h3,html[data-theme="dark"] h4,html[data-theme="dark"] .profile__signoff .nm,html[data-theme="dark"] .profile__summary strong,html[data-theme="dark"] .exp__term,html[data-theme="dark"] .scard h3,html[data-theme="dark"] .cred-card:not(.cred-card--accent) h3,html[data-theme="dark"] .formcard h3,html[data-theme="dark"] .snapshot__item strong{color:#F3F7FB}
html[data-theme="dark"] .statement,html[data-theme="dark"] .snapshot,html[data-theme="dark"] .profile,html[data-theme="dark"] .expertise,html[data-theme="dark"] .credentials,html[data-theme="dark"] .contact{background:#07111F}
html[data-theme="dark"] .sectors{background:linear-gradient(180deg,#091625,#0B1B2D);border-color:var(--hair)}
html[data-theme="dark"] .statement .wrap{background:linear-gradient(145deg,rgba(19,39,61,.96),rgba(10,27,45,.94));border-color:rgba(255,255,255,.08);box-shadow:0 36px 100px -62px rgba(0,0,0,.9),inset 0 1px 0 rgba(255,255,255,.05)}
html[data-theme="dark"] .profile__aside,html[data-theme="dark"] .profile__summary,html[data-theme="dark"] .exp__item,html[data-theme="dark"] .scard,html[data-theme="dark"] .cred-card:not(.cred-card--accent),html[data-theme="dark"] .snapshot__item{background:linear-gradient(145deg,rgba(15,34,54,.96),rgba(9,25,42,.94));border-color:rgba(255,255,255,.09);box-shadow:0 28px 72px -52px rgba(0,0,0,.94)}
html[data-theme="dark"] .exp__item:nth-child(1),html[data-theme="dark"] .exp__item:nth-child(6){background:linear-gradient(145deg,#102A44,#0A1E33)}
html[data-theme="dark"] .profile__avatar{box-shadow:0 0 0 5px #10243A,0 14px 30px -18px rgba(0,0,0,.8)}
html[data-theme="dark"] .profile__summary>div{border-color:var(--hair)}
html[data-theme="dark"] .cred-list li,html[data-theme="dark"] .exp__desc,html[data-theme="dark"] .scard p,html[data-theme="dark"] .cred-card>p,html[data-theme="dark"] .sectors__head p,html[data-theme="dark"] .exp__head p,html[data-theme="dark"] .contact__head p{color:#AABBCD}
html[data-theme="dark"] .formcard{background:linear-gradient(145deg,rgba(16,36,57,.98),rgba(9,25,42,.97));border-color:rgba(255,255,255,.09);box-shadow:0 46px 110px -64px rgba(0,0,0,.95),inset 0 1px 0 rgba(255,255,255,.04)}
html[data-theme="dark"] .field input,html[data-theme="dark"] .field textarea{background:rgba(5,18,32,.72);border-color:rgba(255,255,255,.12);color:#F1F6FA}
html[data-theme="dark"] .field input:hover,html[data-theme="dark"] .field textarea:hover{border-color:rgba(119,196,255,.32)}
html[data-theme="dark"] .field input:focus,html[data-theme="dark"] .field textarea:focus{background:#08182A}
html[data-theme="dark"] .field input::placeholder,html[data-theme="dark"] .field textarea::placeholder{color:#6F8398}
html[data-theme="dark"] .nav.solid .nav__inner{background:rgba(7,20,36,.84);border-color:rgba(255,255,255,.1);box-shadow:0 22px 60px -42px rgba(0,0,0,.95),inset 0 1px 0 rgba(255,255,255,.05)}
html[data-theme="dark"] .nav.solid .brand,html[data-theme="dark"] .nav.solid .nav__links a,html[data-theme="dark"] .nav.solid .nav__phone{color:#D9E6F1}
html[data-theme="dark"] .nav.solid .nav__links a.active{color:#70C4FF}
html[data-theme="dark"] .nav.solid .theme-toggle{background:rgba(255,255,255,.045);color:#8FD0FF;box-shadow:inset 0 0 0 1px rgba(255,255,255,.11)}
html[data-theme="dark"] .nav.solid .burger{box-shadow:inset 0 0 0 1.3px rgba(255,255,255,.14)}
html[data-theme="dark"] .nav.solid .burger span,html[data-theme="dark"] .nav.solid .burger span::before,html[data-theme="dark"] .nav.solid .burger span::after{background:#E8F1F8}
html[data-theme="dark"] .btn--ghost{color:#E7F0F8;box-shadow:inset 0 0 0 1.4px rgba(255,255,255,.18)}
html[data-theme="dark"] .snapshot__item small,html[data-theme="dark"] .profile__signoff .rl,html[data-theme="dark"] .field-meta,html[data-theme="dark"] .formcard .sub{color:#8297AB}
html[data-theme="dark"] ::-webkit-scrollbar-track{background:#07111F}
html[data-theme="dark"] ::-webkit-scrollbar-thumb{border-color:#07111F}

@media (max-width:1180px){.theme-toggle{width:38px;height:38px}.nav__right{gap:.72rem}}
@media (max-width:1000px){.theme-toggle{display:none}}
@media (max-width:720px){
  html{scroll-padding-top:84px}
  .hero__media{display:none}
  .hero__mobile-portrait{display:grid;grid-template-columns:92px 1fr;align-items:center;gap:1rem;width:min(100%,360px);margin:1.35rem auto 1.4rem;padding:.72rem;border:1px solid rgba(255,255,255,.13);border-radius:24px;background:linear-gradient(135deg,rgba(255,255,255,.085),rgba(255,255,255,.025));box-shadow:0 22px 60px -42px rgba(0,0,0,.9),inset 0 1px 0 rgba(255,255,255,.07);text-align:left}
  .hero__mobile-portrait img{width:92px;height:92px;border-radius:18px;object-fit:cover;object-position:50% 20%;box-shadow:0 12px 30px -18px rgba(0,0,0,.75)}
  .hero__mobile-portrait figcaption span{display:block;font-family:var(--mono);font-size:.59rem;letter-spacing:.14em;text-transform:uppercase;color:#74C4FF}
  .hero__mobile-portrait figcaption strong{display:block;margin-top:.35rem;font-family:var(--serif);font-size:1.13rem;color:#fff;font-weight:720;letter-spacing:-.03em}
  .profile__copy{position:relative;max-height:570px;overflow:hidden;transition:max-height .5s var(--ease)}
  .profile__copy::after{content:"";position:absolute;left:0;right:0;bottom:0;height:150px;background:linear-gradient(transparent,var(--porcelain));pointer-events:none;transition:opacity .25s}
  .profile__body.is-expanded .profile__copy{max-height:2200px}
  .profile__body.is-expanded .profile__copy::after{opacity:0}
  .profile__toggle{display:flex;align-items:center;justify-content:center;gap:.55rem;width:100%;margin-top:1.25rem;padding:.82rem 1rem;border:1px solid var(--hair);border-radius:999px;background:rgba(255,255,255,.65);color:var(--ink);font-weight:650;box-shadow:var(--shadow-s)}
  .profile__toggle svg{width:18px;height:18px;transition:transform .28s var(--ease)}
  .profile__body.is-expanded .profile__toggle svg{transform:rotate(180deg)}
  html[data-theme="dark"] .profile__copy::after{background:linear-gradient(transparent,#07111F)}
  html[data-theme="dark"] .profile__toggle{background:rgba(255,255,255,.045);color:#EFF5FA;border-color:rgba(255,255,255,.12)}
  .field.is-valid::after{top:38px}
}
@media (max-width:430px){.hero__mobile-portrait{grid-template-columns:78px 1fr}.hero__mobile-portrait img{width:78px;height:78px}.drawer__theme{grid-template-columns:36px 1fr 42px}}
@media (prefers-reduced-motion:reduce){body,.statement,.snapshot,.profile,.expertise,.sectors,.credentials,.contact,.nav__inner,.theme-toggle,.drawer__theme-switch i,.profile__copy{transition:none!important}}


/* V6 final contrast and mobile navigation refinements */
html[data-theme="dark"] .profile__body strong,
html[data-theme="dark"] .prose strong,
html[data-theme="dark"] .pull{color:#F3F7FB}
html[data-theme="dark"] .pull{background:linear-gradient(135deg,rgba(32,112,184,.18),rgba(69,153,225,.08));box-shadow:inset 3px 0 0 #2F9AF2}
.mobile-actions.is-scrolling-down{opacity:0;visibility:hidden;transform:translateY(20px)}
@media (max-width:720px){
  .mobile-actions{bottom:max(10px,env(safe-area-inset-bottom))}
  body{padding-bottom:calc(78px + env(safe-area-inset-bottom))}
}

/* =========================================================================
   V7 — interaction clarity, aligned contact utility and tactile polish
   ========================================================================= */

/* Explicit appearance state: the switch is now visible, persistent and obvious. */
html[data-theme="light"]{color-scheme:light}
html[data-theme="dark"]{color-scheme:dark}
html,body{transition:background-color .38s ease,color .38s ease}
::view-transition-old(root),::view-transition-new(root){animation-duration:.34s;animation-timing-function:var(--ease)}
html[data-theme="dark"] .hero{background:linear-gradient(132deg,#02070D 0%,#06111D 46%,#071A2B 100%)}
html[data-theme="dark"] .hero::before{
  background:
    radial-gradient(60% 85% at 82% 14%,rgba(31,134,229,.22),transparent 62%),
    radial-gradient(52% 80% at -4% 98%,rgba(6,86,166,.17),transparent 66%),
    linear-gradient(110deg,rgba(255,255,255,.015),transparent 45%);
}
html[data-theme="light"] .hero{background:linear-gradient(132deg,#07172A 0%,#0A223C 46%,#0D3154 100%)}
.theme-toggle,.drawer__theme{position:relative;isolation:isolate;overflow:hidden}
.theme-toggle[aria-pressed="true"]{box-shadow:inset 0 0 0 1px rgba(105,199,255,.34),0 0 0 5px rgba(42,162,255,.08)}
.drawer__theme:active,.theme-toggle:active{scale:.97}

/* Align the copy utility precisely with the email, phone, LinkedIn and location rows. */
.contact__methods{padding:.3rem 1.2rem}
.contact__methods>.cmethod:last-child{border-bottom:0}
.cmethod--copy{
  appearance:none;-webkit-appearance:none;width:100%;margin:0;border:0;border-bottom:0;background:transparent;
  color:inherit;font:inherit;text-align:left;cursor:pointer;position:relative;overflow:hidden;
}
.cmethod--copy:hover{background:linear-gradient(90deg,rgba(75,178,255,.07),transparent 72%)}
.copy-email__address{display:block;margin-top:.28rem;font-family:var(--mono);font-size:.61rem;letter-spacing:.045em;color:#7FA0BD;overflow-wrap:anywhere}
.copy-email__action{
  margin-left:auto;min-width:62px;padding:.46rem .7rem;border-radius:999px;text-align:center;
  font-family:var(--mono);font-size:.59rem;letter-spacing:.1em;text-transform:uppercase;color:#8CCEFF;
  background:rgba(91,183,255,.09);box-shadow:inset 0 0 0 1px rgba(112,197,255,.17);transition:.25s var(--ease)
}
.cmethod--copy:hover .copy-email__action{background:#198BE8;color:#fff;box-shadow:0 10px 24px -14px rgba(25,139,232,.8)}
.cmethod--copy.copied .copy-email__action{background:rgba(49,190,125,.18);color:#83E4B5;box-shadow:inset 0 0 0 1px rgba(80,216,150,.28)}
.cmethod--copy.copied .cmethod__ic{background:rgba(49,190,125,.18);color:#83E4B5}
.cmethod--copy .val{transition:color .2s}
.cmethod--copy.copied .val{color:#8CE7BB}

/* Context-aware cursor lighting, adapted from the Cashbook interaction language. */
.cursor-aura{
  position:fixed;left:0;top:0;width:190px;height:190px;margin:-95px 0 0 -95px;border-radius:50%;z-index:80;
  pointer-events:none;opacity:0;transform:translate3d(-300px,-300px,0);will-change:transform,opacity;
  background:radial-gradient(circle,rgba(132,211,255,.18) 0%,rgba(48,158,241,.085) 31%,transparent 72%);
  filter:blur(.2px);mix-blend-mode:screen;transition:opacity .18s ease
}
.cursor-aura.visible{opacity:.68}
html[data-theme="light"] .cursor-aura{
  mix-blend-mode:multiply;
  background:radial-gradient(circle,rgba(16,132,220,.105) 0%,rgba(16,132,220,.04) 35%,transparent 72%)
}
html[data-theme="light"] .cursor-aura.visible{opacity:.42}

.cursor-glow-zone{position:relative;isolation:isolate;--cursor-glow-x:50%;--cursor-glow-y:50%}
.cursor-glow-layer{
  position:absolute;inset:0;z-index:0;border-radius:inherit;pointer-events:none;opacity:0;will-change:opacity,background;
  background:radial-gradient(620px circle at var(--cursor-glow-x) var(--cursor-glow-y),rgba(81,181,255,.18) 0%,rgba(24,133,222,.085) 27%,transparent 59%);
  mix-blend-mode:screen;transition:opacity .36s ease
}
.cursor-glow-zone.is-cursor-lit>.cursor-glow-layer{opacity:1}
.cursor-glow-zone.glow-light>.cursor-glow-layer{
  background:radial-gradient(520px circle at var(--cursor-glow-x) var(--cursor-glow-y),rgba(72,174,250,.13) 0%,rgba(72,174,250,.052) 30%,transparent 62%);
  mix-blend-mode:multiply
}
html[data-theme="dark"] .cursor-glow-zone.glow-light>.cursor-glow-layer{
  background:radial-gradient(520px circle at var(--cursor-glow-x) var(--cursor-glow-y),rgba(88,190,255,.14) 0%,rgba(34,143,228,.06) 31%,transparent 63%);
  mix-blend-mode:screen
}
.cursor-glow-zone.glow-card>.cursor-glow-layer{
  background:radial-gradient(330px circle at var(--cursor-glow-x) var(--cursor-glow-y),rgba(66,171,250,.16) 0%,rgba(66,171,250,.055) 34%,transparent 68%)
}
.cursor-glow-zone.glow-card>:not(.cursor-glow-layer){position:relative;z-index:1}
.cursor-glow-zone.glow-dark>.cursor-glow-layer{
  background:radial-gradient(680px circle at var(--cursor-glow-x) var(--cursor-glow-y),rgba(104,198,255,.22) 0%,rgba(34,146,235,.10) 28%,transparent 58%)
}
.hero.cursor-glow-zone>.cursor-glow-layer{z-index:1}
.cashbook.cursor-glow-zone>.cursor-glow-layer,.foot.cursor-glow-zone>.cursor-glow-layer{z-index:0}

/* Tactile confirmation for key actions. */
.ui-ripple{position:absolute;width:12px;height:12px;margin:-6px;border-radius:50%;pointer-events:none;z-index:5;background:rgba(255,255,255,.46);transform:scale(0);animation:uiRipple .68s ease-out forwards}
@keyframes uiRipple{to{transform:scale(22);opacity:0}}
.ui-toast{
  position:fixed;right:max(22px,env(safe-area-inset-right));bottom:max(24px,env(safe-area-inset-bottom));z-index:250;
  max-width:min(360px,calc(100vw - 32px));padding:.82rem 1rem;border-radius:999px;color:#F6FBFF;background:rgba(5,20,36,.9);
  border:1px solid rgba(255,255,255,.14);box-shadow:0 24px 70px -30px rgba(0,0,0,.75),inset 0 1px 0 rgba(255,255,255,.08);
  backdrop-filter:blur(18px) saturate(150%);-webkit-backdrop-filter:blur(18px) saturate(150%);
  font-size:.82rem;font-weight:650;letter-spacing:.01em;opacity:0;transform:translateY(14px) scale(.97);pointer-events:none;
  transition:opacity .22s ease,transform .3s var(--ease)
}
.ui-toast::before{content:"";display:inline-block;width:7px;height:7px;margin-right:.58rem;border-radius:50%;background:#63C5FF;box-shadow:0 0 0 5px rgba(99,197,255,.1)}
.ui-toast.show{opacity:1;transform:none}

/* More expressive, still restrained, card interaction. */
.snapshot__item,.approach__item,.cmethod{isolation:isolate}
.snapshot__item::after,.approach__item::after{
  content:"";position:absolute;inset:0;z-index:-1;pointer-events:none;opacity:0;
  background:radial-gradient(240px circle at var(--mx,50%) var(--my,50%),rgba(65,172,255,.12),transparent 68%);
  transition:opacity .28s ease
}
.snapshot__item:hover::after,.approach__item:hover::after{opacity:1}
.approach__item{position:relative;border-radius:16px;padding-inline:.75rem;margin-inline:-.75rem}
.approach__item:hover{background:rgba(255,255,255,.025);padding-left:1rem}
.snapshot__item:hover{z-index:2;transform:translateY(-4px);box-shadow:0 30px 70px -52px rgba(10,26,47,.7)}
.cmethod{border-radius:14px;padding-inline:.45rem;margin-inline:-.45rem}
.cmethod:hover{background:rgba(255,255,255,.035);padding-left:.7rem;padding-right:.45rem}

/* Stronger visual rhythm while preserving speed. */
.section[id]::before{content:"";position:absolute;top:0;left:50%;width:min(1180px,calc(100% - 48px));height:1px;transform:translateX(-50%);background:linear-gradient(90deg,transparent,var(--hair),transparent);opacity:.65}
.contact::before,.company::before{display:none}
.hero__float{transition:transform .35s var(--ease),border-color .35s,background .35s}
.hero__media:hover .hero__float--top{transform:translate3d(-5px,-4px,0)}
.hero__media:hover .hero__float--bottom{transform:translate3d(6px,4px,0)}
.hero__facts .fact{transition:transform .25s var(--ease),background .25s,border-color .25s}
.hero__facts .fact:hover{transform:translateY(-3px);background:rgba(255,255,255,.09);border-color:rgba(117,198,255,.32)}

@media (max-width:1000px){
  .cursor-aura,.cursor-glow-layer{display:none}
}
@media (max-width:720px){
  .contact__methods{padding:.2rem .78rem}
  .cmethod,.cmethod--copy{margin-inline:0;padding-inline:.15rem;border-radius:0}
  .cmethod:hover,.cmethod--copy:hover{padding-left:.15rem;padding-right:.15rem;background:transparent}
  .copy-email__action{min-width:54px;padding:.42rem .58rem}
  .ui-toast{left:16px;right:16px;bottom:calc(82px + env(safe-area-inset-bottom));text-align:center;border-radius:16px}
  .cursor-aura{display:none}
  .section[id]::before{width:calc(100% - 32px)}
}
@media (prefers-reduced-motion:reduce){
  .cursor-aura,.cursor-glow-layer{display:none}
  .ui-ripple{display:none}
  .ui-toast,.snapshot__item,.approach__item,.cmethod,.hero__float,.hero__facts .fact{transition:none!important}
}
.cmethod--copy>span:nth-child(2){min-width:0;flex:1}
.copy-email__action{flex:none}
.mobile-actions a{position:relative;overflow:hidden}


/* =========================================================================
   V8 typography — contemporary executive system
   ========================================================================= */
.hero__name{
  font-weight:800;
  letter-spacing:-.078em;
  line-height:.82;
  text-wrap:balance;
}
.hero__name .sur{font-weight:800;letter-spacing:-.082em}
.statement__q{font-weight:760;line-height:1.03;letter-spacing:-.055em}
.profile__aside h2,.exp__term,.scard h3,.cred-card h3,.product h3,.formcard h3,
.snapshot__item strong,.approach__item h3{
  font-family:var(--serif);
  font-variation-settings:normal;
}
.section .h2{max-width:15ch}
.cred-card__kicker,.eyebrow,.product__badge,.field label,.foot__col h4,
.hero__role,.local-time,.copy-email__address{
  font-weight:600;
  letter-spacing:.13em;
}
.btn{min-height:48px;justify-content:center}
@media (max-width:700px){
  .hero__name{letter-spacing:-.066em;line-height:.86}
  .h2{letter-spacing:-.046em}
}


/* =========================================================================
   V9 — unified contact utility and final interface polish
   ========================================================================= */

/* Copy email is now a true fifth contact row, with identical alignment. */
.contact__methods{
  padding:.42rem .68rem;
  border-radius:28px;
  background:linear-gradient(145deg,rgba(255,255,255,.07),rgba(255,255,255,.025)),rgba(7,29,50,.3);
  border:1px solid rgba(150,205,245,.14);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.055),0 26px 70px -54px rgba(0,0,0,.7);
}
.cmethod,.cmethod--copy{
  width:100%;min-height:92px;display:grid;grid-template-columns:52px minmax(0,1fr) 34px;
  align-items:center;gap:1.15rem;margin:0;padding:1rem .72rem;border:0;
  border-bottom:1px solid rgba(160,205,238,.11);border-radius:17px;background:transparent;
  text-align:left;color:inherit;overflow:hidden;isolation:isolate;
  transition:transform .28s var(--ease),border-color .22s ease;
}
.contact__methods>.cmethod:last-child{border-bottom-color:transparent}
.cmethod::before{
  content:"";position:absolute;inset:5px;z-index:-1;border-radius:14px;opacity:0;
  background:linear-gradient(100deg,rgba(52,163,246,.13),rgba(52,163,246,.025) 58%,transparent 82%);
  transform:scale(.985);transition:opacity .22s ease,transform .28s var(--ease);
}
.cmethod:hover{padding:1rem .72rem;transform:translateX(3px);background:transparent}
.cmethod:hover::before,.cmethod:focus-visible::before{opacity:1;transform:none}
.cmethod:focus-visible{outline:2px solid rgba(94,190,255,.68);outline-offset:-2px}
.cmethod__ic{
  width:52px;height:52px;border-radius:16px;
  background:linear-gradient(145deg,rgba(255,255,255,.095),rgba(255,255,255,.045));
  color:#72C5FF;box-shadow:inset 0 0 0 1px rgba(150,211,255,.12),0 10px 28px -24px rgba(41,155,235,.8);
  transition:background .24s ease,color .24s ease,transform .3s var(--ease),box-shadow .3s var(--ease);
}
.cmethod:hover .cmethod__ic,.cmethod:focus-visible .cmethod__ic{
  background:linear-gradient(145deg,#2399F2,#0876D2);color:#fff;transform:translateY(-2px) rotate(-1deg);
  box-shadow:0 16px 32px -20px rgba(31,151,239,.85),inset 0 1px 0 rgba(255,255,255,.25);
}
.cmethod__body,.cmethod>span:nth-child(2){min-width:0}
.cmethod .lbl{margin-bottom:.24rem;font-size:.62rem;letter-spacing:.17em;color:#8EA9C1}
.cmethod .val{font-size:clamp(.98rem,.91rem + .28vw,1.08rem);line-height:1.3;overflow-wrap:anywhere}
.cmethod .arr2,.copy-email__action{
  width:34px;height:34px;margin-left:0;border-radius:50%;display:grid;place-items:center;
  color:rgba(157,196,225,.42);background:transparent;box-shadow:none;
  transition:color .22s ease,background .22s ease,transform .28s var(--ease),box-shadow .28s var(--ease);
}
.cmethod:hover .arr2,.cmethod:focus-visible .arr2{
  color:#8ED0FF;background:rgba(97,188,255,.1);transform:translateX(2px);
  box-shadow:inset 0 0 0 1px rgba(123,201,255,.13);
}
.copy-email__action svg{width:18px;height:18px}
.copy-email__check-icon{display:none}
.cmethod--copy.copied::before{opacity:1;background:linear-gradient(100deg,rgba(51,190,128,.15),rgba(51,190,128,.025) 64%,transparent)}
.cmethod--copy.copied .cmethod__ic{background:linear-gradient(145deg,#31B77D,#16875B);color:#fff;box-shadow:0 16px 32px -20px rgba(49,183,125,.8),inset 0 1px 0 rgba(255,255,255,.2)}
.cmethod--copy.copied .copy-email__copy-icon{display:none}
.cmethod--copy.copied .copy-email__check-icon{display:block}
.cmethod--copy.copied .copy-email__action{color:#80E2B4;background:rgba(63,194,135,.11)}
.cmethod--copy.copied .lbl,.cmethod--copy.copied .val{color:#9BE6C1}
.copy-email__address{display:none}

/* Cleaner, more premium surface hierarchy. */
:where(.snapshot__item,.exp__item,.scard,.cred-card,.product,.approach__item,.formcard,.profile__aside){backface-visibility:hidden;transform:translateZ(0)}
:where(.snapshot__item,.exp__item,.scard,.cred-card,.product){
  box-shadow:0 1px 0 rgba(255,255,255,.65),0 22px 60px -52px rgba(8,30,53,.75)
}
@media (hover:hover){
  :where(.exp__item,.scard,.cred-card,.product):hover{
    transform:translateY(-5px);border-color:rgba(28,137,225,.24);
    box-shadow:0 1px 0 rgba(255,255,255,.78),0 34px 76px -48px rgba(8,67,111,.46)
  }
}

/* More deliberate button and navigation feedback. */
.btn{position:relative;isolation:isolate;overflow:hidden;box-shadow:inset 0 1px 0 rgba(255,255,255,.16)}
.btn::after{content:"";position:absolute;inset:-60% auto -60% -35%;width:28%;z-index:-1;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transform:skewX(-18deg);transition:left .55s var(--ease)}
@media (hover:hover){.btn:hover::after{left:115%}}
.nav__links a{position:relative}
.nav__links a::after{content:"";position:absolute;left:50%;right:50%;bottom:-.48rem;height:2px;border-radius:2px;background:linear-gradient(90deg,#50B8FF,#1687E4);transition:left .25s var(--ease),right .25s var(--ease),opacity .25s;opacity:0}
.nav__links a:hover::after,.nav__links a.active::after{left:12%;right:12%;opacity:1}

/* Cleaner form rhythm and stronger affordance. */
.field input,.field textarea{background:linear-gradient(180deg,rgba(255,255,255,.96),rgba(249,252,255,.9));box-shadow:inset 0 1px 0 rgba(255,255,255,.8)}
.field input:focus,.field textarea:focus{transform:translateY(-1px);box-shadow:0 0 0 4px rgba(25,139,232,.1),0 18px 36px -28px rgba(9,85,143,.55),inset 0 1px 0 rgba(255,255,255,.9)}
.formcard{overflow:hidden}
.formcard::after{content:"";position:absolute;inset:0;pointer-events:none;border-radius:inherit;box-shadow:inset 0 1px 0 rgba(255,255,255,.72)}

html[data-theme="dark"] .contact__methods{background:linear-gradient(145deg,rgba(255,255,255,.05),rgba(255,255,255,.018)),rgba(2,17,31,.46);border-color:rgba(142,203,244,.13)}
html[data-theme="dark"] :where(.snapshot__item,.exp__item,.scard,.cred-card,.product){box-shadow:inset 0 1px 0 rgba(255,255,255,.035),0 24px 64px -54px rgba(0,0,0,.88)}
html[data-theme="dark"] .field input,html[data-theme="dark"] .field textarea{background:linear-gradient(180deg,rgba(15,35,54,.96),rgba(9,27,44,.94));box-shadow:inset 0 1px 0 rgba(255,255,255,.035)}

@media (max-width:720px){
  .contact__methods{padding:.34rem .45rem;border-radius:23px}
  .cmethod,.cmethod--copy{min-height:82px;grid-template-columns:46px minmax(0,1fr) 30px;gap:.85rem;padding:.82rem .48rem;border-radius:15px}
  .cmethod:hover{padding:.82rem .48rem;transform:none}
  .cmethod__ic{width:46px;height:46px;border-radius:14px}
  .cmethod .arr2,.copy-email__action{width:30px;height:30px}
  .cmethod .val{font-size:.94rem}
}
@media (prefers-reduced-motion:reduce){
  .cmethod,.cmethod::before,.cmethod__ic,.cmethod .arr2,.btn::after,.nav__links a::after,:where(.exp__item,.scard,.cred-card,.product),.field input,.field textarea{transition:none!important}
}


/* =========================================================================
   DESIGN REFINEMENT V10 — deliberate contact typography + tactile UI
   ========================================================================= */

/* Keep the contact invitation optically balanced across two deliberate lines. */
.contact__head .contact__intro{
  max-width:44rem;
  font-size:clamp(1.06rem,1rem + .28vw,1.16rem);
  line-height:1.72;
  letter-spacing:-.018em;
}
.contact__intro span{display:block}

/* More tactile contact rows while retaining the clean list structure. */
.cmethod{
  position:relative;
  isolation:isolate;
  overflow:hidden;
  margin-inline:-.72rem;
  padding-inline:.92rem;
  border-radius:18px;
  border-bottom-color:transparent;
  box-shadow:inset 0 -1px 0 var(--hair);
  transition:transform .32s var(--ease),box-shadow .32s var(--ease),background .32s,border-color .32s;
}
.cmethod::before{
  content:"";
  position:absolute;
  inset:0;
  z-index:-1;
  opacity:0;
  background:
    radial-gradient(190px circle at var(--mx,15%) var(--my,50%),rgba(35,150,255,.16),transparent 68%),
    linear-gradient(100deg,rgba(8,119,232,.075),rgba(255,255,255,.55));
  transition:opacity .3s var(--ease);
}
.cmethod:hover,.cmethod:focus-visible{
  transform:translate3d(6px,-2px,0);
  box-shadow:inset 0 0 0 1px rgba(8,119,232,.16),0 18px 42px -32px rgba(7,20,38,.5);
}
.cmethod:hover::before,.cmethod:focus-visible::before{opacity:1}
.cmethod__ic{transition:transform .34s var(--ease),background .34s,color .34s,box-shadow .34s}
.cmethod:hover .cmethod__ic,.cmethod:focus-visible .cmethod__ic{
  transform:scale(1.06) rotate(-3deg);
  box-shadow:0 14px 30px -18px rgba(8,119,232,.7),inset 0 0 0 1px rgba(255,255,255,.16);
}
.cmethod .arr2 svg{transition:transform .32s var(--ease)}
.cmethod:hover .arr2 svg,.cmethod:focus-visible .arr2 svg{transform:translate(2px,-2px) scale(1.08)}
.cmethod--copy:hover .copy-email__action,.cmethod--copy:focus-visible .copy-email__action{color:var(--azure)}

/* Small, high-quality depth response on the key information cards. */
.js-tilt{
  --tilt-x:0deg;
  --tilt-y:0deg;
  --tilt-lift:0px;
  transform:perspective(1050px) translate3d(0,var(--tilt-lift),0) rotateX(var(--tilt-x)) rotateY(var(--tilt-y));
  transform-style:preserve-3d;
  transition:transform .22s ease-out,box-shadow .34s var(--ease),border-color .34s;
  will-change:transform;
}
.js-tilt:hover{--tilt-lift:-7px}
.js-tilt:active{--tilt-lift:-2px;transition-duration:.1s}
.js-tilt .exp__num,.js-tilt .scard__ic,.js-tilt .product__top,.js-tilt .cred-card__kicker,.js-tilt .snapshot__value{
  transform:translateZ(18px);
  transition:transform .28s var(--ease);
}
.js-tilt:hover .exp__num,.js-tilt:hover .scard__ic,.js-tilt:hover .product__top,.js-tilt:hover .cred-card__kicker,.js-tilt:hover .snapshot__value{
  transform:translateZ(28px);
}

/* Supporting micro-interactions. */
.fact{transition:transform .28s var(--ease),background .28s,border-color .28s,box-shadow .28s}
.fact:hover{transform:translateY(-3px);background:rgba(255,255,255,.09);box-shadow:inset 0 0 0 1px rgba(127,192,255,.28),0 14px 30px -24px rgba(0,0,0,.7)}
.eyebrow::before{transition:transform .32s var(--ease),filter .32s}
.section:hover .eyebrow::before{transform:translateX(4px);filter:drop-shadow(0 0 8px rgba(8,119,232,.35))}
.field{position:relative}
.field::after{
  content:"";
  position:absolute;
  left:14px;
  right:14px;
  bottom:0;
  height:2px;
  border-radius:99px;
  background:linear-gradient(90deg,var(--azure),var(--sky));
  transform:scaleX(0);
  transform-origin:left;
  transition:transform .3s var(--ease);
  pointer-events:none;
}
.field:focus-within::after{transform:scaleX(1)}
.field:focus-within label{color:var(--azure)}
.formcard h3{position:relative;display:inline-block}
.formcard h3::after{
  content:"";
  position:absolute;
  left:0;
  bottom:-.48rem;
  width:42px;
  height:3px;
  border-radius:99px;
  background:linear-gradient(90deg,var(--azure),var(--sky));
  transition:width .35s var(--ease);
}
.formcard:hover h3::after{width:72px}

/* Better pressed states on touch and mouse. */
.btn:active,.theme-toggle:active,.drawer__theme:active,.mobile-actions a:active{transform:translateY(1px) scale(.985)}

/* Dark appearance parity for the new contact row treatment. */
html[data-theme="dark"] .cmethod::before{
  background:
    radial-gradient(190px circle at var(--mx,15%) var(--my,50%),rgba(78,174,255,.2),transparent 68%),
    linear-gradient(100deg,rgba(34,137,231,.11),rgba(255,255,255,.025));
}
html[data-theme="dark"] .cmethod:hover,html[data-theme="dark"] .cmethod:focus-visible{
  box-shadow:inset 0 0 0 1px rgba(93,183,255,.2),0 18px 42px -32px rgba(0,0,0,.85);
}

@media (min-width:1050px){
  .contact__intro span{white-space:nowrap}
}
@media (max-width:1049px){
  .contact__intro span{display:inline}
  .contact__intro span+span::before{content:" "}
}
@media (max-width:720px){
  .contact__head .contact__intro{max-width:34rem;line-height:1.62}
  .cmethod{margin-inline:-.35rem;padding-inline:.55rem;border-radius:15px}
}
@media (hover:none),(prefers-reduced-motion:reduce){
  .js-tilt{transform:none!important}
  .cmethod:hover,.cmethod:focus-visible{transform:none}
  .fact:hover{transform:none}
  .section:hover .eyebrow::before{transform:none}
}

/* =========================================================================
   V11 — final layout QA, cleaner sector cards and balanced contact system
   ========================================================================= */

/* The old connector line crossed through the cards at some viewport widths.
   The cards now read as a clean, evenly aligned set instead. */
.sect-grid::before{display:none!important}
.sect-grid{
  gap:clamp(1rem,1.55vw,1.4rem);
  padding-bottom:0;
  align-items:stretch;
}
.scard,
.scard:nth-child(even),
.scard:nth-child(even):hover{
  transform:none;
}
.scard{
  min-height:260px;
  display:flex;
  flex-direction:column;
  padding:clamp(1.5rem,2vw,1.85rem);
  border-radius:26px;
  background:
    radial-gradient(220px circle at var(--mx,20%) var(--my,15%),rgba(55,164,255,.085),transparent 68%),
    linear-gradient(155deg,rgba(255,255,255,.98),rgba(248,251,254,.92));
  border-color:rgba(22,76,120,.105);
  box-shadow:0 1px 0 rgba(255,255,255,.86),0 24px 60px -50px rgba(8,45,74,.62);
  overflow:hidden;
}
.scard::before{
  content:attr(data-no);
  position:absolute;
  top:1.42rem;
  right:1.5rem;
  z-index:2;
  font-family:var(--mono);
  font-size:.58rem;
  font-weight:600;
  letter-spacing:.16em;
  color:rgba(42,91,131,.38);
  transition:color .28s ease,transform .32s var(--ease);
}
.scard::after{
  background:
    radial-gradient(300px circle at var(--mx,50%) var(--my,50%),rgba(35,150,255,.115),transparent 62%),
    linear-gradient(90deg,var(--azure),var(--sky));
  background-size:100% 100%,0 3px;
  background-position:center,0 0;
  background-repeat:no-repeat;
}
.scard__ic{
  margin:0 0 clamp(2.1rem,3vw,3rem);
  flex:none;
}
.scard h3{
  margin:0 0 .72rem;
  min-height:1.2em;
  font-size:clamp(1.12rem,1.02rem + .35vw,1.32rem);
  line-height:1.14;
}
.scard p{
  margin:0;
  max-width:31ch;
  font-size:clamp(.88rem,.84rem + .16vw,.96rem);
  line-height:1.62;
}
@media (hover:hover){
  .scard:hover{
    transform:translateY(-7px);
    border-color:rgba(26,137,224,.22);
    box-shadow:0 1px 0 rgba(255,255,255,.94),0 36px 78px -49px rgba(7,72,119,.44);
  }
  .scard:hover::before{color:var(--azure);transform:translateY(-2px)}
  .scard:hover::after{background-size:100% 100%,100% 3px;opacity:1}
}
html[data-theme="dark"] .scard{
  background:
    radial-gradient(220px circle at var(--mx,20%) var(--my,15%),rgba(77,177,255,.11),transparent 68%),
    linear-gradient(155deg,rgba(15,35,55,.97),rgba(8,24,41,.96));
  border-color:rgba(255,255,255,.085);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.035),0 28px 68px -54px rgba(0,0,0,.95);
}
html[data-theme="dark"] .scard::before{color:rgba(153,195,227,.36)}

/* Contact panels use a deliberate gutter and matching internal geometry. */
.contact .wrap{max-width:1280px}
.contact__grid{
  grid-template-columns:minmax(0,1fr) minmax(0,1fr);
  gap:clamp(1.65rem,2.5vw,2.65rem);
  align-items:stretch;
}
.contact__grid::before{display:none!important}
.contact__head,.formcard{
  min-width:0;
  height:100%;
  border-radius:34px;
}
.contact__head{
  padding:clamp(2.15rem,3.35vw,3.25rem);
  box-shadow:0 44px 100px -62px rgba(4,18,33,.78),inset 0 1px 0 rgba(255,255,255,.045);
}
.contact__head::after{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  border-radius:inherit;
  box-shadow:inset 0 0 0 1px rgba(151,211,255,.075);
}
.contact__head .contact__intro{
  max-width:42rem;
  margin-top:1.35rem;
}
.contact__methods{
  margin-top:clamp(2rem,3vw,2.8rem);
  padding:.42rem .72rem;
}
.formcard{
  padding:clamp(2.15rem,3.35vw,3.25rem);
  justify-content:flex-start;
  border-color:rgba(24,83,130,.09);
  box-shadow:0 44px 100px -62px rgba(8,47,78,.5),inset 0 1px 0 rgba(255,255,255,.92);
}
.formcard form{
  width:100%;
  min-height:100%;
  display:flex;
  flex-direction:column;
}
.formcard .sub{margin-bottom:2rem}
.form-foot{margin-top:auto;padding-top:.55rem}
.field-2{gap:1.15rem}
.field{margin-bottom:1.15rem}
.field input,.field textarea{min-height:54px}
.field textarea{min-height:150px}

/* A slightly calmer, more coherent interaction language across the page. */
:where(.exp__item,.scard,.cred-card,.product,.snapshot__item,.approach__item){
  outline:1px solid transparent;
  outline-offset:0;
}
:where(.exp__item,.scard,.cred-card,.product,.snapshot__item,.approach__item):focus-within{
  outline-color:rgba(27,143,230,.52);
  outline-offset:4px;
}
:where(.btn,.cmethod,.nav__links a,.foot a){-webkit-tap-highlight-color:transparent}
.btn,.cmethod,.product,.foot a{touch-action:manipulation}
.product__arrow{box-shadow:inset 0 1px 0 rgba(255,255,255,.06)}
.product:hover .product__arrow{box-shadow:0 12px 28px -16px rgba(0,0,0,.55)}

/* Desktop rhythm and tablet fallback. */
@media (max-width:1160px){
  .sect-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .scard{min-height:235px}
}
@media (max-width:1000px){
  .contact__grid{grid-template-columns:1fr;gap:1.5rem}
  .contact__head,.formcard{height:auto;border-radius:29px}
  .formcard form{min-height:auto}
  .form-foot{margin-top:.55rem}
}
@media (max-width:720px){
  .sect-grid{grid-template-columns:1fr;gap:.9rem}
  .scard{min-height:0;padding:1.45rem;border-radius:21px}
  .scard__ic{margin-bottom:1.65rem}
  .scard h3{min-height:0}
  .contact__grid{gap:1.05rem}
  .contact__head,.formcard{border-radius:24px;padding:1.55rem}
  .contact__methods{margin-top:1.65rem;padding:.34rem .45rem}
  .field-2{gap:0}
  .field textarea{min-height:138px}
}
@media (hover:none),(prefers-reduced-motion:reduce){
  .scard,.scard:hover,.scard:nth-child(even),.scard:nth-child(even):hover{transform:none!important}
  .scard::before,.scard::after{transition:none!important}
}

/* Preserve the intended two-line contact statement only where both panels have room. */
@media (min-width:1200px){
  .contact__intro span{white-space:nowrap}
}
@media (min-width:1050px) and (max-width:1199px){
  .contact__intro span{white-space:normal}
}

/* =========================================================================
   V13 — richer, better-balanced contact form
   ========================================================================= */
.label-note{
  text-transform:none;
  letter-spacing:0;
  font-family:var(--sans);
  font-size:.78em;
  font-weight:500;
}
.field input,.field textarea,.field select{
  width:100%;
  font-family:var(--sans);
  font-size:1rem;
  color:var(--ink);
  background:rgba(255,255,255,.7);
  border:1.4px solid #D7E2ED;
  border-radius:15px;
  padding:.94em 1em;
  transition:border-color .25s,background .25s,box-shadow .25s,transform .25s var(--ease);
}
.field select{
  appearance:none;
  -webkit-appearance:none;
  cursor:pointer;
  padding-right:3rem;
}
.field input:hover,.field textarea:hover,.field select:hover{border-color:#B8CDE1}
.field input:focus,.field textarea:focus,.field select:focus{
  outline:none;
  border-color:var(--azure);
  background:#fff;
  box-shadow:0 0 0 4px rgba(14,118,214,.1),0 12px 28px -20px rgba(7,20,38,.36);
}
.select-wrap{position:relative}
.select-wrap::after{
  content:"";
  position:absolute;
  top:50%;
  right:1.05rem;
  width:.55rem;
  height:.55rem;
  border-right:1.7px solid var(--azure);
  border-bottom:1.7px solid var(--azure);
  transform:translateY(-68%) rotate(45deg);
  pointer-events:none;
  transition:transform .22s var(--ease);
}
.select-wrap:focus-within::after{transform:translateY(-38%) rotate(225deg)}
.field--message{margin-bottom:.85rem}
.field--message textarea{min-height:156px}
.field-meta{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:1rem;
  margin-top:.62rem;
  color:var(--slate-soft);
  font-size:.76rem;
  line-height:1.45;
}
.field-meta #messageCount{
  flex:none;
  font-family:var(--mono);
  letter-spacing:.04em;
  color:var(--slate);
}
.form-foot{margin-top:0}

[data-theme="dark"] .field input,
[data-theme="dark"] .field textarea,
[data-theme="dark"] .field select{
  color:#EAF3FC;
  background:rgba(255,255,255,.055);
  border-color:rgba(255,255,255,.13);
}
[data-theme="dark"] .field input::placeholder,
[data-theme="dark"] .field textarea::placeholder{color:#7890A8}
[data-theme="dark"] .field input:hover,
[data-theme="dark"] .field textarea:hover,
[data-theme="dark"] .field select:hover{border-color:rgba(127,192,255,.34)}
[data-theme="dark"] .field input:focus,
[data-theme="dark"] .field textarea:focus,
[data-theme="dark"] .field select:focus{
  background:rgba(255,255,255,.085);
  border-color:var(--sky);
  box-shadow:0 0 0 4px rgba(91,164,240,.12);
}
[data-theme="dark"] .field select option{color:#071426;background:#fff}

@media (max-width:600px){
  .field--message textarea{min-height:170px}
  .field-meta{gap:.75rem;font-size:.72rem}
}


/* V15 — balanced contact-form spacing */
.formcard form{justify-content:center}
.field-meta{justify-content:flex-end}
@media (max-width:1000px){.formcard form{justify-content:flex-start}}

/* =========================================================================
   V17 — dark-mode contrast refinement (desktop + mobile)
   Stronger hierarchy, clearer surfaces and more legible secondary text.
   ========================================================================= */
html[data-theme="dark"]{
  --porcelain:#050D18;
  --paper:#0A1929;
  --cloud:#10263B;
  --slate:#C3D1DE;
  --slate-deep:#E4EDF5;
  --slate-soft:#A0B3C5;
  --platinum:#294158;
  --platinum-2:#152B40;
  --hair:rgba(164,210,242,.17);
  --on-dark:#F4F8FC;
  --on-dark-mut:#B8C9D8;
  --azure:#2E9DF4;
  --azure-bright:#56B8FF;
  --sky:#83CDFF;
}
html[data-theme="dark"] body{
  color:#C7D5E2;
  background:
    radial-gradient(900px 520px at 4% 16%,rgba(46,157,244,.075),transparent 63%),
    radial-gradient(760px 500px at 96% 54%,rgba(86,184,255,.055),transparent 67%),
    #050D18;
}
html[data-theme="dark"] body::before{opacity:.12}
html[data-theme="dark"] ::selection{background:#2E9DF4;color:#fff}

/* Global hierarchy */
html[data-theme="dark"] :where(.statement,.snapshot,.profile,.expertise,.credentials,.contact){background:#050D18}
html[data-theme="dark"] :where(.h2,h1,h2,h3,h4,.statement__q,.profile__signoff .nm,.profile__summary strong,.snapshot__item strong,.exp__term,.scard h3,.cred-card:not(.cred-card--accent) h3,.formcard h3){color:#F7FAFD}
html[data-theme="dark"] :where(.lead,.prose p,.exp__desc,.scard p,.cred-card>p,.cred-list li,.sectors__head p,.exp__head p,.contact__head p,.formcard .sub){color:#C2D0DD}
html[data-theme="dark"] :where(.statement__side,.profile__signoff .rl,.snapshot__item small,.field-meta,.form-note,.foot__brand p){color:#9EB2C5}
html[data-theme="dark"] :where(.eyebrow,.snapshot__label,.cred-card__kicker,.field label,.local-time){color:#82CBFF}
html[data-theme="dark"] .ulink{color:#74C5FF}
html[data-theme="dark"] .ulink:hover{color:#A6DCFF}

/* Navigation */
html[data-theme="dark"] .nav__inner,
html[data-theme="dark"] .nav.solid .nav__inner{
  background:rgba(6,18,31,.9);
  border-color:rgba(157,207,242,.17);
  box-shadow:0 22px 60px -40px rgba(0,0,0,.96),inset 0 1px 0 rgba(255,255,255,.06);
}
html[data-theme="dark"] .nav.solid :where(.brand,.nav__links a,.nav__phone),
html[data-theme="dark"] .nav :where(.brand,.nav__links a,.nav__phone){color:#DCE8F2}
html[data-theme="dark"] .nav__links a:hover{color:#FFFFFF}
html[data-theme="dark"] .nav__links a.active{color:#79CBFF}
html[data-theme="dark"] .theme-toggle,
html[data-theme="dark"] .nav.solid .theme-toggle{
  color:#93D3FF;background:rgba(128,202,255,.075);
  box-shadow:inset 0 0 0 1px rgba(151,211,255,.17);
}
html[data-theme="dark"] .theme-toggle:hover{color:#fff;background:rgba(128,202,255,.13);box-shadow:inset 0 0 0 1px rgba(151,211,255,.3),0 14px 30px -20px rgba(0,0,0,.9)}

/* Editorial and card surfaces */
html[data-theme="dark"] .statement .wrap{
  background:linear-gradient(145deg,#10263B,#091B2D);
  border-color:rgba(157,207,242,.16);
  box-shadow:0 38px 100px -62px rgba(0,0,0,.96),inset 0 1px 0 rgba(255,255,255,.055);
}
html[data-theme="dark"] :where(.profile__aside,.profile__summary,.snapshot__item,.exp__item,.scard,.cred-card:not(.cred-card--accent)){
  background:linear-gradient(150deg,#10263B,#091A2C);
  border-color:rgba(157,207,242,.15);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.045),0 30px 72px -54px rgba(0,0,0,.98);
}
html[data-theme="dark"] .exp__item:nth-child(1),
html[data-theme="dark"] .exp__item:nth-child(6){background:linear-gradient(145deg,#13304A,#0A2035)}
html[data-theme="dark"] .exp__item:nth-child(3){background:linear-gradient(145deg,#0B1C2E,#153754)}
html[data-theme="dark"] .profile__summary>div{border-color:rgba(157,207,242,.14)}
html[data-theme="dark"] .profile__avatar{box-shadow:0 0 0 5px #10263B,0 16px 34px -18px rgba(0,0,0,.9)}
html[data-theme="dark"] .pull{
  color:#F3F8FC;
  background:linear-gradient(135deg,rgba(46,157,244,.2),rgba(86,184,255,.08));
  box-shadow:inset 3px 0 0 #4DAEFF;
}
html[data-theme="dark"] .sectors{background:linear-gradient(180deg,#071321,#0A1A2B);border-color:rgba(157,207,242,.13)}
html[data-theme="dark"] .scard{
  background:
    radial-gradient(240px circle at var(--mx,20%) var(--my,15%),rgba(91,183,255,.15),transparent 68%),
    linear-gradient(155deg,#10263B,#091A2C);
  border-color:rgba(157,207,242,.15);
}
html[data-theme="dark"] .scard::before{color:rgba(184,216,239,.5)}
html[data-theme="dark"] .scard__ic{color:#83CDFF;background:linear-gradient(145deg,rgba(69,169,243,.2),rgba(117,204,255,.08));box-shadow:inset 0 0 0 1px rgba(138,211,255,.16)}
html[data-theme="dark"] :where(.snapshot__item,.exp__item,.scard,.cred-card,.product):hover{border-color:rgba(111,195,255,.34)}

/* Dark feature sections */
html[data-theme="dark"] .approach{background:linear-gradient(135deg,#061321,#0A2238)}
html[data-theme="dark"] .approach__items{border-color:rgba(170,214,245,.18)}
html[data-theme="dark"] .approach__item{border-color:rgba(170,214,245,.17)}
html[data-theme="dark"] .approach__item p{color:#C0D0DF}
html[data-theme="dark"] .cashbook{background:linear-gradient(135deg,#030B14,#082037 55%,#0A3152)}
html[data-theme="dark"] .product{background:rgba(255,255,255,.07);border-color:rgba(166,215,248,.17)}
html[data-theme="dark"] .product p,html[data-theme="dark"] .cb__note{color:#BED0DF}
html[data-theme="dark"] .product__badge{color:#9CD8FF;background:rgba(93,187,255,.14);border-color:rgba(145,211,255,.23)}

/* Contact panel and form */
html[data-theme="dark"] .contact__head{
  background:linear-gradient(145deg,#07192A,#0C2944);
  box-shadow:0 48px 110px -64px rgba(0,0,0,.98),inset 0 1px 0 rgba(255,255,255,.055);
}
html[data-theme="dark"] .contact__head>div>p,
html[data-theme="dark"] .contact__head .contact__intro{color:#C7D6E3}
html[data-theme="dark"] .contact__methods{
  background:linear-gradient(145deg,rgba(255,255,255,.075),rgba(255,255,255,.028)),rgba(2,15,27,.58);
  border-color:rgba(151,211,255,.19);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.055),0 28px 70px -54px rgba(0,0,0,.9);
}
html[data-theme="dark"] .cmethod{box-shadow:inset 0 -1px 0 rgba(161,211,245,.14)}
html[data-theme="dark"] .cmethod .lbl{color:#9DB9D0}
html[data-theme="dark"] .cmethod .val{color:#F0F6FB}
html[data-theme="dark"] .cmethod__ic{color:#82CCFF;background:linear-gradient(145deg,rgba(96,187,255,.16),rgba(255,255,255,.045));box-shadow:inset 0 0 0 1px rgba(151,211,255,.17)}
html[data-theme="dark"] .cmethod .arr2,html[data-theme="dark"] .copy-email__action{color:rgba(178,215,240,.64)}
html[data-theme="dark"] .cmethod:hover,html[data-theme="dark"] .cmethod:focus-visible{box-shadow:inset 0 0 0 1px rgba(111,195,255,.3),0 20px 44px -32px rgba(0,0,0,.9)}
html[data-theme="dark"] .formcard{
  background:linear-gradient(145deg,#10263B,#091A2C);
  border-color:rgba(157,207,242,.16);
  box-shadow:0 48px 110px -64px rgba(0,0,0,.98),inset 0 1px 0 rgba(255,255,255,.05);
}
html[data-theme="dark"] .field label{color:#A7BED2}
html[data-theme="dark"] .field input,
html[data-theme="dark"] .field textarea,
html[data-theme="dark"] .field select{
  color:#F4F8FC;
  background:linear-gradient(180deg,#0D2237,#0A1B2D);
  border-color:rgba(159,210,245,.22);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.045);
}
html[data-theme="dark"] .field input::placeholder,
html[data-theme="dark"] .field textarea::placeholder{color:#91A7BA;opacity:1}
html[data-theme="dark"] .field input:hover,
html[data-theme="dark"] .field textarea:hover,
html[data-theme="dark"] .field select:hover{border-color:rgba(127,203,255,.42)}
html[data-theme="dark"] .field input:focus,
html[data-theme="dark"] .field textarea:focus,
html[data-theme="dark"] .field select:focus{
  color:#fff;background:#102A43;border-color:#63BEFF;
  box-shadow:0 0 0 4px rgba(86,184,255,.16),0 18px 38px -28px rgba(0,0,0,.94),inset 0 1px 0 rgba(255,255,255,.06);
}
html[data-theme="dark"] .field select option{color:#F2F7FB;background:#0D2237}
html[data-theme="dark"] .field-meta,html[data-theme="dark"] .field-meta #messageCount{color:#A6BACB}
html[data-theme="dark"] .form-ok p{color:#BDD0DE}

/* Footer, drawer and mobile dock */
html[data-theme="dark"] .foot{background:linear-gradient(135deg,#02070D,#061522 55%,#08233A)}
html[data-theme="dark"] .foot__col h4{color:#A5BCD0}
html[data-theme="dark"] .foot__col a{color:#D8E5EF}
html[data-theme="dark"] .foot__col a:hover{color:#8FD3FF}
html[data-theme="dark"] .foot__bottom,html[data-theme="dark"] .foot__bottom a{color:#98AEC1}
html[data-theme="dark"] .drawer__panel{background:linear-gradient(155deg,#040C15,#09233A)}
html[data-theme="dark"] .drawer__panel .drawer__nav a{color:#EFF6FB;border-color:rgba(166,215,248,.14)}
html[data-theme="dark"] .drawer__nav a::before{color:#7ACBFF}
html[data-theme="dark"] .drawer__meta,html[data-theme="dark"] .drawer__theme{color:#E5EEF6;background:rgba(255,255,255,.055);border-color:rgba(159,210,245,.16)}
html[data-theme="dark"] .drawer__theme small{color:#A8BBCB}
html[data-theme="dark"] .mobile-actions{
  background:rgba(5,15,26,.92);
  border-color:rgba(151,211,255,.17);
  box-shadow:0 18px 45px -25px rgba(0,0,0,.95),inset 0 1px 0 rgba(255,255,255,.05);
}
html[data-theme="dark"] .mobile-actions a{color:#DCE8F2}

/* Accessibility: stronger keyboard visibility in dark appearance */
html[data-theme="dark"] :focus-visible{outline-color:#78CBFF;box-shadow:0 0 0 4px rgba(76,177,247,.18)}

@media (max-width:720px){
  html[data-theme="dark"] body{background:#050D18}
  html[data-theme="dark"] :where(.profile__aside,.profile__summary,.snapshot__item,.exp__item,.scard,.cred-card:not(.cred-card--accent),.formcard){
    border-color:rgba(157,207,242,.18);
  }
  html[data-theme="dark"] .contact__methods{border-color:rgba(151,211,255,.21)}
  html[data-theme="dark"] .cmethod .lbl{color:#A7BED2}
  html[data-theme="dark"] .cmethod .val{color:#F4F8FC}
  html[data-theme="dark"] .field input,
  html[data-theme="dark"] .field textarea,
  html[data-theme="dark"] .field select{font-size:16px}
  html[data-theme="dark"] .mobile-actions a{color:#E7F0F7}
}

/* =========================================================================
   V18 — compact appearance switch + simplified footer return control
   ========================================================================= */
.theme-switch{
  --switch-w:68px;
  --switch-h:36px;
  width:var(--switch-w);height:var(--switch-h);padding:0;border:0;border-radius:999px;
  display:inline-grid;place-items:center;flex:none;color:inherit;background:transparent;
  position:relative;isolation:isolate;overflow:visible;cursor:pointer;
  transition:transform .22s var(--ease),filter .22s var(--ease)
}
.theme-switch__track{
  width:100%;height:100%;padding:3px;border-radius:inherit;display:grid;grid-template-columns:1fr 1fr;align-items:center;
  position:relative;overflow:hidden;
  background:linear-gradient(145deg,rgba(255,255,255,.78),rgba(232,241,249,.72));
  border:1px solid rgba(15,74,120,.16);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.92),0 9px 24px -16px rgba(7,25,44,.65)
}
.theme-switch__track::after{
  content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;
  background:linear-gradient(110deg,transparent 18%,rgba(255,255,255,.48) 46%,transparent 70%);
  transform:translateX(-110%);transition:transform .55s var(--ease)
}
.theme-switch:hover .theme-switch__track::after{transform:translateX(110%)}
.theme-switch__icon{z-index:2;display:grid;place-items:center;width:100%;height:100%;transition:color .28s,opacity .28s,transform .28s var(--ease)}
.theme-switch__icon svg{width:16px;height:16px}
.theme-switch__icon--sun{color:#0A6FC8}
.theme-switch__icon--moon{color:#71859A;opacity:.72}
.theme-switch__thumb{
  position:absolute;z-index:1;left:3px;top:3px;width:calc(50% - 3px);height:calc(100% - 6px);border-radius:999px;
  background:linear-gradient(145deg,#FFFFFF,#EAF4FC);
  border:1px solid rgba(16,100,164,.13);
  box-shadow:0 6px 16px -8px rgba(6,38,66,.72),inset 0 1px 0 rgba(255,255,255,.95);
  transition:transform .34s cubic-bezier(.22,.8,.22,1),background .3s,border-color .3s,box-shadow .3s
}
.theme-switch:hover{transform:translateY(-2px)}
.theme-switch:active{transform:translateY(0) scale(.97)}
.theme-switch:focus-visible{outline:3px solid rgba(42,162,255,.28);outline-offset:3px}
.theme-switch[aria-pressed="true"] .theme-switch__thumb{transform:translateX(100%)}
.theme-switch[aria-pressed="true"] .theme-switch__icon--sun{color:#8AA0B4;opacity:.7}
.theme-switch[aria-pressed="true"] .theme-switch__icon--moon{color:#8FD0FF;opacity:1;transform:rotate(-8deg)}
.nav:not(.solid) .theme-switch__track,
html[data-theme="dark"] .theme-switch__track{
  background:linear-gradient(145deg,rgba(12,34,55,.92),rgba(6,22,38,.94));
  border-color:rgba(139,203,245,.18);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.055),0 10px 26px -18px rgba(0,0,0,.95)
}
.nav:not(.solid) .theme-switch__thumb,
html[data-theme="dark"] .theme-switch__thumb{
  background:linear-gradient(145deg,#173A58,#0E2942);border-color:rgba(144,208,251,.18);
  box-shadow:0 8px 18px -9px rgba(0,0,0,.95),inset 0 1px 0 rgba(255,255,255,.08)
}
.nav:not(.solid) .theme-switch__icon--sun{color:#73C5FF}
.nav:not(.solid) .theme-switch__icon--moon{color:#A8BDD0}

.drawer__appearance{
  display:flex;align-items:center;justify-content:space-between;gap:1rem;width:100%;margin:.85rem 0 .2rem;padding:.78rem .85rem;
  border:1px solid var(--hair-dark);border-radius:16px;background:rgba(255,255,255,.035);color:#fff
}
.drawer__appearance strong{display:block;font-size:.84rem;font-family:var(--sans)}
.drawer__appearance small{display:block;margin-top:.12rem;color:#9DB0C2;font-size:.66rem;font-family:var(--mono)}
.theme-switch--drawer{--switch-w:72px;--switch-h:38px}
html[data-theme="dark"] .drawer__appearance{color:#E5EEF6;background:rgba(255,255,255,.055);border-color:rgba(159,210,245,.16)}
html[data-theme="dark"] .drawer__appearance small{color:#A8BBCB}

/* Remove the full-width footer band; retain one compact return control on the right. */
.foot__toplink{
  width:46px;height:46px;margin:1.35rem 0 0 auto;padding:0;border:1px solid rgba(159,210,245,.17);border-radius:50%;
  display:grid;place-items:center;color:#B5C6D5;background:rgba(255,255,255,.035);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.045),0 16px 36px -25px rgba(0,0,0,.9);
  transition:transform .26s var(--ease),background .26s,border-color .26s,color .26s,box-shadow .26s
}
.foot__toplink svg{width:19px;height:19px;transition:transform .3s var(--ease)}
.foot__toplink:hover{color:#fff;background:rgba(42,162,255,.16);border-color:rgba(117,199,255,.42);transform:translateY(-4px);box-shadow:0 18px 38px -22px rgba(0,0,0,.92)}
.foot__toplink:hover svg{transform:translateY(-2px)}
.foot__toplink:focus-visible{outline:3px solid rgba(111,195,255,.27);outline-offset:4px}

/* Retire legacy appearance and duplicate floating return styles. */
.theme-toggle,.drawer__theme,.floating-top{display:none!important}

@media (max-width:1000px){
  .theme-switch:not(.theme-switch--drawer){display:none}
  .foot__toplink{margin-top:1rem}
}
@media (prefers-reduced-motion:reduce){
  .theme-switch,.theme-switch__thumb,.theme-switch__track::after,.theme-switch__icon,.foot__toplink,.foot__toplink svg{transition:none!important}
}


/* ==========================================================================
   V19 — Cashbook-style floating return-to-top control
   Fixed at the lower-right edge, revealed after meaningful scrolling, and
   carrying a subtle reading-progress ring. The former footer row is retired.
   ========================================================================== */
.foot__toplink{display:none!important}
.site-top-control{
  --top-progress:0deg;
  position:fixed;
  right:clamp(18px,2vw,28px);
  bottom:clamp(18px,2vw,28px);
  z-index:118;
  width:52px;
  height:52px;
  padding:0;
  border:0;
  border-radius:50%;
  display:grid;
  place-items:center;
  color:#eaf6ff;
  background:linear-gradient(145deg,rgba(18,55,84,.96),rgba(6,29,49,.98));
  box-shadow:0 18px 44px -20px rgba(0,0,0,.78),inset 0 1px 0 rgba(255,255,255,.12);
  -webkit-backdrop-filter:blur(14px) saturate(135%);
  backdrop-filter:blur(14px) saturate(135%);
  cursor:pointer;
  opacity:0;
  visibility:hidden;
  pointer-events:none;
  transform:translate3d(0,12px,0) scale(.92);
  transition:opacity .28s ease,visibility .28s ease,transform .32s var(--ease),box-shadow .28s ease,background .28s ease;
}
.site-top-control::before{
  content:"";
  position:absolute;
  inset:3px;
  z-index:-1;
  border-radius:inherit;
  background:linear-gradient(145deg,rgba(20,74,112,.94),rgba(7,31,52,.98));
  border:1px solid rgba(143,211,255,.16);
}
.site-top-control__ring{
  position:absolute;
  inset:0;
  border-radius:inherit;
  background:conic-gradient(from -90deg,var(--azure) var(--top-progress),rgba(147,205,245,.16) 0);
  -webkit-mask:radial-gradient(farthest-side,transparent calc(100% - 2px),#000 0);
  mask:radial-gradient(farthest-side,transparent calc(100% - 2px),#000 0);
  pointer-events:none;
}
.site-top-control svg{
  width:20px;
  height:20px;
  position:relative;
  z-index:1;
  filter:drop-shadow(0 4px 8px rgba(0,0,0,.22));
  transition:transform .28s var(--ease),color .28s ease;
}
.site-top-control.is-visible{
  opacity:1;
  visibility:visible;
  pointer-events:auto;
  transform:none;
}
.site-top-control:hover{
  background:linear-gradient(145deg,#178fe8,#0876cf);
  box-shadow:0 22px 50px -20px rgba(0,112,202,.72),inset 0 1px 0 rgba(255,255,255,.22);
  transform:translateY(-4px);
}
.site-top-control:hover::before{background:linear-gradient(145deg,#168fe8,#0871c7);border-color:rgba(255,255,255,.22)}
.site-top-control:hover svg{transform:translateY(-2px)}
.site-top-control:active{transform:translateY(-1px) scale(.96)}
.site-top-control:focus-visible{outline:3px solid rgba(86,184,255,.42);outline-offset:4px}
html[data-theme="light"] .site-top-control{
  color:#fff;
  background:linear-gradient(145deg,rgba(12,56,91,.96),rgba(5,31,53,.98));
  box-shadow:0 18px 44px -22px rgba(7,46,78,.58),inset 0 1px 0 rgba(255,255,255,.14);
}
@media (max-width:720px){
  .site-top-control{
    width:46px;
    height:46px;
    right:14px;
    bottom:calc(82px + env(safe-area-inset-bottom,0px));
  }
  .site-top-control svg{width:18px;height:18px}
}
@media (prefers-reduced-motion:reduce){
  .site-top-control,.site-top-control svg{transition:none!important}
}


/* ==========================================================================
   V21 — light-first experience + mobile layout and spacing refinement
   ========================================================================== */

/* A deliberate, stable default prevents a dark flash before JavaScript loads. */
html:not([data-theme]),html[data-theme="light"]{color-scheme:light}
html:not([data-theme]) body{background:#f4f7fb;color:#071426}
:where(section,[id]){scroll-margin-top:92px}

/* Tablet rhythm: retain the premium composition without oversized gaps. */
@media (min-width:721px) and (max-width:1000px){
  :root{--pad:clamp(24px,4vw,38px);--sect:clamp(72px,9vw,104px)}
  .hero{padding-top:118px;padding-bottom:72px}
  .hero__grid{gap:2rem}
  .hero__lead{max-width:760px;margin-inline:auto}
  .statement{padding-block:58px}
  .snapshot{padding-bottom:64px}
  .profile__grid,.contact__grid{gap:1.35rem}
  .contact__head,.formcard{padding:clamp(1.8rem,4vw,2.4rem)}
  .foot__top{gap:2rem}
}

@media (max-width:720px){
  :root{
    --pad:18px;
    --sect:72px;
  }
  html{scroll-padding-top:84px}
  body{
    padding-bottom:calc(76px + env(safe-area-inset-bottom,0px));
    -webkit-text-size-adjust:100%;
  }
  .wrap{width:100%;padding-inline:var(--pad)}

  /* Compact, well-proportioned mobile header. */
  .nav{top:8px;padding-inline:8px}
  .nav__inner{
    min-height:56px;
    padding:.48rem .52rem .48rem .78rem;
    border-radius:17px;
    gap:.6rem;
  }
  .brand{font-size:1rem;letter-spacing:-.025em}
  .burger{width:40px;height:40px;border-radius:12px}
  .burger span{width:18px}

  /* The first screen is tighter, clearer and immediately recognisable. */
  .hero{
    padding-top:102px;
    padding-bottom:58px;
  }
  .hero__grid{gap:0}
  .hero__lead{width:100%;max-width:540px;margin-inline:auto}
  .hero__eyebrow{margin-bottom:.9rem;font-size:.61rem;letter-spacing:.145em}
  .hero__name{
    font-size:clamp(3.45rem,18vw,4.9rem);
    line-height:.84;
    letter-spacing:-.073em;
  }
  .hero__role{
    margin-top:.95rem;
    gap:.42rem .62rem;
    font-size:.66rem;
    letter-spacing:.115em;
    line-height:1.55;
  }
  .hero__mobile-portrait{
    grid-template-columns:74px minmax(0,1fr);
    gap:.82rem;
    width:100%;
    max-width:350px;
    margin:1.05rem auto 1.15rem;
    padding:.58rem;
    border-radius:20px;
  }
  .hero__mobile-portrait img{width:74px;height:74px;border-radius:15px}
  .hero__mobile-portrait figcaption span{font-size:.54rem;letter-spacing:.12em}
  .hero__mobile-portrait figcaption strong{font-size:1rem;margin-top:.2rem;line-height:1.15}
  .hero__intro{
    margin-top:1.05rem;
    max-width:34ch;
    font-size:1rem;
    line-height:1.62;
  }
  .hero__cta-row{
    max-width:none;
    margin-top:1.45rem;
    gap:.65rem;
  }
  .hero__cta-row .btn{min-height:50px;width:100%;padding:.82rem 1.1rem}
  .hero__facts{
    width:100%;
    max-width:none;
    margin-top:1.35rem;
    gap:.48rem;
  }
  .fact{min-height:38px;padding:.58rem .72rem;font-size:.59rem}

  /* Horizontal capability rail behaves like a purposeful touch carousel. */
  .capability-group{
    padding:.76rem var(--pad);
    gap:.72rem;
    scroll-snap-type:x proximity;
    overscroll-behavior-inline:contain;
  }
  .capability-group b,.capability-group span{scroll-snap-align:start}

  /* Consistent section rhythm and less dead space between mobile blocks. */
  .section{padding-block:var(--sect)}
  .statement{padding-block:42px}
  .statement .wrap{padding:1.55rem 1.25rem;border-radius:22px}
  .statement__side{margin-bottom:.85rem;font-size:.6rem}
  .statement__q{font-size:clamp(1.8rem,8.7vw,2.65rem);line-height:1.08}

  .snapshot{padding-bottom:54px}
  .snapshot__grid{
    grid-template-columns:1fr;
    gap:.7rem;
    background:transparent;
    border:0;
    border-radius:0;
    overflow:visible;
  }
  .snapshot__item{
    padding:1.05rem 1.12rem 1.12rem;
    border:1px solid var(--hair)!important;
    border-radius:18px!important;
    box-shadow:0 18px 44px -38px rgba(7,28,49,.45);
  }
  .snapshot__label{margin-bottom:.42rem}
  .snapshot__item strong{font-size:1.12rem;line-height:1.15}
  .snapshot__item small{font-size:.79rem;line-height:1.45}

  .profile__grid{gap:1.25rem}
  .profile__aside,.profile__summary{border-radius:21px}
  .profile__aside{padding:1.28rem}
  .profile__summary{padding:1.25rem}
  .profile__body p{font-size:.98rem;line-height:1.72}
  .profile__tags{gap:.48rem}
  .profile__tags span{padding:.5rem .68rem;font-size:.64rem}

  .approach{padding-block:58px}
  .approach__grid{gap:1.05rem}
  .approach__intro{margin-bottom:.25rem}
  .approach__item{grid-template-columns:36px minmax(0,1fr);gap:.8rem;padding:1.05rem 0}
  .approach__item h3{font-size:1.12rem}
  .approach__item p{margin-top:.32rem;font-size:.9rem;line-height:1.55}

  .exp__head,.sectors__head{margin-bottom:1.65rem}
  .exp__grid,.sect-grid{gap:.72rem}
  .exp__item,.scard,.cred-card{padding:1.3rem;border-radius:19px}
  .exp__item{min-height:0}
  .exp__term,.scard h3,.cred-card h3{font-size:1.17rem}
  .exp__desc,.scard p,.cred-card>p{font-size:.91rem;line-height:1.58}
  .scard__ic{margin-bottom:1.15rem}
  .scard{min-height:0}

  .cashbook{margin-inline:8px;border-radius:24px}
  .cashbook .wrap{padding-inline:18px}
  .cashbook__head{margin-bottom:1.5rem}
  .product-grid{gap:.72rem}
  .product{padding:1.2rem;border-radius:17px}
  .product h3{font-size:1.15rem}
  .product p{font-size:.9rem;line-height:1.55}

  /* Contact panels now share one mobile spacing system. */
  .contact{padding-bottom:82px}
  .contact__grid{gap:.78rem}
  .contact__head,.formcard{
    height:auto;
    padding:1.3rem;
    border-radius:22px;
  }
  .contact__head h2{margin-top:.72rem}
  .contact__head .contact__intro{
    margin-top:.85rem;
    font-size:.98rem;
    line-height:1.58;
  }
  .contact__intro span{display:inline;white-space:normal}
  .contact__methods{margin-top:1.25rem;padding:.28rem .38rem;border-radius:19px}
  .cmethod,.cmethod--copy{
    min-height:70px;
    grid-template-columns:42px minmax(0,1fr) 28px;
    gap:.7rem;
    padding:.7rem .42rem;
    border-radius:14px;
  }
  .cmethod:hover{padding:.7rem .42rem}
  .cmethod__ic{width:42px;height:42px;border-radius:13px}
  .cmethod .lbl{font-size:.55rem;letter-spacing:.13em}
  .cmethod .val{font-size:.88rem;line-height:1.25}
  .local-time{font-size:.57rem;margin-top:.2rem}
  .cmethod .arr2,.copy-email__action{width:28px;height:28px}
  .formcard h3{font-size:1.7rem}
  .formcard .sub{margin-top:.38rem;font-size:.9rem;line-height:1.5}
  .formcard form{margin-top:1.25rem;gap:.86rem}
  .field label{margin-bottom:.42rem;font-size:.59rem}
  .field input,.field select{min-height:50px;padding:.78rem .9rem;border-radius:14px;font-size:16px}
  .field textarea{min-height:150px;padding:.86rem .9rem;border-radius:14px;font-size:16px}
  .field-meta{margin-top:.38rem;font-size:.66rem}
  .form-foot{gap:.7rem;margin-top:.25rem}
  .form-foot .btn{width:100%;min-height:50px;justify-content:center}
  .form-foot p{width:100%;margin:0;text-align:center;font-size:.78rem;line-height:1.45}

  /* Footer is compact without feeling compressed. */
  .foot{padding-top:3rem;padding-bottom:90px}
  .foot__top{gap:1.55rem;padding-bottom:1.8rem}
  .foot__brand p{margin-top:.72rem;font-size:.9rem;line-height:1.58}
  .foot__soc{margin-top:1rem}
  .foot__col h4{margin-bottom:.55rem}
  .foot__col a{padding:.25rem 0}
  .foot__bottom{gap:.55rem;padding-top:1.2rem;font-size:.75rem}

  /* Drawer spacing and tap targets are tuned for one-handed use. */
  .drawer__panel{
    width:min(94%,390px);
    padding:5.4rem 1.15rem calc(1.15rem + env(safe-area-inset-bottom,0px));
  }
  .drawer__brand{margin-bottom:.35rem}
  .drawer__appearance{margin:.62rem 0 .22rem;padding:.68rem .72rem;border-radius:14px}
  .drawer__panel .drawer__nav a{font-size:1.22rem;padding:.6rem .1rem}
  .drawer__actions{gap:.52rem;margin-top:.75rem;margin-bottom:.6rem}
  .drawer__panel .drawer__action{min-height:48px;padding:.72rem .8rem;border-radius:13px;font-size:.84rem}
  .drawer__meta{padding:.78rem .85rem;border-radius:14px}

  /* Fixed actions stay clear of device edges and the return-to-top button. */
  .mobile-actions{
    left:8px;
    right:8px;
    bottom:max(8px,env(safe-area-inset-bottom,0px));
    height:60px;
    padding:5px;
    border-radius:18px;
  }
  .mobile-actions a{min-width:0;font-size:.68rem}
  .site-top-control{
    right:12px;
    bottom:calc(76px + env(safe-area-inset-bottom,0px));
  }
}

@media (max-width:430px){
  :root{--pad:16px;--sect:66px}
  .nav{padding-inline:7px}
  .nav__inner{min-height:54px;padding-left:.72rem}
  .hero{padding-top:96px;padding-bottom:52px}
  .hero__name{font-size:clamp(3.25rem,17.5vw,4.35rem)}
  .hero__mobile-portrait{grid-template-columns:68px minmax(0,1fr);padding:.52rem}
  .hero__mobile-portrait img{width:68px;height:68px}
  .hero__role{font-size:.61rem}
  .hero__intro{font-size:.96rem}
  .hero__facts{grid-template-columns:1fr 1fr;margin-top:1.1rem}
  .fact{padding:.54rem .55rem}
  .statement .wrap{padding:1.35rem 1.1rem}
  .profile__aside,.profile__summary,.exp__item,.scard,.cred-card{padding:1.16rem}
  .contact__head,.formcard{padding:1.15rem}
  .contact__methods{margin-top:1.08rem}
  .cmethod,.cmethod--copy{grid-template-columns:39px minmax(0,1fr) 26px;gap:.62rem;min-height:66px}
  .cmethod__ic{width:39px;height:39px}
  .cmethod .val{font-size:.83rem}
  .formcard h3{font-size:1.55rem}
  .drawer__panel{width:96%;padding-inline:1rem}
  .theme-switch--drawer{--switch-w:66px;--switch-h:36px}
}

@media (max-width:350px){
  :root{--pad:14px}
  .hero__name{font-size:3.15rem}
  .hero__role{letter-spacing:.08em}
  .hero__mobile-portrait{grid-template-columns:60px minmax(0,1fr)}
  .hero__mobile-portrait img{width:60px;height:60px}
  .fact{font-size:.54rem}
  .mobile-actions a span{font-size:.62rem}
}

/* =========================================================================
   DESKTOP SECTION DOCK ALIGNMENT FIX — V22
   Keep every marker optically centred inside the right-side scroller.
   ========================================================================= */
@media (min-width:1321px){
  .section-dock{
    right:18px;
    align-items:center;
    justify-content:center;
    min-width:38px;
    padding:.9rem .45rem;
    box-sizing:border-box;
  }
  .section-dock a{
    width:28px;
    height:22px;
    flex:0 0 22px;
    align-items:center;
    justify-content:center;
  }
  .section-dock a::after{
    display:block;
    flex:0 0 auto;
    margin:0;
    transform-origin:center;
  }
  .section-dock a.active::after{
    width:5px;
    height:22px;
  }
  .section-dock a span{
    top:50%;
    right:calc(100% + 8px);
    transform:translate(8px,-50%);
  }
  .section-dock a:hover span,
  .section-dock a:focus-visible span{
    transform:translate(0,-50%);
  }
}


/* =========================================================================
   RELEASE QA — V23
   Final cross-device rhythm, accessibility and interaction safeguards.
   ========================================================================= */
html{
  overflow-x:clip;
  scroll-padding-top:96px;
  scrollbar-gutter:stable;
}
body{overflow-x:clip;text-rendering:optimizeLegibility}
section[id]{scroll-margin-top:96px}
h1,h2,h3,.hero__role,.eyebrow{text-wrap:balance}
p,.prose,.exp__desc,.scard p,.cred-card p,.product p{text-wrap:pretty}
img{height:auto}
.cmethod .val,.form-note,.foot__col a{overflow-wrap:anywhere}

/* Visible keyboard focus is consistent across light and dark surfaces. */
:where(a,button,input,select,textarea,[tabindex]):focus-visible{
  outline:3px solid color-mix(in srgb,var(--azure) 78%,white 22%);
  outline-offset:3px;
}

/* The right-side orientation control stays optically centred. */
@media (min-width:1321px){
  .section-dock{right:20px;width:40px;min-width:40px;padding:.9rem 0;align-items:center}
  .section-dock a{width:40px;justify-content:center}
  .section-dock a span{right:44px}
}

/* Prevent large desktop rows from feeling over-stretched on ultrawide screens. */
@media (min-width:1600px){
  .wrap{max-width:1240px}
  .hero__grid{gap:6rem}
  .contact__grid{gap:1.75rem}
}

/* Tablet and mobile consistency. */
@media (max-width:1000px){
  html{scroll-padding-top:78px;scrollbar-gutter:auto}
  section[id]{scroll-margin-top:78px}
  .hero__cta-row .btn{min-height:50px}
  .contact__grid{align-items:start}
}
@media (max-width:720px){
  html{scroll-padding-top:70px}
  section[id]{scroll-margin-top:70px}
  body{padding-bottom:calc(72px + env(safe-area-inset-bottom,0px))}
  .nav__inner{max-width:100%}
  .hero__cta-row{align-items:stretch}
  .hero__cta-row .btn{min-height:50px;justify-content:center}
  .hero__facts{align-items:stretch}
  .fact{display:flex;align-items:center;justify-content:center;min-height:42px;text-align:center}
  .profile__grid,.exp__grid,.sect-grid,.cred-grid,.product-grid{min-width:0}
  .profile__aside,.profile__summary,.exp__item,.scard,.cred-card,.product,.contact__head,.formcard{min-width:0}
  .field input,.field select,.field textarea{font-size:16px}
  .contact__methods{overflow:hidden}
  .cmethod,.cmethod--copy{width:100%;min-width:0}
  .form-note{line-height:1.45}
  .foot__bottom{align-items:flex-start}
}
@media (max-width:350px){
  .hero__cta-row{gap:.55rem}
  .hero__cta-row .btn{padding-inline:.8rem}
  .cmethod,.cmethod--copy{grid-template-columns:38px minmax(0,1fr) 24px}
  .cmethod .val{font-size:.79rem}
  .mobile-actions{left:6px;right:6px}
}

/* Preserve usability where blur/transparency is undesirable or expensive. */
@media (prefers-reduced-transparency:reduce){
  .nav__inner,.drawer__panel,.mobile-actions,.site-top-control{backdrop-filter:none!important;-webkit-backdrop-filter:none!important}
  .cursor-aura,.cursor-glow-layer{display:none!important}
}
@media (forced-colors:active){
  .btn,.cmethod,.exp__item,.scard,.cred-card,.product,.formcard,.contact__head{border:1px solid CanvasText}
  .theme-switch__thumb,.section-dock a::after{forced-color-adjust:auto}
}
