/* ============================================================
   AUTO-GENERATED — do not edit by hand.
   Source: src/styles/tokens.css + src/styles/global.css
   Regenerate with: npm run sync:grav
   ============================================================ */

/* ============================================================
   Convergo — Colors & Type (design tokens)
   "Visibility creates value." Light through fog. Signal in noise.
   Ported verbatim from the design handoff (colors_and_type.css).
   Fonts are self-hosted via @fontsource-variable (imported in
   BaseLayout) instead of the Google Fonts @import, for Core Web
   Vitals — the families are identical, so rendering is unchanged.
   ============================================================ */

:root {

  /* ------------------------------------------------------------
     COLORS — Convergo primary palette (4 colors)
       Lavender  #A9AFFF — brand signal / primary CTA
       Mint      #45FFB3 — emerging signal / accent / data viz
       Gray      #A0A3C2 — cool neutral, body of UI
       Black     #000000 — ink, structure, dark surface
     ------------------------------------------------------------ */

  /* — Lavender (primary) — */
  --lavender-50:  #F2F3FF;
  --lavender-100: #E5E7FF;
  --lavender-200: #CDD0FF;
  --lavender-300: #BABEFF;
  --lavender-400: #A9AFFF;   /* ← Convergo Lavender (primary) */
  --lavender-500: #8A91F5;
  --lavender-600: #6C73E4;
  --lavender-700: #5057C4;
  --lavender-800: #383E93;
  --lavender-900: #21255F;

  --brand:        var(--lavender-400);
  --brand-deep:   var(--lavender-600);
  --brand-soft:   var(--lavender-100);

  /* — Mint (primary signal / accent) — */
  --mint-50:  #EBFFF6;
  --mint-100: #D1FFE9;
  --mint-200: #A8FFD3;
  --mint-300: #7BFFC2;
  --mint-400: #45FFB3;   /* ← Convergo Mint (signal) */
  --mint-500: #20E89A;
  --mint-600: #14C883;
  --mint-700: #0E9E68;
  --mint-800: #0B7350;
  --mint-900: #074A34;

  --signal:      var(--mint-400);
  --signal-deep: var(--mint-700);

  /* — Gray (primary cool neutral) — */
  --gray-50:  #F4F5F9;
  --gray-100: #E8EAF1;
  --gray-200: #D4D7E4;
  --gray-300: #BCC0D5;
  --gray-400: #A0A3C2;   /* ← Convergo Gray (cool neutral) */
  --gray-500: #82869F;
  --gray-600: #696C81;
  --gray-700: #4F5263;
  --gray-800: #353747;
  --gray-900: #1C1D27;

  /* — Ink (true black) — */
  --ink-900: #000000;   /* ← Convergo Black (primary) */
  --ink-800: #14141A;
  --ink-700: #26262F;
  --ink-600: #3B3B47;
  --ink-500: var(--gray-700);
  --ink-400: var(--gray-500);
  --ink-300: var(--gray-300);
  --ink-200: var(--gray-200);
  --ink-100: var(--gray-100);
  --ink-50:  var(--gray-50);

  /* — Fog (off-white surfaces) — */
  --fog-0:   #FFFFFF;
  --fog-50:  #FBFBFD;
  --fog-100: #F4F5F9;
  --fog-200: #E8EAF1;
  --fog-300: #D4D7E4;

  /* — Semantic — */
  --success-500: #4FB286;
  --success-100: #E1F2EA;
  --warn-500:    #E8B14A;
  --warn-100:    #FBEFD3;
  --danger-500:  #DB5461;
  --danger-100:  #FADCDF;

  /* — Foreground tokens (semantic) — */
  --fg-1: var(--ink-900);   /* primary text — true black */
  --fg-2: var(--gray-700);  /* secondary text */
  --fg-3: var(--gray-500);  /* tertiary, captions */
  --fg-4: var(--gray-400);  /* placeholders, disabled — Convergo Gray */
  --fg-on-brand: var(--fog-0);
  --fg-on-dark:  var(--fog-50);
  --fg-link: var(--brand-deep);

  /* — Background tokens (semantic) — */
  --bg-0: var(--fog-0);
  --bg-1: var(--fog-50);    /* page */
  --bg-2: var(--fog-100);   /* card on page */
  --bg-3: var(--fog-200);   /* well / inset */
  --bg-brand: var(--brand);
  --bg-ink: var(--ink-900); /* dark surface */

  /* — Borders / dividers — */
  --border-1: rgba(0, 0, 0, 0.06);   /* hairline */
  --border-2: rgba(0, 0, 0, 0.10);   /* card */
  --border-3: rgba(0, 0, 0, 0.18);   /* input */
  --border-brand: var(--lavender-300);

  /* — Gradients — "light through fog" — */
  --grad-fog:    linear-gradient(180deg, #FBFBFD 0%, #ECEDF5 100%);
  --grad-signal: linear-gradient(135deg, var(--lavender-300) 0%, var(--mint-300) 100%);
  --grad-reveal: radial-gradient(120% 80% at 20% 0%, rgba(169,175,255,0.55) 0%, rgba(169,175,255,0) 60%),
                 linear-gradient(180deg, #FBFBFD 0%, #EEEFFB 100%);
  --grad-ink:    linear-gradient(180deg, #14141A 0%, #000000 100%);

  /* ------------------------------------------------------------
     TYPE  (self-hosted Fontsource variable families; identical to
     the Google Fonts used in the mock, with the static-name fallback)
     ------------------------------------------------------------ */

  --font-display: "Quicksand Variable", "Quicksand", "Avenir Next", "Avenir", system-ui, sans-serif;
  --font-sans:    "Manrope Variable", "Manrope", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;
  --font-caps:    "Jost Variable", "Jost", "Futura", "Avenir Next", system-ui, sans-serif;
  --font-mono:    "JetBrains Mono Variable", "JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace;

  /* Type scale — modular, generous breathing */
  --fs-display-1: clamp(48px, 8vw, 112px);
  --fs-display-2: clamp(40px, 6vw, 80px);
  --fs-h1: clamp(36px, 4.4vw, 56px);
  --fs-h2: clamp(28px, 3.2vw, 40px);
  --fs-h3: 28px;
  --fs-h4: 22px;
  --fs-h5: 18px;
  --fs-lead: 20px;
  --fs-body: 16px;
  --fs-sm: 14px;
  --fs-xs: 12px;
  --fs-eyebrow: 12px;

  --lh-tight: 1.08;
  --lh-snug:  1.2;
  --lh-base:  1.55;
  --lh-loose: 1.7;

  /* Letter-spacing — wide for tagline caps; tight for display */
  --tracking-tagline:  0.32em;
  --tracking-eyebrow:  0.18em;
  --tracking-display: -0.02em;
  --tracking-body:     0em;

  /* ------------------------------------------------------------
     SPACE / RADIUS / SHADOWS
     ------------------------------------------------------------ */
  --s-0:  0;
  --s-1:  4px;
  --s-2:  8px;
  --s-3:  12px;
  --s-4:  16px;
  --s-5:  20px;
  --s-6:  24px;
  --s-7:  32px;
  --s-8:  40px;
  --s-9:  56px;
  --s-10: 72px;
  --s-11: 96px;
  --s-12: 128px;

  --r-xs: 4px;
  --r-sm: 8px;
  --r-md: 12px;
  --r-lg: 18px;
  --r-xl: 24px;
  --r-2xl: 32px;
  --r-pill: 999px;

  /* Shadows — soft, low, lavender-tinted (no harsh blacks) */
  --shadow-0: 0 1px 0 rgba(20,19,43,0.04);
  --shadow-1: 0 1px 2px rgba(20,19,43,0.06), 0 1px 1px rgba(20,19,43,0.04);
  --shadow-2: 0 4px 12px rgba(40,36,93,0.06), 0 1px 2px rgba(20,19,43,0.04);
  --shadow-3: 0 12px 32px rgba(60,55,140,0.10), 0 2px 6px rgba(20,19,43,0.05);
  --shadow-4: 0 24px 60px rgba(60,55,140,0.16), 0 4px 12px rgba(20,19,43,0.06);
  --shadow-brand: 0 8px 24px rgba(114,108,221,0.28);
  --inner-soft: inset 0 0 0 1px rgba(20,19,43,0.06);

  /* Motion */
  --ease-out-soft: cubic-bezier(0.22, 0.61, 0.36, 1);
  --ease-in-out:   cubic-bezier(0.65, 0, 0.35, 1);
  --dur-fast: 140ms;
  --dur-base: 240ms;
  --dur-slow: 480ms;
  --dur-reveal: 900ms;       /* "fog clearing" reveals */
}

/* ============================================================
   SEMANTIC ELEMENT STYLES
   ============================================================ */

html, body {
  font-family: var(--font-sans);
  font-size: var(--fs-body);
  line-height: var(--lh-base);
  color: var(--fg-1);
  background: var(--bg-1);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

h1, .h1 {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-h1);
  line-height: var(--lh-tight);
  letter-spacing: var(--tracking-display);
  color: var(--fg-1);
  text-wrap: balance;
}
h2, .h2 {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-h2);
  line-height: var(--lh-snug);
  letter-spacing: var(--tracking-display);
  color: var(--fg-1);
  text-wrap: balance;
}
h3, .h3 {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: var(--fs-h3);
  line-height: var(--lh-snug);
  color: var(--fg-1);
}
h4, .h4 {
  font-family: var(--font-sans);
  font-weight: 700;
  font-size: var(--fs-h4);
  line-height: var(--lh-snug);
  color: var(--fg-1);
}
h5, .h5 {
  font-family: var(--font-sans);
  font-weight: 700;
  font-size: var(--fs-h5);
  line-height: var(--lh-snug);
  color: var(--fg-1);
}

.display-1 {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-display-1);
  line-height: 0.98;
  letter-spacing: -0.025em;
  color: var(--fg-1);
}
.display-2 {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-display-2);
  line-height: 1.02;
  letter-spacing: -0.022em;
  color: var(--fg-1);
}

