/* ==========================================================================
   LEXIN LEGAL — Main stylesheet (homepage / shared components)
   Design: "Sıcak Modern" — warm ivory + navy + red
   ========================================================================== */
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;overflow-x:hidden}
body{font-family:var(--sans);color:var(--navy);background:var(--paper);line-height:1.6;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:clip}
a{color:inherit;text-decoration:none}
img,svg{display:block}
::selection{background:var(--navy);color:#fff}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 40px}
.eyebrow{font-family:var(--label);text-transform:uppercase;letter-spacing:.24em;font-size:var(--t-3xs);font-weight:600;color:var(--red);display:inline-flex;align-items:center;gap:10px}
.eyebrow::before{content:"";width:22px;height:1px;background:var(--red);display:inline-block}
.eyebrow.center{justify-content:center}
.eyebrow.on-dark{color:var(--red-light)}
.eyebrow.on-dark::before{background:var(--red-light)}

/* ---- reveal (CSS-only, no JS dependency) ---- */
@keyframes rise{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:none}}
.rev{opacity:0;animation:rise .85s var(--ease) forwards}
.d1{animation-delay:.06s}.d2{animation-delay:.14s}.d3{animation-delay:.22s}.d4{animation-delay:.30s}.d5{animation-delay:.38s}.d6{animation-delay:.46s}
@media (prefers-reduced-motion:reduce){.rev{animation:none;opacity:1}}

/* ---- buttons ---- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;font-weight:600;font-size:var(--t-sm);border-radius:3px;padding:13px 24px;transition:.24s var(--ease);letter-spacing:.005em;cursor:pointer;border:1px solid transparent;white-space:nowrap}
.btn-red{background:var(--red);color:#fff;box-shadow:0 6px 18px rgba(221,50,17,.22)}
.btn-red:hover{background:var(--red-hover);transform:translateY(-2px);box-shadow:0 10px 26px rgba(221,50,17,.28)}
.btn-red .arr{transition:transform .24s var(--ease)}
.btn-red:hover .arr{transform:translateX(4px)}
.btn-ghost{background:#fff;color:var(--navy);border:1px solid var(--hair)}
.btn-ghost:hover{border-color:var(--navy);box-shadow:var(--shadow-md);transform:translateY(-2px)}
.btn-lg{padding:15px 30px;font-size:var(--t-base)}
.header-cta{padding:10px 20px}

/* ---- header ---- */
body>header{position:sticky;top:0;z-index:60;background:rgba(250,248,243,.84);backdrop-filter:saturate(180%) blur(16px);-webkit-backdrop-filter:saturate(180%) blur(16px);border-bottom:1px solid var(--hair)}
.nav{display:flex;align-items:center;justify-content:space-between;height:84px}
.brand img{height:44px;width:auto;display:block}
.menu{display:flex;align-items:center;gap:25px}
.menu a{font-size:var(--t-sm);font-weight:500;color:var(--navy-600);position:relative;padding:6px 0;white-space:nowrap}
.menu a::after{content:"";position:absolute;left:0;bottom:0;height:2px;width:0;background:var(--red);transition:width .28s var(--ease)}
.menu a:hover{color:var(--navy)}
.menu a:hover::after{width:100%}
.nav-right{display:flex;align-items:center;gap:17px}
.lang{display:flex;align-items:center;font-size:var(--t-2xs);font-weight:600;color:var(--navy-300)}
.lang a{color:var(--navy-400);transition:color .2s var(--ease);cursor:pointer}
.lang a:hover{color:var(--red)}
.lang .off{color:var(--navy-200)}
.lang b{color:var(--navy);position:relative;font-weight:600}
.lang b::after{content:"";position:absolute;left:0;right:0;bottom:-5px;height:2px;background:var(--red)}
.lang span:not(:last-child)::after{content:"·";margin:0 5px;color:var(--navy-200)}
.nav-divider{width:1px;height:22px;background:var(--hair)}
.menu-toggle{display:none}

/* ---- mobile nav — D2: full-screen navy ---- */
.mnav{display:none}
.mnav{position:fixed;inset:0;height:100dvh;background:var(--navy);z-index:80;flex-direction:column;
  padding:calc(env(safe-area-inset-top) + 18px) 24px calc(env(safe-area-inset-bottom) + 26px);
  overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;
  opacity:0;visibility:hidden;transform:translateY(-10px);transition:opacity .32s var(--ease),transform .38s cubic-bezier(.4,0,.2,1),visibility .32s}
body.mnav-on .mnav{opacity:1;visibility:visible;transform:none}
.mnav-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}
.mnav-brand img{height:38px;width:auto;display:block}
.mnav-x{width:42px;height:42px;border:none;background:none;position:relative;cursor:pointer;flex:none}
.mnav-x span,.mnav-x span::before,.mnav-x span::after{position:absolute;left:11px;width:20px;height:2px;background:#fff;border-radius:2px}
.mnav-x span{top:20px;background:transparent}
.mnav-x span::before,.mnav-x span::after{content:"";left:0;top:0}
.mnav-x span::before{transform:rotate(45deg)}
.mnav-x span::after{transform:rotate(-45deg)}
.mnav-links{display:flex;flex-direction:column}
.mnav-links>a,.mnav-arow{font-family:var(--serif);font-size:27px;font-weight:500;color:#fff;padding:13px 2px;
  border-bottom:1px solid rgba(255,255,255,.10);display:flex;align-items:center;justify-content:space-between;
  width:100%;background:none;border-left:0;border-right:0;border-top:0;text-align:left;cursor:pointer;transition:color .2s var(--ease)}
.mnav-links>a:active,.mnav-arow:active{color:var(--red)}
.mnav-arow .mchev{width:11px;height:11px;border-right:2px solid var(--red);border-bottom:2px solid var(--red);
  transform:rotate(45deg);margin:-4px 4px 0 0;transition:transform .35s cubic-bezier(.4,0,.2,1);flex:none}
.mnav-acc.open .mnav-arow .mchev{transform:rotate(-135deg);margin-top:2px}
.mnav-sub{overflow:hidden;max-height:0;opacity:0;transition:max-height .42s cubic-bezier(.4,0,.2,1),opacity .3s}
.mnav-acc.open .mnav-sub{max-height:640px;opacity:1}
.mnav-sub a{display:inline-block;font-family:var(--sans);font-size:13px;color:#cfd0e0;
  background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.13);border-radius:22px;
  padding:8px 14px;margin:0 7px 9px 0;transition:background .2s var(--ease)}
