/* ===========================================================================
   ClientsFlow — Variant B "Bright" theme (PandaDoc-inspired, isometric)
   Same HTML classes as Variant A, restyled bright. Keeps brand blue accent.
   =========================================================================== */
:root{
  --blue-400:#3d96ff; --blue-500:#1d85ff; --blue-600:#0a6ee0; --blue-700:#0d52b3; --deep-blue:#2a54ff; --cyan:#0acfff;
  --navy:#0d1b3e; --ink:#33415c; --ink-soft:#5b6b86;
  --bg:#ffffff; --soft:#f4f7fd; --soft2:#eef3fc; --card:#ffffff; --line:#e6ecf5; --line-strong:#d4ddec;
  --grad:linear-gradient(135deg,#2A54FF 0%,#06DAFF 100%);
  --grad-soft:linear-gradient(180deg,#ffffff 0%,#f1f6ff 100%);
  --action:var(--blue-500); --action-hover:#0a6ee0;
  --f-display:'Montserrat',system-ui,sans-serif;
  --f-body:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --t-md:1.0625rem;
  --t-h3:clamp(1.25rem,1.05rem + .9vw,1.6rem);
  --t-h2:clamp(1.8rem,1.3rem + 2.1vw,2.9rem);
  --t-h1:clamp(2.3rem,1.6rem + 3.4vw,4rem);
  --t-display:clamp(2.6rem,1.7rem + 4.6vw,5rem);
  --t-lg:clamp(1.1rem,1rem + .5vw,1.3rem);
  --sp:clamp(1rem,4vw,3rem); --section-y:clamp(3.5rem,7vw,7rem);
  --maxw:1200px; --maxw-wide:1320px; --maxw-text:680px;
  --r:18px; --r-sm:10px; --r-lg:22px; --r-full:9999px;
  --sh-sm:0 6px 18px -10px rgba(13,27,62,.12);
  --sh:0 12px 34px -14px rgba(13,27,62,.16);
  --sh-lg:0 26px 60px -22px rgba(13,27,62,.24);
  --sh-blue:0 16px 38px -12px rgba(42,84,255,.4);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{font-family:var(--f-body);font-size:var(--t-md);line-height:1.65;color:var(--ink);background:var(--bg);
  -webkit-font-smoothing:antialiased;overflow-x:hidden}
img,svg,video{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}
h1,h2,h3,h4{font-family:var(--f-display);font-weight:800;line-height:1.08;letter-spacing:-.02em;color:var(--navy)}
h2{font-size:var(--t-h2)}h3{font-size:var(--t-h3);font-weight:700}
strong{font-weight:600;color:var(--navy)}
::selection{background:#cfe0ff;color:var(--navy)}
:focus-visible{outline:3px solid var(--blue-600);outline-offset:2px;border-radius:6px}
.container{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:var(--sp)}
.container--wide{max-width:var(--maxw-wide)}
.section{padding-block:var(--section-y)}
.section--tight{padding-block:clamp(2.5rem,5vw,4.5rem)}
.section--subtle{background:var(--soft)}
.section--brand{background:var(--soft2)}
.section--dark{background:var(--navy);color:#fff}
.section--dark h2,.section--dark h3{color:#fff}
.skip-link{position:absolute;left:-9999px;top:0;background:var(--navy);color:#fff;padding:.7rem 1.1rem;z-index:200}
.skip-link:focus{left:0}
.sr-only{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* eyebrow / heads */
.eyebrow{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--f-display);font-weight:700;font-size:.8rem;
  letter-spacing:.08em;text-transform:uppercase;color:var(--blue-600)}
.section--dark .eyebrow{color:var(--cyan)}
.eyebrow::before{content:"";width:22px;height:2px;background:currentColor;border-radius:2px}
.head{max-width:48rem}.head--center{margin-inline:auto;text-align:center}
.head p.lead{margin-top:1rem;font-size:var(--t-lg);color:var(--ink-soft)}
.section--dark .head p.lead{color:#c2cde4}

/* buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.55rem;font-family:var(--f-display);font-weight:700;
  font-size:1rem;line-height:1;padding:1rem 1.7rem;border-radius:var(--r-full);border:2px solid transparent;cursor:pointer;
  transition:transform .25s cubic-bezier(.16,1,.3,1),box-shadow .25s,background .2s,color .2s;min-height:54px}
.btn svg{width:1.1em;height:1.1em}
.btn--primary{background:var(--blue-500);color:#fff;box-shadow:var(--sh-blue)}
.btn--primary:hover{background:var(--blue-600);transform:translateY(-2px)}
.btn--solid{background:var(--navy);color:#fff}.btn--solid:hover{background:#12244d;transform:translateY(-2px)}
.btn--ghost{background:#fff;color:var(--navy);border-color:var(--line-strong)}
.btn--ghost:hover{border-color:var(--blue-500);color:var(--blue-700);transform:translateY(-2px)}
.section--dark .btn--ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.3)}
.section--dark .btn--ghost:hover{border-color:#fff}
.btn--sm{padding:.7rem 1.15rem;min-height:46px;font-size:.9rem}
.btn-row{display:flex;flex-wrap:wrap;gap:.9rem;margin-top:1.8rem}.btn-row--center{justify-content:center}

/* nav */
.nav{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.9);backdrop-filter:saturate(160%) blur(14px);
  border-bottom:1px solid transparent;transition:border-color .3s,box-shadow .3s}
.nav.is-scrolled{border-color:var(--line);box-shadow:var(--sh-sm)}
.nav__inner{display:flex;align-items:center;gap:1.5rem;height:78px}
.brandmark{display:inline-flex;align-items:center;gap:.55rem}
.brandmark .b-mark{width:34px;height:34px}
.brandmark .bw{font-family:var(--f-display);font-weight:800;font-size:1.25rem;letter-spacing:-.02em;color:var(--navy)}
.brandmark--light .bw{color:#fff}
.nav__links{display:flex;align-items:center;gap:.3rem;margin-left:auto}
.nav__link{position:relative;font-family:var(--f-display);font-weight:600;font-size:.96rem;color:var(--navy);padding:.55rem .75rem;border-radius:10px}
.nav__link::after{content:"";position:absolute;left:.75rem;right:.75rem;bottom:.3rem;height:2px;background:var(--blue-500);transform:scaleX(0);transform-origin:right;transition:transform .35s cubic-bezier(.16,1,.3,1)}
.nav__link:hover::after,.nav__link[aria-current="page"]::after{transform:scaleX(1);transform-origin:left}
.nav__cta{margin-left:.4rem}
.nav__drop{position:relative}
.nav__drop>button{display:inline-flex;align-items:center;gap:.3rem;background:none;border:0;cursor:pointer;font-family:var(--f-display);font-weight:600;font-size:.96rem;color:var(--navy);padding:.55rem .75rem;border-radius:10px}
.nav__drop>button svg{width:14px;height:14px;transition:transform .25s}
.nav__drop.is-open>button svg{transform:rotate(180deg)}
.nav__menu{position:absolute;top:calc(100% + .5rem);left:0;min-width:310px;background:#fff;border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--sh-lg);padding:.6rem;opacity:0;visibility:hidden;transform:translateY(8px);transition:opacity .2s,transform .2s,visibility .2s}
.nav__drop.is-open .nav__menu{opacity:1;visibility:visible;transform:translateY(0)}
@media(min-width:921px){.nav__drop:hover .nav__menu,.nav__drop:focus-within .nav__menu{opacity:1;visibility:visible;transform:translateY(0)}}
.nav__menu a{display:flex;gap:.8rem;align-items:flex-start;padding:.7rem .8rem;border-radius:12px;transition:background .15s}
.nav__menu a:hover{background:var(--soft)}
.nav__menu .mi-ic{flex:0 0 auto;width:36px;height:36px;border-radius:10px;background:var(--soft2);display:grid;place-items:center;color:var(--blue-600)}
.nav__menu .mi-t{font-family:var(--f-display);font-weight:700;font-size:.95rem;color:var(--navy)}
.nav__menu .mi-d{font-size:.82rem;color:var(--ink-soft);line-height:1.4}
.nav__toggle{display:none;margin-left:auto;width:46px;height:46px;border:1px solid var(--line-strong);background:#fff;border-radius:12px;cursor:pointer;flex-direction:column;align-items:center;justify-content:center;gap:5px}
.nav__toggle span{display:block;width:20px;height:2px;background:var(--navy);border-radius:2px;transition:.3s}
.nav.is-open .nav__toggle span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav.is-open .nav__toggle span:nth-child(2){opacity:0}
.nav.is-open .nav__toggle span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* hero (bright) */
.hero{position:relative;background:var(--grad-soft);overflow:hidden;border-bottom:1px solid var(--line)}
.hero::before{content:"";position:absolute;inset:-20% -10% auto auto;width:60%;height:120%;z-index:0;
  background:radial-gradient(45% 45% at 80% 20%,rgba(29,133,255,.14),transparent 70%)}
.hero__inner{position:relative;z-index:1;display:grid;gap:clamp(2rem,4vw,3.5rem);padding-block:clamp(3.5rem,7vw,6rem);align-items:center}
@media(min-width:980px){.hero__inner{grid-template-columns:1.1fr .9fr}}
.hero h1{font-size:var(--t-display);letter-spacing:-.03em}
.hero h1 .hl{color:var(--blue-600)}
.hero__sub{margin-top:1.4rem;font-size:var(--t-lg);color:var(--ink-soft);max-width:34rem}
.hero__badge{display:inline-flex;align-items:center;gap:.5rem;background:#fff;border:1px solid var(--line-strong);border-radius:var(--r-full);
  padding:.45rem .9rem;font-family:var(--f-display);font-weight:600;font-size:.82rem;color:var(--blue-700);margin-bottom:1.2rem;box-shadow:var(--sh-sm)}
.hero__badge .dot{width:8px;height:8px;border-radius:50%;background:var(--cyan);box-shadow:0 0 10px var(--cyan)}
.hero__trust{display:flex;flex-wrap:wrap;gap:1.2rem 1.8rem;margin-top:2rem;padding-top:1.6rem;border-top:1px solid var(--line)}
.hero__trust div{display:flex;flex-direction:column}
.hero__trust b{font-family:var(--f-display);font-size:1.5rem;font-weight:800;color:var(--navy)}
.hero__trust span{font-size:.82rem;color:var(--ink-soft)}
.hero__art{position:relative;display:grid;place-items:center}
.hero__art img{width:min(100%,460px)}
.hero__pricepill{position:absolute;bottom:4%;left:0;background:#fff;border:1px solid var(--line);box-shadow:var(--sh);border-radius:var(--r);padding:.7rem 1rem;font-size:.85rem;color:var(--ink-soft)}
.hero__pricepill b{color:var(--navy);font-family:var(--f-display)}
.illus-glow{position:relative}
.illus--float{animation:fl 7s ease-in-out infinite}@keyframes fl{0%,100%{transform:translateY(0)}50%{transform:translateY(-14px)}}
@media(prefers-reduced-motion:reduce){.illus--float{animation:none}}
.illus{display:block;max-width:100%;height:auto}

/* logo wall */
.logowall{padding-block:clamp(2rem,4vw,3rem);border-bottom:1px solid var(--line);background:#fff}
.logos__label{text-align:center;font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft);font-weight:600;margin-bottom:1.4rem}
.marquee{overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.marquee__track{display:flex;width:max-content;gap:1rem;align-items:center;animation:marq 40s linear infinite}
.marquee:hover .marquee__track{animation-play-state:paused}
@keyframes marq{to{transform:translateX(-50%)}}
.chip{display:inline-flex;align-items:center;gap:.6rem;white-space:nowrap;padding:.5rem .95rem;border:1px solid var(--line);border-radius:var(--r-full);background:var(--soft)}
.chip .mono{width:26px;height:26px;border-radius:8px;display:grid;place-items:center;color:#fff;font-family:var(--f-display);font-weight:800;font-size:.72rem;background:var(--grad)}
.chip span{font-family:var(--f-display);font-weight:600;font-size:.92rem;color:var(--navy)}

/* generic grids / cards */
.grid{display:grid;gap:clamp(1.1rem,2.4vw,1.8rem)}
.grid--3{grid-template-columns:repeat(auto-fit,minmax(min(290px,100%),1fr))}
.grid--2{grid-template-columns:repeat(auto-fit,minmax(min(340px,100%),1fr))}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:1.7rem;box-shadow:var(--sh-sm);transition:transform .3s cubic-bezier(.16,1,.3,1),box-shadow .3s,border-color .3s}
.card:hover{transform:translateY(-5px);box-shadow:var(--sh);border-color:#cfe0ff}
.card__ic{width:52px;height:52px;border-radius:14px;background:var(--soft2);color:var(--blue-600);display:grid;place-items:center;margin-bottom:1.1rem}
.card__ic svg{width:26px;height:26px}
.card h3{margin-bottom:.5rem}.card p{color:var(--ink-soft)}
.card__list{margin-top:1rem;display:grid;gap:.55rem}
.card__list li{display:flex;gap:.6rem;font-size:.95rem;color:var(--ink)}
.card__list li::before{content:"";flex:0 0 auto;width:20px;height:20px;margin-top:1px;border-radius:50%;background:var(--soft2) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%231d85ff' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E") center/12px no-repeat}
.card__link{display:inline-flex;align-items:center;gap:.4rem;margin-top:1.1rem;font-family:var(--f-display);font-weight:700;font-size:.92rem;color:var(--blue-700)}
.card__link svg{width:15px;height:15px;transition:transform .25s}.card:hover .card__link svg{transform:translateX(4px)}

/* pains */
.pains{display:grid;gap:1.1rem}
.pain{display:flex;gap:1rem;align-items:flex-start;background:#fff;border:1px solid var(--line);border-left:4px solid var(--blue-400);border-radius:var(--r-sm);padding:1.2rem 1.3rem}
.pain .q{font-style:italic;color:var(--ink);font-size:1.02rem}.pain .ic{flex:0 0 auto;color:var(--blue-500)}

/* stats */
.stats{display:grid;gap:1.2rem;grid-template-columns:repeat(auto-fit,minmax(min(180px,100%),1fr));text-align:center}
.stat b{display:block;font-family:var(--f-display);font-weight:800;font-size:clamp(2.4rem,4vw,3.4rem);line-height:1;white-space:nowrap;color:#fff}
.stat b span{color:var(--cyan)}
.stat>span{display:block;margin-top:.6rem;color:#c2cde4;font-size:.95rem}

/* steps / process */
.steps{counter-reset:s;display:grid;gap:1.1rem}
@media(min-width:760px){.steps{grid-template-columns:repeat(5,1fr)}}
.step{position:relative;padding:1.4rem 1.2rem;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:var(--r)}
.section:not(.section--dark) .step{background:#fff;border-color:var(--line);box-shadow:var(--sh-sm)}
.step::before{counter-increment:s;content:counter(s);display:grid;place-items:center;width:40px;height:40px;border-radius:12px;background:var(--grad);color:#fff;font-family:var(--f-display);font-weight:800;margin-bottom:.9rem}
.step h3{font-size:1.05rem;margin-bottom:.4rem}.step p{font-size:.9rem;color:var(--ink-soft)}
.section--dark .step p{color:#aeb9d4}

/* split intro (pipeline) */
.split-intro{display:grid;gap:2rem;align-items:center}
@media(min-width:880px){.split-intro{grid-template-columns:1.1fr .9fr}}

/* 2-card flow */
.flow{display:grid;gap:1.4rem;align-items:stretch}
@media(min-width:820px){.flow{grid-template-columns:1fr auto 1fr}}
.flow__card{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:1.8rem;box-shadow:var(--sh-sm);transition:transform .3s cubic-bezier(.16,1,.3,1),box-shadow .3s,border-color .3s}
.flow__card:hover{transform:translateY(-6px);box-shadow:var(--sh);border-color:#cfe0ff}
.flow__card .ic{width:54px;height:54px;border-radius:15px;background:var(--grad);display:grid;place-items:center;color:#fff;margin-bottom:1rem;box-shadow:var(--sh-blue)}
.flow__card .ic svg{width:28px;height:28px}.flow__card h3{margin-bottom:.8rem}
.flow__arrow{display:grid;place-items:center;color:var(--blue-400)}.flow__arrow svg{width:40px;height:40px}
@media(max-width:819px){.flow__arrow{transform:rotate(90deg)}}
.flow__label{display:flex;justify-content:center;gap:.6rem;margin-top:1.4rem;font-family:var(--f-display);font-weight:700;letter-spacing:.06em;text-transform:uppercase;font-size:.82rem;color:var(--blue-700)}
.flow__label .arr{color:var(--cyan)}

/* gradient-icon cards */
.gcard{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:1.9rem;box-shadow:var(--sh-sm);text-align:center;transition:transform .3s cubic-bezier(.16,1,.3,1),box-shadow .3s}
.gcard:hover{transform:translateY(-6px);box-shadow:var(--sh)}
.gcard .gic{width:72px;height:72px;margin:0 auto 1.1rem;border-radius:20px;display:grid;place-items:center;color:#fff;background:var(--grad);box-shadow:var(--sh-blue)}
.gcard .gic svg{width:36px;height:36px}.gcard h3{margin-bottom:.5rem}.gcard p{color:var(--ink-soft);font-size:.96rem}

/* bento */
.bento{display:grid;gap:1rem;grid-template-columns:repeat(2,1fr)}
@media(min-width:760px){.bento{grid-template-columns:repeat(4,1fr);grid-auto-rows:1fr}}
.bento__cell{position:relative;overflow:hidden;background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:1.6rem;box-shadow:var(--sh-sm);transition:transform .3s cubic-bezier(.16,1,.3,1),box-shadow .3s,border-color .3s;min-height:175px}
.bento__cell:hover{transform:translateY(-5px);box-shadow:var(--sh);border-color:#cfe0ff}
.bento__cell h3{font-size:1.12rem;margin-bottom:.4rem}.bento__cell p{font-size:.9rem;color:var(--ink-soft)}
.bento__cell .illus{position:absolute;right:-6px;bottom:-6px;width:130px;pointer-events:none}
@media(min-width:760px){.bento__cell--lg{grid-column:span 2;grid-row:span 2;min-height:370px}.bento__cell--wide{grid-column:span 2}}
.bento__cell--lg .illus{width:250px}
.bento__cell--dark{background:linear-gradient(135deg,#123a8f,#1d85ff);color:#fff;border:0}
.bento__cell--dark h3{color:#fff}.bento__cell--dark p{color:#dbe6ff}
.bento__cell .tag{display:inline-block;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--blue-700);margin-bottom:.7rem}
.bento__cell--dark .tag{color:#bcd3ff}

/* feature rows */
.frow{display:grid;gap:clamp(1.5rem,4vw,3rem);align-items:center}
@media(min-width:880px){.frow{grid-template-columns:1fr 1fr}.frow--rev .frow__media{order:-1}}
.frow__media{display:grid;place-items:center}.frow__media img{width:min(100%,420px)}
.frow ul{margin-top:1rem;display:grid;gap:.6rem}
.frow ul li{position:relative;padding-left:1.8rem;color:var(--ink)}
.frow ul li::before{content:"";position:absolute;left:0;top:.15rem;width:22px;height:22px;border-radius:50%;background:var(--soft2) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%231d85ff' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E") center/12px no-repeat}

/* zigzag */
.zz{position:relative;max-width:780px;margin-inline:auto;padding:1rem 0}
.zz::before{content:"";position:absolute;left:50%;top:0;bottom:0;width:2px;background:linear-gradient(#cfe0ff,var(--blue-400));transform:translateX(-50%)}
.zz__item{position:relative;width:50%;padding:1rem 2.2rem;box-sizing:border-box}
.zz__item:nth-child(odd){left:0;text-align:right}.zz__item:nth-child(even){left:50%}
.zz__item .node{position:absolute;top:1.4rem;width:34px;height:34px;border-radius:50%;background:var(--grad);color:#fff;display:grid;place-items:center;font-family:var(--f-display);font-weight:800;font-size:.9rem;box-shadow:var(--sh-blue);z-index:1}
.zz__item:nth-child(odd) .node{right:-17px}.zz__item:nth-child(even) .node{left:-17px}
.zz__item h3{font-size:1.08rem;margin-bottom:.3rem}.zz__item p{font-size:.92rem;color:var(--ink-soft)}
@media(max-width:680px){.zz::before{left:17px}.zz__item{width:100%;left:0!important;text-align:left!important;padding-left:3.2rem;padding-right:0}.zz__item .node{left:0!important;right:auto!important}}

/* comparison */
.compare{overflow:hidden;border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh);background:#fff}
.compare table{width:100%;border-collapse:collapse;font-size:.96rem}
.compare th,.compare td{padding:1rem 1.1rem;text-align:left;border-bottom:1px solid var(--line)}
.compare thead th{font-family:var(--f-display);background:var(--soft);color:var(--navy)}
.compare thead th.us{background:var(--grad);color:#fff}
.compare td.us{background:var(--soft2);font-weight:600;color:var(--navy)}
.compare tbody tr:last-child td{border-bottom:0}
.compare .yes{color:#16a34a;font-weight:700}.compare .no{color:#c0c6d2}
.compare td:first-child{font-weight:600;color:var(--navy)}
@media(max-width:640px){.compare{font-size:.84rem}.compare th,.compare td{padding:.7rem .6rem}}

/* reference bento mockups */
.refbento{display:grid;gap:1.1rem;grid-template-columns:repeat(2,1fr)}
@media(min-width:780px){.refbento{grid-template-columns:repeat(3,1fr)}}
.refb{position:relative;display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh-sm);transition:transform .35s cubic-bezier(.16,1,.3,1),box-shadow .35s}
.refb:hover{transform:translateY(-6px);box-shadow:var(--sh-lg)}
.refb--lg{grid-column:span 2}
.browser{background:#eef2f8;padding:8px 10px 0;border-bottom:1px solid var(--line)}
.browser__bar{display:flex;align-items:center;gap:6px;padding-bottom:8px}
.browser__bar i{width:9px;height:9px;border-radius:50%;background:#cfd6e2;display:block}
.browser__bar .url{margin-left:8px;flex:1;height:16px;border-radius:8px;background:#fff;border:1px solid #e0e5ee;font-size:.62rem;color:#9aa3b8;display:flex;align-items:center;padding:0 8px;overflow:hidden}
.browser__shot{aspect-ratio:16/10;overflow:hidden;background:#fff}
.browser__shot img{width:100%;height:100%;object-fit:cover;object-position:top;transition:object-position 3s ease}
.refb:hover .browser__shot img{object-position:bottom}
.refb__foot{display:flex;align-items:center;justify-content:space-between;gap:.6rem;padding:1rem 1.2rem}
.refb__foot .t{font-family:var(--f-display);font-weight:700;color:var(--navy);font-size:1rem}
.refb__foot .tag{font-size:.72rem;font-weight:700;text-transform:uppercase;color:var(--blue-700);background:var(--soft2);padding:.25rem .55rem;border-radius:var(--r-full)}
.refb__phone{position:absolute;right:14px;bottom:54px;width:84px;border-radius:14px;border:3px solid #15131a;overflow:hidden;box-shadow:var(--sh-lg);background:#000;display:none}
@media(min-width:780px){.refb--lg .refb__phone{display:block}}
.refb__phone img{width:100%}
.filterbar{display:flex;flex-wrap:wrap;gap:.6rem;justify-content:center;margin-bottom:2rem}
.filterbtn{font-family:var(--f-display);font-weight:600;font-size:.9rem;padding:.55rem 1rem;border-radius:var(--r-full);border:1px solid var(--line-strong);background:#fff;color:var(--navy);cursor:pointer;transition:.2s}
.filterbtn:hover{border-color:var(--blue-400);color:var(--blue-700)}
.filterbtn.is-active{background:var(--navy);color:#fff;border-color:var(--navy)}
.refgrid{display:grid;gap:1.1rem;grid-template-columns:repeat(auto-fill,minmax(min(270px,100%),1fr))}
.ref{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:1.3rem;box-shadow:var(--sh-sm);transition:transform .3s cubic-bezier(.16,1,.3,1),box-shadow .3s,border-color .3s}
.ref:hover{transform:translateY(-4px);box-shadow:var(--sh);border-color:#cfe0ff}
.ref__tag{align-self:flex-start;font-size:.72rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--blue-700);background:var(--soft2);padding:.3rem .6rem;border-radius:var(--r-full)}
.ref h3{font-size:1.1rem;margin:.9rem 0 .25rem}.ref p{font-size:.88rem;color:var(--ink-soft);flex:1}
.ref__url{display:inline-flex;align-items:center;gap:.4rem;margin-top:1rem;font-family:var(--f-display);font-weight:700;font-size:.85rem;color:var(--blue-700)}
.ref__url svg{width:14px;height:14px}.is-hidden{display:none!important}

/* case cards / pages */
.cs-card{display:flex;flex-direction:column;overflow:hidden;background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh-sm);transition:transform .3s cubic-bezier(.16,1,.3,1),box-shadow .3s}
.cs-card:hover{transform:translateY(-5px);box-shadow:var(--sh-lg)}
.cs-card__top{padding:1.5rem 1.5rem 0}
.cs-card__tags{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:.9rem}
.cs-card__tags span{font-size:.72rem;font-weight:700;text-transform:uppercase;color:var(--blue-700);background:var(--soft2);padding:.28rem .6rem;border-radius:var(--r-full)}
.cs-card h3{font-size:1.25rem;margin-bottom:.5rem}.cs-card__top p{color:var(--ink-soft);font-size:.95rem}
.cs-stats{display:flex;gap:1.2rem;flex-wrap:wrap;margin:1.3rem 1.5rem;padding:1.1rem 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.cs-stats div{display:flex;flex-direction:column}.cs-stats b{font-family:var(--f-display);font-weight:800;font-size:1.4rem;color:var(--navy)}.cs-stats span{font-size:.78rem;color:var(--ink-soft)}
.cs-card__cta{padding:0 1.5rem 1.5rem;margin-top:auto}
.cs-hero{background:var(--navy);color:#fff}
.cs-hero .container{padding-block:clamp(2.6rem,5vw,4.5rem)}
.cs-hero .tags span{font-size:.74rem;font-weight:700;text-transform:uppercase;color:var(--cyan);margin-right:.8rem}
.cs-hero h1{color:#fff;margin:.8rem 0;font-size:var(--t-h1)}.cs-hero p{color:#c2cde4;max-width:40rem;font-size:var(--t-lg)}
.cs-bigstats{display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));margin-top:2rem}
.cs-bigstats div{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.14);border-radius:var(--r);padding:1.1rem}
.cs-bigstats b{display:block;font-family:var(--f-display);font-weight:800;font-size:1.9rem;color:#fff}.cs-bigstats span{font-size:.8rem;color:#aeb9d4}

/* prose */
.prose{max-width:var(--maxw-text);margin-inline:auto}
.prose h2{margin-top:2.4rem;margin-bottom:.8rem}.prose h3{margin-top:1.6rem;margin-bottom:.5rem}
.prose p{margin-bottom:1.1rem;color:var(--ink)}
.prose ul{margin:0 0 1.2rem;display:grid;gap:.6rem}
.prose ul li{position:relative;padding-left:1.6rem;color:var(--ink)}
.prose ul li::before{content:"";position:absolute;left:0;top:.55em;width:8px;height:8px;border-radius:50%;background:var(--blue-500)}
.prose .pullquote{border-left:4px solid var(--blue-400);background:var(--soft2);padding:1.2rem 1.4rem;border-radius:0 var(--r-sm) var(--r-sm) 0;font-size:1.15rem;color:var(--navy);font-weight:500;margin:1.6rem 0}
.prose .pullquote cite{display:block;margin-top:.6rem;font-size:.9rem;font-style:normal;color:var(--ink-soft);font-weight:600}

/* testimonials */
.quote{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:1.8rem;box-shadow:var(--sh-sm)}
.quote .mark{font-family:var(--f-display);font-size:3rem;line-height:.6;color:#cfe0ff;font-weight:800}
.quote p{font-size:1.05rem;color:var(--navy);margin:.3rem 0 1.2rem}
.quote .by{display:flex;align-items:center;gap:.8rem}
.quote .av{width:44px;height:44px;border-radius:50%;background:var(--grad);color:#fff;display:grid;place-items:center;font-family:var(--f-display);font-weight:800}
.quote .by b{display:block;font-size:.95rem;color:var(--navy)}.quote .by span{font-size:.82rem;color:var(--ink-soft)}

/* faq */
.faq{max-width:46rem;margin-inline:auto;display:grid;gap:.8rem}
.faq details{background:#fff;border:1px solid var(--line);border-radius:var(--r-sm);overflow:hidden}
.faq summary{cursor:pointer;list-style:none;padding:1.1rem 1.3rem;font-family:var(--f-display);font-weight:700;font-size:1.02rem;color:var(--navy);display:flex;justify-content:space-between;gap:1rem;align-items:center}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:1.5rem;color:var(--blue-600);transition:transform .25s;line-height:1}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details[open]{border-color:#cfe0ff}
.faq .ans{padding:0 1.3rem 1.2rem;color:var(--ink-soft)}

/* cta band */
.ctaband{background:linear-gradient(135deg,#123a8f,#1d85ff);color:#fff;border-radius:var(--r-lg);padding:clamp(2rem,5vw,3.5rem);text-align:center;box-shadow:var(--sh-lg);position:relative;overflow:hidden}
.ctaband::before{content:"";position:absolute;inset:auto -10% -60% auto;width:60%;height:120%;background:radial-gradient(circle,rgba(10,207,255,.3),transparent 70%)}
.ctaband h2{color:#fff;position:relative}.ctaband p{color:#dbe6ff;max-width:36rem;margin:.8rem auto 0;position:relative}
.ctaband .btn-row{position:relative}
.ctaband .btn--ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.4)}.ctaband .btn--ghost:hover{border-color:#fff}

/* booking + contact */
.booking{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh);overflow:hidden;min-height:680px}
.booking iframe{width:100%;min-height:680px;border:0;display:block}
.contact-grid{display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(min(220px,100%),1fr))}
.contact-card{display:flex;gap:.9rem;align-items:center;background:#fff;border:1px solid var(--line);border-radius:var(--r-sm);padding:1.1rem}
.contact-card .ic{flex:0 0 auto;width:42px;height:42px;border-radius:12px;background:var(--soft2);color:var(--blue-600);display:grid;place-items:center}
.contact-card b{display:block;font-family:var(--f-display);font-size:.78rem;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-soft)}
.contact-card a{font-weight:600;color:var(--navy)}
.infoline{display:flex;gap:.9rem;align-items:center;padding:.7rem 0}
.infoline .ic{flex:0 0 auto;width:44px;height:44px;border-radius:12px;background:var(--grad);display:grid;place-items:center;color:#fff;box-shadow:var(--sh-blue)}
.infoline b{display:block;font-family:var(--f-display);font-size:.76rem;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-soft)}
.infoline a,.infoline span.v{font-weight:600;color:var(--navy)}
.mapcard{border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh-lg);border:1px solid var(--line);min-height:320px}
.mapcard iframe{width:100%;height:100%;min-height:320px;border:0}

/* blog */
.posts{display:grid;gap:1.4rem;grid-template-columns:repeat(auto-fill,minmax(min(320px,100%),1fr))}
.post-card{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh-sm);transition:transform .3s cubic-bezier(.16,1,.3,1),box-shadow .3s}
.post-card:hover{transform:translateY(-5px);box-shadow:var(--sh-lg)}
.post-card__thumb{aspect-ratio:16/9;background:linear-gradient(135deg,#eaf1ff,#f6faff);display:grid;place-items:center;padding:1.2rem;overflow:hidden;border-bottom:1px solid var(--line)}
.post-card__thumb img.illus{width:auto;max-width:60%;max-height:120px;filter:drop-shadow(0 12px 22px rgba(13,27,62,.18))}
.post-card__body{padding:1.3rem;display:flex;flex-direction:column;flex:1}
.post-card__cat{font-size:.74rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--blue-700)}
.post-card h3{font-size:1.12rem;margin:.45rem 0;line-height:1.25}.post-card p{font-size:.9rem;color:var(--ink-soft);flex:1}
.post-card .meta{margin-top:1rem;font-size:.8rem;color:#9aa3b8}
.article-hero{background:var(--soft);border-bottom:1px solid var(--line)}
.article-hero .container{padding-block:clamp(2.4rem,5vw,4rem)}
.article-hero .ah-grid{display:grid;gap:1.6rem;align-items:center}
@media(min-width:820px){.article-hero .ah-grid{grid-template-columns:1.5fr .5fr}}
.article-hero .ah-art{display:grid;place-items:center}.article-hero .ah-art img{width:min(70%,200px)}
@media(max-width:819px){.article-hero .ah-art{display:none}}
.article-hero .cat{font-family:var(--f-display);font-weight:700;font-size:.8rem;letter-spacing:.06em;text-transform:uppercase;color:var(--blue-700)}
.article-hero h1{margin:.8rem 0;max-width:24ch}.article-hero .meta{color:var(--ink-soft);font-size:.9rem}
.article{padding-block:var(--section-y)}

/* breadcrumb */
.crumb{font-size:.85rem;color:var(--ink-soft);padding-top:1.4rem}
.crumb a:hover{color:var(--blue-700)}.crumb span{margin:0 .4rem;color:#b9c2d4}

/* footer (navy) */
.footer{background:var(--navy);color:#c2cde4;padding-block:clamp(3rem,5vw,4.5rem) 2rem}
.footer__top{display:grid;gap:2.2rem}
@media(min-width:760px){.footer__top{grid-template-columns:1.4fr 1fr 1fr 1fr}}
.footer__brand .brandmark{margin-bottom:1rem}
.footer__brand p{color:#9aa6c2;font-size:.92rem;max-width:24rem}
.footer h3{color:#fff;font-family:var(--f-display);font-size:.8rem;letter-spacing:.08em;text-transform:uppercase;margin-bottom:1rem}
.footer__col a{display:block;padding:.32rem 0;color:#aeb9d4;font-size:.92rem}.footer__col a:hover{color:#fff}
.footer__bottom{margin-top:2.6rem;padding-top:1.6rem;border-top:1px solid rgba(255,255,255,.1);display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;font-size:.84rem;color:#8a96b4}
.footer__bottom a{color:#8a96b4}.footer__bottom a:hover{color:#fff}

/* cookie */
.cc{position:fixed;left:1rem;right:1rem;bottom:1rem;max-width:560px;margin-inline:auto;z-index:120;background:#fff;border:1px solid var(--line);border-radius:18px;box-shadow:var(--sh-lg);padding:1.2rem 1.3rem;display:none}
.cc.show{display:block;animation:ccUp .5s cubic-bezier(.2,.7,.3,1)}
@keyframes ccUp{from{transform:translateY(24px);opacity:0}to{transform:translateY(0);opacity:1}}
.cc__row{display:flex;gap:.9rem;align-items:flex-start}
.cc__dot{flex:0 0 auto;width:38px;height:38px;border-radius:11px;background:var(--grad);display:grid;place-items:center;color:#fff}
.cc h4{font-size:1rem;margin-bottom:.25rem;color:var(--navy)}.cc p{font-size:.86rem;color:var(--ink-soft)}
.cc__btns{display:flex;gap:.6rem;margin-top:1rem;flex-wrap:wrap}.cc__btns .btn{flex:1;min-width:120px}

/* sticky mobile call bar */
.callbar{display:none}

/* reveal */
html.js .reveal{opacity:0;transform:translateY(22px)}
@media(prefers-reduced-motion:no-preference){html.js .reveal{transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1)}}
html.js .reveal.in{opacity:1;transform:none}

/* responsive nav */
@media(max-width:920px){
  .nav__links{position:fixed;inset:78px 0 auto;flex-direction:column;align-items:stretch;gap:.2rem;background:#fff;border-bottom:1px solid var(--line);padding:1rem var(--sp) 1.6rem;box-shadow:var(--sh-lg);transform:translateY(-130%);transition:transform .35s cubic-bezier(.16,1,.3,1);max-height:calc(100dvh - 78px);overflow:auto}
  .nav.is-open .nav__links{transform:none}
  .nav__link,.nav__drop>button{font-size:1.05rem;padding:.85rem .4rem;width:100%}.nav__link::after{display:none}
  .nav__cta{margin:.6rem 0 0}.nav__cta .btn{width:100%}.nav__toggle{display:flex}
  .nav__menu{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:0;padding:.2rem 0 .2rem 1rem;min-width:0}
  .nav__drop>button{justify-content:space-between}
  .callbar{display:flex;position:fixed;left:0;right:0;bottom:0;z-index:90;gap:.6rem;padding:.7rem var(--sp);padding-bottom:calc(.7rem + env(safe-area-inset-bottom));background:rgba(255,255,255,.94);backdrop-filter:blur(12px);border-top:1px solid var(--line)}
  .callbar .btn{flex:1}
  body{padding-bottom:74px}
}