p, .body {
  font-family: var(--font-sans);
  font-size: var(--fs-body);
  line-height: var(--lh-base);
  color: var(--fg-2);
  text-wrap: pretty;
}

.lead {
  font-family: var(--font-sans);
  font-size: var(--fs-lead);
  line-height: 1.45;
  color: var(--fg-2);
  font-weight: 400;
}

.eyebrow {
  font-family: var(--font-caps);
  font-weight: 400;
  font-size: var(--fs-eyebrow);
  letter-spacing: var(--tracking-eyebrow);
  text-transform: uppercase;
  color: var(--brand-deep);
}

.tagline {
  font-family: var(--font-caps);
  font-weight: 300;
  font-size: 14px;
  letter-spacing: var(--tracking-tagline);
  text-transform: uppercase;
  color: var(--fg-2);
}

small, .small, .caption {
  font-family: var(--font-sans);
  font-size: var(--fs-sm);
  color: var(--fg-3);
  line-height: 1.5;
}

code, kbd, samp, .mono {
  font-family: var(--font-mono);
  font-size: 0.94em;
  background: var(--bg-2);
  padding: 0.1em 0.4em;
  border-radius: var(--r-xs);
  color: var(--ink-800);
}

a {
  color: var(--fg-link);
  text-decoration: none;
  border-bottom: 1px solid transparent;
  transition: border-color var(--dur-fast) var(--ease-out-soft),
              color var(--dur-fast) var(--ease-out-soft);
}
a:hover { border-bottom-color: currentColor; }

