/* =========================================================================
   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}
}


/* =========================================================================
   V23.1 — contact navigation and mobile action-dock behaviour
   ========================================================================= */
/* Keep the contact target in normal layout so programmatic and anchor scrolling
   land accurately even when other long sections use content-visibility. */
.contact{content-visibility:visible;contain-intrinsic-size:auto}
/* During a deliberate contact jump, use real section geometry rather than
   deferred intrinsic estimates so the final landing point cannot drift. */
html.contact-scroll-layout section{content-visibility:visible!important;contain-intrinsic-size:auto!important}

@media (max-width:720px){
  /* Hidden before JavaScript runs; shown only after the visitor starts scrolling. */
  .mobile-actions{
    opacity:0;
    visibility:hidden;
    pointer-events:none;
    transform:translateY(calc(100% + 24px));
  }
  .mobile-actions.is-visible{
    opacity:1;
    visibility:visible;
    pointer-events:auto;
    transform:translateY(0);
  }
}


/* ==========================================================================
   V23.3 — Aurora Signal section navigator
   A desktop-only reading instrument: luminous progress spine, orbital cursor,
   numbered context labels and restrained magnetic depth.
   ========================================================================== */
@media (min-width:1321px){
  .section-dock{
    --dock-progress-pos:0%;
    --dock-progress-size:0%;
    --dock-shift-x:0px;
    --dock-shift-y:0px;
    right:22px;
    top:50%;
    width:58px;
    min-width:58px;
    padding:24px 8px;
    gap:11px;
    align-items:center;
    justify-content:center;
    overflow:visible;
    isolation:isolate;
    border:1px solid rgba(151,213,255,.2);
    border-radius:30px;
    background:
      linear-gradient(180deg,rgba(255,255,255,.075),transparent 18%,transparent 82%,rgba(255,255,255,.04)),
      radial-gradient(circle at 50% 6%,rgba(59,168,245,.17),transparent 36%),
      linear-gradient(155deg,rgba(11,35,57,.9),rgba(4,18,32,.94));
    box-shadow:
      0 28px 68px -30px rgba(0,0,0,.88),
      0 0 0 1px rgba(4,18,32,.42),
      inset 0 1px 0 rgba(255,255,255,.11),
      inset 0 -18px 36px rgba(0,0,0,.18);
    -webkit-backdrop-filter:blur(22px) saturate(165%);
    backdrop-filter:blur(22px) saturate(165%);
    transform:translate3d(var(--dock-shift-x),calc(-50% + var(--dock-shift-y)),0);
    transition:transform .24s var(--ease),border-color .3s ease,box-shadow .3s ease,background .3s ease;
  }
  .section-dock::before{
    content:"";
    position:absolute;
    inset:5px;
    z-index:-1;
    border-radius:25px;
    border:1px solid rgba(255,255,255,.035);
    background:
      linear-gradient(105deg,transparent 10%,rgba(255,255,255,.06) 38%,transparent 58%) 0 0/220% 100% no-repeat;
    pointer-events:none;
    animation:dockGlassSweep 8s ease-in-out infinite;
  }
  .section-dock::after{
    content:"";
    position:absolute;
    left:50%;
    top:12px;
    width:18px;
    height:3px;
    border-radius:99px;
    background:linear-gradient(90deg,transparent,rgba(116,206,255,.76),transparent);
    box-shadow:0 0 14px rgba(53,169,246,.4);
    transform:translateX(-50%);
    opacity:.72;
    pointer-events:none;
  }
  .section-dock:hover{
    border-color:rgba(142,216,255,.34);
    box-shadow:
      0 32px 78px -30px rgba(0,0,0,.92),
      0 0 34px -18px rgba(45,164,244,.76),
      inset 0 1px 0 rgba(255,255,255,.15),
      inset 0 -20px 38px rgba(0,0,0,.2);
  }
  .section-dock__progress{
    position:absolute;
    z-index:0;
    left:50%;
    top:31px;
    bottom:31px;
    width:2px;
    border-radius:999px;
    transform:translateX(-50%);
    background:linear-gradient(180deg,rgba(143,198,235,.24),rgba(102,156,197,.1));
    box-shadow:inset 0 0 0 1px rgba(255,255,255,.025);
    pointer-events:none;
  }
  .section-dock__progress::before{
    content:"";
    position:absolute;
    left:0;
    top:0;
    width:100%;
    height:var(--dock-progress-size);
    min-height:2px;
    border-radius:inherit;
    background:linear-gradient(180deg,#9BD9FF 0%,#42B3FF 34%,#0786E8 100%);
    box-shadow:0 0 12px rgba(61,177,253,.72),0 0 28px rgba(26,143,230,.28);
    transition:height .12s linear;
  }
  .section-dock__cursor{
    position:absolute;
    left:50%;
    top:var(--dock-progress-pos);
    width:16px;
    height:16px;
    border-radius:50%;
    background:radial-gradient(circle at 38% 34%,#fff 0 13%,#AEE3FF 15%,#2FABF8 48%,#087ED8 72%,#045C9E 100%);
    border:1px solid rgba(216,244,255,.82);
    box-shadow:
      0 0 0 4px rgba(46,169,246,.1),
      0 0 18px 4px rgba(42,164,242,.48),
      0 6px 18px -5px rgba(0,0,0,.95);
    transform:translate(-50%,-50%);
    transition:top .12s linear;
  }
  .section-dock__cursor::before{
    content:"";
    position:absolute;
    inset:-7px;
    border-radius:50%;
    background:conic-gradient(from 20deg,transparent 0 18%,rgba(119,210,255,.9) 24% 36%,transparent 42% 68%,rgba(38,158,235,.72) 74% 82%,transparent 88%);
    -webkit-mask:radial-gradient(circle,transparent 54%,#000 56% 64%,transparent 66%);
    mask:radial-gradient(circle,transparent 54%,#000 56% 64%,transparent 66%);
    animation:dockOrbit 5s linear infinite;
    opacity:.8;
  }
  .section-dock a{
    position:relative;
    z-index:2;
    width:42px;
    height:28px;
    flex:0 0 28px;
    display:flex;
    align-items:center;
    justify-content:center;
    border-radius:14px;
    outline:none;
    transition:background .26s ease,transform .28s var(--ease);
  }
  .section-dock a::before{
    content:"";
    position:absolute;
    width:27px;
    height:27px;
    border-radius:50%;
    background:conic-gradient(from 80deg,transparent 0 20%,rgba(123,213,255,.82) 27% 38%,transparent 45% 73%,rgba(38,157,234,.72) 79% 86%,transparent 92%);
    -webkit-mask:radial-gradient(circle,transparent 52%,#000 54% 62%,transparent 64%);
    mask:radial-gradient(circle,transparent 52%,#000 54% 62%,transparent 64%);
    opacity:0;
    transform:scale(.72) rotate(-35deg);
    transition:opacity .28s ease,transform .36s var(--ease);
    pointer-events:none;
  }
  .section-dock a::after{
    content:"";
    width:7px;
    height:7px;
    flex:0 0 auto;
    margin:0;
    border-radius:3px;
    background:linear-gradient(145deg,rgba(232,248,255,.78),rgba(108,165,203,.72));
    border:1px solid rgba(255,255,255,.24);
    box-shadow:0 0 0 3px rgba(122,194,239,.035),0 4px 9px -5px rgba(0,0,0,.95);
    transform:rotate(45deg);
    transform-origin:center;
    transition:width .3s var(--ease),height .3s var(--ease),border-radius .3s var(--ease),background .3s ease,box-shadow .3s ease,transform .3s var(--ease),opacity .3s ease;
  }
  .section-dock a:hover,
  .section-dock a:focus-visible{
    background:rgba(73,169,235,.08);
    transform:scale(1.04);
  }
  .section-dock a:hover::before,
  .section-dock a:focus-visible::before,
  .section-dock a.active::before{
    opacity:1;
    transform:scale(1) rotate(0deg);
  }
  .section-dock a:hover::after,
  .section-dock a:focus-visible::after{
    width:10px;
    height:10px;
    background:linear-gradient(145deg,#FFFFFF,#65C8FF 46%,#128FEA);
    box-shadow:0 0 0 4px rgba(63,177,246,.09),0 0 18px rgba(59,175,246,.5);
  }
  .section-dock a.active::after{
    width:13px;
    height:13px;
    border-radius:50%;
    background:radial-gradient(circle at 36% 30%,#fff 0 18%,#85D7FF 21%,#209FEF 56%,#0877C9 100%);
    border-color:rgba(223,247,255,.8);
    box-shadow:
      0 0 0 5px rgba(42,164,242,.11),
      0 0 22px 3px rgba(39,161,239,.5),
      0 7px 16px -8px rgba(0,0,0,.95);
    transform:none;
  }
  .section-dock a.active::before{animation:dockOrbit 5.5s linear infinite}
  .section-dock a span{
    position:absolute;
    top:50%;
    right:calc(100% + 12px);
    min-width:112px;
    padding:7px 10px 7px 8px;
    display:flex;
    align-items:center;
    gap:8px;
    border:1px solid rgba(147,211,252,.16);
    border-radius:12px;
    background:
      linear-gradient(135deg,rgba(255,255,255,.055),transparent 42%),
      rgba(5,24,41,.94);
    color:#ECF7FF;
    font-family:var(--mono);
    font-size:.56rem;
    font-weight:650;
    letter-spacing:.105em;
    line-height:1;
    text-transform:uppercase;
    white-space:nowrap;
    box-shadow:0 16px 38px -20px rgba(0,0,0,.94),inset 0 1px 0 rgba(255,255,255,.06);
    -webkit-backdrop-filter:blur(14px) saturate(145%);
    backdrop-filter:blur(14px) saturate(145%);
    opacity:0;
    transform:translate(10px,-50%) scale(.96);
    transform-origin:right center;
    pointer-events:none;
    transition:opacity .22s ease,transform .28s var(--ease),border-color .28s ease;
  }
  .section-dock a span::before{
    content:attr(data-step);
    width:25px;
    height:22px;
    display:grid;
    place-items:center;
    flex:0 0 25px;
    border-radius:8px;
    color:#8FD5FF;
    background:linear-gradient(145deg,rgba(49,165,239,.18),rgba(20,111,177,.07));
    border:1px solid rgba(102,196,252,.13);
    font-size:.5rem;
    letter-spacing:.06em;
  }
  .section-dock a span::after{
    content:"";
    position:absolute;
    right:-5px;
    top:50%;
    width:9px;
    height:9px;
    border-top:1px solid rgba(147,211,252,.16);
    border-right:1px solid rgba(147,211,252,.16);
    background:#0A2338;
    transform:translateY(-50%) rotate(45deg);
  }
  .section-dock a:hover span,
  .section-dock a:focus-visible span{
    opacity:1;
    transform:translate(0,-50%) scale(1);
  }
  .section-dock a.active span{
    border-color:rgba(102,196,252,.24);
    box-shadow:0 18px 42px -20px rgba(0,0,0,.96),0 0 24px -16px rgba(57,174,246,.7),inset 0 1px 0 rgba(255,255,255,.07);
  }
  .section-dock a.active span::before{
    color:#DDF5FF;
    background:linear-gradient(145deg,rgba(52,173,246,.36),rgba(14,101,168,.16));
    box-shadow:0 0 14px -7px rgba(65,185,255,.9);
  }
}

html[data-theme="light"] .section-dock{
  background:
    linear-gradient(180deg,rgba(255,255,255,.08),transparent 20%,transparent 82%,rgba(255,255,255,.04)),
    radial-gradient(circle at 50% 6%,rgba(59,168,245,.15),transparent 36%),
    linear-gradient(155deg,rgba(11,38,61,.91),rgba(4,20,35,.95));
  border-color:rgba(151,213,255,.21);
}

@keyframes dockOrbit{to{transform:scale(1) rotate(360deg)}}
@keyframes dockGlassSweep{0%,68%,100%{background-position:150% 0}82%{background-position:-120% 0}}

@media (prefers-reduced-motion:reduce){
  .section-dock,.section-dock::before,.section-dock__cursor,.section-dock__cursor::before,.section-dock a,.section-dock a::before,.section-dock a::after,.section-dock a span{animation:none!important;transition:none!important}
}


/* =========================================================================
   V23.4 — desktop command-deck header
   A split, pointer-responsive navigation system. Mobile/tablet remain intact.
   ========================================================================= */
.nav .brand__copy{display:inline-flex;align-items:baseline;gap:0}
.nav .brand__copy strong{font:inherit;color:inherit}
.nav .brand__copy small{display:none}
.nav__cta-icon{display:none}

@media (min-width:1001px){
  .nav{
    --nav-pointer-x:50%;
    --nav-pointer-y:50%;
    top:16px;
    padding-inline:clamp(16px,2vw,32px);
  }
  .nav__inner{
    width:min(1320px,calc(100vw - 32px));
    max-width:1320px;
    min-height:70px;
    margin-inline:auto;
    padding:0;
    display:grid;
    grid-template-columns:minmax(194px,226px) minmax(0,1fr) auto;
    align-items:center;
    gap:10px;
    overflow:visible;
    border:0!important;
    border-radius:0!important;
    background:transparent!important;
    box-shadow:none!important;
    backdrop-filter:none!important;
    -webkit-backdrop-filter:none!important;
    isolation:isolate;
    transform:none!important;
  }
  .nav.solid .nav__inner{min-height:64px;padding:0}
  .nav__inner::before{
    content:"";
    position:absolute;
    z-index:-2;
    left:160px;
    right:188px;
    top:50%;
    height:1px;
    transform:translateY(-50%);
    background:linear-gradient(90deg,transparent,rgba(100,195,255,.28) 14%,rgba(100,195,255,.12) 50%,rgba(100,195,255,.28) 86%,transparent);
    pointer-events:none;
  }
  .nav__inner::after{
    content:"";
    position:absolute;
    z-index:-1;
    width:310px;
    height:132px;
    left:var(--nav-pointer-x);
    top:var(--nav-pointer-y);
    transform:translate(-50%,-50%);
    border-radius:50%;
    background:radial-gradient(circle,rgba(56,174,247,.2),rgba(42,151,226,.08) 34%,transparent 70%);
    filter:blur(9px);
    opacity:.72;
    pointer-events:none;
    transition:opacity .3s ease;
  }
  .nav__inner:not(:hover)::after{opacity:.32}

  .nav .brand,
  .nav__links,
  .nav__right{
    position:relative;
    height:70px;
    min-width:0;
    border:1px solid rgba(151,211,248,.15);
    background:
      linear-gradient(135deg,rgba(255,255,255,.055),transparent 38%),
      rgba(5,24,42,.82);
    box-shadow:
      0 18px 46px -28px rgba(0,0,0,.9),
      inset 0 1px 0 rgba(255,255,255,.065),
      inset 0 -1px 0 rgba(0,0,0,.18);
    backdrop-filter:blur(24px) saturate(155%);
    -webkit-backdrop-filter:blur(24px) saturate(155%);
    transition:height .32s var(--ease),background .32s ease,border-color .32s ease,box-shadow .32s ease,transform .3s var(--ease);
  }
  .nav.solid .brand,.nav.solid .nav__links,.nav.solid .nav__right{height:64px}

  .nav .brand{
    justify-content:flex-start;
    gap:.72rem;
    padding:0 1rem 0 .72rem;
    border-radius:22px 11px 11px 22px;
    color:#F2F8FE;
    white-space:nowrap;
    overflow:hidden;
  }
  .nav .brand::after{
    content:"";
    position:absolute;
    right:0;
    top:13px;
    bottom:13px;
    width:1px;
    background:linear-gradient(transparent,rgba(97,190,248,.42),transparent);
  }
  .nav .brand__emblem{
    position:relative;
    width:42px;
    height:42px;
    flex:0 0 42px;
    display:grid;
    place-items:center;
    border-radius:14px 8px 14px 8px;
    background:linear-gradient(145deg,rgba(38,154,229,.28),rgba(8,70,119,.08));
    border:1px solid rgba(118,205,255,.24);
    box-shadow:inset 0 1px 0 rgba(255,255,255,.1),0 12px 24px -16px rgba(12,139,224,.8);
    transition:transform .34s var(--ease),border-radius .34s var(--ease),background .34s ease;
  }
  .nav .brand:hover .brand__emblem{transform:rotate(-4deg) scale(1.04);border-radius:9px 14px 9px 14px;background:linear-gradient(145deg,rgba(45,176,255,.4),rgba(8,82,139,.13))}
  .nav .brand__emblem::before,
  .nav .brand__emblem::after{
    content:"";
    position:absolute;
    width:5px;
    height:5px;
    border-radius:50%;
    background:#7FD2FF;
    box-shadow:0 0 13px rgba(65,188,255,.95);
  }
  .nav .brand__emblem::before{left:6px;top:6px}
  .nav .brand__emblem::after{right:6px;bottom:6px;opacity:.38}
  .nav .brand__mark{
    width:24px;
    height:15px;
    margin:0;
    background:linear-gradient(90deg,#8FDCFF,#2BA7F4);
    filter:drop-shadow(0 0 9px rgba(63,178,246,.5));
  }
  .nav .brand__emblem i{
    position:absolute;
    inset:5px;
    border-radius:10px 5px 10px 5px;
    border:1px solid rgba(137,216,255,.08);
    pointer-events:none;
  }
  .nav .brand__copy{
    min-width:0;
    display:flex;
    flex-direction:column;
    align-items:flex-start;
    justify-content:center;
    gap:.11rem;
    line-height:1;
  }
  .nav .brand__copy strong{font-size:1.04rem;font-weight:700;letter-spacing:-.025em}
  .nav .brand__copy small{
    display:block;
    color:#83A5C0;
    font-family:var(--mono);
    font-size:.51rem;
    font-weight:650;
    letter-spacing:.16em;
    text-transform:uppercase;
  }

  .nav__links{
    justify-self:stretch;
    justify-content:center;
    gap:3px;
    padding:7px;
    border-radius:11px;
    overflow:hidden;
  }
  .nav__links::before{
    content:"";
    position:absolute;
    inset:0;
    pointer-events:none;
    background:linear-gradient(105deg,transparent 0 42%,rgba(116,207,255,.055) 50%,transparent 58%);
    transform:translateX(-70%);
    transition:transform .8s var(--ease);
  }
  .nav__links:hover::before{transform:translateX(70%)}
  .nav__links a{
    position:relative;
    z-index:2;
    min-width:0;
    height:54px;
    padding:0 clamp(.62rem,1.05vw,.94rem);
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:.42rem;
    border-radius:9px;
    color:#BFD0E0;
    font-size:.79rem;
    font-weight:650;
    letter-spacing:-.008em;
    overflow:hidden;
    transition:color .24s ease,background .3s ease,box-shadow .3s ease,transform .28s var(--ease);
  }
  .nav.solid .nav__links a{height:48px}
  .nav__links a::before{
    content:attr(data-nav-no);
    flex:0 0 auto;
    color:#6D91AE;
    font-family:var(--mono);
    font-size:.48rem;
    letter-spacing:.06em;
    opacity:.58;
    transform:translateY(-.5px);
    transition:color .24s ease,opacity .24s ease,transform .28s var(--ease);
  }
  .nav__links a::after{display:none!important}
  .nav__links a:hover{
    color:#FFFFFF;
    background:rgba(114,202,255,.075);
    transform:translateY(-1px);
  }
  .nav__links a:hover::before{color:#80D2FF;opacity:1;transform:translateY(-.5px) scale(1.08)}
  .nav__links a.active{
    color:#FFFFFF!important;
    background:
      linear-gradient(135deg,rgba(73,184,251,.94),rgba(7,117,206,.95));
    box-shadow:
      0 13px 28px -16px rgba(29,157,238,.95),
      inset 0 1px 0 rgba(255,255,255,.3),
      inset 0 -1px 0 rgba(0,55,104,.25);
  }
  .nav__links a.active::before{color:#DDF5FF;opacity:.92}
  .nav__links a.active::after{
    content:""!important;
    display:block!important;
    position:absolute;
    width:46px;
    height:46px;
    right:-28px;
    top:-28px;
    left:auto;
    bottom:auto;
    border-radius:50%;
    background:radial-gradient(circle,rgba(255,255,255,.34),transparent 70%);
    opacity:.9;
    transform:none;
  }
  .nav__progress{
    position:absolute;
    z-index:3;
    left:9px;
    bottom:4px;
    width:calc((100% - 18px) * var(--page-progress));
    height:2px;
    border-radius:999px;
    transform:none;
    transform-origin:left;
    background:linear-gradient(90deg,#53C4FF,#1389E6);
    box-shadow:0 0 10px rgba(47,175,248,.65);
    opacity:.82;
    transition:width .12s linear,opacity .25s ease;
    pointer-events:none;
  }
  .nav__progress::after{
    content:"";
    position:absolute;
    right:-3px;
    top:50%;
    width:7px;
    height:7px;
    border-radius:50%;
    transform:translateY(-50%);
    background:#E8F8FF;
    border:1px solid #6DCBFF;
    box-shadow:0 0 0 4px rgba(53,178,247,.1),0 0 14px rgba(45,174,247,.8);
  }

  .nav__right{
    padding:7px;
    gap:6px;
    border-radius:11px 22px 22px 11px;
    justify-content:flex-end;
  }
  .nav__context{
    height:42px;
    max-width:118px;
    padding:0 .72rem;
    display:inline-flex;
    align-items:center;
    gap:.45rem;
    border-radius:10px;
    color:#8DA9BF;
    background:rgba(255,255,255,.035);
    border:1px solid rgba(160,213,247,.08);
    font-family:var(--mono);
    font-size:.49rem;
    font-weight:650;
    letter-spacing:.11em;
    text-transform:uppercase;
    overflow:hidden;
    text-overflow:ellipsis;
  }
  .nav__context::before{
    content:"";
    width:6px;
    height:6px;
    flex:0 0 6px;
    border-radius:50%;
    background:#42BEFF;
    box-shadow:0 0 0 4px rgba(54,178,245,.09),0 0 10px rgba(54,178,245,.8);
  }
  .nav .theme-switch{--switch-w:62px;--switch-h:42px}
  .nav .theme-switch__track{border-radius:11px}
  .nav__phone{
    height:42px;
    padding:0 .78rem;
    gap:.45rem;
    border-radius:10px;
    color:#D8E8F5!important;
    background:rgba(255,255,255,.04)!important;
    border:1px solid rgba(160,213,247,.08);
    font-family:var(--mono);
    font-size:.64rem;
    letter-spacing:.015em;
    box-shadow:none;
  }
  .nav__phone:hover{color:#FFFFFF!important;background:rgba(77,177,239,.11)!important;border-color:rgba(111,201,255,.2);transform:translateY(-1px)}
  .nav__phone svg{width:16px;height:16px;color:#6FCBFF!important}
  .nav__cta{
    min-height:42px;
    height:42px;
    padding:0 6px 0 .94rem;
    gap:.72rem;
    border-radius:11px 17px 17px 11px;
    border-color:rgba(255,255,255,.17);
    background:linear-gradient(135deg,#1798F0,#0876D5 72%);
    box-shadow:0 14px 28px -15px rgba(6,126,214,.95),inset 0 1px 0 rgba(255,255,255,.24);
    font-size:.78rem;
    font-weight:700;
    white-space:nowrap;
  }
  .nav__cta:hover{transform:translateY(-2px);background:linear-gradient(135deg,#27A9FA,#0C83E7 72%)}
  .nav__cta-icon{
    width:31px;
    height:31px;
    display:grid;
    place-items:center;
    border-radius:9px 13px 13px 9px;
    color:#FFFFFF;
    background:rgba(255,255,255,.13);
    box-shadow:inset 0 1px 0 rgba(255,255,255,.13);
    font-family:var(--sans);
    font-size:.94rem;
    transition:transform .3s var(--ease),background .3s ease;
  }
  .nav__cta:hover .nav__cta-icon{transform:translate(2px,-2px);background:rgba(255,255,255,.2)}

  /* Light shell after the hero. */
  .nav.solid .brand,
  .nav.solid .nav__links,
  .nav.solid .nav__right{
    background:
      linear-gradient(135deg,rgba(255,255,255,.94),rgba(244,249,253,.84));
    border-color:rgba(161,188,211,.36);
    box-shadow:0 18px 46px -30px rgba(7,28,47,.48),inset 0 1px 0 rgba(255,255,255,.96);
  }
  .nav.solid .brand{color:#0B2035}
  .nav.solid .brand__copy small{color:#698198}
  .nav.solid .brand__emblem{background:linear-gradient(145deg,rgba(21,143,224,.16),rgba(53,173,244,.05));border-color:rgba(37,153,226,.2)}
  .nav.solid .nav__links a{color:#425970}
  .nav.solid .nav__links a:hover{color:#0C263E;background:rgba(22,135,212,.065)}
  .nav.solid .nav__links a::before{color:#7190AA}
  .nav.solid .nav__links a.active{color:#FFFFFF!important}
  .nav.solid .nav__context{color:#557089;background:rgba(10,87,145,.035);border-color:rgba(25,122,190,.1)}
  .nav.solid .nav__phone{color:#304B64!important;background:rgba(10,87,145,.035)!important;border-color:rgba(25,122,190,.1)}
  .nav.solid .nav__phone:hover{color:#0B263E!important;background:rgba(15,125,204,.08)!important}
  .nav.solid .theme-switch__track{border-radius:11px}

  /* Dark theme keeps the command deck dark after scrolling. */
  html[data-theme="dark"] .nav.solid .brand,
  html[data-theme="dark"] .nav.solid .nav__links,
  html[data-theme="dark"] .nav.solid .nav__right{
    background:linear-gradient(135deg,rgba(255,255,255,.05),transparent 38%),rgba(5,22,38,.9);
    border-color:rgba(151,211,248,.14);
    box-shadow:0 18px 46px -28px rgba(0,0,0,.95),inset 0 1px 0 rgba(255,255,255,.055);
  }
  html[data-theme="dark"] .nav.solid .brand{color:#F2F8FE}
  html[data-theme="dark"] .nav.solid .brand__copy small{color:#83A5C0}
  html[data-theme="dark"] .nav.solid .nav__links a{color:#BFD0E0}
  html[data-theme="dark"] .nav.solid .nav__links a:hover{color:#FFFFFF;background:rgba(114,202,255,.075)}
  html[data-theme="dark"] .nav.solid .nav__context{color:#8DA9BF;background:rgba(255,255,255,.035);border-color:rgba(160,213,247,.08)}
  html[data-theme="dark"] .nav.solid .nav__phone{color:#D8E8F5!important;background:rgba(255,255,255,.04)!important;border-color:rgba(160,213,247,.08)}

  .nav .brand:focus-visible,
  .nav__links a:focus-visible,
  .nav__phone:focus-visible,
  .nav__cta:focus-visible,
  .nav .theme-switch:focus-visible{outline:3px solid rgba(69,184,250,.38);outline-offset:3px}
}

@media (min-width:1001px) and (max-width:1190px){
  .nav__inner{grid-template-columns:minmax(168px,190px) minmax(0,1fr) auto;gap:7px}
  .nav .brand{padding-left:.58rem;padding-right:.72rem;gap:.55rem}
  .nav .brand__emblem{width:38px;height:38px;flex-basis:38px}
  .nav .brand__copy small,.nav__context{display:none}
  .nav__links{gap:1px;padding:6px}
  .nav__links a{padding-inline:.58rem;font-size:.73rem}
  .nav__phone{width:42px;padding:0;justify-content:center}
  .nav__phone span{display:none}
  .nav .theme-switch{--switch-w:56px}
}

@media (prefers-reduced-motion:reduce){
  .nav__inner::after,.nav .brand__emblem,.nav__links::before,.nav__links a,.nav__cta-icon{transition:none!important}
}

/* ==========================================================================
   V23.5 — Executive Signal System
   Site-wide refinement aligned with the command header and Aurora navigator.
   ========================================================================== */
:root{
  --signal:#1598f0;
  --signal-hi:#7fd6ff;
  --signal-deep:#075fae;
  --night:#04101e;
  --night-2:#071a2e;
  --night-3:#0b2946;
  --ice:#edf7ff;
  --glass:rgba(255,255,255,.76);
  --glass-strong:rgba(255,255,255,.92);
  --signal-border:rgba(20,128,204,.15);
  --signal-shadow:0 34px 90px -52px rgba(4,25,44,.5),0 12px 32px -24px rgba(7,119,202,.28);
  --cut:18px;
}

.site-main{position:relative;overflow:clip}
.site-main::before{
  content:"";position:absolute;inset:0;z-index:-2;pointer-events:none;
  background:
    linear-gradient(90deg,transparent calc(50% - .5px),rgba(28,109,164,.045) 50%,transparent calc(50% + .5px)),
    radial-gradient(700px 440px at 8% 27%,rgba(23,151,239,.075),transparent 70%),
    radial-gradient(760px 520px at 95% 63%,rgba(26,133,210,.065),transparent 72%);
}
.site-main::after{
  content:"";position:absolute;inset:0;z-index:-1;pointer-events:none;opacity:.32;
  background-image:
    linear-gradient(rgba(13,92,150,.03) 1px,transparent 1px),
    linear-gradient(90deg,rgba(13,92,150,.03) 1px,transparent 1px);
  background-size:72px 72px;
  -webkit-mask-image:linear-gradient(to bottom,transparent 9%,#000 18%,#000 84%,transparent 96%);
  mask-image:linear-gradient(to bottom,transparent 9%,#000 18%,#000 84%,transparent 96%);
}

/* Section chapter telemetry */
.section[data-index]{isolation:isolate}
.section[data-index]::before{
  content:attr(data-index) "  /  " attr(data-chapter);
  position:absolute;z-index:0;top:clamp(22px,3.4vw,48px);left:max(22px,calc((100vw - var(--maxw))/2 + var(--pad)));
  font-family:var(--mono);font-size:.56rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;
  color:rgba(23,111,173,.48);white-space:nowrap;
}
.section[data-index]::after{
  content:"";position:absolute;z-index:0;top:clamp(34px,4.3vw,62px);left:max(22px,calc((100vw - var(--maxw))/2 + var(--pad)));right:max(22px,calc((100vw - var(--maxw))/2 + var(--pad)));
  height:1px;background:linear-gradient(90deg,rgba(26,142,218,.22),rgba(26,142,218,.035) 36%,transparent 78%);pointer-events:none;
}
.section[data-index]>.wrap{position:relative;z-index:1}

/* Hero — more architectural, while retaining the established identity. */
.hero{min-height:min(940px,100svh);border-radius:0 0 clamp(34px,5vw,74px) clamp(34px,5vw,74px);box-shadow:0 34px 90px -52px rgba(0,0,0,.85)}
.hero::after{
  height:210px;background:
    linear-gradient(to bottom,transparent,rgba(1,8,16,.31)),
    linear-gradient(90deg,rgba(43,167,244,.16),transparent 24%,transparent 76%,rgba(43,167,244,.1));
}
.hero__gridlines{opacity:.28;background-size:84px 84px;transform:perspective(900px) rotateX(56deg) scale(1.42);transform-origin:50% 84%}
.hero__lead::before{
  content:"EXECUTIVE / COMMERCIAL / DIGITAL";display:block;margin-bottom:1rem;color:rgba(142,211,250,.52);
  font-family:var(--mono);font-size:.55rem;font-weight:700;letter-spacing:.2em;
}
.hero__name{position:relative;display:inline-grid}
.hero__name::after{
  content:"";position:absolute;left:0;right:9%;bottom:-18px;height:2px;border-radius:10px;
  background:linear-gradient(90deg,var(--signal-hi),var(--signal),transparent 84%);box-shadow:0 0 22px rgba(41,173,249,.44)
}
.hero__intro{margin-top:2.35rem}
.hero__facts{position:relative;padding-left:1.1rem}
.hero__facts::before{content:"";position:absolute;left:0;top:6px;bottom:6px;width:2px;border-radius:3px;background:linear-gradient(var(--signal-hi),var(--signal),transparent)}
.hero__media::before,.hero__media::after{
  content:"";position:absolute;z-index:6;width:62px;height:62px;pointer-events:none;
  border-color:rgba(125,215,255,.72);filter:drop-shadow(0 0 12px rgba(52,176,244,.32));
}
.hero__media::before{left:-20px;top:-20px;border-left:2px solid;border-top:2px solid;border-radius:16px 0 0 0}
.hero__media::after{right:-20px;bottom:-20px;border-right:2px solid;border-bottom:2px solid;border-radius:0 0 16px 0}
.portrait{clip-path:polygon(0 0,calc(100% - 32px) 0,100% 32px,100% 100%,32px 100%,0 calc(100% - 32px));border-radius:28px}
.portrait::after{
  content:"";position:absolute;inset:0;z-index:3;pointer-events:none;
  background:linear-gradient(90deg,transparent 0 86%,rgba(78,192,255,.12)),linear-gradient(0deg,rgba(5,22,38,.34),transparent 28%);
}
.hero__float--top{clip-path:polygon(0 0,calc(100% - 13px) 0,100% 13px,100% 100%,0 100%);border-radius:13px 3px 13px 13px}
.hero__float--bottom{border-radius:10px 999px 999px 10px}
.scrollcue{font-size:.57rem;letter-spacing:.17em}

/* Capability transmission band */
.capability-strip{margin-top:-2px;background:linear-gradient(90deg,#04111f,#09233b 48%,#04111f);border-block:1px solid rgba(119,205,255,.1);box-shadow:0 18px 50px -32px rgba(4,18,32,.9)}
.capability-strip::before,.capability-strip::after{display:block!important;width:120px;z-index:4;pointer-events:none}
.capability-strip::before{background:linear-gradient(90deg,#04111f,transparent)}
.capability-strip::after{background:linear-gradient(-90deg,#04111f,transparent)}
.capability-group{gap:1rem}
.capability-group b{padding:.43rem .78rem;border:1px solid rgba(111,203,255,.18);border-radius:999px;background:rgba(43,164,237,.08);color:#9adeff}
.capability-group i{width:4px;height:4px;border-radius:50%;background:#42b8fa;box-shadow:0 0 10px rgba(66,184,250,.88)}

/* Positioning thesis */
.statement{padding-block:clamp(76px,9vw,126px)}
.statement .wrap{
  min-height:310px;display:grid;grid-template-columns:minmax(170px,.34fr) minmax(0,1fr);align-items:center;gap:clamp(2rem,5vw,5rem);
  padding:clamp(2rem,4.5vw,4.6rem);border-radius:0;clip-path:polygon(0 0,calc(100% - 38px) 0,100% 38px,100% 100%,38px 100%,0 calc(100% - 38px));
  border:1px solid rgba(28,132,202,.18);background:
    radial-gradient(360px 280px at 96% 8%,rgba(30,157,236,.15),transparent 70%),
    linear-gradient(140deg,rgba(255,255,255,.97),rgba(242,248,253,.85));
  box-shadow:var(--signal-shadow),inset 0 1px 0 #fff;
}
.statement .wrap::before{
  content:"01";position:absolute;left:clamp(1.6rem,4vw,4.4rem);top:50%;transform:translateY(-52%);
  color:rgba(11,113,187,.075);font-family:var(--mono);font-size:clamp(7rem,12vw,12.5rem);font-weight:700;line-height:1;
}
.statement .wrap::after{width:380px;height:380px;right:-110px;top:-170px;background:conic-gradient(from 80deg,transparent,rgba(43,172,247,.12),transparent 45%)}
.statement__side{position:relative;z-index:2;align-self:start;margin-top:.55rem;padding-top:1rem;border-top:2px solid var(--signal);color:var(--signal-deep);letter-spacing:.2em}
.statement__q{position:relative;z-index:2;max-width:20ch;font-size:clamp(2.25rem,4.3vw,4.75rem);line-height:.98;letter-spacing:-.056em}
.statement__q em{position:relative;color:var(--signal-deep);font-style:normal}
.statement__q em::after{content:"";position:absolute;left:0;right:0;bottom:.03em;height:.16em;background:rgba(30,157,236,.16);z-index:-1;transform:skewX(-12deg)}

/* Executive snapshot dashboard */
.snapshot{padding:0 0 clamp(80px,9vw,124px);background:transparent}
.snapshot__grid{display:grid;grid-template-columns:1.15fr 1fr 1fr .85fr;gap:10px}
.snapshot__item{
  position:relative;overflow:hidden;min-height:155px;padding:1.45rem 1.4rem 1.3rem;border:1px solid rgba(26,119,183,.13);border-radius:0;
  clip-path:polygon(0 0,calc(100% - 15px) 0,100% 15px,100% 100%,0 100%);
  background:linear-gradient(145deg,rgba(255,255,255,.95),rgba(246,250,254,.78));box-shadow:0 20px 56px -44px rgba(5,35,57,.55);transition:transform .34s var(--ease),border-color .3s,box-shadow .3s;
}
.snapshot__item::before{content:"";position:absolute;inset:auto 0 0;height:3px;background:linear-gradient(90deg,var(--signal),var(--signal-hi),transparent 78%);transform:scaleX(.32);transform-origin:left;transition:transform .45s var(--ease)}
.snapshot__item::after{content:"0" counter(snapshot);counter-increment:snapshot;position:absolute;right:1rem;top:.9rem;font:700 .58rem/1 var(--mono);letter-spacing:.12em;color:rgba(18,117,182,.34)}
.snapshot__grid{counter-reset:snapshot}
.snapshot__item:hover{transform:translateY(-6px);border-color:rgba(25,144,218,.28);box-shadow:0 26px 70px -42px rgba(4,55,91,.5)}
.snapshot__item:hover::before{transform:scaleX(1)}
.snapshot__label{font-size:.55rem;letter-spacing:.18em}
.snapshot__item strong{margin-top:auto;font-size:clamp(1.25rem,1.5vw,1.55rem)}
.snapshot__item small{color:#6d8298}

/* Profile: editorial command board */
.profile{padding-top:clamp(105px,11vw,156px);padding-bottom:clamp(100px,11vw,160px)}
.profile__grid{grid-template-columns:minmax(300px,.44fr) minmax(0,1fr);gap:clamp(1rem,2.2vw,1.6rem);align-items:start}
.profile__aside{
  position:sticky;top:118px;overflow:hidden;padding:clamp(1.7rem,2.8vw,2.7rem);border:1px solid rgba(103,193,247,.17);border-radius:0;
  clip-path:polygon(0 0,calc(100% - 26px) 0,100% 26px,100% 100%,26px 100%,0 calc(100% - 26px));
  color:#dcebf7;background:
    radial-gradient(340px 260px at 85% 0%,rgba(35,157,231,.22),transparent 72%),
    linear-gradient(150deg,#061422,#0a2944);box-shadow:0 34px 82px -46px rgba(1,22,38,.84);
}
.profile__aside::before{content:"PROFILE / 01";position:absolute;right:1.4rem;top:1.25rem;font:700 .52rem/1 var(--mono);letter-spacing:.16em;color:rgba(129,209,255,.46)}
.profile__aside::after{content:"";position:absolute;right:-80px;bottom:-90px;width:240px;height:240px;border:1px solid rgba(93,190,247,.12);border-radius:50%;box-shadow:0 0 0 34px rgba(93,190,247,.03),0 0 0 68px rgba(93,190,247,.025)}
.profile__aside .eyebrow{color:#85d4ff}.profile__aside h2{color:#fff;font-size:clamp(2.4rem,3.7vw,4.5rem);line-height:.93;max-width:8ch;margin-top:1.3rem}
.profile__signoff{position:relative;z-index:2;margin-top:2.5rem;padding-top:1.25rem;border-top:1px solid rgba(151,211,248,.14)}
.profile__avatar{border:2px solid rgba(124,211,255,.32);box-shadow:0 0 0 5px rgba(70,166,225,.08)}
.profile__signoff .nm{color:#fff}.profile__signoff .rl{color:#8fb0c7}
.profile__summary{position:relative;z-index:2;margin-top:1.4rem;padding:0;border:0;background:transparent;box-shadow:none}
.profile__summary>div{padding:.92rem 0;border-bottom:1px solid rgba(151,211,248,.11)}
.profile__summary>div:last-child{border-bottom:0}
.profile__summary span{color:#7fb5d7}.profile__summary strong{color:#fff;font-size:.92rem}
.profile__body{
  position:relative;padding:clamp(2rem,4vw,4.25rem);border:1px solid rgba(18,112,177,.13);border-radius:0;
  clip-path:polygon(24px 0,100% 0,100% calc(100% - 24px),calc(100% - 24px) 100%,0 100%,0 24px);
  background:linear-gradient(145deg,rgba(255,255,255,.96),rgba(246,250,254,.86));box-shadow:var(--signal-shadow)
}
.profile__body::before{content:"";position:absolute;left:0;top:0;width:6px;height:38%;background:linear-gradient(var(--signal-hi),var(--signal),transparent)}
.profile__copy{max-width:72ch}
.profile__copy>p{font-size:1.02rem;line-height:1.78;color:#40536a}
.profile__copy .dropcap::first-letter{font-size:4.2rem;line-height:.73;color:var(--signal-deep);font-weight:700;margin-right:.12em}
.pull{margin:2.2rem 0;padding:1.55rem 1.65rem 1.55rem 2rem;border:1px solid rgba(57,155,218,.16);border-left:3px solid var(--signal);border-radius:0;background:linear-gradient(90deg,rgba(25,151,231,.09),rgba(25,151,231,.02));font-size:clamp(1.28rem,2.1vw,1.85rem);line-height:1.28;color:#0a3353}

/* Working approach: connected route map */
.approach{position:relative;overflow:hidden;padding:clamp(86px,10vw,132px) 0;background:linear-gradient(128deg,#04111f,#08243d 52%,#0b3151);color:#d9e9f5}
.approach::before{content:"";position:absolute;inset:0;background:radial-gradient(480px 300px at 8% 18%,rgba(35,156,232,.2),transparent 72%),radial-gradient(520px 340px at 95% 88%,rgba(43,171,246,.14),transparent 70%);pointer-events:none}
.approach::after{content:"";position:absolute;inset:0;opacity:.18;background-image:linear-gradient(rgba(133,211,255,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(133,211,255,.05) 1px,transparent 1px);background-size:58px 58px;mask-image:linear-gradient(90deg,black,transparent 82%)}
.approach__grid{grid-template-columns:minmax(260px,.48fr) minmax(0,1fr);gap:clamp(3rem,7vw,7rem)}
.approach__intro{position:sticky;top:135px;align-self:start}
.approach__intro .eyebrow{color:#7fd4ff}.approach__intro h2{color:#fff;font-size:clamp(3rem,5vw,5.9rem);line-height:.88;max-width:8ch;margin-top:1.35rem}
.approach__items{position:relative;display:grid;gap:13px}
.approach__items::before{content:"";position:absolute;left:31px;top:42px;bottom:42px;width:2px;background:linear-gradient(var(--signal-hi),var(--signal),rgba(54,170,237,.12));box-shadow:0 0 18px rgba(41,169,241,.22)}
.approach__item{
  position:relative;display:grid;grid-template-columns:64px 1fr;gap:1.2rem;min-height:150px;padding:1.65rem 1.6rem 1.65rem 0;border:1px solid rgba(132,208,251,.13);border-radius:0;
  clip-path:polygon(0 0,calc(100% - 18px) 0,100% 18px,100% 100%,0 100%);background:linear-gradient(145deg,rgba(255,255,255,.07),rgba(255,255,255,.025));box-shadow:inset 0 1px 0 rgba(255,255,255,.04)
}
.approach__item>span{position:relative;z-index:2;width:42px;height:42px;margin-left:10px;display:grid;place-items:center;border-radius:50%;background:linear-gradient(145deg,#39b4f8,#0877d5);border:1px solid rgba(255,255,255,.3);box-shadow:0 0 0 7px rgba(49,168,236,.08),0 10px 28px -14px rgba(20,150,229,.9);color:#fff;font:700 .62rem/1 var(--mono)}
.approach__item h3{color:#fff;font-size:1.35rem;line-height:1.08}.approach__item p{color:#9fb4c6;max-width:54ch;margin-top:.55rem}
.approach__item:hover{border-color:rgba(116,203,251,.27);background:linear-gradient(145deg,rgba(52,167,234,.12),rgba(255,255,255,.035))}

/* Expertise bento matrix */
.expertise{padding-block:clamp(112px,12vw,168px);background:linear-gradient(180deg,rgba(255,255,255,.28),rgba(233,244,252,.38))}
.exp__head{align-items:end;margin-bottom:clamp(2rem,4vw,3.6rem)}
.exp__head p{max-width:38ch;padding-left:1.2rem;border-left:2px solid rgba(17,133,209,.22)}
.exp__grid{display:grid;grid-template-columns:repeat(12,minmax(0,1fr));gap:12px}
.exp__item{
  position:relative;min-height:220px;padding:1.65rem;border:1px solid rgba(20,116,181,.13);border-radius:0;overflow:hidden;
  clip-path:polygon(0 0,calc(100% - 17px) 0,100% 17px,100% 100%,0 100%);
  background:linear-gradient(145deg,rgba(255,255,255,.96),rgba(246,250,254,.8));box-shadow:0 24px 60px -46px rgba(4,45,76,.46);
  transition:transform .34s var(--ease),border-color .3s,box-shadow .3s,background .3s;
}
.exp__item:nth-child(1){grid-column:span 5}.exp__item:nth-child(2){grid-column:span 7}
.exp__item:nth-child(3),.exp__item:nth-child(4),.exp__item:nth-child(5){grid-column:span 4}
.exp__item:nth-child(6){grid-column:span 12;min-height:178px;padding-right:36%}
.exp__item::before{content:"";position:absolute;inset:0;opacity:0;background:radial-gradient(360px circle at var(--mx,50%) var(--my,50%),rgba(39,165,239,.15),transparent 58%);transition:opacity .3s}
.exp__item::after{content:"";position:absolute;right:-64px;bottom:-84px;width:210px;height:210px;border:1px solid rgba(20,134,206,.09);border-radius:50%;box-shadow:0 0 0 32px rgba(20,134,206,.025),0 0 0 64px rgba(20,134,206,.018)}
.exp__item:hover{transform:translateY(-7px);border-color:rgba(22,144,219,.3);box-shadow:0 34px 82px -48px rgba(3,55,91,.55)}
.exp__item:hover::before{opacity:1}
.exp__item .brand__mark{position:relative;z-index:2;width:30px;height:18px;filter:drop-shadow(0 0 11px rgba(29,150,224,.26))}
.exp__index{position:absolute;right:1.35rem;top:1.2rem;font-size:.58rem;letter-spacing:.14em;color:rgba(15,115,181,.4)}
.exp__term{position:relative;z-index:2;margin-top:auto;font-size:clamp(1.55rem,2.25vw,2.35rem);line-height:1;max-width:13ch}
.exp__desc{position:relative;z-index:2;max-width:45ch;margin-top:.7rem;color:#60758b}
.exp__item:nth-child(3){color:#dcecf8;background:linear-gradient(145deg,#061729,#0b3150);border-color:rgba(102,197,249,.2)}
.exp__item:nth-child(3) .exp__term{color:#fff}.exp__item:nth-child(3) .exp__desc{color:#a6bdcf}.exp__item:nth-child(3) .exp__index{color:rgba(129,213,255,.48)}.exp__item:nth-child(3) .brand__mark{background:#73d1ff!important}
.exp__item:nth-child(6)::after{right:4%;bottom:-85px;width:260px;height:260px}

/* Sector constellation */
.sectors{padding-block:clamp(108px,11vw,158px)}
.sectors__head{display:grid;grid-template-columns:minmax(0,.75fr) minmax(260px,.35fr);gap:clamp(2rem,6vw,6rem);align-items:end;margin-bottom:clamp(2rem,4vw,3.4rem)}
.sectors__head .eyebrow,.sectors__head .h2{grid-column:1}.sectors__head p{grid-column:2;grid-row:1/3;padding:1.2rem 0 1.2rem 1.35rem;border-left:1px solid rgba(24,125,190,.2)}
.sect-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}
.scard{
  position:relative;min-height:310px;padding:1.55rem 1.35rem;border:1px solid rgba(20,118,182,.13);border-radius:0;overflow:hidden;
  clip-path:polygon(0 0,calc(100% - 17px) 0,100% 17px,100% 100%,0 100%);
  background:linear-gradient(155deg,rgba(255,255,255,.94),rgba(244,249,253,.78));box-shadow:0 24px 60px -47px rgba(4,45,76,.52)
}
.scard::before{content:"SECTOR / " attr(data-no);position:absolute;left:1.35rem;top:1.2rem;color:rgba(13,110,175,.42);font:700 .5rem/1 var(--mono);letter-spacing:.15em}
.scard::after{content:"";position:absolute;left:1.35rem;right:1.35rem;top:58px;height:1px;background:linear-gradient(90deg,rgba(23,141,215,.22),transparent)}
.scard__ic{width:58px;height:58px;margin-top:3.4rem;border-radius:17px 5px 17px 5px;background:linear-gradient(145deg,rgba(29,158,236,.14),rgba(29,158,236,.035));border:1px solid rgba(31,148,219,.17);box-shadow:inset 0 1px 0 rgba(255,255,255,.8)}
.scard h3{margin-top:auto;font-size:1.55rem;line-height:1.05}.scard p{color:#687c91}
.scard:hover{transform:translateY(-8px);border-color:rgba(24,145,219,.28);box-shadow:0 36px 82px -50px rgba(3,55,91,.55)}
.scard:nth-child(even){transform:translateY(28px)}.scard:nth-child(even):hover{transform:translateY(20px)}

/* Credentials — modular qualification ledger */
.credentials{padding-block:clamp(120px,12vw,174px);background:linear-gradient(180deg,rgba(232,242,250,.3),rgba(255,255,255,.48))}
.cred__head{align-items:end;margin-bottom:clamp(2.2rem,4.5vw,4rem)}
.cred__head>p{padding:1.25rem;border:1px solid rgba(18,118,182,.11);background:rgba(255,255,255,.52);clip-path:polygon(0 0,calc(100% - 13px) 0,100% 13px,100% 100%,0 100%)}
.cred__grid{display:grid;grid-template-columns:1fr 1fr 1.12fr;gap:12px}
.cred-card{
  position:relative;min-height:470px;padding:1.75rem 1.65rem;border-radius:0;overflow:hidden;
  clip-path:polygon(0 0,calc(100% - 19px) 0,100% 19px,100% 100%,19px 100%,0 calc(100% - 19px));
  border:1px solid rgba(20,118,182,.14);background:linear-gradient(145deg,rgba(255,255,255,.96),rgba(246,250,254,.84));box-shadow:0 28px 72px -50px rgba(4,45,76,.5)
}
.cred-card::before{content:"";position:absolute;left:0;top:0;width:100%;height:4px;background:linear-gradient(90deg,var(--signal),var(--signal-hi),transparent 76%)}
.cred-card__kicker{display:inline-flex;padding:.42rem .62rem;border-radius:999px;background:rgba(20,141,217,.07);border:1px solid rgba(20,141,217,.1)}
.cred-card h3{font-size:clamp(1.8rem,2.5vw,2.55rem);line-height:.98;margin-top:1.3rem}.cred-card p{color:#667b90}
.cred-list{margin-top:1.5rem;display:grid;gap:.75rem}
.cred-list li{position:relative;padding:.75rem .8rem .75rem 2rem;border:1px solid rgba(18,118,182,.09);background:rgba(240,247,252,.68)}
.cred-list li::before{left:.8rem;top:1.05rem;width:7px;height:7px;border-radius:2px;background:linear-gradient(145deg,var(--signal-hi),var(--signal));box-shadow:0 0 10px rgba(25,154,230,.35)}
.cred-card--accent{background:radial-gradient(320px 220px at 94% 0%,rgba(43,174,246,.2),transparent 70%),linear-gradient(145deg,#051524,#0a3150);border-color:rgba(110,203,252,.18);color:#dbeaf6}
.cred-card--accent h3{color:#fff}.cred-card--accent .cred-card__kicker{color:#8bd7ff;background:rgba(58,179,245,.09);border-color:rgba(112,207,255,.14)}
.role-line{padding:1.2rem 0;border-top:1px solid rgba(144,209,247,.12)}.role-line strong{color:#fff}.role-line span{color:#9eb7c9}

/* Cashbook role module */
.cashbook{margin-inline:clamp(12px,2.2vw,30px);border-radius:0;clip-path:polygon(0 0,calc(100% - 44px) 0,100% 44px,100% 100%,44px 100%,0 calc(100% - 44px));padding-block:clamp(112px,12vw,166px)}
.cashbook::before{background:radial-gradient(620px 440px at 93% 3%,rgba(39,169,244,.3),transparent 67%),radial-gradient(500px 420px at 2% 100%,rgba(12,113,190,.2),transparent 68%),linear-gradient(120deg,rgba(255,255,255,.025),transparent 48%)}
.cashbook::after{opacity:.28;background-size:56px 56px;mask-image:linear-gradient(90deg,transparent 0,black 36%,black)}
.cashbook__chev{opacity:.085;right:-5%;bottom:-8%;width:42%;transform:rotate(-9deg)}
.cb__grid{grid-template-columns:minmax(0,.78fr) minmax(420px,.72fr);gap:clamp(3rem,7vw,7.5rem);align-items:center}
.cb__chip{display:inline-flex;max-width:220px;padding:.72rem 1rem;border:1px solid rgba(151,217,255,.12);background:rgba(255,255,255,.055);clip-path:polygon(0 0,calc(100% - 12px) 0,100% 12px,100% 100%,0 100%)}
.cb__role{margin-top:1.4rem;padding:.7rem .9rem;border:1px solid rgba(131,205,245,.11);background:rgba(255,255,255,.035);clip-path:polygon(0 0,calc(100% - 9px) 0,100% 9px,100% 100%,0 100%)}
.cb p{color:#aec2d2;font-size:1.03rem;line-height:1.75}.cb p strong{color:#fff}
.cb__products{display:grid;gap:12px}
.product{
  position:relative;min-height:220px;padding:1.6rem;border-radius:0;overflow:hidden;
  clip-path:polygon(0 0,calc(100% - 19px) 0,100% 19px,100% 100%,0 100%);
  border:1px solid rgba(131,205,245,.14);background:linear-gradient(145deg,rgba(255,255,255,.08),rgba(255,255,255,.025));box-shadow:inset 0 1px 0 rgba(255,255,255,.05)
}
.product::before{content:"";position:absolute;inset:0;opacity:0;background:radial-gradient(380px circle at var(--mx,50%) var(--my,50%),rgba(64,182,248,.18),transparent 58%);transition:opacity .3s}
.product:hover{transform:translateY(-6px);border-color:rgba(122,211,255,.32);background:linear-gradient(145deg,rgba(61,172,237,.12),rgba(255,255,255,.035))}.product:hover::before{opacity:1}
.product h3{font-size:clamp(1.75rem,2.4vw,2.45rem)}.product p{position:relative;z-index:1;color:#a9bfd0}.product__badge{position:relative;z-index:1;background:rgba(63,181,243,.09);border:1px solid rgba(114,209,255,.15);color:#8edaff}
.product__arrow{width:46px;height:46px;display:grid;place-items:center;border-radius:14px 4px 14px 4px;background:linear-gradient(145deg,#31aff7,#0877d4);box-shadow:0 14px 34px -18px rgba(29,162,237,.9)}

/* Contact — executive communications console */
.contact{padding-block:clamp(112px,12vw,168px);background:linear-gradient(180deg,transparent,rgba(224,239,250,.42))}
.contact__grid{
  position:relative;display:grid;grid-template-columns:minmax(340px,.72fr) minmax(0,1fr);gap:12px;padding:12px;
  border:1px solid rgba(17,112,176,.14);background:rgba(255,255,255,.54);box-shadow:var(--signal-shadow);
  clip-path:polygon(0 0,calc(100% - 30px) 0,100% 30px,100% 100%,30px 100%,0 calc(100% - 30px));
}
.contact__head{
  min-height:100%;padding:clamp(1.7rem,3.5vw,3.4rem);border:1px solid rgba(122,205,250,.15);border-radius:0;
  clip-path:polygon(0 0,calc(100% - 20px) 0,100% 20px,100% 100%,0 100%);
  background:radial-gradient(390px 260px at 95% 0%,rgba(48,175,244,.2),transparent 70%),linear-gradient(145deg,#051523,#0a3151);box-shadow:none;color:#dbeaf5
}
.contact__head::before{content:"COMMS / OPEN";position:absolute;right:1.4rem;top:1.25rem;color:rgba(126,212,255,.5);font:700 .5rem/1 var(--mono);letter-spacing:.16em}
.contact__head .eyebrow{color:#80d4ff}.contact__head .h2{color:#fff;font-size:clamp(3.2rem,5vw,5.7rem)}
.contact__intro{color:#a8bfce}.contact__intro span{display:block}
.contact__methods{margin-top:2rem;display:grid;gap:8px}
.cmethod,.cmethod--copy{
  min-height:74px;border-radius:0;clip-path:polygon(0 0,calc(100% - 10px) 0,100% 10px,100% 100%,0 100%);
  border:1px solid rgba(133,207,247,.11);background:rgba(255,255,255,.045);box-shadow:none;color:#fff
}
.cmethod:hover,.cmethod--copy:hover{border-color:rgba(121,209,255,.24);background:rgba(55,172,236,.09);transform:translateX(4px)}
.cmethod__ic{border-radius:12px 4px 12px 4px;background:rgba(41,164,231,.12);color:#86d8ff}.cmethod .lbl{color:#79b4d8}.cmethod .val{color:#eef8ff}.local-time{color:#77d2ff}.cmethod .arr2{color:#7ed5ff}
.formcard{
  min-height:100%;padding:clamp(1.8rem,3.6vw,3.6rem);border:1px solid rgba(20,118,182,.11);border-radius:0;
  clip-path:polygon(20px 0,100% 0,100% calc(100% - 20px),calc(100% - 20px) 100%,0 100%,0 20px);
  background:linear-gradient(145deg,rgba(255,255,255,.98),rgba(245,249,253,.91));box-shadow:none
}
.formcard::before{content:"MESSAGE / SECURE FORM";position:absolute;right:1.5rem;top:1.35rem;color:rgba(15,112,177,.38);font:700 .49rem/1 var(--mono);letter-spacing:.14em}
.formcard h3{font-size:clamp(2rem,3vw,3.1rem)}
.field input,.field select,.field textarea{border-radius:0;clip-path:polygon(0 0,calc(100% - 8px) 0,100% 8px,100% 100%,0 100%);background:rgba(241,247,252,.82);border-color:rgba(23,117,180,.12)}
.field input:focus,.field select:focus,.field textarea:focus{background:#fff;border-color:rgba(18,139,214,.42);box-shadow:0 0 0 4px rgba(27,151,225,.08)}
.form-foot{align-items:center}.form-foot .btn{clip-path:polygon(0 0,calc(100% - 10px) 0,100% 10px,100% 100%,10px 100%,0 calc(100% - 10px));border-radius:0}

/* Footer continuation of the signal language */
.foot{position:relative;padding-top:clamp(70px,8vw,105px);background:linear-gradient(150deg,#03101d,#061b2e 55%,#082744)}
.foot::before{content:"";position:absolute;left:0;right:0;top:0;height:2px;background:linear-gradient(90deg,transparent,var(--signal-hi),var(--signal),transparent);box-shadow:0 0 20px rgba(35,169,244,.32)}
.foot__top{border-bottom-color:rgba(147,209,245,.12)}
.foot__soc a{border-radius:12px 4px 12px 4px;background:rgba(255,255,255,.045);border:1px solid rgba(150,213,248,.11)}
.foot__soc a:hover{background:rgba(42,167,235,.12);border-color:rgba(114,208,255,.24)}

/* Buttons and back-to-top receive the same angular signature. */
.btn{border-radius:11px 4px 11px 4px}
.nav .btn{border-radius:11px 17px 17px 11px}
.site-top-control{border-radius:16px 5px 16px 5px}

/* Dark theme continuity */
html[data-theme="dark"] .site-main{background:#050d18}
html[data-theme="dark"] .site-main::after{opacity:.15}
html[data-theme="dark"] .statement .wrap,
html[data-theme="dark"] .snapshot__item,
html[data-theme="dark"] .profile__body,
html[data-theme="dark"] .exp__item:not(:nth-child(3)),
html[data-theme="dark"] .scard,
html[data-theme="dark"] .cred-card:not(.cred-card--accent),
html[data-theme="dark"] .formcard{
  background:linear-gradient(145deg,rgba(13,34,52,.94),rgba(7,22,37,.9));border-color:rgba(114,198,244,.14);box-shadow:0 28px 72px -46px rgba(0,0,0,.9)
}
html[data-theme="dark"] .statement__q,
html[data-theme="dark"] .snapshot__item strong,
html[data-theme="dark"] .profile__body h2,
html[data-theme="dark"] .profile__copy,
html[data-theme="dark"] .exp__item:not(:nth-child(3)) .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{color:#f4f9fd}
html[data-theme="dark"] .profile__copy>p,
html[data-theme="dark"] .exp__item:not(:nth-child(3)) .exp__desc,
html[data-theme="dark"] .scard p,
html[data-theme="dark"] .cred-card:not(.cred-card--accent) p{color:#a6bacb}
html[data-theme="dark"] .cred-list li,html[data-theme="dark"] .field input,html[data-theme="dark"] .field select,html[data-theme="dark"] .field textarea{background:rgba(255,255,255,.035);border-color:rgba(127,202,244,.11);color:#eaf4fb}
html[data-theme="dark"] .contact__grid{background:rgba(7,24,40,.72);border-color:rgba(111,199,247,.13)}

/* Tablet — retain character without forcing desktop geometry. */
@media (max-width:1180px){
  .snapshot__grid{grid-template-columns:repeat(2,1fr)}
  .profile__aside{position:relative;top:auto}
  .exp__item:nth-child(n){grid-column:span 6}.exp__item:nth-child(6){padding-right:1.65rem}
  .sect-grid{grid-template-columns:repeat(2,1fr)}.scard:nth-child(even){transform:none}.scard:nth-child(even):hover{transform:translateY(-8px)}
  .cred__grid{grid-template-columns:1fr 1fr}.cred-card--accent{grid-column:1/-1;min-height:auto}
  .cb__grid{grid-template-columns:1fr;gap:2.5rem}.cb__products{grid-template-columns:1fr 1fr}
}

/* Mobile — intentionally designed, not compressed. */
@media (max-width:720px){
  :root{--cut:13px}
  .site-main::after{background-size:44px 44px;opacity:.22}
  .section[data-index]::before{top:18px;left:20px;font-size:.49rem}
  .section[data-index]::after{top:31px;left:20px;right:20px}
  .hero{min-height:auto;padding-top:94px;padding-bottom:54px;border-radius:0 0 28px 28px}
  .hero__gridlines{background-size:46px 46px;opacity:.2}
  .hero__lead::before{font-size:.47rem;letter-spacing:.13em;margin-bottom:.75rem}
  .hero__name{font-size:clamp(3.8rem,18vw,5.2rem);line-height:.82}
  .hero__name::after{bottom:-11px;right:18%}
  .hero__role{margin-top:1.45rem;gap:.42rem;font-size:.55rem;letter-spacing:.08em}
  .hero__mobile-portrait{margin-top:1.5rem;border-radius:0;clip-path:polygon(0 0,calc(100% - 18px) 0,100% 18px,100% 100%,18px 100%,0 calc(100% - 18px));border-color:rgba(129,210,255,.19)}
  .hero__mobile-portrait figcaption{border-radius:10px 3px 10px 3px}
  .hero__intro{margin-top:1.4rem;font-size:1.03rem;line-height:1.56}
  .hero__cta-row{display:grid;grid-template-columns:1fr;gap:.65rem;margin-top:1.35rem}.hero__cta-row .btn{border-radius:10px 3px 10px 3px}
  .hero__facts{display:grid;grid-template-columns:1fr 1fr;gap:7px;margin-top:1.2rem;padding-left:0}.hero__facts::before{display:none}.fact{min-height:44px;border-radius:0;clip-path:polygon(0 0,calc(100% - 7px) 0,100% 7px,100% 100%,0 100%);font-size:.57rem;padding:.55rem .5rem}.fact:last-child{grid-column:1/-1}
  .scrollcue{display:none}
  .capability-strip{padding-block:.7rem}.capability-group{gap:.7rem}.capability-group b{padding:.34rem .55rem}.capability-group span{font-size:.57rem}
  .statement{padding:54px 14px}.statement .wrap{min-height:auto;display:block;padding:1.55rem 1.25rem 1.65rem;clip-path:polygon(0 0,calc(100% - 20px) 0,100% 20px,100% 100%,20px 100%,0 calc(100% - 20px))}.statement .wrap::before{left:auto;right:.7rem;top:.5rem;transform:none;font-size:5.8rem}.statement__side{display:inline-block;margin:0 0 1rem;padding-top:.6rem}.statement__q{font-size:clamp(1.9rem,9.6vw,2.65rem);max-width:none}
  .snapshot{padding-inline:14px;padding-bottom:66px}.snapshot__grid{grid-template-columns:1fr;gap:8px;padding-inline:0}.snapshot__item{min-height:116px;padding:1.2rem;clip-path:polygon(0 0,calc(100% - 12px) 0,100% 12px,100% 100%,0 100%)}.snapshot__item strong{font-size:1.3rem}
  .profile{padding:84px 14px 78px}.profile .wrap{padding-inline:0}.profile__grid{grid-template-columns:1fr;gap:10px}.profile__aside{padding:1.45rem;clip-path:polygon(0 0,calc(100% - 19px) 0,100% 19px,100% 100%,19px 100%,0 calc(100% - 19px))}.profile__aside h2{font-size:2.55rem;max-width:9ch}.profile__signoff{margin-top:1.7rem}.profile__summary{margin-top:1rem}.profile__summary>div{padding:.75rem 0}.profile__body{padding:1.35rem 1.15rem;clip-path:polygon(15px 0,100% 0,100% calc(100% - 15px),calc(100% - 15px) 100%,0 100%,0 15px)}.profile__copy>p{font-size:.96rem;line-height:1.67}.profile__copy .dropcap::first-letter{font-size:3.2rem}.pull{margin:1.35rem 0;padding:1.1rem 1rem 1.1rem 1.2rem;font-size:1.18rem}
  .approach{padding:72px 14px}.approach .wrap{padding-inline:0}.approach__grid{grid-template-columns:1fr;gap:1.4rem}.approach__intro{position:relative;top:auto}.approach__intro h2{font-size:3rem}.approach__items{gap:8px}.approach__items::before{left:25px;top:32px;bottom:32px}.approach__item{grid-template-columns:52px 1fr;min-height:auto;padding:1.25rem .95rem 1.25rem 0;gap:.7rem;clip-path:polygon(0 0,calc(100% - 13px) 0,100% 13px,100% 100%,0 100%)}.approach__item>span{width:34px;height:34px;margin-left:8px}.approach__item h3{font-size:1.17rem}.approach__item p{font-size:.88rem;line-height:1.55}
  .expertise{padding:86px 14px}.expertise .wrap{padding-inline:0}.exp__head{display:block;margin-bottom:1.4rem}.exp__head p{margin-top:1rem;padding-left:.85rem}.exp__grid{display:grid;grid-template-columns:1fr;gap:8px}.exp__item:nth-child(n){grid-column:auto;min-height:180px;padding:1.3rem}.exp__item:nth-child(6){padding-right:1.3rem}.exp__term{font-size:1.65rem}.exp__desc{font-size:.89rem}
  .sectors{padding:84px 14px}.sectors .wrap{padding-inline:0}.sectors__head{display:block;margin-bottom:1.4rem}.sectors__head .eyebrow,.sectors__head .h2,.sectors__head p{display:block}.sectors__head p{margin-top:1rem;padding:.85rem 0 .85rem 1rem}.sect-grid{grid-template-columns:1fr;gap:8px}.scard{min-height:205px;padding:1.25rem}.scard::before{left:1.25rem}.scard::after{left:1.25rem;right:1.25rem}.scard__ic{width:50px;height:50px;margin-top:3rem}.scard h3{font-size:1.45rem}.scard:nth-child(even),.scard:nth-child(even):hover{transform:none}
  .credentials{padding:88px 14px}.credentials .wrap{padding-inline:0}.cred__head{display:block;margin-bottom:1.4rem}.cred__head>p{margin-top:1rem;padding:1rem}.cred__grid{grid-template-columns:1fr;gap:8px}.cred-card,.cred-card--accent{grid-column:auto;min-height:auto;padding:1.35rem;clip-path:polygon(0 0,calc(100% - 14px) 0,100% 14px,100% 100%,14px 100%,0 calc(100% - 14px))}.cred-card h3{font-size:1.8rem}.cred-list li{font-size:.86rem}
  .cashbook{margin-inline:8px;padding:84px 0;clip-path:polygon(0 0,calc(100% - 24px) 0,100% 24px,100% 100%,24px 100%,0 calc(100% - 24px))}.cashbook .wrap{padding-inline:16px}.cb__grid{grid-template-columns:1fr;gap:1.6rem}.cb__chip{max-width:175px}.cb p{font-size:.94rem;line-height:1.66}.cb__products{grid-template-columns:1fr;gap:8px}.product{min-height:190px;padding:1.25rem}.product h3{font-size:1.7rem}.product__arrow{width:40px;height:40px}
  .contact{padding:86px 8px}.contact>.wrap{padding-inline:0}.contact__grid{grid-template-columns:1fr;gap:8px;padding:8px;clip-path:polygon(0 0,calc(100% - 20px) 0,100% 20px,100% 100%,20px 100%,0 calc(100% - 20px))}.contact__head,.formcard{padding:1.35rem;clip-path:polygon(0 0,calc(100% - 14px) 0,100% 14px,100% 100%,0 100%)}.contact__head .h2{font-size:3rem}.contact__head::before,.formcard::before{font-size:.42rem;right:1rem;top:.9rem}.contact__intro span{display:inline}.contact__methods{margin-top:1.3rem}.cmethod,.cmethod--copy{min-height:68px}.formcard h3{font-size:2rem}.formcard .sub{max-width:26ch}.field-2{grid-template-columns:1fr}.form-foot{display:grid}.form-foot .btn{border-radius:0;clip-path:polygon(0 0,calc(100% - 9px) 0,100% 9px,100% 100%,9px 100%,0 calc(100% - 9px))}
  .foot{padding-top:3.5rem}.foot__top{grid-template-columns:1fr 1fr}.foot__brand{grid-column:1/-1}.foot__bottom{display:grid;gap:.5rem}
  .mobile-actions{border-radius:13px 4px 13px 4px;clip-path:polygon(0 0,calc(100% - 12px) 0,100% 12px,100% 100%,12px 100%,0 calc(100% - 12px))}
}

@media (max-width:390px){
  .hero__name{font-size:3.65rem}.hero__role{font-size:.51rem}.statement__q{font-size:1.88rem}.profile__aside h2,.approach__intro h2,.contact__head .h2{font-size:2.65rem}.h2{font-size:2.45rem}
}

@media (prefers-reduced-motion:reduce){
  .snapshot__item,.exp__item,.scard,.product,.cmethod{transition:none!important}
}

/* V23.5.1 — layout hardening after cross-viewport validation */
.approach__item>.cursor-glow-layer{
  position:absolute!important;inset:0!important;z-index:0!important;width:auto!important;height:auto!important;margin:0!important;
  display:block!important;border-radius:0!important;background:radial-gradient(360px circle at var(--cursor-glow-x,50%) var(--cursor-glow-y,50%),rgba(68,181,244,.13),transparent 68%)!important;
  opacity:0;pointer-events:none;transition:opacity .28s ease!important;
}
.approach__item.is-cursor-lit>.cursor-glow-layer{opacity:1}
.approach__item>span:not(.cursor-glow-layer){grid-column:1;grid-row:1;align-self:start}
.approach__item>div{grid-column:2;grid-row:1;min-width:0;width:auto;position:relative;z-index:2}

@media (min-width:721px){
  .sectors__head{grid-template-columns:minmax(460px,.9fr) minmax(330px,.5fr);column-gap:clamp(4rem,8vw,8rem)}
  .sectors__head .h2{max-width:7.4ch}
  .sectors__head p{align-self:end}
}

@media (max-width:720px){
  .hero .anim{transition:none!important}
  .hero__role{opacity:1!important;transform:none!important;position:relative;z-index:3;white-space:nowrap}
  .hero__mobile-portrait{position:relative;z-index:4;background:linear-gradient(135deg,rgba(20,58,91,.98),rgba(12,41,69,.98));overflow:hidden}
  .approach__item>div{grid-column:2;grid-row:1}
}

/* Restore the hero telemetry label to normal flow; the base theme used this pseudo-element as a decorative orb. */
.hero__lead::before{
  position:static!important;left:auto!important;top:auto!important;width:auto!important;height:auto!important;
  border-radius:0!important;background:none!important;pointer-events:none;
}

/* V23.5.1 — keep the opening identity anchored to the left on tablet and mobile. */
@media (max-width:1000px){
  .hero__lead{text-align:left}
  .hero__eyebrow{justify-content:flex-start}
  .hero__name{text-align:left;justify-self:start;width:100%}
  .hero__role{justify-content:flex-start;text-align:left}
  .hero__intro{margin-inline:0;text-align:left}
  .hero__cta-row{justify-content:flex-start;margin-inline:0}
  .hero__facts{justify-content:flex-start;margin-inline:0}
}

@media (max-width:430px){
  .hero__facts{margin-inline:0}
}

/* ==========================================================================
   V23.5.2 — requested composition and control refinements
   ========================================================================== */

/* Opening identity: the name now owns the left edge and the director signal
   occupies the position previously held by the name. */
.hero__identity-line{
  width:100%;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:clamp(.8rem,1.25vw,1.15rem);
}
.hero__identity-line .hero__name{flex:0 0 auto;margin:0;justify-self:start}
.hero__identity-line .hero__eyebrow{
  flex:1 1 230px;
  min-width:0;
  margin:0;
  justify-content:flex-start;
  line-height:1.45;
}
/* Remove the decorative corner that was visually enclosing “Growth”. */
.hero__media::before{display:none!important}

/* Centre the complete identity group inside the left header module. */
@media (min-width:1001px){
  .nav .brand{justify-content:center;padding-inline:.8rem}
  .nav .brand__copy{align-items:center;text-align:center}
}

/* Cashbook role line and reverse transparent logo share one optical centre. */
.cb__identity{
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  gap:clamp(1rem,2vw,1.6rem);
  margin-bottom:1.9rem;
}
.cb__identity .cb__eyebrow{margin:0;flex:0 0 auto}
.cb__identity .cb__chip{
  margin:0;
  padding:0;
  max-width:205px;
  min-height:54px;
  display:flex;
  align-items:center;
  background:transparent;
  border:0;
  border-radius:0;
  box-shadow:none;
  clip-path:none;
}
.cb__identity .cb__chip img{display:block;width:auto;height:52px;object-fit:contain}

/* Product links use a dedicated action column: no absolute positioning,
   no collision with headings, badges or descriptive text. */
.product{
  display:grid;
  grid-template-columns:minmax(0,1fr) 48px;
  align-items:center;
  gap:1.25rem;
  padding:1.6rem!important;
}
.product__content{min-width:0;position:relative;z-index:1}
.product__content .product__top{margin-bottom:.72rem}
.product__content p{margin:0;padding:0}
.product .product__arrow{
  position:static;
  inset:auto;
  align-self:center;
  justify-self:end;
  transform:none;
  flex:0 0 auto;
}
.product:hover .product__arrow{transform:translate(3px,-3px)}

/* The contact introduction now uses the complete inner width established by
   the panel padding, producing equal structural spacing on both sides. */
.contact__head .contact__intro{
  width:100%;
  max-width:none!important;
  margin-left:0;
  margin-right:0;
  padding-left:0;
  padding-right:0;
}

/* Floating appearance control: mirrored partner to the return-to-top control. */
.site-theme-control{
  position:fixed;
  left:clamp(18px,2vw,28px);
  bottom:clamp(18px,2vw,28px);
  z-index:118;
  width:52px;
  height:52px;
  padding:0;
  border:0;
  border-radius:16px 5px 16px 5px;
  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-theme-control::before{
  content:"";
  position:absolute;
  inset:3px;
  z-index:-1;
  border-radius:13px 4px 13px 4px;
  background:linear-gradient(145deg,rgba(20,74,112,.94),rgba(7,31,52,.98));
  border:1px solid rgba(143,211,255,.16);
}
.site-theme-control__ring{
  position:absolute;
  inset:0;
  border-radius:inherit;
  background:conic-gradient(from -45deg,rgba(67,180,252,.9),rgba(67,180,252,.12) 34%,transparent 35% 65%,rgba(133,218,255,.62) 66%,rgba(67,180,252,.9));
  -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;
  opacity:.82;
  transition:transform .55s var(--ease),opacity .28s;
}
.site-theme-control svg{
  position:absolute;
  width:20px;
  height:20px;
  z-index:1;
  filter:drop-shadow(0 4px 8px rgba(0,0,0,.22));
  transition:opacity .28s var(--ease),transform .34s var(--ease),color .28s ease;
}
.site-theme-control__sun{opacity:1;transform:scale(1) rotate(0deg)}
.site-theme-control__moon{opacity:0;transform:scale(.72) rotate(18deg)}
.site-theme-control[aria-pressed="true"] .site-theme-control__sun{opacity:0;transform:scale(.72) rotate(-18deg)}
.site-theme-control[aria-pressed="true"] .site-theme-control__moon{opacity:1;transform:scale(1) rotate(0deg)}
.site-theme-control.is-visible{
  opacity:1;
  visibility:visible;
  pointer-events:auto;
  transform:none;
}
.site-theme-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-theme-control:hover::before{background:linear-gradient(145deg,#168fe8,#0871c7);border-color:rgba(255,255,255,.22)}
.site-theme-control:hover .site-theme-control__ring{transform:rotate(42deg);opacity:1}
.site-theme-control:active{transform:translateY(-1px) scale(.96)}
.site-theme-control:focus-visible{outline:3px solid rgba(86,184,255,.42);outline-offset:4px}
html[data-theme="light"] .site-theme-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);
}

/* Quieter Aurora navigator: retain the distinctive interaction while reducing
   its visual footprint and glow. */
@media (min-width:1321px){
  .section-dock{
    right:14px;
    width:42px;
    min-width:42px;
    padding:17px 4px;
    gap:7px;
    border-radius:23px;
    border-color:rgba(151,213,255,.15);
    box-shadow:0 22px 48px -31px rgba(0,0,0,.82),inset 0 1px 0 rgba(255,255,255,.075),inset 0 -12px 26px rgba(0,0,0,.14);
  }
  .section-dock::before{inset:4px;border-radius:19px}
  .section-dock::after{top:9px;width:12px;height:2px;opacity:.56}
  .section-dock:hover{box-shadow:0 26px 58px -31px rgba(0,0,0,.88),0 0 24px -18px rgba(45,164,244,.56),inset 0 1px 0 rgba(255,255,255,.12)}
  .section-dock__progress{top:23px;bottom:23px;width:1.5px}
  .section-dock__cursor{width:12px;height:12px;box-shadow:0 0 0 3px rgba(46,169,246,.075),0 0 12px 2px rgba(42,164,242,.36),0 5px 13px -5px rgba(0,0,0,.9)}
  .section-dock__cursor::before{inset:-5px;opacity:.66}
  .section-dock a{width:32px;height:22px;flex-basis:22px;border-radius:11px}
  .section-dock a::before{width:21px;height:21px}
  .section-dock a::after{width:5px;height:5px;border-radius:2px}
  .section-dock a:hover::after,.section-dock a:focus-visible::after{width:8px;height:8px}
  .section-dock a.active::after{width:10px;height:10px;box-shadow:0 0 0 4px rgba(42,164,242,.08),0 0 15px 2px rgba(39,161,239,.4),0 6px 13px -8px rgba(0,0,0,.92)}
  .section-dock a span{right:calc(100% + 9px);min-width:104px;padding:6px 9px 6px 7px;font-size:.52rem}
  .section-dock a span::before{width:22px;height:20px;flex-basis:22px;font-size:.46rem}
}

@media (max-width:1000px){
  .hero__identity-line{display:block}
  .hero__identity-line .hero__eyebrow{margin-top:1.15rem;margin-bottom:0;width:100%}
}

@media (max-width:720px){
  .product{grid-template-columns:minmax(0,1fr) 42px;gap:.8rem;padding:1.25rem!important}
  .product .product__arrow{width:40px;height:40px}
  .cb__identity{gap:.85rem;margin-bottom:1.35rem}
  .cb__identity .cb__chip{max-width:170px;min-height:44px}
  .cb__identity .cb__chip img{height:42px}
  .site-theme-control{
    width:46px;
    height:46px;
    left:12px;
    bottom:calc(76px + env(safe-area-inset-bottom,0px));
  }
  .site-theme-control svg{width:18px;height:18px}
}

@media (max-width:430px){
  .hero__identity-line .hero__eyebrow{margin-top:.95rem}
  .cb__identity{align-items:center}
  .cb__identity .cb__eyebrow{font-size:.55rem}
  .cb__identity .cb__chip{max-width:145px}
  .cb__identity .cb__chip img{height:36px}
}

@media (prefers-reduced-motion:reduce){
  .site-theme-control,.site-theme-control svg,.site-theme-control__ring{transition:none!important}
}
/* Remove the remaining rotated media frame that intersected the Growth label. */
.hero__media::after{display:none!important}


/* ==========================================================================
   V23.5.3 — finishing fixes requested after visual QA
   ========================================================================== */

/* Footer brand now mirrors the command-header identity. */
.foot__brand-lockup{
  display:inline-flex;
  align-items:center;
  gap:.82rem;
  color:#fff;
  text-decoration:none;
}
.foot__brand-lockup .brand__emblem{
  position:relative;
  width:42px;
  height:42px;
  flex:0 0 42px;
  display:grid;
  place-items:center;
  border-radius:14px 8px 14px 8px;
  background:linear-gradient(145deg,rgba(38,154,229,.28),rgba(8,70,119,.08));
  border:1px solid rgba(118,205,255,.24);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.1),0 12px 24px -16px rgba(12,139,224,.8);
}
.foot__brand-lockup .brand__emblem::before,
.foot__brand-lockup .brand__emblem::after{
  content:"";
  position:absolute;
  width:5px;
  height:5px;
  border-radius:50%;
  background:#7FD2FF;
  box-shadow:0 0 13px rgba(65,188,255,.95);
}
.foot__brand-lockup .brand__emblem::before{left:6px;top:6px}
.foot__brand-lockup .brand__emblem::after{right:6px;bottom:6px;opacity:.38}
.foot__brand-lockup .brand__emblem i{
  position:absolute;
  inset:5px;
  border-radius:10px 5px 10px 5px;
  border:1px solid rgba(137,216,255,.08);
  pointer-events:none;
}
.foot__brand-lockup .brand__mark{
  width:24px;
  height:15px;
  margin:0;
  background:linear-gradient(90deg,#8FDCFF,#2BA7F4);
  filter:drop-shadow(0 0 9px rgba(63,178,246,.5));
}
.foot__brand-lockup .brand__copy{display:flex;flex-direction:column;align-items:flex-start;justify-content:center;gap:.16rem;line-height:1}
.foot__brand-lockup .brand__copy strong{font-size:1.04rem;font-weight:700;letter-spacing:-.025em;color:#fff}
.foot__brand-lockup .brand__copy small{display:block;color:#83A5C0;font-family:var(--mono);font-size:.51rem;font-weight:650;letter-spacing:.16em;text-transform:uppercase}

/* Contact rows: keep email addresses on a single line. */
.contact__methods .cmethod[href^="mailto:"] .val,
.contact__methods .cmethod--copy .val{
  white-space:nowrap;
  overflow-wrap:normal;
  word-break:normal;
  font-size:clamp(.84rem,.78rem + .22vw,.98rem);
  letter-spacing:-.015em;
}
.contact__methods .cmethod[href^="mailto:"] .cmethod__body,
.contact__methods .cmethod--copy .cmethod__body,
.contact__methods .cmethod[href^="mailto:"] > span:nth-child(2){min-width:0}

/* Community roles: organisation on one row, period on its own line. */
.role-line .role-org,
.role-line .role-period{
  display:block;
  font-family:var(--mono);
  font-size:.68rem;
  line-height:1.55;
}
.role-line .role-org{color:var(--on-dark-mut);margin-top:.28rem}
.role-line .role-period{color:#8FA8C0;margin-top:.08rem}

/* Cashbook identity: smaller logo, cleaner title. */
.cb__identity .cb__chip{max-width:178px;min-height:46px}
.cb__identity .cb__chip img{height:40px}
.cb__role{letter-spacing:.16em}

/* Product cards: avoid title wrapping and keep the action lane clean. */
.product__top{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  align-items:start;
  gap:.8rem 1rem;
}
.product h3{
  white-space:nowrap;
  font-size:clamp(1.32rem,1.18rem + .42vw,1.78rem);
  line-height:1.05;
}
.product__badge{align-self:start}

/* Sector icons: slightly crisper and more premium. */
.scard__ic svg{width:24px;height:24px}

/* Remove decorative portrait corners on hover. */
.hero__media::before,
.hero__media::after{display:none!important}

/* Header spacing and stronger numeric contrast while scrolling. */
@media (min-width:1001px){
  .nav .brand{justify-content:center;padding:7px 14px}
  .nav__right{padding:7px 10px;gap:8px}
  .nav__context,.nav__phone,.nav__cta{margin:0}
  .nav__links a::before{
    font-size:.54rem;
    font-weight:700;
    opacity:.92;
    color:#88ABC6;
    text-shadow:0 0 10px rgba(11,19,31,.28);
  }
  .nav.solid .nav__links a::before{color:#6F90AD;opacity:1}
  html[data-theme="dark"] .nav.solid .nav__links a::before{color:#9EC7E8}
  html[data-theme="light"] .nav.solid .nav__links a::before{color:#5D7F9D}
  .nav__links a.active::before{color:#F2FAFF!important;opacity:1}
}

/* Footer text lock-up matches the hero/header vocabulary. */
.foot__brand p{max-width:32ch}

/* Right dock: smaller, quieter and centre-aligned with the back-to-top control. */
@media (min-width:1321px){
  .section-dock{
    right:calc(clamp(18px,2vw,28px) + 8px)!important;
    width:36px!important;
    min-width:36px!important;
    padding:14px 4px!important;
    border-radius:22px!important;
  }
  .section-dock::before{border-radius:18px!important}
  .section-dock__progress{top:21px!important;bottom:21px!important;width:1.5px!important}
  .section-dock__cursor{width:11px!important;height:11px!important}
  .section-dock a{width:28px!important;height:20px!important;flex-basis:20px!important}
  .section-dock a::before{width:18px!important;height:18px!important}
  .section-dock a::after{width:4px!important;height:4px!important}
  .section-dock a.active::after{width:9px!important;height:9px!important}
}

@media (max-width:720px){
  .contact__methods .cmethod[href^="mailto:"] .val,
  .contact__methods .cmethod--copy .val{font-size:clamp(.7rem,3.15vw,.88rem)}
  .product h3{font-size:clamp(1.24rem,5.1vw,1.46rem)}
}


/* ==========================================================================
   V23.5.4 — contact-system cleanup, square hero transition and type polish
   ========================================================================== */

/* The hero now meets the capability rail with a clean, architectural edge. */
.hero{
  border-radius:0!important;
  box-shadow:none!important;
}

/* Site-wide typography: predictable rhythm, cleaner wrapping and line lengths. */
:where(h1,h2,h3,h4,.hero__name,.statement__q,.exp__term){
  text-wrap:balance;
  hanging-punctuation:first last;
}
:where(p,li,.lead,.prose,.exp__desc,.scard p,.cred-card p,.product p,.contact__intro,.formcard .sub){
  text-wrap:pretty;
  orphans:3;
  widows:3;
}
:where(.prose p,.profile__copy>p,.cb>div>p,.contact__intro,.formcard .sub){
  max-width:62ch;
}
:where(.eyebrow,.snapshot__label,.product__badge,.role-period,.role-org,.local-time,.field label){
  text-rendering:geometricPrecision;
}

/* Contact console: one coherent surround, two consistent panels and restrained accents. */
.contact{
  background:linear-gradient(180deg,rgba(228,240,250,.22),rgba(222,237,248,.54));
}
.contact__grid{
  position:relative;
  gap:12px;
  padding:12px;
  border:1px solid rgba(28,116,176,.16);
  border-radius:28px;
  clip-path:none!important;
  overflow:hidden;
  background:linear-gradient(145deg,rgba(255,255,255,.78),rgba(238,246,252,.74));
  box-shadow:0 34px 90px -60px rgba(7,43,72,.48),inset 0 1px 0 rgba(255,255,255,.94);
}
.contact__grid::before{
  content:""!important;
  display:block!important;
  position:absolute;
  left:30px;
  right:30px;
  top:0;
  height:2px;
  background:linear-gradient(90deg,transparent,rgba(55,177,245,.62),rgba(55,177,245,.2),transparent);
  pointer-events:none;
}
.contact__grid::after{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  border-radius:inherit;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.46);
}
.contact__head,
.formcard{
  border-radius:20px!important;
  clip-path:none!important;
  overflow:hidden;
}
.contact__head{
  border:1px solid rgba(118,202,249,.16);
  background:
    radial-gradient(440px 300px at 100% 0%,rgba(47,173,243,.18),transparent 68%),
    linear-gradient(145deg,#061827,#0A3150);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.045),0 24px 62px -52px rgba(0,0,0,.88);
}
.contact__head::before,
.formcard::before{
  top:1.45rem;
  right:1.65rem;
  opacity:.86;
}
.contact__head::after,
.formcard::after{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  border-radius:inherit;
  box-shadow:inset 0 0 0 1px rgba(143,211,251,.06);
}
.contact__methods{
  padding:6px;
  gap:6px;
  border:1px solid rgba(135,207,247,.13);
  border-radius:18px;
  overflow:hidden;
  background:rgba(255,255,255,.035);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.035);
}
.cmethod,
.cmethod--copy{
  min-height:76px;
  margin:0!important;
  padding:1rem .85rem!important;
  border:1px solid rgba(137,207,246,.09)!important;
  border-radius:13px!important;
  clip-path:none!important;
  background:linear-gradient(105deg,rgba(255,255,255,.052),rgba(255,255,255,.025));
  transform:none!important;
}
.cmethod::before{border-radius:inherit!important}
.cmethod:hover,
.cmethod:focus-visible{
  padding:1rem .85rem!important;
  border-color:rgba(121,209,255,.25)!important;
  background:linear-gradient(105deg,rgba(55,172,236,.12),rgba(255,255,255,.035));
  transform:translateY(-1px)!important;
}
.cmethod__ic{border-radius:12px!important}
.cmethod .arr2,
.copy-email__action{flex:0 0 auto}
.cmethod--location .val{
  white-space:nowrap;
  overflow-wrap:normal;
  word-break:normal;
  font-size:clamp(.86rem,.8rem + .2vw,1rem);
  letter-spacing:-.012em;
}
.formcard{
  border:1px solid rgba(25,111,169,.12);
  background:
    radial-gradient(420px 260px at 0 0,rgba(87,181,244,.13),transparent 70%),
    linear-gradient(145deg,rgba(255,255,255,.99),rgba(246,250,253,.96));
  box-shadow:inset 0 1px 0 rgba(255,255,255,.96),0 24px 62px -52px rgba(7,51,82,.46);
}
.formcard h3::after{height:2px;border-radius:2px}
.field input,
.field select,
.field textarea{
  border-radius:10px!important;
  clip-path:none!important;
  border-color:rgba(23,117,180,.14);
  background:rgba(239,246,251,.82);
}
.form-foot .btn{
  border-radius:11px 4px 11px 4px;
  clip-path:none!important;
}

/* Dark theme receives the same geometry, with tuned surface contrast. */
html[data-theme="dark"] .contact{
  background:linear-gradient(180deg,#061321,#071725);
}
html[data-theme="dark"] .contact__grid{
  border-color:rgba(131,205,245,.13);
  background:linear-gradient(145deg,rgba(8,30,50,.9),rgba(4,19,33,.94));
  box-shadow:0 38px 92px -58px rgba(0,0,0,.92),inset 0 1px 0 rgba(255,255,255,.035);
}
html[data-theme="dark"] .contact__grid::after{
  box-shadow:inset 0 0 0 1px rgba(143,211,251,.035);
}
html[data-theme="dark"] .formcard{
  border-color:rgba(129,202,243,.1);
  background:
    radial-gradient(440px 280px at 0 0,rgba(41,151,219,.1),transparent 70%),
    linear-gradient(145deg,#0B2237,#071725);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.035),0 28px 70px -56px rgba(0,0,0,.95);
}
html[data-theme="dark"] .formcard h3{color:#F4F8FC}
html[data-theme="dark"] .formcard .sub{color:#9DB1C3}
html[data-theme="dark"] .field input,
html[data-theme="dark"] .field select,
html[data-theme="dark"] .field textarea{
  color:#EAF2F8;
  background:rgba(255,255,255,.045);
  border-color:rgba(135,205,245,.11);
}
html[data-theme="dark"] .field input:focus,
html[data-theme="dark"] .field select:focus,
html[data-theme="dark"] .field textarea:focus{
  background:rgba(255,255,255,.07);
  border-color:rgba(92,192,250,.38);
  box-shadow:0 0 0 4px rgba(27,151,225,.08);
}

/* Ensure the full location is stable on one line within the compact console. */
@media (max-width:1180px){
  .cmethod--location .val{font-size:.86rem}
}
@media (max-width:720px){
  .contact__grid{padding:8px;gap:8px;border-radius:20px}
  .contact__head,.formcard{border-radius:15px!important}
  .contact__methods{border-radius:15px}
  .cmethod,.cmethod--copy{padding:.85rem .65rem!important;min-height:70px}
  .cmethod:hover,.cmethod:focus-visible{padding:.85rem .65rem!important}
  .cmethod--location .val{font-size:clamp(.72rem,3.35vw,.88rem)}
}
@media (max-width:390px){
  .cmethod--location .val{font-size:.7rem;letter-spacing:-.025em}
}

/* Location row has no trailing action, so it uses the full content lane. */
.cmethod--location{grid-template-columns:52px minmax(0,1fr)}
@media (max-width:720px){.cmethod--location{grid-template-columns:46px minmax(0,1fr)}}


/* ==========================================================================
   V23.5.5 — dark credentials panel and precise contact navigation
   ========================================================================== */

/* The credentials introduction panel must remain intentional in dark mode,
   not inherit the light translucent surface. */
html[data-theme="dark"] .cred__head>p{
  color:#C5D4E1;
  border-color:rgba(126,203,246,.18);
  background:
    radial-gradient(340px 190px at 100% 0%,rgba(47,169,239,.13),transparent 68%),
    linear-gradient(145deg,rgba(18,46,70,.96),rgba(8,28,47,.98));
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.055),
    0 24px 54px -46px rgba(0,0,0,.9);
}
html[data-theme="dark"] .cred__head>p::selection{background:rgba(61,177,245,.35);color:#fff}

/* Keep the equivalent light surface crisp and deliberate. */
html[data-theme="light"] .cred__head>p{
  color:#536D84;
  border-color:rgba(20,122,191,.15);
  background:
    radial-gradient(340px 190px at 100% 0%,rgba(83,184,244,.14),transparent 68%),
    linear-gradient(145deg,rgba(255,255,255,.94),rgba(238,246,252,.92));
  box-shadow:inset 0 1px 0 rgba(255,255,255,.95),0 20px 48px -42px rgba(17,67,104,.42);
}


/* ==========================================================================
   V23.5.7 — mobile identity, drawer alignment and content-flow refinements
   ========================================================================== */

/* Mobile header uses the same emblem system as the footer. */
@media (max-width:1000px){
  .nav .brand{display:inline-flex;align-items:center;gap:.68rem}
  .nav .brand__emblem,
  .drawer__brand .brand__emblem{
    position:relative;
    width:38px;
    height:38px;
    flex:0 0 38px;
    display:grid;
    place-items:center;
    border-radius:13px 7px 13px 7px;
    background:linear-gradient(145deg,rgba(38,154,229,.24),rgba(8,70,119,.07));
    border:1px solid rgba(118,205,255,.22);
    box-shadow:inset 0 1px 0 rgba(255,255,255,.1),0 11px 22px -16px rgba(12,139,224,.75);
  }
  .nav .brand__emblem::before,
  .nav .brand__emblem::after,
  .drawer__brand .brand__emblem::before,
  .drawer__brand .brand__emblem::after{
    content:"";
    position:absolute;
    width:4px;
    height:4px;
    border-radius:50%;
    background:#7FD2FF;
    box-shadow:0 0 10px rgba(65,188,255,.92);
  }
  .nav .brand__emblem::before,.drawer__brand .brand__emblem::before{left:5px;top:5px}
  .nav .brand__emblem::after,.drawer__brand .brand__emblem::after{right:5px;bottom:5px;opacity:.38}
  .nav .brand__emblem i,
  .drawer__brand .brand__emblem i{
    position:absolute;
    inset:5px;
    border-radius:9px 4px 9px 4px;
    border:1px solid rgba(137,216,255,.08);
    pointer-events:none;
  }
  .nav .brand__emblem .brand__mark,
  .drawer__brand .brand__emblem .brand__mark{
    width:22px;
    height:14px;
    margin:0;
    background:linear-gradient(90deg,#8FDCFF,#2BA7F4);
    filter:drop-shadow(0 0 8px rgba(63,178,246,.46));
  }
  .nav .brand__copy{display:flex;flex-direction:column;align-items:flex-start;justify-content:center;gap:.12rem;line-height:1}
  .nav .brand__copy strong{font-size:1rem}
  .nav .brand__copy small{display:block;font-family:var(--mono);font-size:.48rem;letter-spacing:.15em;text-transform:uppercase;color:#7997B0}
  .nav:not(.solid) .brand__copy small{color:#8EACC5}
}

/* Drawer identity and close control share one clean top baseline. */
@media (max-width:720px){
  .drawer__panel{padding-top:5.15rem}
  .drawer__brand{
    position:absolute;
    top:1rem;
    left:1.15rem;
    right:4.75rem;
    min-height:44px;
    margin:0;
    padding:0;
    display:flex;
    align-items:center;
    gap:.72rem;
    border:0;
  }
  .drawer__brand strong{font-size:1.04rem;line-height:1.05}
  .drawer__brand small{margin-top:.18rem;font-size:.51rem;letter-spacing:.14em}
  .drawer__close{top:1rem;right:1.15rem;width:44px;height:44px}
}

/* Keep appearance controls, but remove the redundant enabled-state copy. */
.drawer__appearance>span small{display:none}
.drawer__appearance>span strong{line-height:1.2}

/* Mobile hero paragraph aligns to the full CTA width. */
@media (max-width:720px){
  .hero__intro{width:100%;max-width:none!important;margin-inline:0}
}

/* Current role sequence on mobile: label, logo, then title. */
@media (max-width:720px){
  .cb__identity{
    width:100%;
    display:flex;
    flex-direction:column;
    align-items:flex-start;
    gap:.8rem;
    margin-bottom:.9rem;
  }
  .cb__identity .cb__eyebrow{order:1}
  .cb__identity .cb__chip{order:2;max-width:174px;min-height:42px}
  .cb__identity .cb__chip img{height:40px}
  .cb__role{margin-top:0}
}

/* Console labels are centred and share one accent colour in both themes. */
.contact__head::before,
.formcard::before{
  left:50%!important;
  right:auto!important;
  transform:translateX(-50%);
  width:max-content;
  color:rgba(126,212,255,.56)!important;
  text-align:center;
}
html[data-theme="light"] .formcard::before,
html[data-theme="light"] .contact__head::before{color:rgba(17,128,195,.56)!important}
html[data-theme="dark"] .formcard::before,
html[data-theme="dark"] .contact__head::before{color:rgba(126,212,255,.56)!important}

/* Footer legal details form three deliberate rows on mobile. */
@media (max-width:720px){
  .foot__bottom{display:grid;grid-template-columns:1fr;gap:.42rem}
  .foot__bottom span{display:block}
}


/* V23.5.8 — desktop footer registration row restored; mobile keeps its three-row layout. */
.foot__reg--mobile,.foot__company-mobile{display:none}
@media (max-width:1000px){
  .foot__reg--desktop{display:none}
  .foot__reg--mobile,.foot__company-mobile{display:block}
}


/* V23.5.9 — mobile profile is always fully expanded. */
@media (max-width:720px){
  .profile__copy{max-height:none!important;overflow:visible!important;transition:none!important}
  .profile__copy::after{display:none!important;content:none!important}
  .profile__toggle{display:none!important}
}


/* ==========================================================================
   V23.6.0 — mobile overlay, contact surface and legal-footer hardening
   ========================================================================== */

/* The console labels previously retained dimensions and a radial background
   from an older decorative pseudo-element. Reset them to text-only labels. */
.contact__head::before,
.formcard::before{
  width:max-content!important;
  height:auto!important;
  min-width:0!important;
  min-height:0!important;
  padding:0!important;
  margin:0!important;
  border:0!important;
  border-radius:0!important;
  background:none!important;
  background-image:none!important;
  box-shadow:none!important;
  filter:none!important;
}

/* New mobile legal rows; desktop keeps the compact single registration line. */
.foot__mobile-line{display:none}

@media (max-width:720px){
  /* Remove floating controls while the modal drawer is open. */
  body.drawer-open .site-theme-control,
  body.drawer-open .site-top-control,
  .drawer.open ~ .site-theme-control,
  .drawer.open ~ .site-top-control{
    opacity:0!important;
    visibility:hidden!important;
    pointer-events:none!important;
    transform:translate3d(0,14px,0) scale(.86)!important;
  }

  /* Four clean legal rows in the requested order. */
  .foot__reg--desktop{display:none!important}
  .foot__mobile-line{display:block!important}
  .foot__bottom{
    display:grid!important;
    grid-template-columns:minmax(0,1fr)!important;
    gap:.36rem!important;
    align-items:start!important;
  }

  /* Equal columns and a shared icon/text baseline in the popup action bar. */
  .mobile-actions{
    grid-template-columns:repeat(3,minmax(0,1fr))!important;
    align-items:stretch;
  }
  .mobile-actions a{
    display:grid!important;
    grid-template-columns:18px auto;
    align-items:center!important;
    justify-content:center!important;
    justify-items:start;
    column-gap:.42rem!important;
    min-width:0;
    padding-inline:.28rem;
    line-height:1;
    text-align:left;
  }
  .mobile-actions a svg{
    width:18px!important;
    height:18px!important;
    display:block;
    justify-self:center;
  }
  .mobile-actions a span{
    display:block;
    min-width:0;
    line-height:1;
    white-space:nowrap;
  }
}

@media (max-width:340px){
  .mobile-actions a{column-gap:.26rem!important;padding-inline:.14rem;font-size:.61rem!important}
  .mobile-actions a svg{width:16px!important;height:16px!important}
}

/* ==========================================================================
   V23.6.2 — mobile quick-action icon/text alignment
   ========================================================================== */
@media (max-width:720px){
  .mobile-actions{
    grid-template-columns:repeat(3,minmax(0,1fr))!important;
    align-items:center!important;
  }
  .mobile-actions a{
    display:flex!important;
    flex-direction:row!important;
    align-items:center!important;
    justify-content:center!important;
    gap:.5rem!important;
    min-width:0!important;
    padding-inline:.3rem!important;
    line-height:1!important;
    text-align:center!important;
  }
  .mobile-actions a svg{
    display:block!important;
    flex:0 0 19px!important;
    width:19px!important;
    height:19px!important;
    margin:0!important;
    padding:0!important;
    transform:none!important;
    vertical-align:middle!important;
  }
  .mobile-actions a span{
    display:block!important;
    flex:0 0 auto!important;
    min-width:0!important;
    margin:0!important;
    padding:0!important;
    line-height:1!important;
    white-space:nowrap!important;
    transform:none!important;
  }
  .mobile-actions__primary{
    display:flex!important;
    align-items:center!important;
    justify-content:center!important;
  }
}

@media (max-width:340px){
  .mobile-actions a{gap:.34rem!important;padding-inline:.12rem!important}
  .mobile-actions a svg{flex-basis:17px!important;width:17px!important;height:17px!important}
}

@media (max-width:720px){
  .mobile-actions__icon{
    width:20px!important;
    height:20px!important;
    flex:0 0 20px!important;
    display:grid!important;
    place-items:center!important;
    margin:0!important;
    padding:0!important;
    line-height:0!important;
  }
  .mobile-actions__icon svg{
    width:19px!important;
    height:19px!important;
    display:block!important;
    margin:0!important;
    padding:0!important;
    transform:none!important;
  }
  .mobile-actions__label{
    display:block!important;
    margin:0!important;
    padding:0!important;
    line-height:1!important;
  }
}