.mnav-sub{padding:14px 0 6px}
.mnav-sub a:active{background:rgba(221,50,17,.7)}
.mnav-sub a.mnav-all{display:block;background:none;border:none;color:var(--red-light,#ff6a47);font-weight:600;padding:8px 2px;margin-top:2px}
.mnav-cta{margin-top:24px;width:100%;justify-content:center}
.mnav-lang{margin-top:24px;justify-content:center;font-size:var(--t-sm);color:#8f90a6}
.mnav-lang b{color:#fff}
.mnav-lang a{color:#b9bacb}
.mnav-lang .off{color:#5a5b72}
/* hamburger → X (header button, when open) */
.menu-toggle span,.menu-toggle span::before,.menu-toggle span::after{transition:transform .26s var(--ease),top .26s var(--ease),background-color .2s var(--ease)}
body.mnav-on{overflow:hidden}

/* ---- hero ---- */
.hero{padding:88px 0 96px;position:relative;background:var(--paper)}
.hero::before{content:"";position:absolute;top:0;right:0;width:48%;height:100%;background:linear-gradient(180deg,var(--band),var(--paper));z-index:0;opacity:.7;-webkit-mask-image:linear-gradient(90deg,transparent,#000 42%);mask-image:linear-gradient(90deg,transparent,#000 42%)}
.hero-grid{display:grid;grid-template-columns:7fr 5fr;gap:72px;align-items:center;position:relative;z-index:1}
.hero h1{font-family:var(--serif);font-weight:500;color:var(--navy);font-size:clamp(46px,5.6vw,78px);line-height:1.0;letter-spacing:-.012em;margin:22px 0 0}
.hero h1 em{font-style:italic;color:var(--red);font-weight:500}
.hero .sub{font-size:var(--t-md);color:var(--slate);max-width:40ch;margin:26px 0 36px;line-height:1.62}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.wapp{display:inline-flex;align-items:center;gap:10px;font-weight:600;font-size:var(--t-sm);color:var(--navy);padding:13px 6px}
.wapp:hover{color:var(--red)}
.wapp .dot{width:8px;height:8px;border-radius:50%;background:#25D366;box-shadow:0 0 0 4px rgba(37,211,102,.16)}
.trustline{display:flex;align-items:center;gap:12px;margin-top:38px;padding-top:26px;border-top:1px solid var(--hair);font-size:var(--t-xs);color:var(--slate);flex-wrap:wrap}
.stars{color:var(--red);letter-spacing:3px;font-size:var(--t-sm)}
.trustline b{color:var(--navy);font-weight:600}
.trustline .sep{color:var(--navy-200)}

/* ---- hero fact card ---- */
.factcard{background:var(--navy);color:#fff;border-radius:8px;padding:6px;box-shadow:var(--shadow-navy);position:relative}
.factcard-inner{border:1px solid rgba(255,255,255,.10);border-radius:5px;padding:34px 32px 30px}
.factcard .fc-emblem{position:absolute;top:0;right:0;width:128px;height:128px;opacity:.06;pointer-events:none;overflow:hidden;border-top-right-radius:8px}
.factcard .fc-emblem img{width:170px;height:170px;position:absolute;top:-14px;right:-30px}
.fc-head{display:flex;align-items:center;gap:12px;margin-bottom:24px}
.fc-head .ico{width:34px;height:34px;flex:none;display:flex;align-items:center;justify-content:center}
.fc-head .ico img{width:100%;height:100%}
.fc-title{font-family:var(--serif);font-size:var(--t-xl);font-weight:600;line-height:1.05;letter-spacing:.005em}
.fc-sub{font-size:var(--t-2xs);color:var(--navy-300);letter-spacing:.02em;margin-top:3px}
.fc-list{list-style:none}
.fc-row{display:flex;align-items:flex-start;gap:14px;padding:15px 0;border-top:1px solid rgba(255,255,255,.09)}
.fc-row:first-child{border-top:none;padding-top:4px}
.fc-row .k{font-size:var(--t-2xs);text-transform:uppercase;letter-spacing:.14em;color:var(--navy-300);width:118px;flex:none;padding-top:2px;font-weight:600}
.fc-row .v{font-size:var(--t-sm);color:#fff;font-weight:500;line-height:1.45}
.fc-row .v small{display:block;color:var(--navy-200);font-weight:400;font-size:var(--t-2xs);margin-top:2px}
.fc-langs{display:flex;gap:6px;flex-wrap:wrap}
.fc-lang{font-size:var(--t-2xs);font-weight:600;letter-spacing:.06em;padding:3px 8px;border:1px solid rgba(255,255,255,.16);border-radius:3px;color:#fff}
.fc-foot{margin-top:22px;padding-top:18px;border-top:1px solid rgba(255,255,255,.09);display:flex;align-items:center;gap:9px;font-size:var(--t-xs);color:var(--navy-200)}
.fc-foot .pulse{width:7px;height:7px;border-radius:50%;background:var(--red-light);flex:none;animation:pulse 2.4s var(--ease) infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(232,92,63,.45)}70%{box-shadow:0 0 0 7px rgba(232,92,63,0)}100%{box-shadow:0 0 0 0 rgba(232,92,63,0)}}
@media (prefers-reduced-motion:reduce){.fc-foot .pulse{animation:none}}

/* ---- trust strip ---- */
.trust{border-top:1px solid var(--hair);border-bottom:1px solid var(--hair);background:var(--band)}
.trust-inner{display:flex;align-items:center;gap:36px;padding:24px 0;flex-wrap:wrap}
.trust-label{font-family:var(--label);text-transform:uppercase;letter-spacing:.2em;font-size:var(--t-3xs);font-weight:600;color:var(--navy-400);flex:none}
.trust-logos{display:flex;align-items:center;gap:32px;flex-wrap:wrap;flex:1}
.trust-logos a,.trust-logos span{display:inline-flex;align-items:center;line-height:0}
.trust-logos img{height:26px;width:auto;opacity:.5;transition:opacity .24s var(--ease),transform .24s var(--ease)}
.trust-logos img.tl-badge{height:33px}            /* shield seals read better a touch larger */
.trust-logos a:hover img{opacity:1;transform:translateY(-2px)}
.trust-logos .tl-acq img{opacity:.46}             /* award seal, not clickable — stays calm */
/* text wordmarks (The Manifest, HG.org) share the same muted-navy rhythm */
.trust-logos .tl-text{font-family:var(--serif);font-size:var(--t-lg);font-weight:600;color:var(--navy-400);letter-spacing:.01em;opacity:.6;line-height:1;transition:color .24s var(--ease),opacity .24s var(--ease),transform .24s var(--ease)}
.trust-logos a.tl-text:hover{color:var(--navy);opacity:1;transform:translateY(-2px)}
.trust-logos span.tl-text{opacity:.46}

/* ---- home intro/trust band (real office photo) ---- */
.introband{padding:100px 0;background:var(--paper)}
.ib-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:64px;align-items:center;perspective:1500px}
.ib-media{position:relative;transform-style:preserve-3d;transition:transform .55s var(--ease),box-shadow .3s var(--ease);transform-origin:center;will-change:transform}
.ib-media img{width:100%;height:auto;aspect-ratio:3/2;object-fit:cover;border-radius:14px;display:block;box-shadow:var(--shadow-lg);transition:box-shadow .35s var(--ease)}
.ib-media.tilt img{box-shadow:0 50px 92px -22px rgba(8,7,18,.42)}
.ib-media .ib-badge{transition:transform .45s var(--ease)}
.ib-media.tilt .ib-badge{transform:translateZ(55px)}
.ib-media .ib-badge{position:absolute;left:-18px;bottom:24px;background:var(--navy);color:#fff;border-radius:10px;padding:16px 20px;box-shadow:var(--shadow-navy);display:flex;align-items:center;gap:13px;max-width:78%}
.ib-media .ib-badge .em{width:34px;height:34px;flex:none;color:var(--red-light)}
.ib-media .ib-badge .em img{width:100%;height:100%;object-fit:contain;border-radius:0;box-shadow:none;aspect-ratio:auto}
.ib-media .ib-badge b{display:block;font-family:var(--serif);font-size:var(--t-md);font-weight:600;line-height:1.15}
.ib-media .ib-badge span{font-size:var(--t-2xs);color:var(--navy-200)}
.ib-copy .eyebrow{margin-bottom:20px}
.ib-copy h2{font-family:var(--serif);font-weight:600;font-size:clamp(30px,3.6vw,44px);line-height:1.1;letter-spacing:-.012em;color:var(--navy)}
.ib-copy h2 em{font-style:italic;color:var(--red)}
.ib-copy p{font-size:var(--t-md);color:var(--slate);line-height:1.66;margin-top:22px;max-width:48ch}
.ib-points{list-style:none;margin:26px 0 0;display:flex;flex-direction:column;gap:13px}
.ib-points li{position:relative;padding-left:30px;font-size:var(--t-sm);color:var(--navy-600);font-weight:500}
.ib-points li svg{position:absolute;left:0;top:1px;width:19px;height:19px;color:var(--red)}
.ib-cta{margin-top:30px;display:flex;gap:14px;align-items:center;flex-wrap:wrap}

/* ---- sections ---- */
section{position:relative}
.sec{padding:108px 0}
.sec-head{max-width:680px;margin-bottom:56px}
.sec-head.center{margin-left:auto;margin-right:auto;text-align:center}
.sec-head h2{font-family:var(--serif);font-weight:600;font-size:clamp(33px,4vw,48px);line-height:1.04;letter-spacing:-.01em;color:var(--navy);margin:18px 0 0}
.sec-head p{font-size:var(--t-md);color:var(--slate);margin-top:18px;line-height:1.6}
.sec-head .row{display:flex;align-items:flex-end;justify-content:space-between;gap:32px}

/* ---- practice grid ---- */
.pgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.pcard{background:var(--white);border:1px solid var(--hair);border-radius:7px;padding:30px 28px 28px;position:relative;transition:transform .3s var(--ease),box-shadow .3s var(--ease),border-color .3s var(--ease);overflow:hidden;box-shadow:var(--shadow-sm);display:block;text-decoration:none;color:inherit}
.pcard::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--red);transform:scaleX(0);transform-origin:left;transition:transform .34s var(--ease)}
.pcard:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:transparent}
.pcard:hover::before{transform:scaleX(1)}
.pcard .pico{width:48px;height:48px;margin-bottom:22px;display:flex;align-items:center;justify-content:center;border:1px solid var(--hair);border-radius:9px;background:var(--paper);transition:background .3s var(--ease),border-color .3s var(--ease),transform .3s var(--ease)}
.pcard .pico .pic{width:25px;height:25px;color:var(--navy);transition:color .3s var(--ease)}
.pcard:hover .pico{background:var(--navy);border-color:var(--navy)}
.pcard:hover .pico .pic{color:#fff}

/* 9th card — gateway to all practice areas (deliberately distinct: navy, attention-drawing) */
.pcard-all{background:var(--navy);border-color:var(--navy);color:#fff;display:flex;flex-direction:column;align-items:flex-start;text-decoration:none;box-shadow:var(--shadow-md)}
.pcard-all::before{background:var(--red-light)}
.pcard-all .pall-em{position:absolute;right:-26px;bottom:-32px;width:158px;height:158px;opacity:.07;pointer-events:none}
.pcard-all .pico{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.18)}
.pcard-all .pico .pic{color:#fff}
.pcard-all .pall-body{position:relative;z-index:1}
.pcard-all h3{color:#fff}
.pcard-all p{color:var(--navy-200)}
.pcard-all .plink{color:var(--red-light);margin-top:auto;padding-top:18px}
.pcard-all:hover{background:var(--navy-800);border-color:var(--navy-800);transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.pcard-all:hover .pico{background:var(--red);border-color:var(--red)}
.pcard .pnum{position:absolute;top:24px;right:26px;font-family:var(--label);font-size:var(--t-2xs);font-weight:600;color:var(--navy-200);letter-spacing:.08em}
.pcard h3{font-size:var(--t-md);font-weight:600;color:var(--navy);letter-spacing:-.005em;line-height:1.25;margin-bottom:9px}
.pcard p{font-size:var(--t-xs);color:var(--slate);line-height:1.55}
.pcard .plink{display:inline-flex;align-items:center;gap:6px;margin-top:16px;font-size:var(--t-xs);font-weight:600;color:var(--red);letter-spacing:.02em}
.pcard .plink .arr{transition:transform .24s var(--ease)}
.pcard:hover .plink .arr{transform:translateX(4px)}
/* whole card clickable — stretched link covers the entire box */
.pcard{cursor:pointer}
.pcard a.plink{position:static}
.pcard a.plink::after{content:"";position:absolute;inset:0;z-index:1}

/* ---- stats band ---- */
.stats{background:var(--navy);color:#fff;position:relative;overflow:hidden}
.stats::before{content:"";position:absolute;inset:0;background:radial-gradient(900px 380px at 82% -10%,rgba(221,50,17,.14),transparent 60%),linear-gradient(180deg,var(--navy-800),var(--navy))}
/* fluted-column texture (brand motif) — faint vertical lines, faded top & bottom */
.stats::after{content:"";position:absolute;inset:0;pointer-events:none;background-image:repeating-linear-gradient(90deg,rgba(255,255,255,.05) 0 1px,transparent 1px 26px);-webkit-mask-image:linear-gradient(180deg,transparent,#000 22%,#000 78%,transparent);mask-image:linear-gradient(180deg,transparent,#000 22%,#000 78%,transparent)}
.stats .wrap{position:relative;z-index:1}
.stats-inner{padding:80px 0}
.stats-top{display:flex;align-items:flex-end;justify-content:space-between;gap:32px;margin-bottom:44px;flex-wrap:wrap}
.stats-top h2{font-family:var(--serif);font-weight:500;font-size:clamp(28px,3.4vw,40px);line-height:1.08;letter-spacing:-.005em;max-width:18ch}
.stats-top h2 em{font-style:italic;color:var(--red-light)}
.stats-top p{font-size:var(--t-sm);color:var(--navy-200);max-width:34ch;line-height:1.6}
.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid rgba(255,255,255,.12)}
.stat{padding:34px 28px 4px;border-right:1px solid rgba(255,255,255,.10);position:relative}
.stat:last-child{border-right:none}
.stat .num{font-family:var(--serif);font-size:clamp(40px,4.6vw,58px);font-weight:600;line-height:1;letter-spacing:-.01em}
.stat .num .accent{color:var(--red-light)}
.stat .lbl{font-size:var(--t-2xs);text-transform:uppercase;letter-spacing:.14em;color:var(--navy-300);margin-top:14px;font-weight:600}
.stat .desc{font-size:var(--t-xs);color:var(--navy-200);margin-top:8px;line-height:1.5}

/* ---- how it works — connected timeline (stations on a path) ---- */
.how{background:var(--band)}
.steps{--node:56px;--rail-y:28px;--halo:7px;--gap:40px;display:grid;grid-template-columns:repeat(3,1fr);gap:0 var(--gap);align-items:stretch;counter-reset:step;position:relative}
/* rail = two pseudo-elements (no markup); connects the three left-aligned node centres (node radius 28px) */
.steps::before,.steps::after{content:"";position:absolute;top:var(--rail-y);height:2px;border-radius:2px;pointer-events:none;z-index:0}
.steps::before{left:28px;right:calc((100% - 2*var(--gap))/3 - 28px);background:var(--navy-100)}
/* red progress rail spans the FULL path (node1 -> node3); fills on scroll-in */
.steps::after{left:28px;right:calc((100% - 2*var(--gap))/3 - 28px);background:linear-gradient(90deg,var(--red) 0%,var(--red-light) 100%);box-shadow:0 0 10px rgba(221,50,17,.18);transform-origin:left center;transform:scaleX(1)}
/* resting / no-JS state: stations 2 & 3 read as "reached" (red outline) */
.step:nth-child(2) .snum,.step:nth-child(3) .snum{border-color:var(--red);color:var(--red)}
.step:nth-child(2) .snum::before,.step:nth-child(3) .snum::before{border-color:rgba(221,50,17,.22)}
/* armed = pre-animation snapshot (JS adds this only when the journey will play) */
.steps.armed::after{transform:scaleX(0);transition:none}
.steps.armed .step:nth-child(2) .snum,.steps.armed .step:nth-child(3) .snum{border-color:var(--navy-200);color:var(--navy);transition:none}
.steps.armed .step:nth-child(2) .snum::before,.steps.armed .step:nth-child(3) .snum::before{border-color:var(--navy-100);transition:none}
/* playing = the rail draws 1 -> 3 while stations light up in sequence */
.steps.armed.playing::after{transform:scaleX(1);transition:transform 2.4s var(--ease)}
.steps.armed.playing .step:nth-child(2) .snum{border-color:var(--red);color:var(--red);transition:border-color .5s var(--ease) 1s,color .5s var(--ease) 1s}
.steps.armed.playing .step:nth-child(3) .snum{border-color:var(--red);color:var(--red);transition:border-color .5s var(--ease) 2s,color .5s var(--ease) 2s}
.steps.armed.playing .step:nth-child(2) .snum::before{border-color:rgba(221,50,17,.22);transition:border-color .5s var(--ease) 1s}
.steps.armed.playing .step:nth-child(3) .snum::before{border-color:rgba(221,50,17,.22);transition:border-color .5s var(--ease) 2s}
.step{position:relative;z-index:1;padding-top:calc(var(--node) + 30px);display:flex;flex-direction:column;align-items:flex-start;min-height:100%}
.step::before{content:none}
/* oversized faint Cormorant italic ghost numeral — pure CSS counter, zero i18n */
.step::after{content:counter(step,decimal-leading-zero);position:absolute;top:-18px;right:0;font-family:var(--serif);font-style:italic;font-weight:600;font-size:120px;line-height:1;letter-spacing:-.04em;color:var(--navy);opacity:.05;pointer-events:none;user-select:none;z-index:0}
.step .snum{counter-increment:step;position:absolute;top:0;left:0;z-index:2;display:inline-flex;align-items:center;justify-content:center;width:var(--node);height:var(--node);border-radius:50%;border:1.5px solid var(--navy-200);color:var(--navy);font-family:var(--label);font-weight:600;font-size:var(--t-lg);background:var(--paper);box-shadow:0 0 0 var(--halo) var(--band),var(--shadow-sm);transition:transform .4s var(--ease),box-shadow .4s var(--ease),border-color .4s var(--ease)}
.step .snum::after{content:counter(step,decimal-leading-zero)}
.step .snum::before{content:"";position:absolute;inset:calc(-1 * var(--halo) - 3px);border-radius:50%;border:1px solid var(--navy-100);transition:border-color .4s var(--ease)}
.step:first-child .snum{background:var(--red);border-color:var(--red);color:#fff;box-shadow:0 0 0 var(--halo) var(--band),0 8px 20px rgba(221,50,17,.30)}
.step:first-child .snum::before{border-color:rgba(221,50,17,.28)}
/* per-step icon hidden — it collided with the rail; nodes + ghost numerals carry the design */
.step .sicon{display:none}
.step h3{font-family:var(--serif);font-size:26px;font-weight:600;color:var(--navy);margin-bottom:11px;letter-spacing:-.01em;line-height:1.12;position:relative;z-index:1}
.step p{font-size:var(--t-sm);color:var(--slate);line-height:1.65;max-width:34ch;position:relative;z-index:1;margin-bottom:20px}
.step .schip{display:inline-flex;align-items:center;gap:8px;margin-top:auto;font-size:var(--t-2xs);font-weight:600;letter-spacing:.04em;color:var(--navy-500);background:var(--white);border:1px solid var(--hair);border-radius:30px;padding:7px 15px;box-shadow:var(--shadow-sm);position:relative;z-index:1}
.step .schip .d{width:6px;height:6px;border-radius:50%;background:var(--red);box-shadow:0 0 0 3px rgba(221,50,17,.12)}
.step:hover .snum{transform:translateY(-3px)}
.step:not(:first-child):hover .snum{box-shadow:0 0 0 var(--halo) var(--band),var(--shadow-md)}
.step:not(:first-child):hover .snum::before{border-color:rgba(221,50,17,.4)}
.step:hover .sicon{color:var(--red);transform:translateY(-2px)}
@media (prefers-reduced-motion:reduce){.step .snum,.step .sicon{transition:none}.steps::after{animation:none;transform:none}}

/* ---- cta band ---- */
.ctaband{padding:104px 0;background:var(--paper)}
.ctabox{background:var(--navy);border-radius:12px;padding:6px;box-shadow:var(--shadow-navy);position:relative;overflow:hidden}
.ctabox::before{content:"";position:absolute;inset:0;background:radial-gradient(700px 320px at 88% 120%,rgba(221,50,17,.18),transparent 60%)}
.ctabox-inner{border:1px solid rgba(255,255,255,.10);border-radius:8px;padding:60px 56px;display:grid;grid-template-columns:1.2fr .8fr;gap:48px;align-items:center;position:relative;z-index:1}
.ctabox-inner .em{position:absolute;right:-30px;bottom:-50px;width:240px;height:240px;opacity:.06;pointer-events:none}
.ctabox-inner .em img{width:100%;height:100%}
.ctabox h2{font-family:var(--serif);font-weight:500;color:#fff;font-size:clamp(32px,3.8vw,46px);line-height:1.06;letter-spacing:-.01em}
.ctabox h2 em{font-style:italic;color:var(--red-light)}
.ctabox p{font-size:var(--t-md);color:var(--navy-200);margin-top:18px;line-height:1.6;max-width:42ch}
.cta-actions{display:flex;flex-direction:column;gap:14px;align-items:flex-start}
.cta-actions .btn{width:100%}
.btn-white{background:#fff;color:var(--navy)}
.btn-white:hover{background:var(--paper);transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.btn-line{background:transparent;color:#fff;border:1px solid rgba(255,255,255,.26)}
.btn-line:hover{border-color:#fff;background:rgba(255,255,255,.06);transform:translateY(-2px)}
.cta-mail{font-size:var(--t-xs);color:var(--navy-300);margin-top:4px}
.cta-mail a{color:#fff;border-bottom:1px solid rgba(255,255,255,.3);padding-bottom:1px}
.cta-mail a:hover{border-color:var(--red-light);color:var(--red-light)}

/* ---- footer ---- */
footer{background:var(--navy-900);color:var(--navy-200);padding:74px 0 36px;position:relative;overflow:hidden}
footer::before{content:"";position:absolute;inset:0;pointer-events:none;background-image:repeating-linear-gradient(90deg,rgba(255,255,255,.04) 0 1px,transparent 1px 26px);-webkit-mask-image:linear-gradient(180deg,transparent,#000 24%);mask-image:linear-gradient(180deg,transparent,#000 24%)}
footer .wrap{position:relative;z-index:1}
.foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.4fr;gap:48px;padding-bottom:48px;border-bottom:1px solid rgba(255,255,255,.08)}
.foot-brand img{height:44px;width:auto;margin-bottom:22px;display:block}
.foot-social{display:flex;gap:10px;margin-top:22px}
.foot-social a{width:38px;height:38px;border-radius:9px;border:1px solid rgba(255,255,255,.14);display:flex;align-items:center;justify-content:center;color:var(--navy-200);transition:.22s var(--ease)}
.foot-social a svg{width:18px;height:18px}
.foot-social a:hover{background:var(--red);border-color:var(--red);color:#fff;transform:translateY(-2px)}
.foot-addr{font-style:normal}
.foot-recog{display:flex;align-items:center;gap:26px;flex-wrap:wrap;padding:30px 0 4px}
.foot-recog-label{font-family:var(--label);text-transform:uppercase;letter-spacing:.14em;font-size:var(--t-3xs);color:var(--navy-400);font-weight:600}
.foot-mondaq{display:inline-flex;align-items:center;transition:transform .22s var(--ease)}
.foot-mondaq img{height:22px;width:auto;display:block;filter:brightness(0) invert(1);opacity:.68;transition:opacity .22s var(--ease)}
.foot-mondaq:hover{transform:translateY(-1px)}
.foot-mondaq:hover img{opacity:1}
.foot-marks{font-size:var(--t-xs);color:var(--navy-400);letter-spacing:.03em}
.foot-brand p{font-size:var(--t-sm);color:var(--navy-300);line-height:1.65;max-width:34ch}
.foot-col h4{font-family:var(--label);text-transform:uppercase;letter-spacing:.16em;font-size:var(--t-3xs);color:var(--navy-300);margin-bottom:18px;font-weight:600}
.foot-col a{display:block;font-size:var(--t-sm);color:var(--navy-200);padding:6px 0;transition:.2s var(--ease)}
.foot-col a:hover{color:#fff;transform:translateX(3px)}
.foot-contact .line{font-size:var(--t-sm);color:var(--navy-200);margin-bottom:12px;line-height:1.5}
.foot-contact .line b{display:block;margin-bottom:2px;font-size:var(--t-2xs);text-transform:uppercase;letter-spacing:.12em;color:var(--navy-400);font-weight:600}
.foot-contact a{color:#fff}
.foot-contact a:hover{color:var(--red-light)}
.foot-bottom{display:flex;align-items:center;justify-content:space-between;padding-top:28px;gap:20px;flex-wrap:wrap}
.foot-bottom p{font-size:var(--t-2xs);color:var(--navy-400)}
.foot-langs{display:flex;gap:4px;font-size:var(--t-2xs);color:var(--navy-400);font-weight:500}
.foot-langs a{color:var(--navy-300);transition:color .2s var(--ease);cursor:pointer}
.foot-langs a:hover{color:#fff}
.foot-langs .off{color:var(--navy-600)}
.foot-langs b{color:#fff}
.foot-langs span:not(:last-child)::after{content:"·";margin:0 4px;color:var(--navy-600)}

/* ---- floating whatsapp ---- */
.wa-float{position:fixed;right:22px;bottom:22px;z-index:80;display:inline-flex;align-items:center;gap:10px;background:var(--navy);color:#fff;padding:13px 18px 13px 15px;border-radius:40px;box-shadow:var(--shadow-navy);font-weight:600;font-size:var(--t-sm);transition:.24s var(--ease)}
.wa-float:hover{background:var(--navy-800);transform:translateY(-2px)}
.wa-float .wa-ic{width:22px;height:22px;border-radius:50%;background:#25D366;flex:none;display:flex;align-items:center;justify-content:center}
.wa-float .wa-ic svg{width:14px;height:14px}
.wa-float .wa-txt{display:none}
@media(min-width:600px){.wa-float .wa-txt{display:inline}}

/* ---- interior pages ---- */
.page-hero{padding:80px 0 64px;background:var(--paper);position:relative;border-bottom:1px solid var(--hair)}
.page-hero .page-h1{font-family:var(--serif);font-weight:600;font-size:clamp(40px,5vw,62px);line-height:1.02;letter-spacing:-.012em;color:var(--navy);margin:18px 0 0;max-width:18ch}
.page-hero .page-h1 em{font-style:italic;color:var(--red);font-weight:500}
.page-hero .page-intro{font-size:var(--t-md);color:var(--slate);max-width:60ch;margin:24px 0 0;line-height:1.62}
.page-hero .page-cta{margin-top:34px}
.page-body{padding:80px 0}
.page-body .lead{font-family:var(--serif);font-size:clamp(24px,3vw,32px);font-weight:500;color:var(--navy);line-height:1.3;max-width:30ch}
.page-note{background:var(--band);border:1px solid var(--hair);border-radius:8px;padding:22px 26px;margin-top:28px;font-size:var(--t-sm);color:var(--slate);max-width:60ch}
.page-note b{color:var(--navy)}
@media (max-width:900px){.page-hero{padding:48px 0 44px}.page-body{padding:56px 0}}

/* ---- blog: single article ---- */
.wrap-narrow{max-width:760px;margin:0 auto;padding:0 40px}
.post-head{padding:72px 0 36px;background:var(--paper);border-bottom:1px solid var(--hair)}
.post-head .post-h1{font-family:var(--serif);font-weight:600;font-size:clamp(34px,4.4vw,52px);line-height:1.08;letter-spacing:-.012em;color:var(--navy);margin:16px 0 0}
.post-meta{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-top:22px;font-size:var(--t-sm);color:var(--slate)}
.post-meta .dot{width:3px;height:3px;border-radius:50%;background:var(--navy-200)}
.post-meta b{color:var(--navy);font-weight:600}
.post-body{padding:52px 0 40px}
.post-body .prose{max-width:none}
.post-cta{margin:44px 0 8px;background:var(--navy);color:#fff;border-radius:10px;padding:28px 30px;display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap;box-shadow:var(--shadow-navy)}
.post-cta .pc-t{font-family:var(--serif);font-size:var(--t-xl);font-weight:600;line-height:1.2}
.post-cta .pc-t small{display:block;font-family:var(--sans);font-size:var(--t-sm);font-weight:400;color:var(--navy-200);margin-top:6px}
.post-cta .btn{flex:none}
.post-related{margin-top:48px;padding-top:34px;border-top:1px solid var(--hair)}
.post-related h3{font-family:var(--label);text-transform:uppercase;letter-spacing:.16em;font-size:var(--t-3xs);color:var(--muted);font-weight:600;margin-bottom:18px}
.post-related a{display:block;padding:14px 0;border-bottom:1px solid var(--hair);font-family:var(--serif);font-size:var(--t-lg);font-weight:600;color:var(--navy);transition:.2s var(--ease)}
.post-related a:last-child{border-bottom:none}
.post-related a:hover{color:var(--red);padding-left:4px}

/* ---- blog: index ---- */
.blog-cluster{margin-bottom:52px}
.blog-cluster h2{font-family:var(--serif);font-weight:600;font-size:clamp(24px,2.6vw,30px);color:var(--navy);margin-bottom:6px;letter-spacing:-.01em}
.blog-cluster .ch-rule{height:2px;width:42px;background:var(--red);margin-bottom:24px}
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.barticle{display:flex;flex-direction:column;background:#fff;border:1px solid var(--hair);border-radius:8px;padding:24px 24px 22px;box-shadow:var(--shadow-sm);transition:transform .3s var(--ease),box-shadow .3s var(--ease),border-color .3s var(--ease);position:relative;overflow:hidden}
.barticle::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--red);transform:scaleX(0);transform-origin:left;transition:transform .34s var(--ease)}
.barticle:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg);border-color:transparent}
.barticle:hover::before{transform:scaleX(1)}
.barticle .bcat{font-family:var(--label);text-transform:uppercase;letter-spacing:.14em;font-size:var(--t-3xs);color:var(--red);font-weight:600;margin-bottom:12px}
.barticle h3{font-family:var(--serif);font-size:var(--t-lg);font-weight:600;line-height:1.22;color:var(--navy);margin-bottom:10px;letter-spacing:-.005em}
.barticle p{font-size:var(--t-xs);color:var(--slate);line-height:1.55;margin-bottom:16px;flex:1}
.barticle .bmore{font-size:var(--t-xs);font-weight:600;color:var(--red);display:inline-flex;align-items:center;gap:6px}
/* whole card clickable — stretched link covers the entire box (same fix as homepage practice cards) */
.barticle h3 a.bstretch::after{content:"";position:absolute;inset:0;z-index:1}
.barticle .bmore{position:relative;z-index:2}
.barticle:hover h3 a{color:var(--red)}
.barticle .bmore .arr{transition:transform .24s var(--ease)}
.barticle:hover .bmore .arr{transform:translateX(4px)}

/* ---- contact page ---- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:start;margin-top:6px}
.contact-methods{display:flex;flex-direction:column;gap:14px;margin-bottom:26px}
.cmethod{display:flex;gap:16px;align-items:flex-start;background:#fff;border:1px solid var(--hair);border-radius:10px;padding:18px 20px;transition:box-shadow .25s var(--ease)}
.cmethod:hover{box-shadow:var(--shadow-md)}
.cmethod .ic{width:42px;height:42px;border-radius:8px;background:var(--band);display:flex;align-items:center;justify-content:center;flex:none;color:var(--navy)}
.cmethod .ic svg{width:20px;height:20px}
.cmethod b{display:block;font-size:var(--t-3xs);text-transform:uppercase;letter-spacing:.12em;color:var(--muted);font-weight:600;margin-bottom:3px}
.cmethod a,.cmethod .v{font-size:var(--t-md);color:var(--navy);font-weight:600}
.cmethod a:hover{color:var(--red)}
.cmethod small{display:block;font-size:var(--t-xs);color:var(--slate);font-weight:400;margin-top:3px;line-height:1.5}
.map-embed{border-radius:10px;overflow:hidden;border:1px solid var(--hair);line-height:0}
.map-embed iframe{width:100%;height:280px;border:0}
.contact-form{display:flex;flex-direction:column;gap:16px;background:#fff;border:1px solid var(--hair);border-radius:12px;padding:30px;box-shadow:var(--shadow-sm)}
.contact-form .frow{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.field label{display:block;font-size:var(--t-3xs);font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--navy-500);margin-bottom:7px}
.field input,.field select,.field textarea{width:100%;font-family:var(--sans);font-size:var(--t-sm);color:var(--navy);background:var(--paper);border:1px solid var(--hair);border-radius:6px;padding:13px 14px;transition:border-color .2s var(--ease),box-shadow .2s var(--ease)}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--navy-400);background:#fff;box-shadow:0 0 0 3px rgba(41,42,61,.07)}
.field textarea{min-height:130px;resize:vertical}
.contact-form .btn{margin-top:4px}
.form-note{font-size:var(--t-xs);color:var(--muted);line-height:1.5}

/* ---- team page ---- */
.team-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:26px;margin-top:8px}
.tcard{display:grid;grid-template-columns:140px 1fr;gap:26px;background:#fff;border:1px solid var(--hair);border-radius:10px;padding:26px;align-items:start;box-shadow:var(--shadow-sm);transition:box-shadow .3s var(--ease),transform .3s var(--ease)}
.tcard:hover{box-shadow:var(--shadow-lg);transform:translateY(-3px)}
.tcard .tphoto{width:140px;height:140px;border-radius:8px;object-fit:cover;object-position:center top;background:var(--band)}
.tcard .tname{font-family:var(--serif);font-size:var(--t-xl);font-weight:600;color:var(--navy);line-height:1.1}
.tcard .trole{font-family:var(--label);font-size:var(--t-3xs);letter-spacing:.14em;text-transform:uppercase;color:var(--red);font-weight:600;margin:6px 0 14px}
.tcard .tbio{font-size:var(--t-sm);color:var(--slate);line-height:1.62}
.tcard .tmeta{margin-top:14px;font-size:var(--t-2xs);color:var(--muted);letter-spacing:.02em}
.tcard .tmeta b{color:var(--navy-500);font-weight:600}

/* ---- service page ---- */
.svc-hero .facts{display:grid;grid-template-columns:repeat(auto-fit,minmax(165px,1fr));gap:1px;margin-top:36px;border:1px solid var(--hair);border-radius:11px;overflow:hidden;background:var(--hair);box-shadow:var(--shadow-sm)}
.svc-hero .fact{background:#fff;padding:19px 22px;font-size:var(--t-sm);color:var(--navy);line-height:1.45}
.svc-hero .fact b{display:block;font-family:var(--label);font-size:var(--t-3xs);letter-spacing:.14em;text-transform:uppercase;color:var(--red);font-weight:600;margin-bottom:7px}
.svc-body{padding:72px 0 40px}
.svc-wrap{display:grid;grid-template-columns:1fr 330px;gap:60px;align-items:start}
.prose{max-width:70ch;min-width:0}
.prose h2{font-family:var(--serif);font-weight:600;font-size:clamp(27px,3vw,35px);color:var(--navy);letter-spacing:-.01em;line-height:1.12;margin:50px 0 16px}
.prose > h2:first-child,.prose > *:first-child{margin-top:0}
.prose h3{font-size:var(--t-xl);font-weight:600;color:var(--navy);margin:34px 0 12px;letter-spacing:-.005em}
.prose p{font-size:var(--t-base);color:var(--navy-600);line-height:1.72;margin:0 0 18px}
.prose ul,.prose ol{margin:0 0 20px;padding-left:0;list-style:none}
.prose li{font-size:var(--t-base);color:var(--navy-600);line-height:1.65;margin-bottom:10px;position:relative;padding-left:24px}
.prose ul li::before{content:"";position:absolute;left:2px;top:10px;width:7px;height:7px;border-radius:2px;background:var(--red);transform:rotate(45deg)}
.prose ol{counter-reset:li}
.prose ol li{counter-increment:li}
.prose ol li::before{content:counter(li);position:absolute;left:0;top:1px;font-family:var(--label);font-weight:600;font-size:var(--t-2xs);color:var(--red)}
.prose a{color:var(--red);border-bottom:1px solid rgba(221,50,17,.3)}
.prose a:hover{border-color:var(--red)}
.prose strong{color:var(--navy);font-weight:600}
.prose blockquote{position:relative;border:none;padding:10px 0 10px 32px;margin:38px 0;font-family:var(--serif);font-size:clamp(21px,2.5vw,27px);font-style:italic;color:var(--navy);line-height:1.4}
.prose blockquote::before{content:"";position:absolute;left:0;top:8px;bottom:8px;width:3px;border-radius:2px;background:linear-gradient(180deg,var(--red),var(--red-light))}
.prose blockquote::after{content:"\201D";position:absolute;left:18px;top:-28px;font-family:var(--serif);font-size:72px;line-height:1;color:rgba(221,50,17,.13);pointer-events:none;z-index:0}
.prose blockquote *{position:relative;z-index:1}
.prose .callout{background:var(--band);border:1px solid var(--hair);border-radius:8px;padding:20px 24px;margin:26px 0;font-size:var(--t-sm);color:var(--navy-600)}
.prose .callout b{color:var(--navy)}
/* premium comparison tables */
.prose table{width:100%;border-collapse:separate;border-spacing:0;margin:30px 0;font-size:var(--t-sm);border:1px solid var(--hair);border-radius:12px;overflow:hidden;box-shadow:var(--shadow-sm)}
.prose thead th{background:var(--navy);color:#fff;font-family:var(--label);text-transform:uppercase;letter-spacing:.07em;font-size:var(--t-2xs);font-weight:600;text-align:left;padding:14px 18px;vertical-align:bottom;border-bottom:2px solid var(--red)}
.prose tbody th,.prose tbody td{padding:14px 18px;border-top:1px solid var(--hair);vertical-align:top;line-height:1.55;text-align:left}
.prose tbody td{color:var(--navy-600)}
.prose tbody td:first-child,.prose tbody th[scope=row]{background:var(--band);color:var(--navy);font-weight:600}
.prose tbody td:first-child strong,.prose tbody th strong{color:var(--navy);font-weight:600}
.prose tbody tr:hover td{background:rgba(221,50,17,.045)}
.prose tbody tr:hover td:first-child{background:rgba(221,50,17,.08)}
.prose table p,.prose td p{margin:0}
.tbl-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;overscroll-behavior-x:contain;margin:30px 0;border-radius:12px}
.tbl-wrap>table{margin:0}
/* editorial lead paragraph + drop cap (articles) */
.post-body .prose > p:first-of-type{font-size:var(--t-md);color:var(--navy);line-height:1.72}
.post-body .prose > p:first-of-type::first-letter{float:left;font-family:var(--serif);font-size:3.6em;line-height:.78;font-weight:600;color:var(--red);padding:9px 12px 0 0}

/* "How we handle it" — visual process timeline */
.svc-process{counter-reset:s;margin:30px 0 12px;position:relative}
.svc-process::before{content:"";position:absolute;left:23px;top:26px;bottom:34px;width:2px;background:linear-gradient(180deg,var(--red),var(--red-light) 28%,var(--hair));border-radius:2px}
.svc-step{display:grid;grid-template-columns:48px 1fr;gap:22px;padding:0 0 30px;position:relative;align-items:start}
.svc-step:last-child{padding-bottom:4px}
.svc-step .n{counter-increment:s;width:48px;height:48px;border-radius:50%;background:#fff;border:2px solid var(--red);color:var(--red);font-family:var(--label);font-weight:700;font-size:var(--t-md);display:flex;align-items:center;justify-content:center;position:relative;z-index:1;box-shadow:0 0 0 6px var(--paper);transition:background .25s var(--ease),color .25s var(--ease),transform .25s var(--ease)}
.svc-step .n::before{content:counter(s,decimal-leading-zero)}
.svc-step:hover .n{background:var(--red);color:#fff;transform:scale(1.07)}
.svc-step h4{font-size:var(--t-md);font-weight:600;color:var(--navy);margin:12px 0 6px;letter-spacing:-.005em}
.svc-step p{font-size:var(--t-sm);color:var(--slate);margin:0;line-height:1.62}

.faq{margin-top:14px;border-top:1px solid var(--hair)}
.faq details{border-bottom:1px solid var(--hair)}
.faq summary{list-style:none;cursor:pointer;padding:20px 44px 20px 0;position:relative;font-size:var(--t-md);font-weight:600;color:var(--navy);line-height:1.4}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";position:absolute;right:4px;top:18px;font-size:26px;line-height:1;color:var(--red);font-weight:300}
.faq details[open] summary::after{content:"\2013"}
.faq .faq-a{padding:0 40px 22px 0}
.faq .faq-a p{font-size:var(--t-base);color:var(--navy-600);line-height:1.7;margin:0 0 12px}
.faq .faq-a p:last-child{margin-bottom:0}

.svc-aside{position:sticky;top:98px;display:flex;flex-direction:column;gap:22px}
.svc-cta-card{background:var(--navy);color:#fff;border-radius:10px;padding:28px 26px;box-shadow:var(--shadow-navy);position:relative;overflow:hidden}
.svc-cta-card::before{content:"";position:absolute;inset:0;background:radial-gradient(420px 200px at 100% 0,rgba(221,50,17,.16),transparent 60%);pointer-events:none}
.svc-cta-card > *{position:relative;z-index:1}
.svc-cta-card .cc-emblem{position:absolute;z-index:0;right:-30px;bottom:-44px;width:204px;height:204px;opacity:.07;pointer-events:none;-webkit-mask-image:radial-gradient(130% 120% at 80% 80%,#000 55%,transparent 96%);mask-image:radial-gradient(130% 120% at 80% 80%,#000 55%,transparent 96%)}
.svc-cta-card .cc-emblem img{width:100%;height:100%;display:block}
.svc-cta-card .eyebrow{margin-bottom:12px}
.svc-cta-card h3{font-family:var(--serif);font-size:var(--t-xl);font-weight:600;margin-bottom:8px;line-height:1.15}
.svc-cta-card p{font-size:var(--t-sm);color:var(--navy-200);line-height:1.6;margin-bottom:20px}
.svc-cta-card .btn{width:100%;margin-bottom:10px}
.svc-cta-card .wa{display:flex;align-items:center;justify-content:center;gap:9px;font-size:var(--t-sm);font-weight:600;color:#fff;padding:12px;border:1px solid rgba(255,255,255,.22);border-radius:3px;transition:.2s var(--ease)}
.svc-cta-card .wa:hover{border-color:#fff}
.svc-cta-card .wa .dot{width:8px;height:8px;border-radius:50%;background:#25D366}
.svc-cta-card .cc-wa,.svc-cta-card .cc-mail{display:flex;align-items:center;justify-content:center;gap:9px;font-size:var(--t-sm);font-weight:600;border-radius:6px;padding:13px;margin-bottom:10px;transition:transform .2s var(--ease),background .2s var(--ease),border-color .2s var(--ease)}
.svc-cta-card .cc-ic{width:18px;height:18px;flex:none}
.svc-cta-card .cc-wa{background:#25D366;color:#063b21}
.svc-cta-card .cc-wa:hover{background:#22c35e;transform:translateY(-1px)}
.svc-cta-card .cc-mail{background:transparent;color:#fff;border:1px solid rgba(255,255,255,.28)}
.svc-cta-card .cc-mail:hover{border-color:#fff;background:rgba(255,255,255,.06)}
.svc-cta-card .cc-book{display:block;text-align:center;margin-top:4px;font-size:var(--t-xs);color:var(--navy-200);transition:color .2s var(--ease)}
.svc-cta-card .cc-book:hover{color:#fff}
.post-contact{position:sticky;top:108px;align-self:start}
/* blog contact rail: graceful entrance, then a living green WhatsApp button that travels down with the reader */
.post-contact .svc-cta-card{animation:contact-in .7s var(--ease) both}
@keyframes contact-in{from{opacity:0;transform:translateY(26px) scale(.985)}to{opacity:1;transform:none}}
.svc-cta-card .cc-wa{position:relative;overflow:hidden;isolation:isolate;animation:wa-glow 2.8s ease-in-out infinite}
.svc-cta-card .cc-wa::after{content:"";position:absolute;top:0;left:-80%;width:55%;height:100%;z-index:-1;pointer-events:none;background:linear-gradient(105deg,transparent,rgba(255,255,255,.5),transparent);transform:skewX(-18deg);animation:cta-shine 4.6s ease-in-out infinite}
.svc-cta-card .cc-wa:hover{animation-duration:1.4s}
@keyframes wa-glow{0%,100%{box-shadow:0 6px 16px -7px rgba(37,211,102,.55)}50%{box-shadow:0 12px 30px -5px rgba(37,211,102,.9)}}
.svc-related h4{font-family:var(--label);text-transform:uppercase;letter-spacing:.16em;font-size:var(--t-3xs);color:var(--muted);margin-bottom:8px;font-weight:600}
.svc-related a{display:block;padding:13px 0;border-bottom:1px solid var(--hair);font-size:var(--t-sm);font-weight:500;color:var(--navy);transition:.2s var(--ease)}
.svc-related a:last-child{border-bottom:none}
.svc-related a:hover{color:var(--red);padding-left:4px}

/* ============ CTA emphasis — attractive + click-inviting ============ */
/* primary red CTA: stronger glow, lively hover, periodic light sweep */
.btn-red{box-shadow:0 8px 22px rgba(221,50,17,.26)}
.btn-red:hover{transform:translateY(-3px);box-shadow:0 16px 36px rgba(221,50,17,.42)}
.btn-red:active{transform:translateY(-1px)}
.btn-red,.btn-white{position:relative;overflow:hidden;isolation:isolate}
.btn-red::after,.btn-white::after{content:"";position:absolute;top:0;left:-75%;width:48%;height:100%;z-index:-1;pointer-events:none;transform:skewX(-18deg);animation:cta-shine 5s ease-in-out infinite}
.btn-red::after{background:linear-gradient(105deg,transparent,rgba(255,255,255,.42),transparent)}
.btn-white::after{background:linear-gradient(105deg,transparent,rgba(41,42,61,.10),transparent)}
.btn-red:hover::after,.btn-white:hover::after{animation:cta-shine 1.1s ease}
@keyframes cta-shine{0%{left:-75%}13%{left:155%}100%{left:155%}}
.btn-white:hover{transform:translateY(-3px)}
/* secondary stays calm but clearly tappable — fills on hover */
.btn-ghost:hover{transform:translateY(-2px);background:var(--navy);color:#fff;border-color:var(--navy)}
.btn-line:hover{transform:translateY(-2px);background:rgba(255,255,255,.10);border-color:#fff}

/* live green "light" = online, message us now */
@keyframes gpulse{0%{box-shadow:0 0 0 0 rgba(37,211,102,.55)}70%{box-shadow:0 0 0 9px rgba(37,211,102,0)}100%{box-shadow:0 0 0 0 rgba(37,211,102,0)}}
.wapp .dot,.ctaband .btn-line .dot,.svc-cta-card .wa .dot{animation:gpulse 2.2s ease-out infinite}
.wapp:hover .dot{animation-duration:1.1s}
/* floating WhatsApp: gentle attention bob + live halo */
.wa-float{animation:wa-bob 3.6s ease-in-out infinite}
@keyframes wa-bob{0%,100%{transform:translateY(0)}50%{transform:translateY(-4px)}}
.wa-float:hover{animation:none;transform:translateY(-2px)}
.wa-float .wa-ic{animation:gpulse 2.4s ease-out infinite}

@media (prefers-reduced-motion:reduce){
  .btn-red::after,.btn-white::after,.wapp .dot,.ctaband .btn-line .dot,.svc-cta-card .wa .dot,.wa-float,.wa-float .wa-ic{animation:none}
}

/* ---- services hub: rich SEO content block ---- */
.hub-rich{background:var(--band)}
.hub-rich .wrap{max-width:880px}
.hub-rich h2{font-family:var(--serif);font-weight:600;font-size:clamp(28px,3.2vw,38px);color:var(--navy);line-height:1.1;letter-spacing:-.01em;margin-bottom:10px}
.hub-rich h3{font-family:var(--serif);font-weight:600;font-size:var(--t-xl);color:var(--navy);margin:30px 0 6px}
.hub-rich p{font-size:var(--t-md);color:var(--slate);line-height:1.7;margin-bottom:6px}
.hub-rich a{color:var(--red);font-weight:600;border-bottom:1px solid transparent;transition:border-color .2s var(--ease)}
.hub-rich a:hover{border-color:var(--red)}
.hub-rich .hub-faq{margin-top:44px}
.hub-rich .hub-faq h2{font-size:clamp(24px,2.6vw,30px);margin-bottom:14px}

/* ============ Fact card + CTA band — premium 3D refinement ============ */
.hero-grid{perspective:1500px}
/* layered navy depth + interactive 3D tilt (JS sets transform on pointer move) */
.factcard{background:linear-gradient(157deg,#2C2E45 0%,var(--navy) 46%,var(--navy-900) 100%);overflow:hidden;box-shadow:var(--shadow-navy),inset 0 1px 0 rgba(255,255,255,.08);transition:transform .5s var(--ease),box-shadow .3s var(--ease);transform-origin:center}
.factcard.tilt{box-shadow:0 44px 86px rgba(8,7,18,.46),0 18px 36px rgba(8,7,18,.30),inset 0 1px 0 rgba(255,255,255,.12)}
/* CTA band gets the same interactive 3D tilt on hover (JS sets transform on pointer move) */
.ctaband .wrap{perspective:1500px}
.ctabox{transition:transform .5s var(--ease),box-shadow .3s var(--ease);transform-origin:center;will-change:transform}
.ctabox.tilt{box-shadow:0 50px 92px rgba(8,7,18,.40),0 20px 40px rgba(8,7,18,.26),inset 0 1px 0 rgba(255,255,255,.10)}
.factcard-inner{position:relative;z-index:2;border-color:rgba(255,255,255,.08);background:linear-gradient(180deg,rgba(255,255,255,.028),transparent 42%)}
/* breathing warm bloom for depth, top-right */
.factcard::before{content:"";position:absolute;top:-66px;right:-46px;width:320px;height:320px;border-radius:50%;background:radial-gradient(circle,rgba(232,92,63,.15),transparent 66%);z-index:0;pointer-events:none;animation:lx-bloom 7.5s ease-in-out infinite}
/* FULL emblem — fully visible (top NOT clipped), softly vignetted, clearly our temple */
.factcard .fc-emblem{position:absolute;top:28px;right:22px;width:196px;height:auto;opacity:.12;overflow:visible;border-radius:0;z-index:1;-webkit-mask-image:radial-gradient(120% 120% at 66% 34%,#000 58%,transparent 97%);mask-image:radial-gradient(120% 120% at 66% 34%,#000 58%,transparent 97%)}
.factcard .fc-emblem img{position:static;width:100%;height:auto;display:block}
/* header lockup: crisp WHITE logo badge (replaces the muddy red-on-red tile) */
.fc-head{gap:15px;align-items:center}
.fc-head .ico{width:50px;height:50px;border-radius:13px;background:#fff;border:none;padding:10px;box-shadow:0 7px 18px rgba(221,50,17,.24),inset 0 0 0 1px rgba(221,50,17,.08)}
.fc-head .ico img{width:100%;height:100%;object-fit:contain}

/* CTA band — same depth + corrected emblem (was squashed + clipped) */
.ctabox{background:linear-gradient(118deg,#2C2E45 0%,var(--navy) 52%,var(--navy-900) 100%);box-shadow:var(--shadow-navy),inset 0 1px 0 rgba(255,255,255,.06)}
.ctabox::before{animation:lx-glow 8s ease-in-out infinite}
.ctabox-inner .em{position:absolute;left:-34px;bottom:-42px;right:auto;width:330px;height:auto;opacity:.06;z-index:-1;pointer-events:none;-webkit-mask-image:radial-gradient(125% 125% at 10% 100%,#000 30%,transparent 74%);mask-image:radial-gradient(125% 125% at 10% 100%,#000 30%,transparent 74%)}
.ctabox-inner .em img{width:100%;height:auto;display:block}
/* CTA credibility line (helps especially on inner pages with no hero trustline) */
.cta-trust{display:block;margin-top:22px;font-size:var(--t-xs);color:var(--navy-200);letter-spacing:.01em}
.cta-trust .stars{color:var(--red-light);letter-spacing:.12em;margin-right:7px}
.cta-trust b{color:#fff;font-weight:600}

@keyframes lx-bloom{0%,100%{opacity:.45;transform:scale(.95)}50%{opacity:.95;transform:scale(1.05)}}
@keyframes lx-glow{0%,100%{opacity:.7}50%{opacity:1}}
@media (prefers-reduced-motion:reduce){.factcard::before,.ctabox::before{animation:none}.factcard{transition:box-shadow .3s}}

/* ============ Practice section — boutique seamless panel (concept-2 theme) ============ */
#practice .sec-sub{font-size:var(--t-sm);color:var(--slate);max-width:38ch;line-height:1.6;margin:0}
/* one unified panel: cells divided by 1px hairlines, not gapped cards */
#practice .pgrid{gap:1px;background:var(--hair);border:1px solid var(--hair);border-radius:12px}
#practice .pcard{background:#fff;border:none;border-radius:0;box-shadow:none;overflow:hidden;padding:32px 28px 28px;z-index:0;transition:transform .3s var(--ease),box-shadow .3s var(--ease)}
/* a cell lifts out of the panel and floats on hover */
#practice .pcard:hover{transform:translateY(-7px);box-shadow:0 30px 54px -26px rgba(26,20,38,.52);z-index:2;border-radius:11px}
#practice .pgrid>:nth-child(1){border-top-left-radius:11px}
#practice .pgrid>:nth-child(3){border-top-right-radius:11px}
#practice .pgrid>:nth-child(7){border-bottom-left-radius:11px}
#practice .pgrid>:nth-child(9){border-bottom-right-radius:11px}
/* closing cell — editorial "find your area" */
#practice .pcard-all{background:var(--paper);display:flex;flex-direction:column;justify-content:center;align-items:flex-start}
#practice .pcard-all .cell-eyebrow{font-family:var(--label);font-size:var(--t-2xs);text-transform:uppercase;letter-spacing:.14em;color:var(--navy-300);margin-bottom:12px}
#practice .pcard-all .pall-h{font-family:var(--serif);font-weight:500;font-size:24px;line-height:1.16;color:var(--navy);letter-spacing:-.005em}
#practice .pcard-all .plink{margin-top:18px;color:var(--red)}
@media (max-width:900px){
  /* home practice areas: compact, content-rich 2-up cards (icon · title · 2-line blurb · arrow) */
  #practice .pgrid{grid-template-columns:1fr 1fr;gap:11px;border:none;background:none;border-radius:0}
  #practice .pcard{background:#fff;border:1px solid var(--hair);box-shadow:0 6px 18px -12px rgba(26,20,38,.30);
    padding:16px 15px 15px;border-radius:14px;display:flex;flex-direction:column;align-items:flex-start;position:relative}
  #practice .pcard::before{height:2px;border-radius:14px 14px 0 0}
  #practice .pgrid>:nth-child(n){border-radius:14px}     /* drop the desktop corner-rounding overrides */
  #practice .pcard .pico{width:40px;height:40px;margin-bottom:12px;border-radius:11px;background:var(--paper)}
  #practice .pcard .pico .pic{width:21px;height:21px}
  #practice .pcard h3{font-size:14.5px;line-height:1.24;margin-bottom:5px;padding-right:14px}
  #practice .pcard p{display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;
    overflow:hidden;font-size:11.5px;line-height:1.45;color:var(--slate);margin:0}
  #practice .pcard .plink,#practice .pcard .pnum{display:none}
  #practice .pcard::after{content:"\2192";position:absolute;top:15px;right:14px;font-size:14px;color:var(--navy-200);
    transition:color .2s var(--ease),transform .2s var(--ease)}
  #practice .pcard:active{transform:scale(.985)}
  #practice .pcard:active::after{color:var(--red);transform:translateX(2px)}
  /* 9th "all practice areas" cell: full-width navy row */
  #practice .pcard-all{grid-column:1 / -1;flex-direction:row;align-items:center;gap:14px;padding:16px 18px;border:none}
  #practice .pcard-all::after{display:none}
  #practice .pcard-all .pico{margin-bottom:0;flex:none}
  #practice .pcard-all .pall-h{display:block;font-size:15px;line-height:1.2}
  #practice .pcard-all .cell-eyebrow{display:block;margin-bottom:4px}
  #practice .pcard-all .plink{display:none}
}

/* ---- office banner (contact) + about photo ---- */
.office-banner{position:relative;border-radius:14px;overflow:hidden;margin-bottom:48px;box-shadow:var(--shadow-md)}
.office-banner img{width:100%;height:clamp(240px,36vw,400px);object-fit:cover;object-position:center 42%;display:block}
.office-cap{position:absolute;left:18px;bottom:16px;display:inline-flex;align-items:center;gap:8px;background:rgba(25,22,38,.82);color:#fff;border-radius:9px;padding:9px 14px;font-size:var(--t-xs);font-weight:600;letter-spacing:.02em;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}
.office-cap svg{width:15px;height:15px;color:var(--red-light)}
.team-banner-sec{padding:6px 0 2px}
.team-banner{position:relative;max-width:900px;margin:0 auto;border-radius:14px;overflow:hidden;box-shadow:var(--shadow-md)}
.team-banner img{width:100%;height:auto;display:block}
/* ---- press / video cards ---- */
.home-video{background:var(--paper)}
.sec-sub{max-width:62ch;margin:14px auto 0;font-size:var(--t-md);color:var(--slate);line-height:1.6;text-align:center}
.sec-sub a{color:var(--red);font-weight:600;border-bottom:1px solid transparent;transition:border-color .2s var(--ease)}
.sec-sub a:hover{border-color:var(--red)}
.video-grid{display:grid;gap:24px;margin-top:44px}
.video-grid.two{grid-template-columns:repeat(2,1fr);max-width:1000px;margin-left:auto;margin-right:auto}
.video-grid.three{grid-template-columns:repeat(3,1fr)}
.vcard{display:flex;flex-direction:column}
.vthumb{position:relative;display:block;width:100%;aspect-ratio:16/9;border:none;padding:0;border-radius:12px;overflow:hidden;cursor:pointer;background:var(--navy);box-shadow:var(--shadow-md);transition:transform .25s var(--ease),box-shadow .25s var(--ease)}
.vthumb img{width:100%;height:100%;object-fit:cover;display:block}
.vthumb:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.vthumb::after{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;background:linear-gradient(180deg,rgba(18,17,30,.24) 0%,rgba(18,17,30,0) 22%,rgba(18,17,30,0) 58%,rgba(18,17,30,.34) 100%)}
.vthumb .vbadge,.vthumb .vplay{z-index:2}
.vthumb.playing::after,.vthumb.playing .vbadge,.vthumb.playing .vplay{display:none}
.vbadge{position:absolute;top:14px;left:14px;display:inline-flex;align-items:center;gap:7px;background:rgba(255,255,255,.94);color:var(--navy);font-family:var(--label);text-transform:uppercase;letter-spacing:.09em;font-size:var(--t-3xs);font-weight:700;padding:6px 12px;border-radius:30px}
.vbadge .vdot{width:8px;height:8px;border-radius:50%;background:var(--red)}
.vcard.tv .vbadge .vdot{animation:pulse 2s ease-out infinite}
.vplay{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:74px;height:74px;border-radius:50%;background:rgba(255,255,255,.94);display:flex;align-items:center;justify-content:center;color:var(--red);box-shadow:0 12px 32px rgba(8,7,18,.36);transition:transform .25s var(--ease),background .25s var(--ease)}
.vplay svg{width:30px;height:30px;margin-left:3px}
.vthumb:hover .vplay{transform:translate(-50%,-50%) scale(1.08);background:#fff}
.vthumb.playing{cursor:default}
.vthumb video{width:100%;height:100%;display:block;background:#000}
.vmeta{padding:17px 4px 0}
.vtitle{font-family:var(--serif);font-size:var(--t-lg);font-weight:600;color:var(--navy);line-height:1.26;letter-spacing:-.005em}
.vblurb{font-size:var(--t-sm);color:var(--slate);line-height:1.55;margin-top:8px}
.vby{display:inline-block;margin-top:10px;font-family:var(--label);text-transform:uppercase;letter-spacing:.1em;font-size:var(--t-3xs);color:var(--red);font-weight:600}
.press-block-head{margin-bottom:6px}
.press-block-head h2{font-family:var(--serif);font-weight:600;font-size:clamp(24px,2.6vw,32px);color:var(--navy);letter-spacing:-.01em}
.press-block-head .sec-sub{margin:8px 0 0;text-align:left}
.band-sec{background:var(--band)}
/* ---- press page: stats, topics, media enquiries ---- */
.press-stats{display:flex;flex-wrap:wrap;gap:12px;margin-top:30px}
.ps-chip{display:inline-flex;flex-direction:column;gap:3px;background:var(--white);border:1px solid var(--hair);border-radius:10px;padding:11px 17px;box-shadow:var(--shadow-sm);font-size:var(--t-sm);color:var(--navy);line-height:1.3}
.ps-chip b{font-family:var(--label);text-transform:uppercase;letter-spacing:.1em;font-size:var(--t-3xs);color:var(--red);font-weight:700}
.press-block-head.center{text-align:center;max-width:680px;margin:0 auto 40px}
.press-block-head.center h2{margin-top:12px}
.trust-logos.center{justify-content:center;gap:38px;margin-top:6px}
.pt-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.pt-card{display:flex;gap:15px;background:#fff;border:1px solid var(--hair);border-radius:10px;padding:24px 22px;box-shadow:var(--shadow-sm);transition:transform .25s var(--ease),box-shadow .25s var(--ease),border-color .25s var(--ease)}
.pt-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:transparent}
.pt-ic{flex:none;width:46px;height:46px;border-radius:10px;background:var(--band);display:flex;align-items:center;justify-content:center;color:var(--red)}
.pt-ic .pic{width:23px;height:23px}
.pt-body{display:flex;flex-direction:column}
.pt-title{font-family:var(--serif);font-size:var(--t-lg);font-weight:600;color:var(--navy);line-height:1.2}
.pt-text{font-size:var(--t-sm);color:var(--slate);line-height:1.5;margin-top:7px}
.pt-more{margin-top:13px;font-family:var(--label);text-transform:uppercase;letter-spacing:.08em;font-size:var(--t-3xs);font-weight:700;color:var(--red)}
.pt-card:hover .pt-more .arr{margin-left:3px}
.media-enq{position:relative;overflow:hidden;background:linear-gradient(157deg,#2C2E45,var(--navy) 55%,var(--navy-900));color:#fff;border-radius:16px;padding:48px 50px;display:grid;grid-template-columns:1.5fr auto;gap:40px;align-items:center;box-shadow:var(--shadow-navy)}
.media-enq::before{content:"";position:absolute;inset:0;background:radial-gradient(620px 260px at 88% 120%,rgba(221,50,17,.18),transparent 60%);pointer-events:none}
.media-enq > *{position:relative;z-index:1}
.media-enq .cc-emblem{position:absolute;z-index:0;right:-16px;bottom:-54px;width:230px;height:230px;opacity:.07;pointer-events:none}
.media-enq .cc-emblem img{width:100%;height:100%}
.media-enq h2{font-family:var(--serif);font-weight:600;font-size:clamp(26px,3vw,36px);color:#fff;line-height:1.08;margin-top:14px}
.media-enq p{font-size:var(--t-md);color:var(--navy-200);line-height:1.62;margin-top:14px;max-width:56ch}
.me-actions{display:flex;flex-direction:column;gap:12px;align-items:stretch}
.me-actions .btn{white-space:nowrap}
@media (max-width:880px){.pt-grid{grid-template-columns:1fr;max-width:520px;margin-left:auto;margin-right:auto}.media-enq{grid-template-columns:1fr;padding:36px 28px}}
@media (max-width:880px){.video-grid.two,.video-grid.three{grid-template-columns:1fr;max-width:520px;margin-left:auto;margin-right:auto}}
.about-photo{margin:36px 0;border-radius:12px;overflow:hidden;box-shadow:var(--shadow-md)}
.about-photo img{width:100%;height:auto;aspect-ratio:3/2;object-fit:cover;display:block}

/* ---- client reviews ---- */
.reviews{background:var(--paper)}
/* Google-branded summary badge — makes the source unmistakable */
.rv-badge{display:inline-flex;align-items:center;gap:14px;margin-top:24px;background:#fff;border:1px solid var(--hair);border-radius:14px;padding:11px 18px 11px 16px;box-shadow:var(--shadow-sm);transition:transform .2s var(--ease),box-shadow .2s var(--ease)}
.rv-badge:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}
.rv-badge .g-ic{width:30px;height:30px;flex:none}
.rv-badge-txt{display:flex;flex-direction:column;align-items:flex-start;line-height:1.15}
.rv-badge-top{font-family:var(--label);font-size:var(--t-3xs);text-transform:uppercase;letter-spacing:.13em;color:var(--slate);font-weight:600}
.rv-badge-rate{display:inline-flex;align-items:center;gap:8px;margin-top:3px;color:var(--navy)}
.rv-badge-rate b{font-weight:700;font-size:var(--t-lg)}
.rv-badge-count{color:var(--slate);font-size:var(--t-sm)}
.rv-badge-arr{color:var(--navy-300);font-size:var(--t-lg);transition:transform .2s var(--ease),color .2s var(--ease)}
.rv-badge:hover .rv-badge-arr{color:var(--red);transform:translateX(3px)}
/* gold Google-style stars */
.rv-stars{color:#FBBC04;letter-spacing:2px;font-size:15px;white-space:nowrap;line-height:1}
.rv-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:46px}
.rv-card{background:#fff;border:1px solid var(--hair);border-radius:11px;padding:24px 24px 26px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:13px;position:relative;transition:transform .25s var(--ease),box-shadow .25s var(--ease)}
.rv-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.rv-top{display:flex;align-items:center;gap:12px}
.rv-avatar{width:44px;height:44px;flex:none;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-family:var(--serif);font-weight:600;font-size:19px;line-height:1;box-shadow:inset 0 1px 0 rgba(255,255,255,.18)}
.rv-id{display:flex;flex-direction:column;min-width:0;flex:1}
.rv-name{font-weight:600;color:var(--navy);font-size:var(--t-sm)}
.rv-area{font-size:var(--t-2xs);color:var(--slate);text-transform:uppercase;letter-spacing:.09em;margin-top:3px;font-family:var(--label)}
.rv-g{flex:none;display:flex;align-items:center}
.rv-g .g-ic{width:21px;height:21px}
.rv-card blockquote{font-family:var(--serif);font-size:var(--t-md);line-height:1.5;color:var(--navy);font-style:italic;margin:0;flex:1}
@media (max-width:820px){.rv-grid{grid-template-columns:1fr;max-width:520px;margin-left:auto;margin-right:auto}}

/* ===== article reading experience ===== */
.reading-bar{position:fixed;top:0;left:0;right:0;height:3px;z-index:70;pointer-events:none}
.reading-bar span{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--red),var(--red-light));transition:width .1s linear}
.post-byline{display:flex;align-items:center;gap:9px;margin-top:18px;font-size:var(--t-sm);color:var(--slate)}
.post-byline .bl-em{width:22px;height:22px;flex:none;display:flex}
.post-byline .bl-em img{width:100%;height:100%}
.post-byline b{color:var(--navy);font-weight:600}
/* TOC + main two-column layout */
.post-body .post-grid{display:grid;grid-template-columns:200px minmax(0,1fr) 246px;gap:46px;max-width:1200px;margin:0 auto}
.toc{position:sticky;top:108px}
.toc-label{display:block;font-family:var(--label);text-transform:uppercase;letter-spacing:.14em;font-size:var(--t-3xs);color:var(--navy-300);font-weight:600;margin-bottom:14px}
.toc ul{list-style:none;border-left:2px solid var(--hair)}
.toc li a{display:block;padding:7px 0 7px 16px;margin-left:-2px;border-left:2px solid transparent;font-size:var(--t-xs);color:var(--slate);line-height:1.45;transition:color .2s var(--ease),border-color .2s var(--ease)}
.toc li a:hover{color:var(--navy)}
.toc li a.on{color:var(--red);border-left-color:var(--red);font-weight:600}
/* key takeaways */
.takeaways{background:linear-gradient(180deg,var(--band),var(--paper));border:1px solid var(--hair);border-radius:13px;padding:26px 28px;margin-bottom:36px;position:relative;overflow:hidden}
.takeaways::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--red)}
.takeaways .tk-title{display:block;font-family:var(--label);text-transform:uppercase;letter-spacing:.13em;font-size:var(--t-xs);color:var(--red);font-weight:700;margin-bottom:15px}
.takeaways ul{list-style:none;display:flex;flex-direction:column;gap:11px}
.takeaways li{position:relative;padding-left:27px;font-size:var(--t-md);color:var(--navy);line-height:1.5}
.takeaways li::before{content:"";position:absolute;left:2px;top:9px;width:9px;height:9px;border-radius:50%;background:var(--red)}
/* H2 red accent + jump offset (article only) */
.post-body .prose h2,.svc-body .prose h2{position:relative;padding-top:14px;scroll-margin-top:96px}
.post-body .prose h2::before,.svc-body .prose h2::before{content:"";position:absolute;top:0;left:0;width:44px;height:3px;border-radius:2px;background:var(--red);transition:width .3s var(--ease)}
.post-body .prose h2:hover::before,.svc-body .prose h2:hover::before{width:74px}
/* legal callout variants (markup added in the per-article content pass) */
.prose .cl-law,.prose .cl-warn,.prose .cl-tip{border-radius:10px;padding:16px 20px 16px 50px;margin:26px 0;position:relative;font-size:var(--t-sm);line-height:1.62;color:var(--navy-600)}
.prose .cl-law{background:rgba(41,42,61,.045);border:1px solid var(--hair)}
.prose .cl-warn{background:rgba(221,50,17,.05);border:1px solid rgba(221,50,17,.16)}
.prose .cl-tip{background:var(--band);border:1px solid var(--hair)}
.prose .cl-law::before,.prose .cl-warn::before,.prose .cl-tip::before{position:absolute;left:16px;top:15px;font-size:18px;line-height:1}
.prose .cl-law::before{content:"\2696\FE0F"}
.prose .cl-warn::before{content:"\26A0\FE0F"}
.prose .cl-tip::before{content:"\1F4A1"}
.prose .cl-law b,.prose .cl-warn b,.prose .cl-tip b{color:var(--navy)}
/* scroll-reveal */
.post-main .sreveal{opacity:0;transform:translateY(14px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
.post-main .sreveal.in{opacity:1;transform:none}
/* back to top */
.to-top{position:fixed;right:22px;bottom:84px;z-index:79;width:44px;height:44px;border-radius:50%;border:1px solid var(--hair);background:#fff;color:var(--navy);box-shadow:var(--shadow-md);cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transform:translateY(8px);transition:.25s var(--ease)}
.to-top svg{width:18px;height:18px}
.to-top.show{opacity:1;transform:none}
.to-top:hover{background:var(--navy);color:#fff;border-color:var(--navy)}
@media (max-width:1140px){
  .post-body .post-grid{grid-template-columns:200px minmax(0,1fr);max-width:920px}
  .post-contact{display:none}
}
@media (max-width:980px){
  .post-body .post-grid{grid-template-columns:1fr;gap:0;max-width:720px}
  .post-aside{display:none}
}
@media (prefers-reduced-motion:reduce){.post-main .sreveal{opacity:1;transform:none}.reading-bar span,.to-top{transition:none}.post-contact .svc-cta-card{animation:none}.svc-cta-card .cc-wa{animation:none}.svc-cta-card .cc-wa::after{display:none}}

/* ---- blog conceptual search ---- */
.blog-search{position:relative;display:flex;align-items:center;max-width:580px;margin-top:30px;background:#fff;border:1px solid var(--hair);border-radius:12px;box-shadow:var(--shadow-sm);transition:border-color .2s var(--ease),box-shadow .2s var(--ease)}
.blog-search:focus-within{border-color:var(--navy);box-shadow:0 0 0 4px rgba(41,42,61,.08),var(--shadow-md)}
.blog-search .bs-ico{width:20px;height:20px;color:var(--navy-300);margin-left:18px;flex:none}
.blog-search input{flex:1;border:none;background:none;outline:none;padding:17px 14px;font-family:var(--sans);font-size:var(--t-md);color:var(--navy);min-width:0}
.blog-search input::placeholder{color:var(--navy-300)}
.blog-search input::-webkit-search-cancel-button{display:none}
#searchClear{flex:none;margin-right:12px;width:30px;height:30px;border:none;border-radius:50%;background:var(--band);color:var(--slate);font-size:14px;line-height:1;cursor:pointer;transition:.18s var(--ease)}
#searchClear:hover{background:var(--navy);color:#fff}
.bs-status{margin-top:12px;font-size:var(--t-xs);color:var(--slate);min-height:1em}
.bs-status:empty{margin:0;min-height:0}
.bs-wrap{padding-top:8px}
.bs-results{display:grid;gap:12px;max-width:840px}
.bs-hit{display:grid;grid-template-columns:1fr auto;grid-template-areas:"cat go" "title go" "ex go";gap:0 16px;align-items:start;background:#fff;border:1px solid var(--hair);border-radius:10px;padding:20px 22px;box-shadow:var(--shadow-sm);transition:transform .2s var(--ease),box-shadow .2s var(--ease),border-color .2s var(--ease)}
.bs-hit:hover,.bs-hit.on{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:transparent}
.bs-hit.on{outline:2px solid var(--navy);outline-offset:2px}
.bs-cat{grid-area:cat;font-family:var(--label);text-transform:uppercase;letter-spacing:.12em;font-size:var(--t-3xs);color:var(--red);font-weight:600;margin-bottom:5px}
.bs-title{grid-area:title;font-family:var(--serif);font-weight:600;font-size:var(--t-lg);line-height:1.2;color:var(--navy);letter-spacing:-.005em}
.bs-ex{grid-area:ex;font-size:var(--t-sm);color:var(--slate);line-height:1.55;margin-top:7px}
.bs-go{grid-area:go;align-self:center;color:var(--navy-200);font-size:20px;transition:transform .2s var(--ease),color .2s var(--ease)}
.bs-hit:hover .bs-go,.bs-hit.on .bs-go{color:var(--red);transform:translateX(4px)}
.bs-hit mark{background:rgba(221,50,17,.15);color:inherit;border-radius:2px;padding:0 1px}
.bs-empty{background:#fff;border:1px dashed var(--hair);border-radius:10px;padding:30px 26px;display:flex;flex-direction:column;gap:8px;max-width:560px}
.bs-empty b{font-size:var(--t-md);color:var(--navy)}
.bs-empty span{font-size:var(--t-sm);color:var(--slate);line-height:1.55}
.bs-ask{margin-top:6px;font-size:var(--t-sm);font-weight:600;color:var(--red)}

/* ---- responsive ---- */
@media (max-width:900px){
  .svc-wrap{grid-template-columns:1fr;gap:40px}
  .svc-aside{position:static}
  .svc-body{padding:48px 0 24px}
  .team-grid{grid-template-columns:1fr}
  .tcard{grid-template-columns:88px 1fr;gap:18px;padding:18px}
  .tcard .tphoto{width:88px;height:88px}
  .contact-grid{grid-template-columns:1fr;gap:36px}
  .contact-form .frow{grid-template-columns:1fr}
  .contact-form{padding:22px}
  .introband{padding:60px 0}
  .ib-grid{grid-template-columns:1fr;gap:32px}
  .ib-media .ib-badge{left:14px;right:14px;max-width:none}
  .wrap-narrow{padding:0 22px}
  .post-head{padding:48px 0 28px}
  .post-cta{flex-direction:column;align-items:flex-start}
  .post-cta .btn{width:100%}
  .blog-grid{grid-template-columns:1fr}
  .wrap{padding:0 22px}
  .menu,.nav-divider,.nav .header-cta,.nav-right .lang{display:none}
  /* solid header on mobile: backdrop-filter creates a containing block that traps the
     fixed drawer (it would open at the page top); a solid bg also renders reliably while scrolling */
  body>header{background:var(--paper);-webkit-backdrop-filter:none;backdrop-filter:none}
  .mnav{display:flex}
  .mnav-backdrop{display:block}
  .menu-toggle{display:inline-flex;align-items:center;justify-content:center;width:46px;height:46px;border:1px solid var(--hair);border-radius:8px;background:#fff}
  .menu-toggle span{display:block;width:18px;height:2px;background:var(--navy);position:relative}
  .menu-toggle span::before,.menu-toggle span::after{content:"";position:absolute;left:0;width:18px;height:2px;background:var(--navy)}
  .menu-toggle span::before{top:-6px}.menu-toggle span::after{top:6px}
  .hero{padding:52px 0 64px}
  .hero::before{display:none}
  .hero-grid{grid-template-columns:1fr;gap:44px}
  .hero h1{font-size:clamp(40px,11vw,56px)}
  .hero .sub{max-width:none}
  .hero-cta{flex-direction:column;align-items:stretch;gap:12px}
  .hero-cta .btn{width:100%}
  .wapp{justify-content:center;padding:13px;border:1px solid var(--hair);border-radius:3px;background:#fff}
  .trustline{justify-content:flex-start}
  .trust-inner{gap:18px}
  .trust-logos{gap:20px}
  .trust-logos span{font-size:var(--t-base)}
  .sec{padding:68px 0}
  .sec-head{margin-bottom:40px}
  .sec-head .row{flex-direction:column;align-items:flex-start;gap:18px}
  .sec-head .row .btn-ghost{align-self:stretch}
  .pgrid{grid-template-columns:1fr;gap:14px}
  .stats-inner{padding:56px 0}
  .stats-top{flex-direction:column;align-items:flex-start;gap:16px;margin-bottom:32px}
  .stat-grid{grid-template-columns:1fr 1fr}
  .stat{padding:26px 20px 4px}
  .stat:nth-child(2n){border-right:none}
  .stat:nth-child(-n+2){border-bottom:1px solid rgba(255,255,255,.10);padding-bottom:26px}
  .steps{grid-template-columns:1fr;gap:40px 0;align-items:stretch}
  .steps::before,.steps::after{top:30px;bottom:30px;left:28px;right:auto;width:2px;height:auto}
  .steps::before{background:var(--navy-100)}
  .steps::after{background:linear-gradient(180deg,var(--red) 0%,var(--red-light) 100%);transform-origin:top center;transform:scaleY(1);box-shadow:0 0 10px rgba(221,50,17,.18)}
  .steps.armed::after{transform:scaleY(0)}
  .steps.armed.playing::after{transform:scaleY(1);transition:transform 2.4s var(--ease)}
  .step{padding-top:0;padding-left:calc(var(--node) + 26px);min-height:var(--node);justify-content:flex-start}
  .step .snum{top:-2px}
  .step .sicon{display:none}
  .step::after{display:none}
  .step p{max-width:none}
  .step .schip{margin-top:14px}
  .ctaband{padding:64px 0}
  .ctabox-inner{grid-template-columns:1fr;gap:32px;padding:40px 28px}
  .cta-actions{width:100%}
  .foot-grid{grid-template-columns:1fr 1fr;gap:36px 28px}
  .foot-brand{grid-column:1 / -1}
  .foot-bottom{flex-direction:column;align-items:flex-start;gap:14px}
  /* declutter the "recognised on" row: stack label → logo → marks with clear rhythm */
  .foot-recog{flex-direction:column;align-items:flex-start;gap:13px;padding:26px 0 2px}
  .foot-marks{font-size:var(--t-sm);line-height:1.7}
  .foot-mondaq img{height:24px}
}
@media (max-width:520px){
  .stat-grid{grid-template-columns:1fr}
  .stat{border-right:none;border-bottom:1px solid rgba(255,255,255,.10);padding-bottom:26px}
  .stat:last-child{border-bottom:none}
  /* compact footer: keep the two nav columns side-by-side (no long stacked lists); tighter rhythm */
  footer{padding:44px 0 28px}
  .foot-grid{grid-template-columns:1fr 1fr;gap:26px 20px;padding-bottom:30px}
  .foot-brand{grid-column:1 / -1;margin-bottom:0}
  .foot-brand img{margin-bottom:14px}
  .foot-brand p{display:none}
  .foot-social{margin-top:16px}
  .foot-contact{grid-column:1 / -1}
  .foot-col h4{margin-bottom:12px}
  .foot-col a{padding:4px 0;font-size:var(--t-2xs)}
  .foot-recog{padding:22px 0 2px}
}

/* ---- mobile sticky CTA bar (mobile counterpart of the desktop right-rail contact card) ---- */
.mcta{display:none}
@media (max-width:900px){
  .mcta{display:block;position:fixed;left:0;right:0;bottom:0;z-index:75;
    background:rgba(41,42,61,.94);-webkit-backdrop-filter:saturate(160%) blur(14px);backdrop-filter:saturate(160%) blur(14px);
    border-top:1px solid rgba(255,255,255,.09);box-shadow:0 -12px 34px rgba(20,18,32,.30);
    padding:0 11px calc(env(safe-area-inset-bottom) + 9px);
    transform:translateY(110%);animation:mcta-in .55s .2s cubic-bezier(.16,.8,.3,1) forwards}
  .mcta-note{display:flex;align-items:center;justify-content:center;gap:7px;
    font-family:var(--sans);font-size:11.5px;letter-spacing:.01em;color:#c9cadb;white-space:nowrap;
    overflow:hidden;text-overflow:ellipsis;padding:8px 6px 7px;border-bottom:1px solid rgba(255,255,255,.07)}
  .mcta-live{flex:none;width:7px;height:7px;border-radius:50%;background:#34d058;box-shadow:0 0 0 0 rgba(52,208,88,.6);animation:mcta-pulse 2.2s ease-out infinite}
  .mcta-row{display:flex;align-items:stretch;gap:8px;padding:9px 0 0}
  .mcta-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;
    min-height:52px;border-radius:14px;font-family:var(--sans);font-weight:600;font-size:11.5px;line-height:1.1;
    color:#fff;text-decoration:none;flex:1;transition:transform .14s var(--ease),background .2s var(--ease)}
  .mcta-btn:active{transform:scale(.94)}
  .mcta-ic{display:flex;align-items:center;justify-content:center}
  .mcta-ic svg{width:20px;height:20px;display:block}
  .mcta-lb{text-align:center}
  .mcta-wa{background:rgba(37,211,102,.15);border:1px solid rgba(37,211,102,.34)}
  .mcta-wa .mcta-ic{color:#2fce62}
  .mcta-em{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.17)}
  .mcta-bk{flex:1.75;position:relative;overflow:hidden;background:var(--red);border:1px solid var(--red);
    box-shadow:0 7px 18px rgba(221,50,17,.36);animation:mcta-breathe 3.6s ease-in-out infinite}
  .mcta-bk .mcta-lb{font-weight:700;letter-spacing:.01em}
  .mcta-shine{position:absolute;top:0;left:-65%;width:48%;height:100%;pointer-events:none;
    background:linear-gradient(100deg,transparent,rgba(255,255,255,.40),transparent);
    transform:skewX(-18deg);animation:mcta-shine 3.6s ease-in-out infinite}
  .wa-float{display:none}                 /* the bar replaces the lone WhatsApp bubble on mobile */
  body{padding-bottom:98px}               /* clear the fixed bar so it never hides footer/content */
  body.mnav-on .mcta{display:none}        /* the full-screen menu carries its own CTA */
}
@keyframes mcta-in{to{transform:none}}
@keyframes mcta-pulse{0%{box-shadow:0 0 0 0 rgba(52,208,88,.55)}70%{box-shadow:0 0 0 8px rgba(52,208,88,0)}100%{box-shadow:0 0 0 0 rgba(52,208,88,0)}}
@keyframes mcta-breathe{0%,100%{transform:translateY(0)}50%{transform:translateY(-2px)}}
@keyframes mcta-shine{0%,52%{left:-65%}82%,100%{left:135%}}
@media (prefers-reduced-motion:reduce){
  .mcta{animation:none;transform:none}
  .mcta-live,.mcta-bk{animation:none}
  .mcta-shine{display:none}
}

/* ---- careers ---- */
.careers-values{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-bottom:54px}
.cv-item{background:#fff;border:1px solid var(--hair);border-radius:12px;padding:24px 22px;box-shadow:var(--shadow-sm)}
.cv-item h4{font-family:var(--serif);font-size:21px;font-weight:600;color:var(--navy);margin-bottom:8px;letter-spacing:-.005em}
.cv-item p{font-size:var(--t-sm);color:var(--slate);line-height:1.6}
.careers-grid .pcard{display:flex;flex-direction:column;align-items:flex-start}
.careers-tag{display:inline-block;font-family:var(--label);font-size:var(--t-3xs);text-transform:uppercase;letter-spacing:.12em;color:var(--red);background:rgba(221,50,17,.08);border-radius:20px;padding:4px 11px;margin-bottom:13px}
.careers-detail{display:grid;grid-template-columns:1fr 1.05fr;gap:48px;align-items:start}
.careers-copy h2,.careers-formwrap h2{font-family:var(--serif);font-size:25px;font-weight:600;color:var(--navy);margin-bottom:18px;letter-spacing:-.01em}
.careers-points{list-style:none;margin:0 0 22px;display:flex;flex-direction:column;gap:13px}
.careers-points li{position:relative;padding-left:30px;font-size:var(--t-sm);color:var(--navy-600);line-height:1.5}
.careers-points li svg{position:absolute;left:0;top:1px;width:19px;height:19px;color:var(--red)}
.careers-aside-note{font-size:var(--t-xs);color:var(--slate);line-height:1.6;border-left:2px solid var(--hair);padding-left:14px}
.careers-form{margin-top:2px}
.careers-form .field-file input{padding:10px 12px;background:#fff;cursor:pointer;font-size:var(--t-xs)}
.crumbs{margin-bottom:16px}
.crumbs a{font-size:var(--t-sm);color:var(--red);font-weight:600}
@media (max-width:820px){
  .careers-detail{grid-template-columns:1fr;gap:30px}
  .careers-values{grid-template-columns:1fr;gap:14px;margin-bottom:36px}
}

/* ---- Careers · language-skills sliders ---------------------------------- */
.lang-skills{background:var(--paper);border:1px solid var(--hair);border-radius:12px;padding:18px 18px 6px;margin:2px 0 4px}
.ls-title{display:block;font-size:var(--t-3xs);font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--navy-600)}
.ls-hint{font-size:var(--t-xs);color:var(--slate);margin:3px 0 16px}
.ls-row{margin-bottom:15px}
.ls-row:last-child{margin-bottom:6px}
.ls-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:7px}
.ls-name{font-size:var(--t-sm);font-weight:600;color:var(--navy)}
.ls-level{font-size:var(--t-2xs);font-weight:700;letter-spacing:.04em;color:var(--navy-300);transition:color .15s}
.ls-row.ls-on .ls-level{color:var(--red)}
.ls-desc{font-size:var(--t-xs);color:var(--slate);margin-top:6px;min-height:1.45em;line-height:1.45;transition:color .15s}
.ls-row.ls-on .ls-desc{color:var(--navy-600)}
/* range: branded track fill via --ls-fill (set by JS) */
.ls-range{-webkit-appearance:none;appearance:none;width:100%;height:6px;border-radius:6px;cursor:pointer;
  background:linear-gradient(var(--red),var(--red)) no-repeat,var(--hair);
  background-size:var(--ls-fill,0%) 100%;outline:none;margin:2px 0}
.ls-range::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;
  background:#fff;border:2px solid var(--red);box-shadow:0 1px 4px rgba(41,42,61,.25);cursor:pointer;transition:transform .12s}
.ls-range::-webkit-slider-thumb:active{transform:scale(1.18)}
.ls-range::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:#fff;border:2px solid var(--red);box-shadow:0 1px 4px rgba(41,42,61,.25);cursor:pointer}
.ls-range::-moz-range-track{height:6px;border-radius:6px;background:var(--hair)}
.ls-range::-moz-range-progress{height:6px;border-radius:6px;background:var(--red)}
.ls-range:focus-visible{box-shadow:0 0 0 3px rgba(221,50,17,.22)}

/* ---- Press · speaking & events photos ----------------------------------- */
.event-wrap{display:grid;grid-template-columns:1.7fr 1fr;gap:20px;align-items:start}
.event-fig{margin:0}
.event-fig img{width:100%;height:auto;display:block;border-radius:12px;border:1px solid var(--hair)}
.event-fig figcaption{font-size:var(--t-xs);color:var(--slate);margin-top:9px;line-height:1.5}
@media(max-width:760px){.event-wrap{grid-template-columns:1fr;gap:24px}}