hr {
  border: 0;
  height: 1px;
  background: var(--border-1);
  margin: var(--s-8) 0;
}

::selection {
  background: var(--lavender-200);
  color: var(--ink-900);
}


/* ============================================================
   Convergo — global primitives shared by every page
   (nav, footer, buttons, container, eyebrow, section, motion).
   Section-specific homepage rules live in home.css.
   Ported from the design handoff (Convergo Landing.html <style>).
   ============================================================ */

*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--fog-50);color:var(--ink-900);overflow-x:hidden}
html{scroll-behavior:smooth}
/* Offset one-pager anchor targets so the fixed nav doesn't cover the heading. */
section[id], header[id], footer[id]{scroll-margin-top:88px}
img{max-width:100%;display:block}
a{border-bottom:none;text-decoration:none}

.container{max-width:1280px;margin:0 auto;padding:0 40px}

/* Visually-hidden but screen-reader-available */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.skip-link{position:absolute;left:-999px;top:0;z-index:200;background:var(--ink-900);color:#fff;padding:12px 18px;border-radius:0 0 12px 0;font-family:var(--font-sans);font-weight:600;font-size:14px}
.skip-link:focus{left:0}
:focus-visible{outline:2px solid var(--lavender-600);outline-offset:3px;border-radius:4px}

/* ----------------- NAV ----------------- */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:60;
  background:transparent;
  transition: background var(--dur-base) var(--ease-out-soft),
              box-shadow var(--dur-base) var(--ease-out-soft),
              border-color var(--dur-base) var(--ease-out-soft);
  border-bottom:1px solid transparent;
}
.nav.is-scrolled{
  background: rgba(251,251,253,0.85);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-bottom-color: var(--gray-200);
  box-shadow: var(--shadow-1);
}
.nav-inner{display:flex;align-items:center;gap:40px;padding:24px 40px;max-width:1400px;margin:0 auto;transition:padding var(--dur-base) var(--ease-out-soft)}
.nav.is-scrolled .nav-inner{padding:10px 40px}
.nav-brand{display:flex;align-items:center;gap:10px;transition:transform var(--dur-base) var(--ease-out-soft);transform-origin:left center}
.nav-brand img{display:block;transition:width var(--dur-base) var(--ease-out-soft), height var(--dur-base) var(--ease-out-soft)}
.nav.is-scrolled .nav-brand img{width:120px !important;height:58px !important}
.nav:not(.is-scrolled) .nav-brand img{width:300px !important;height:143px !important}
/* Pull the larger expanded-state logo toward the top-left corner. */
.nav:not(.is-scrolled) .nav-brand{transform:translate(-14px,-12px)}
.nav-links{display:flex;gap:36px;flex:1;margin-left:8px;transition:margin var(--dur-base) var(--ease-out-soft)}
.nav-links a{font-family:var(--font-sans);font-weight:500;font-size:16px;color:var(--gray-700);text-decoration:none;border:none;transition:color var(--dur-fast) var(--ease-out-soft), font-size var(--dur-base) var(--ease-out-soft)}
.nav.is-scrolled .nav-links a{font-size:14px;color:var(--gray-600)}
.nav-links a:hover{color:var(--ink-900)}
.nav-links a.is-active{color:var(--ink-900);font-weight:600}
.nav-actions{display:flex;gap:10px;align-items:center;transition:transform var(--dur-base) var(--ease-out-soft)}
.nav-actions .btn{padding:16px 24px;font-size:15px;transition:padding var(--dur-base) var(--ease-out-soft), font-size var(--dur-base) var(--ease-out-soft)}
.nav.is-scrolled .nav-actions .btn{padding:11px 18px;font-size:14px}
/* The booking CTA also lives in the hero, so hide it while the nav is expanded
   (at the top) and reveal it smoothly once the nav is reduced (scrolled). */
