/* ===========================================================================
   ClientsFlow Digital — design system  (brand kept: blue + Montserrat)
   =========================================================================== */
:root{
  /* --- blue ramp (anchor #1d85ff @500) --- */
  --blue-50:#eef5ff; --blue-100:#d6e8ff; --blue-200:#aaceff; --blue-300:#6aaeff;
  --blue-400:#3d96ff; --blue-500:#1d85ff; --blue-600:#0a6ee0; --blue-700:#0d52b3;
  --blue-800:#003d8a; --blue-900:#002860;
  --cyan-400:#0acfff; --deep-blue:#2a54ff;
  /* --- blue-tinted neutrals --- */
  --n-0:#fffbfb; --n-50:#f5f7fa; --n-100:#eaedf2; --n-200:#d4d9e3; --n-300:#b0b8c9;
  --n-400:#8892a4; --n-500:#636e82; --n-600:#4a5468; --n-700:#333c4f; --n-800:#1f2637; --n-900:#141318;
  /* --- semantic --- */
  --bg:var(--n-0); --bg-subtle:var(--n-50); --bg-card:#ffffff; --bg-dark:var(--n-900);
  --bg-brand-subtle:var(--blue-50);
  --text:var(--n-800); --text-soft:var(--n-500); --text-inv:var(--n-0);
  --link:var(--blue-700); --border:var(--n-100); --border-strong:var(--n-200);
  --action:var(--deep-blue); --action-hover:#1a3fe6; --action-text:#fff;
  --grad:linear-gradient(135deg,#2A54FF 0%,#06DAFF 100%);
  --grad-hover:linear-gradient(135deg,#1a3fe6 0%,#00c8f0 100%);
  --grad-hero:linear-gradient(160deg,#141318 0%,#0d1a3a 58%,#141318 100%);
  /* --- type --- */
  --f-display:'Montserrat',system-ui,sans-serif;
  --f-body:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --t-xs:.78rem; --t-sm:.875rem; --t-base:1rem; --t-md:1.0625rem;
  --t-lg:clamp(1.125rem,1rem + .5vw,1.3rem);
  --t-h3:clamp(1.25rem,1.05rem + .9vw,1.6rem);
  --t-h2:clamp(1.7rem,1.3rem + 1.9vw,2.65rem);
  --t-h1:clamp(2.3rem,1.6rem + 3.4vw,4rem);
  --t-display:clamp(2.6rem,1.7rem + 4.4vw,4.9rem);
  /* --- spacing / radius / shadow --- */
  --sp:clamp(1rem,4vw,3rem);
  --section-y:clamp(3.5rem,7vw,7rem);
  --maxw:1200px; --maxw-wide:1320px; --maxw-text:680px;
  --r-sm:6px; --r-md:10px; --r-lg:16px; --r-xl:24px; --r-2xl:32px; --r-full:9999px;
  --sh-sm:0 1px 4px rgba(20,19,24,.06),0 1px 2px -1px rgba(20,19,24,.05);
  --sh-md:0 6px 18px -4px rgba(20,19,24,.10),0 2px 6px -2px rgba(20,19,24,.06);
  --sh-lg:0 18px 44px -10px rgba(20,19,24,.16),0 6px 14px -6px rgba(20,19,24,.08);
  --sh-brand:0 14px 40px -10px rgba(42,84,255,.45);
  --sh-cyan:0 0 60px rgba(10,207,255,.18);
}

/* --- reset --- */
*,*::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(--text);
  background:var(--bg);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;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(--n-900)}
h2{font-size:var(--t-h2);font-weight:800}
h3{font-size:var(--t-h3);font-weight:700;letter-spacing:-.01em}
p{color:var(--text)}
strong{font-weight:600;color:var(--n-900)}
::selection{background:var(--blue-200);color:var(--n-900)}
:focus-visible{outline:3px solid var(--blue-700);outline-offset:2px;border-radius:4px}

/* --- layout --- */
.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--dark{background:var(--bg-dark);color:var(--text-inv)}
.section--dark h2,.section--dark h3{color:#fff}
.section--subtle{background:var(--bg-subtle)}
.section--brand{background:var(--bg-brand-subtle)}
.skip-link{position:absolute;left:-9999px;top:0;background:var(--n-900);color:#fff;padding:.7rem 1.1rem;z-index:200;border-radius:0 0 8px 0}
.skip-link:focus{left:0}

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

/* --- buttons --- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.55rem;font-family:var(--f-display);
  font-weight:700;font-size:var(--t-base);line-height:1;padding:1rem 1.6rem;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;
  text-align:center;min-height:52px}
.btn svg{width:1.1em;height:1.1em}
.btn--primary{background:var(--grad);color:#fff;box-shadow:var(--sh-brand)}
.btn--primary:hover{transform:translateY(-2px);background:var(--grad-hover);box-shadow:0 18px 48px -10px rgba(42,84,255,.55)}
.btn--solid{background:var(--action);color:#fff}
.btn--solid:hover{background:var(--action-hover);transform:translateY(-2px)}
.btn--ghost{background:transparent;color:var(--n-900);border-color:var(--border-strong)}
.btn--ghost:hover{border-color:var(--n-900);transform:translateY(-2px)}
.section--dark .btn--ghost,.hero .btn--ghost,.ctaband .btn--ghost,.cs-hero .btn--ghost{color:#fff;border-color:rgba(255,255,255,.32)}
.section--dark .btn--ghost:hover,.hero .btn--ghost:hover,.ctaband .btn--ghost:hover,.cs-hero .btn--ghost:hover{border-color:#fff;background:rgba(255,255,255,.06)}
.btn--sm{padding:.7rem 1.1rem;min-height:44px;font-size:var(--t-sm)}
.btn--block{width:100%}
.btn-row{display:flex;flex-wrap:wrap;gap:.9rem;margin-top:1.8rem}
.btn-row--center{justify-content:center}

/* --- top nav --- */
.nav{position:sticky;top:0;z-index:100;background:rgba(255,251,251,.82);backdrop-filter:saturate(160%) blur(14px);
  border-bottom:1px solid transparent;transition:border-color .3s,box-shadow .3s}
.nav.is-scrolled{border-color:var(--border);box-shadow:var(--sh-sm)}
.nav__inner{display:flex;align-items:center;gap:1.5rem;height:74px}
.nav__logo{display:flex;align-items:center}
.nav__logo img{height:30px;width:auto}
.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:.95rem;color:var(--n-800);
  padding:.55rem .7rem;border-radius:8px}
.nav__link::after{content:"";position:absolute;left:.7rem;right:.7rem;bottom:.35rem;height:2px;background:var(--deep-blue);
  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}
/* dropdown */
.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:.95rem;color:var(--n-800);padding:.55rem .7rem;border-radius:8px}
.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:300px;background:#fff;border:1px solid var(--border);
  border-radius:var(--r-lg);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:10px;transition:background .15s}
.nav__menu a:hover{background:var(--blue-50)}
.nav__menu .mi-ic{flex:0 0 auto;width:34px;height:34px;border-radius:9px;background:var(--blue-50);display:grid;place-items:center;color:var(--blue-700)}
.nav__menu .mi-t{font-family:var(--f-display);font-weight:700;font-size:.95rem;color:var(--n-900)}
.nav__menu .mi-d{font-size:.82rem;color:var(--text-soft);line-height:1.4}
.nav__toggle{display:none;margin-left:auto;width:46px;height:46px;border:1px solid var(--border-strong);background:#fff;
  border-radius:10px;cursor:pointer;align-items:center;justify-content:center;flex-direction:column;gap:5px}
.nav__toggle span{display:block;width:20px;height:2px;background:var(--n-900);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 --- */
.hero{position:relative;background:var(--grad-hero);color:#fff;overflow:hidden;isolation:isolate}
.hero::before{content:"";position:absolute;inset:-30% -10% auto;height:120%;z-index:-1;
  background:radial-gradient(45% 40% at 78% 18%,rgba(42,84,255,.42),transparent 70%),
             radial-gradient(38% 38% at 12% 88%,rgba(10,207,255,.30),transparent 70%);
  filter:blur(20px)}
.hero__inner{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.15fr .85fr}}
.hero h1{color:#fff;font-size:var(--t-display);letter-spacing:-.03em}
.hero h1 .hl{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.hero__sub{margin-top:1.4rem;font-size:var(--t-lg);color:#c8cee0;max-width:34rem}
.hero__trust{display:flex;flex-wrap:wrap;gap:1.2rem 1.8rem;margin-top:2rem;padding-top:1.6rem;border-top:1px solid rgba(255,255,255,.12)}
.hero__trust div{display:flex;flex-direction:column}
.hero__trust b{font-family:var(--f-display);font-size:1.5rem;font-weight:800;color:#fff}
.hero__trust span{font-size:.82rem;color:#9aa3b8;letter-spacing:.02em}
.hero__card{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);border-radius:var(--r-xl);
  padding:1.6rem;box-shadow:var(--sh-cyan)}
.hero__card-title{color:#fff;font-size:1.05rem;font-family:var(--f-display);font-weight:700;letter-spacing:-.01em;margin-bottom:.3rem}
.hero__mini{display:flex;gap:.8rem;align-items:center;padding:.9rem 0;border-bottom:1px solid rgba(255,255,255,.08)}
.hero__mini:last-child{border-bottom:0}
.hero__mini .ic{flex:0 0 auto;width:38px;height:38px;border-radius:11px;background:var(--grad);display:grid;place-items:center;color:#fff;font-weight:800;font-family:var(--f-display)}
.hero__mini p{color:#cdd3e2;font-size:.92rem;line-height:1.45}
.hero__mini b{color:#fff}

/* --- logo marquee --- */
.logos{padding-block:clamp(2rem,4vw,3rem);border-bottom:1px solid var(--border)}
.logos__label{text-align:center;font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;color:var(--n-500);font-weight:600;margin-bottom:1.4rem}
.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}
.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:3rem;align-items:center;animation:marq 38s linear infinite}
.marquee:hover .marquee__track{animation-play-state:paused}
.marquee__track span{font-family:var(--f-display);font-weight:700;font-size:1.15rem;color:var(--n-500);white-space:nowrap;letter-spacing:-.01em}
@keyframes marq{to{transform:translateX(-50%)}}

/* --- 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))}
.grid--4{grid-template-columns:repeat(auto-fit,minmax(min(230px,100%),1fr))}
.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-xl);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(-4px);box-shadow:var(--sh-lg);border-color:var(--blue-200)}
.card__ic{width:50px;height:50px;border-radius:14px;background:var(--blue-50);color:var(--blue-700);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(--text-soft);font-size:var(--t-base)}
.card__list{margin-top:1rem;display:grid;gap:.55rem}
.card__list li{display:flex;gap:.6rem;font-size:.95rem;color:var(--text)}
.card__list li::before{content:"";flex:0 0 auto;width:20px;height:20px;margin-top:1px;border-radius:50%;
  background:var(--blue-50) 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='%230d52b3' 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)}

/* --- problem list --- */
.pains{display:grid;gap:1.1rem}
.pain{display:flex;gap:1rem;align-items:flex-start;background:var(--bg-card);border:1px solid var(--border);border-left:4px solid var(--blue-400);border-radius:var(--r-md);padding:1.2rem 1.3rem}
.pain .q{font-style:italic;color:var(--n-700);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;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.stat b span{background:inherit;-webkit-background-clip:text;background-clip:text;color:transparent}
.section--dark .stat b{filter:brightness(1.15)}
.stat > span{display:block;margin-top:.6rem;color:var(--text-soft);font-size:.95rem}
.section--dark .stat > span{color:#aab2c4}

/* --- process steps --- */
.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,.04);border:1px solid rgba(255,255,255,.1);border-radius:var(--r-lg)}
.section:not(.section--dark) .step{background:var(--bg-card);border-color:var(--border);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(--text-soft)}
.section--dark .step p{color:#aab2c4}

/* --- pricing anchor + guarantee --- */
.price-band{display:grid;gap:2rem;align-items:center}
@media(min-width:860px){.price-band{grid-template-columns:1.1fr .9fr}}
.price-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-2xl);padding:2rem;box-shadow:var(--sh-md);text-align:center}
.price-card .from{font-size:.85rem;letter-spacing:.08em;text-transform:uppercase;color:var(--text-soft);font-weight:600}
.price-card .amt{font-family:var(--f-display);font-weight:800;font-size:clamp(2.6rem,5vw,3.6rem);line-height:1.05;color:var(--n-900);margin:.2rem 0}
.price-card .amt small{font-size:1rem;font-weight:600;color:var(--text-soft)}
.price-card .note{color:var(--text-soft);font-size:.95rem;margin-top:.4rem}
.guarantee{background:var(--grad-hero);color:#fff;border-radius:var(--r-2xl);padding:2rem;box-shadow:var(--sh-lg)}
.guarantee .badge{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--f-display);font-weight:700;font-size:.8rem;letter-spacing:.06em;text-transform:uppercase;color:var(--cyan-400);margin-bottom:.8rem}
.guarantee h3{color:#fff;font-size:1.4rem;margin-bottom:.6rem}
.guarantee p{color:#c8cee0}

/* --- references grid --- */
.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(--border-strong);background:#fff;color:var(--n-700);cursor:pointer;transition:.2s}
.filterbtn:hover{border-color:var(--blue-400);color:var(--blue-700)}
.filterbtn.is-active{background:var(--n-900);color:#fff;border-color:var(--n-900)}
.refgrid{display:grid;gap:1.1rem;grid-template-columns:repeat(auto-fill,minmax(min(270px,100%),1fr))}
.ref{display:flex;flex-direction:column;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-lg);
  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-md);border-color:var(--blue-200)}
.ref__tag{align-self:flex-start;font-size:.72rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--blue-700);background:var(--blue-50);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(--text-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;transition:transform .25s}
.ref:hover .ref__url svg{transform:translate(2px,-2px)}
.is-hidden{display:none!important}

/* --- case study cards / pages --- */
.cs-card{display:flex;flex-direction:column;overflow:hidden;background:var(--bg-card);border:1px solid var(--border);
  border-radius:var(--r-xl);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;letter-spacing:.04em;color:var(--blue-700);background:var(--blue-50);padding:.28rem .6rem;border-radius:var(--r-full)}
.cs-card h3{font-size:1.25rem;margin-bottom:.5rem}
.cs-card__top p{color:var(--text-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(--border);border-bottom:1px solid var(--border)}
.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(--n-900)}
.cs-stats span{font-size:.78rem;color:var(--text-soft)}
.cs-card__cta{padding:0 1.5rem 1.5rem;margin-top:auto}
/* case detail */
.cs-hero{background:var(--grad-hero);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-400);margin-right:.8rem}
.cs-hero h1{color:#fff;margin:.8rem 0;font-size:var(--t-h1)}
.cs-hero p{color:#c8cee0;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,.05);border:1px solid rgba(255,255,255,.12);border-radius:var(--r-lg);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:#9aa3b8}
.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(--n-700)}
.prose ul{margin:0 0 1.2rem;display:grid;gap:.6rem}
.prose ul li{position:relative;padding-left:1.6rem;color:var(--n-700)}
.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(--blue-50);padding:1.2rem 1.4rem;border-radius:0 var(--r-md) var(--r-md) 0;font-size:1.15rem;color:var(--n-800);font-weight:500;margin:1.6rem 0}
.prose .pullquote cite{display:block;margin-top:.6rem;font-size:.9rem;font-style:normal;color:var(--text-soft);font-weight:600}

/* --- testimonials --- */
.quote{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-xl);padding:1.7rem;box-shadow:var(--sh-sm)}
.quote .mark{font-family:var(--f-display);font-size:3rem;line-height:.6;color:var(--blue-200);font-weight:800}
.quote p{font-size:1.05rem;color:var(--n-800);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(--n-900)}
.quote .by span{font-size:.82rem;color:var(--text-soft)}

/* --- FAQ --- */
.faq{max-width:46rem;margin-inline:auto;display:grid;gap:.8rem}
.faq details{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-md);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(--n-900);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 .ans{padding:0 1.3rem 1.2rem;color:var(--text-soft)}

/* --- CTA band --- */
.ctaband{background:var(--grad-hero);color:#fff;border-radius:var(--r-2xl);padding:clamp(2rem,5vw,3.5rem);text-align:center;box-shadow:var(--sh-lg);position:relative;overflow:hidden;isolation:isolate}
.ctaband::before{content:"";position:absolute;inset:auto -10% -60% auto;width:60%;height:120%;z-index:-1;background:radial-gradient(circle,rgba(10,207,255,.28),transparent 70%);filter:blur(30px)}
.ctaband h2{color:#fff}
.ctaband p{color:#c8cee0;max-width:36rem;margin:.8rem auto 0}

/* --- booking embed --- */
.booking{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-xl);box-shadow:var(--sh-md);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:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-md);padding:1.1rem}
.contact-card .ic{flex:0 0 auto;width:42px;height:42px;border-radius:12px;background:var(--blue-50);color:var(--blue-700);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(--text-soft)}
.contact-card a{font-weight:600;color:var(--n-900)}

/* --- 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:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-xl);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:var(--grad-hero);position:relative;display:grid;place-items:center;padding:1.2rem;text-align:center;overflow:hidden}
.post-card__thumb::before{content:"";position:absolute;inset:0;background:radial-gradient(60% 80% at 30% 20%,rgba(42,84,255,.5),transparent 70%),radial-gradient(50% 60% at 85% 90%,rgba(10,207,255,.4),transparent 70%)}
.post-card__thumb span{position:relative;font-family:var(--f-display);font-weight:800;color:#fff;font-size:1.15rem;line-height:1.25;letter-spacing:-.01em;text-shadow:0 2px 12px rgba(0,0,0,.3)}
.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(--text-soft);flex:1}
.post-card .meta{margin-top:1rem;font-size:.8rem;color:var(--n-400)}
/* article */
.article-hero{background:var(--bg-subtle);border-bottom:1px solid var(--border)}
.article-hero .container{padding-block:clamp(2.4rem,5vw,4rem)}
.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(--text-soft);font-size:.9rem}
.article{padding-block:var(--section-y)}

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

/* --- footer --- */
.footer{background:var(--n-900);color:#c4cad6;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 img{height:30px;margin-bottom:1rem}
.footer__brand p{color:#9aa3b8;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:#aab2c4;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:#8892a4}
.footer__bottom a{color:#8892a4}.footer__bottom a:hover{color:#fff}

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

/* --- reveal animation (gated behind .js so no-JS shows everything) --- */
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 --- */
@media(max-width:920px){
  .nav__links{position:fixed;inset:74px 0 auto;flex-direction:column;align-items:stretch;gap:.2rem;background:var(--n-0);
    border-bottom:1px solid var(--border);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 - 74px);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,251,251,.92);backdrop-filter:blur(12px);border-top:1px solid var(--border)}
  .callbar .btn{flex:1}
  body{padding-bottom:72px}
}