.nav .desktop-cta{opacity:0;transform:translateX(12px) scale(.96);pointer-events:none;transition:opacity .45s var(--ease-out-soft), transform .45s var(--ease-out-soft), padding var(--dur-base) var(--ease-out-soft), font-size var(--dur-base) var(--ease-out-soft)}
.nav.is-scrolled .desktop-cta{opacity:1;transform:none;pointer-events:auto}
/* At the top the nav sits over the hero image — darker, heavier links keep the
   tab labels legible (no background scrim). */
.nav:not(.is-scrolled) .nav-links a{color:var(--ink-900);font-weight:600}
/* language switch */
.lang-switch{display:inline-flex;align-items:center;gap:2px;font-family:var(--font-caps);font-size:12px;letter-spacing:0.16em;text-transform:uppercase}
.lang-switch a{color:var(--gray-500);padding:4px 6px;border:none;border-radius:6px;transition:color var(--dur-fast) var(--ease-out-soft)}
.lang-switch a[aria-current="true"]{color:var(--ink-900);font-weight:600}
.lang-switch a:hover{color:var(--ink-900)}
.lang-switch .sep{color:var(--gray-300)}
/* mobile menu toggle */
.nav-toggle{display:none;flex-direction:column;justify-content:center;gap:5px;width:44px;height:44px;border:1px solid var(--gray-200);border-radius:12px;background:rgba(255,255,255,0.6);cursor:pointer;padding:0 11px;margin-left:auto}
.nav-toggle span{display:block;height:2px;width:100%;background:var(--ink-900);border-radius:2px;transition:transform var(--dur-base) var(--ease-out-soft),opacity var(--dur-base) var(--ease-out-soft)}
.nav[data-open="true"] .nav-toggle span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav[data-open="true"] .nav-toggle span:nth-child(2){opacity:0}
.nav[data-open="true"] .nav-toggle span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ----------------- BUTTON ----------------- */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 22px;border-radius:14px;
  font-family:var(--font-sans);font-weight:700;font-size:15px;
  border:1px solid transparent;cursor:pointer;text-decoration:none;
  transition:all var(--dur-base) var(--ease-out-soft);white-space:nowrap;
}
.btn:active{transform:scale(0.98)}
.btn-primary{background:var(--lavender-400);color:var(--ink-900);box-shadow:0 8px 24px rgba(169,175,255,0.55)}
.btn-primary:hover{background:var(--lavender-500);box-shadow:0 12px 32px rgba(138,145,245,0.6)}
.btn-secondary{background:#fff;color:var(--ink-900);border-color:var(--gray-300)}
.btn-secondary:hover{border-color:var(--ink-900)}
.btn-dark{background:var(--ink-900);color:#fff}
.btn-dark:hover{background:var(--ink-800)}
.btn-arrow{display:inline-grid;place-items:center;width:22px;height:22px;border-radius:50%;background:var(--ink-900);color:var(--lavender-400);font-size:12px}
.btn-primary:hover .btn-arrow{background:var(--ink-900);color:var(--mint-400)}

/* ----------------- EYEBROW (mock variant — overrides tokens.css) ----------------- */
.eyebrow{
  display:inline-flex;align-items:center;gap:12px;
  font-family:var(--font-caps);font-weight:400;
  font-size:12px;letter-spacing:0.22em;text-transform:uppercase;
  color:var(--ink-900);margin:0 0 24px;
}
.eyebrow::before{content:"";width:24px;height:2px;background:var(--mint-400);display:block}
/* Section eyebrow labels (e.g. "02 — A new model", "Our team") removed per request.
   The hero keeps its eyebrow (it lives in <header>, not a <section>). */
main > section .eyebrow, main > section .pull-eyebrow{display:none}
.on-dark .eyebrow{color:#fff}
.tagline-caps{font-family:var(--font-caps);font-weight:300;font-size:12px;letter-spacing:0.32em;text-transform:uppercase;color:var(--gray-500)}

/* ----------------- SECTION + H2 ----------------- */
section{padding:90px 0;position:relative}
.h2{
  font-family:var(--font-display);font-weight:500;
  font-size:clamp(40px, 5.4vw, 88px);
  line-height:1.0;letter-spacing:-0.024em;color:var(--ink-900);
  margin:0;text-wrap:balance;max-width:1200px;
}
.h2 .dim{color:var(--gray-500)}
.h2 em{font-style:normal;background:linear-gradient(180deg, transparent 60%, var(--mint-300) 60%);padding:0 6px}

/* ---------- One-pager: smooth, layered section transitions ----------
   Each section curves up over the previous one, so the page reads as one
   continuous flow of panels rather than separate stacked "pages". ------- */
:root{ --section-curve: 44px; }
main > section, main > .hero-strip, footer{ position: relative; }
main > section:not(.hero),
main > .hero-strip,
footer{
  border-top-left-radius: var(--section-curve);
  border-top-right-radius: var(--section-curve);
  margin-top: calc(-1 * var(--section-curve));
  box-shadow: 0 -22px 44px -24px rgba(20,19,43,0.13);
}
@media (max-width: 900px){ :root{ --section-curve: 30px; } }

/* ----------------- FOOTER (global) ----------------- */
footer{background:var(--ink-900);color:var(--gray-300);padding:80px 0 32px}
.footer-top{display:grid;grid-template-columns:1.2fr 2fr;gap:64px;padding-bottom:64px}
.footer-brand img{height:116px;width:auto;margin-bottom:26px}
.footer-line{font-family:var(--font-display);font-weight:500;font-size:18px;color:#fff;line-height:1.25;letter-spacing:-0.01em;max-width:300px;margin:16px 0 0}
.footer-line em{font-style:normal;color:var(--mint-400)}
.footer-cols{display:grid;grid-template-columns:0.9fr 1.6fr;gap:32px}
.footer-col-title{font-family:var(--font-caps);font-weight:400;font-size:11px;letter-spacing:0.22em;text-transform:uppercase;color:var(--mint-400);margin:0 0 14px}
.footer-col{display:flex;flex-direction:column;gap:10px}
.footer-col a{font-family:var(--font-sans);font-size:14px;color:var(--gray-300);text-decoration:none;border:none;transition:color var(--dur-fast) var(--ease-out-soft)}
.footer-col a:hover{color:#fff}
.footer-col a.footer-cta{display:inline-flex;align-items:center;gap:8px;width:fit-content;margin-top:18px;padding:12px 20px;border-radius:999px;background:var(--mint-400);color:var(--ink-900);font-weight:600;transition:transform var(--dur-base) var(--ease-out-soft), box-shadow var(--dur-base) var(--ease-out-soft)}
.footer-col a.footer-cta:hover{color:var(--ink-900);transform:translateY(-2px);box-shadow:0 10px 26px rgba(69,255,179,0.32)}
.contact-card{display:grid;grid-template-columns:1fr 84px;gap:18px;align-items:center;padding:16px;border-radius:14px;background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.08);margin-top:4px}
.contact-card + .contact-card{margin-top:12px}
.contact-card .info{display:flex;flex-direction:column;gap:4px;min-width:0}
.contact-card .info .who-line{display:flex;align-items:baseline;gap:10px;flex-wrap:nowrap;white-space:nowrap}
.contact-card .info .who{font-family:var(--font-sans);font-weight:600;font-size:14px;color:#fff;line-height:1.2;white-space:nowrap}
.contact-card .info .tel{font-family:var(--font-sans);font-size:13.5px;color:var(--gray-300);letter-spacing:-0.005em;white-space:nowrap}
.contact-card .info .tel:hover{color:#fff}
.contact-card .info .cta{font-family:var(--font-caps);font-weight:400;font-size:10px;letter-spacing:0.22em;text-transform:uppercase;color:var(--mint-400);margin-top:4px;display:flex;align-items:center;gap:6px}
.contact-card .info .cta::before{content:"";width:14px;height:1px;background:var(--mint-400)}
.contact-card .qr{display:block;width:84px;height:84px;border-radius:8px;background:#fff;padding:6px;box-sizing:border-box;flex-shrink:0;transition:transform var(--dur-base) var(--ease-out-soft)}
.contact-card .qr:hover{transform:scale(1.04)}
.contact-card .qr img{width:100%;height:100%;display:block;object-fit:contain}
.footer-bottom{border-top:1px solid rgba(255,255,255,0.08);padding-top:24px;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;font-family:var(--font-sans);font-size:13px;color:var(--gray-500)}
.footer-meta a{color:var(--gray-400);text-decoration:none;border:none;margin-left:24px}
.footer-meta a:hover{color:#fff}

/* ----------------- MOTION UTILITIES -----------------
   The scroll-reveal / parallax / kinetic motion layer now lives in
   src/styles/motion.css (per specs/design_handoff_motion_effects),
   keyed under html.has-anim. ------------------------------------- */

/* ----------------- SHARED RESPONSIVE (nav/footer/container) ----------------- */
@media (max-width: 900px){
  .container{padding:0 22px}
  .nav-inner{padding:14px 22px;gap:20px}
  .nav-links{display:none}
  .nav-links.is-open{display:flex;position:absolute;top:100%;left:0;right:0;flex-direction:column;gap:0;background:rgba(251,251,253,0.97);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--gray-200);padding:8px 22px 18px;box-shadow:var(--shadow-2)}
  .nav-links.is-open a{padding:14px 0;font-size:18px;border-bottom:1px solid var(--border-1)}
  .nav-toggle{display:flex}
  .nav-actions .desktop-cta{display:none}
  section{padding:80px 0}
  .footer-top{grid-template-columns:1fr;gap:40px}
  .footer-cols{grid-template-columns:1fr;gap:28px}
}

