/* ============================================================
   WTS BYG — Global Stylesheet
   Premium static site CSS
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&display=swap');

/* ── CSS Custom Properties ─────────────────────────────────── */
:root {
  --green-900: #0e2612;
  --green-800: #0e2612;
  --green-700: #0e2612;
  --green-600: #0e2612;
  --green-500: #0e2612;
  --green-200: #0e2612;
  --green-100: #0e2612;
  --green-50:  #0e2612;
  --gold:      #0DE85C;
  --gold-dark: #0bc44d;
  --gold-light:#d0fbe6;
  --white:     #ffffff;
  --off-white: #f8faf9;
  --grey-100:  #eef1ee;
  --grey-200:  #d4d9d4;
  --grey-400:  #8a9e8a;
  --grey-600:  #546054;
  --black:     #0a0f0a;
  --font:      'Inter', system-ui, sans-serif;
  --text-xs:   clamp(0.7rem,  1vw, 0.75rem);
  --text-sm:   clamp(0.8rem,  1.2vw, 0.875rem);
  --text-base: clamp(0.9rem,  1.4vw, 1rem);
  --text-lg:   clamp(1rem,    1.6vw, 1.125rem);
  --text-xl:   clamp(1.1rem,  1.8vw, 1.25rem);
  --text-2xl:  clamp(1.25rem, 2.2vw, 1.5rem);
  --text-3xl:  clamp(1.5rem,  3vw,   2rem);
  --text-4xl:  clamp(2rem,    4vw,   2.75rem);
  --text-5xl:  clamp(2.5rem,  5.5vw, 3.75rem);
  --text-6xl:  clamp(3rem,    7vw,   5rem);
  --space-1:  0.25rem; --space-2:  0.5rem;  --space-3:  0.75rem;
  --space-4:  1rem;    --space-5:  1.25rem; --space-6:  1.5rem;
  --space-8:  2rem;    --space-10: 2.5rem;  --space-12: 3rem;
  --space-16: 4rem;    --space-20: 5rem;    --space-24: 6rem;
  --max-w:     1200px;
  --gutter:    clamp(1.25rem, 5vw, 2.5rem);
  --radius-sm: 8px;  --radius-md: 14px;
  --radius-lg: 20px; --radius-xl: 28px; --radius-pill: 999px;
  --shadow-sm:    0 1px 3px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);
  --shadow-md:    0 4px 16px rgba(0,0,0,.08), 0 1px 4px rgba(0,0,0,.04);
  --shadow-lg:    0 12px 40px rgba(0,0,0,.12), 0 4px 12px rgba(0,0,0,.06);
  --shadow-xl:    0 24px 64px rgba(0,0,0,.16), 0 8px 24px rgba(0,0,0,.08);
  --shadow-green: 0 8px 32px rgba(19,49,23,.4);
  --shadow-gold:  0 8px 24px rgba(13,232,92,0.30);
  --ease-out:    cubic-bezier(0.16, 1, 0.3, 1);
  --ease-spring: cubic-bezier(0.34, 1.56, 0.64, 1);
  --ease-in-out: cubic-bezier(0.45, 0, 0.55, 1);
  --dur-fast:   150ms; --dur-base: 250ms;
  --dur-slow:   400ms; --dur-slower: 600ms;
}

/* ── Reset ─────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; text-rendering: optimizeLegibility; -webkit-font-smoothing: antialiased; }
body { font-family: var(--font); font-size: var(--text-base); line-height: 1.65; color: var(--black); background: var(--white); overflow-x: hidden; }
img, video { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
ul, ol { list-style: none; }
button { font-family: inherit; cursor: pointer; border: none; background: none; }
::-webkit-scrollbar { width: 6px; }
::-webkit-scrollbar-track { background: var(--grey-100); }
::-webkit-scrollbar-thumb { background: var(--green-600); border-radius: 99px; }
::selection { background: var(--green-100); color: var(--green-800); }
:focus-visible { outline: 2px solid var(--green-600); outline-offset: 3px; border-radius: var(--radius-sm); }

/* ── Layout ────────────────────────────────────────────────── */
.container { width: 100%; max-width: var(--max-w); margin-inline: auto; padding-inline: var(--gutter); }
.section { padding-block: clamp(4rem, 8vw, 7rem); }
.section--dark  { background: #133117; color: var(--white); }
.section--deeper{ background: #133117; color: var(--white); }
.section--light { background: var(--green-50); }
.section--off   { background: var(--off-white); }

/* ── Typography ────────────────────────────────────────────── */
.eyebrow { display: inline-flex; align-items: center; gap: var(--space-2); font-size: var(--text-xs); font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: var(--green-600); }
.eyebrow--light { color: var(--green-100); }
.eyebrow--gold  { color: var(--gold); }
.eyebrow::before { display: none; }
h1,h2,h3,h4,h5,h6 { font-family: var(--font); line-height: 1.1; font-weight: 800; letter-spacing: -0.03em; }
.headline-xl { font-size: var(--text-6xl); font-weight: 900; letter-spacing: -0.04em; line-height: 1.0; }
.headline-lg { font-size: var(--text-5xl); font-weight: 800; letter-spacing: -0.035em; line-height: 1.05; }
.headline-md { font-size: var(--text-4xl); font-weight: 800; letter-spacing: -0.03em; line-height: 1.1; }
.headline-sm { font-size: var(--text-3xl); font-weight: 700; letter-spacing: -0.025em; line-height: 1.2; }
.body-lg { font-size: var(--text-lg); font-weight: 400; line-height: 1.7; color: var(--grey-600); }
.body-lg--light { color: rgba(255,255,255,0.72); }
.text-balance { text-wrap: balance; }
.text-accent { color: var(--gold); }
.text-green  { color: var(--green-600); }
.grad-text { background: linear-gradient(135deg, var(--white) 0%, rgba(255,255,255,0.7) 100%); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }
.grad-text--gold { background: linear-gradient(135deg, var(--gold) 0%, #0DE85C 100%); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }

/* ── Buttons ───────────────────────────────────────────────── */
.btn { display: inline-flex; align-items: center; justify-content: center; gap: var(--space-2); padding: 0.875rem 2rem; font-size: var(--text-base); font-weight: 700; letter-spacing: -0.01em; border-radius: var(--radius-md); transition: background var(--dur-base) var(--ease-out), transform var(--dur-fast) var(--ease-out), box-shadow var(--dur-base) var(--ease-out), color var(--dur-base) var(--ease-out); position: relative; overflow: hidden; white-space: nowrap; cursor: pointer; text-decoration: none; }
.btn::after { content: ''; position: absolute; inset: 0; background: rgba(255,255,255,0); transition: background var(--dur-fast) var(--ease-out); border-radius: inherit; pointer-events: none; }
.btn:hover::after { background: rgba(255,255,255,0.08); }
.btn:active { transform: scale(0.98); }
.btn-primary { background: var(--gold); color: var(--green-900); box-shadow: var(--shadow-gold); }
.btn-primary:hover { background: var(--gold-dark); transform: translateY(-2px); box-shadow: 0 12px 32px rgba(13,232,92,0.40); }
.btn-secondary { background: transparent; color: var(--white); border: 2px solid rgba(255,255,255,0.3); }
.btn-secondary:hover { border-color: rgba(255,255,255,0.7); background: rgba(255,255,255,0.08); transform: translateY(-2px); }
.btn-ghost { background: transparent; color: var(--green-800); border: 2px solid var(--green-100); }
.btn-ghost:hover { background: var(--green-800); color: var(--white); border-color: var(--green-800); transform: translateY(-2px); box-shadow: var(--shadow-green); }
.btn .arrow { display: inline-block; transition: transform var(--dur-base) var(--ease-spring); }
.btn:hover .arrow { transform: translateX(4px); }

/* ── Navbar ────────────────────────────────────────────────── */
.navbar { position: fixed; top: 0; left: 0; right: 0; z-index: 100; padding: 0 var(--gutter); height: 72px; display: flex; align-items: center; transition: background var(--dur-slow) var(--ease-out), backdrop-filter var(--dur-slow) var(--ease-out), box-shadow var(--dur-slow) var(--ease-out); background: #133117; }
.navbar.scrolled { background: #133117; backdrop-filter: none; -webkit-backdrop-filter: none; box-shadow: 0 1px 0 rgba(0,0,0,0.2), 0 4px 20px rgba(0,0,0,0.25); }
.navbar.scrolled .nav-link { color: rgba(255,255,255,0.85); }
.navbar.scrolled .nav-logo-text { color: rgba(255,255,255,0.9); }
.navbar__inner { width: 100%; max-width: var(--max-w); margin-inline: auto; display: flex; align-items: center; justify-content: space-between; gap: var(--space-8); }
.nav-logo { display: flex; align-items: center; gap: var(--space-3); text-decoration: none; flex-shrink: 0; }
.nav-logo-mark { width: 36px; height: 36px; background: var(--gold); border-radius: 10px; display: flex; align-items: center; justify-content: center; font-weight: 900; font-size: 1rem; color: var(--green-900); letter-spacing: -0.05em; flex-shrink: 0; box-shadow: var(--shadow-gold); }
.nav-logo-text { font-size: var(--text-lg); font-weight: 800; letter-spacing: -0.04em; color: var(--white); transition: color var(--dur-base) var(--ease-out); }
.nav-logo-img { height: 40px; width: auto; max-width: 160px; object-fit: contain; display: block; }
.nav-links { display: flex; align-items: center; gap: var(--space-1); margin-left: auto; }
.nav-link { font-size: var(--text-sm); font-weight: 600; color: rgba(255,255,255,0.85); padding: var(--space-2) var(--space-3); border-radius: var(--radius-sm); transition: color var(--dur-base) var(--ease-out), background var(--dur-base) var(--ease-out); text-decoration: none; letter-spacing: -0.01em; }
.nav-link:hover { color: var(--white); background: rgba(255,255,255,0.1); }
.nav-link.active { color: var(--gold); }
.nav-actions { display: flex; align-items: center; gap: var(--space-3); flex-shrink: 0; }
.hamburger { display: none; flex-direction: column; gap: 5px; width: 28px; cursor: pointer; padding: var(--space-2); border-radius: var(--radius-sm); background: none; border: none; }
.hamburger__line { display: block; width: 100%; height: 2px; background: var(--white); border-radius: 2px; transition: transform var(--dur-base) var(--ease-out), opacity var(--dur-base) var(--ease-out), width var(--dur-base) var(--ease-out); transform-origin: center; }
.hamburger.open .hamburger__line:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.hamburger.open .hamburger__line:nth-child(2) { opacity: 0; width: 0; }
.hamburger.open .hamburger__line:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }
.mobile-menu { position: fixed; inset: 0; top: 72px; background: #133117; z-index: 99; padding: var(--space-8) var(--gutter); display: flex; flex-direction: column; gap: var(--space-2); transform: translateX(100%); transition: transform var(--dur-slow) var(--ease-out); }
.mobile-menu.open { transform: translateX(0); }
.mobile-menu .nav-link { font-size: var(--text-xl); font-weight: 700; color: rgba(255,255,255,0.75); padding: var(--space-4) 0; border-bottom: 1px solid rgba(255,255,255,0.08); border-radius: 0; display: block; }
.mobile-menu .nav-link:hover { color: var(--white); background: none; }

/* ── Hero ─────────────────────────────────────────────────── */
.hero { position: relative; min-height: 100svh; display: flex; flex-direction: column; justify-content: flex-end; overflow: hidden; background: #133117; padding-top: 72px; }
.hero__bg { position: absolute; inset: 0; z-index: 0; }
.hero__video { width: 100%; height: 100%; object-fit: cover; opacity: 0.72; }
.hero__noise { position: absolute; inset: 0; z-index: 1; opacity: 0.03; background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E"); background-size: 200px; }
.hero__gradient-bottom { position: absolute; bottom: 0; left: 0; right: 0; height: 55%; background: linear-gradient(to top, var(--green-900) 0%, rgba(11,31,14,0.7) 35%, transparent 100%); z-index: 2; }
.hero__gradient-left { position: absolute; inset: 0; background: radial-gradient(ellipse 70% 80% at 15% 60%, rgba(19,49,23,0.35) 0%, transparent 70%); z-index: 2; }
.hero__content { position: relative; z-index: 10; padding: var(--space-24) var(--gutter) clamp(3rem, 6vw, 5rem); max-width: var(--max-w); margin-inline: auto; width: 100%; }
.hero__grid { display: grid; grid-template-columns: 1fr 1fr; align-items: end; gap: var(--space-16); }
.hero__left { display: flex; flex-direction: column; gap: var(--space-8); }
.hero__badge { display: inline-flex; align-items: center; gap: var(--space-3); background: rgba(255,255,255,0.08); border: 1px solid rgba(255,255,255,0.15); border-radius: var(--radius-pill); padding: var(--space-2) var(--space-4); backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px); width: fit-content; }
.hero__badge-dot { width: 8px; height: 8px; background: var(--green-500); border-radius: 50%; animation: pulse-dot 2s ease-in-out infinite; }
@keyframes pulse-dot { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.6;transform:scale(1.3)} }
.hero__badge-text { font-size: var(--text-xs); font-weight: 600; color: rgba(255,255,255,0.85); letter-spacing: 0.06em; text-transform: uppercase; }
.hero__heading { font-size: var(--text-6xl); font-weight: 900; letter-spacing: -0.04em; line-height: 1.0; color: var(--white); }
.hero__heading em { font-style: normal; color: var(--gold); }
.hero__sub { font-size: var(--text-lg); color: rgba(255,255,255,0.65); line-height: 1.65; max-width: 46ch; }
.hero__actions { display: flex; align-items: center; gap: var(--space-4); flex-wrap: wrap; }
.hero__right { display: flex; flex-direction: column; gap: var(--space-6); align-items: flex-end; }
.hero__stats { display: flex; flex-direction: column; gap: var(--space-4); width: 100%; max-width: 320px; }
.stat-card { background: rgba(255,255,255,0.07); border: 1px solid rgba(255,255,255,0.12); border-radius: var(--radius-md); padding: var(--space-5) var(--space-6); backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px); display: flex; align-items: center; gap: var(--space-4); }
.stat-card__icon { width: 44px; height: 44px; background: var(--gold); border-radius: var(--radius-sm); display: flex; align-items: center; justify-content: center; flex-shrink: 0; color: var(--green-900); }
.stat-card__num { font-size: var(--text-2xl); font-weight: 900; letter-spacing: -0.03em; color: var(--white); line-height: 1; }
.stat-card__label { font-size: var(--text-xs); color: rgba(255,255,255,0.55); font-weight: 500; letter-spacing: 0.04em; margin-top: 2px; }
.hero__scroll-cue { display: none !important; }
.scroll-line { width: 1px; height: 40px; background: linear-gradient(to bottom, rgba(255,255,255,0), rgba(255,255,255,0.4)); animation: scroll-line 2s ease-in-out infinite; }
@keyframes scroll-line { 0%{transform:scaleY(0);transform-origin:top} 50%{transform:scaleY(1);transform-origin:top} 51%{transform:scaleY(1);transform-origin:bottom} 100%{transform:scaleY(0);transform-origin:bottom} }

/* ── Trust bar ─────────────────────────────────────────────── */
.trust-bar { background: var(--white); border-bottom: 1px solid var(--grey-100); padding: var(--space-6) var(--gutter); }
.trust-bar__inner { max-width: var(--max-w); margin-inline: auto; display: flex; align-items: center; justify-content: space-between; gap: var(--space-6); flex-wrap: wrap; }
.trust-item { display: flex; align-items: center; gap: var(--space-3); }
.trust-item__icon { width: 40px; height: 40px; background: #133117; border-radius: var(--radius-sm); display: flex; align-items: center; justify-content: center; color: var(--gold); flex-shrink: 0; }
.trust-item__text { font-size: var(--text-sm); font-weight: 600; color: var(--grey-600); letter-spacing: -0.01em; }
.trust-item__text strong { display: block; color: var(--green-800); font-size: var(--text-base); font-weight: 800; }
.trust-divider { width: 1px; height: 40px; background: var(--grey-100); }

/* ── Services ──────────────────────────────────────────────── */
.services-section { position: relative; overflow: hidden; }
.services-section::before { content:''; position:absolute; top:-20%; right:-10%; width:60%; height:80%; background:radial-gradient(ellipse at center, rgba(82,183,136,0.12) 0%, transparent 70%); pointer-events:none; }
.services-section::after  { content:''; position:absolute; bottom:-10%; left:-5%; width:40%; height:60%; background:radial-gradient(ellipse at center, rgba(13,232,92,0.08) 0%, transparent 70%); pointer-events:none; }
.section-header { text-align: center; max-width: 56ch; margin-inline: auto; margin-bottom: clamp(2.5rem, 5vw, 4rem); }
.section-header--left { text-align: left; margin-inline: 0; }
.services-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-4); }
.card-glass { background: rgba(255,255,255,0.06); border: 1px solid rgba(255,255,255,0.12); border-radius: var(--radius-lg); backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px); transition: transform var(--dur-slow) var(--ease-out), background var(--dur-slow) var(--ease-out), border-color var(--dur-slow) var(--ease-out); }
.card-glass:hover { background: rgba(255,255,255,0.10); border-color: rgba(255,255,255,0.22); transform: translateY(-4px); }
.service-card { padding: var(--space-8) var(--space-7); display: flex; flex-direction: column; gap: var(--space-5); cursor: pointer; text-decoration: none; color: inherit; }
.service-card__img { margin: calc(-1 * var(--space-8)) calc(-1 * var(--space-7)) var(--space-5); aspect-ratio: 16/9; overflow: hidden; border-radius: var(--radius-lg) var(--radius-lg) 0 0; }
.service-card__img img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--dur-slower) var(--ease-out); }
.service-card:hover .service-card__img img { transform: scale(1.05); }
.service-card__icon-wrap { width: 56px; height: 56px; border-radius: var(--radius-md); background: rgba(255,255,255,0.1); border: 1px solid rgba(255,255,255,0.15); display: flex; align-items: center; justify-content: center; transition: background var(--dur-base) var(--ease-out), transform var(--dur-base) var(--ease-spring); flex-shrink: 0; }
.service-card:hover .service-card__icon-wrap { background: var(--gold); border-color: var(--gold); transform: scale(1.08) rotate(-3deg); }
.service-card__icon-wrap svg { width: 26px; height: 26px; color: rgba(255,255,255,0.85); transition: color var(--dur-base) var(--ease-out); flex-shrink: 0; }
.service-card:hover .service-card__icon-wrap svg { color: #133117 !important; }
.service-card__title { font-size: var(--text-xl); font-weight: 700; color: var(--white); letter-spacing: -0.02em; line-height: 1.3; }
.service-card__desc { font-size: var(--text-sm); color: rgba(255,255,255,0.6); line-height: 1.65; flex: 1; }
.service-card__link { display: inline-flex; align-items: center; gap: var(--space-2); font-size: var(--text-sm); font-weight: 600; color: var(--gold); opacity: 0; transform: translateX(-6px); transition: opacity var(--dur-base) var(--ease-out), transform var(--dur-base) var(--ease-out); }
.service-card:hover .service-card__link { opacity: 1; transform: translateX(0); }

/* ── Split / About ─────────────────────────────────────────── */
.split { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(3rem, 6vw, 6rem); align-items: center; }
.split--reverse .split__media { order: 2; }
.split--reverse .split__text  { order: 1; }
.split__media { position: relative; border-radius: var(--radius-xl); overflow: hidden; aspect-ratio: 4/5; }
.split__media img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--dur-slower) var(--ease-out); }
.split__media:hover img { transform: scale(1.04); }
.split__media-badge { position: absolute; bottom: var(--space-6); right: var(--space-6); background: var(--white); border-radius: var(--radius-md); padding: var(--space-4) var(--space-5); box-shadow: var(--shadow-xl); min-width: 140px; }
.split__media-badge .num { font-size: var(--text-3xl); font-weight: 900; letter-spacing: -0.04em; color: var(--green-800); line-height: 1; }
.split__media-badge .label { font-size: var(--text-xs); font-weight: 600; color: var(--grey-400); letter-spacing: 0.06em; text-transform: uppercase; margin-top: var(--space-1); }
.split__text { display: flex; flex-direction: column; gap: var(--space-6); }
.feature-list { display: flex; flex-direction: column; gap: var(--space-4); margin-top: var(--space-2); }
.feature-item { display: flex; gap: var(--space-4); align-items: flex-start; }
.feature-item__check { width: 22px; height: 22px; border-radius: 50%; background: var(--green-100); display: flex; align-items: center; justify-content: center; flex-shrink: 0; margin-top: 2px; }
.feature-item__check svg { width: 12px; height: 12px; color: var(--green-700); }
.feature-item__text { font-size: var(--text-base); font-weight: 500; color: var(--grey-600); line-height: 1.5; }

/* ── City tags ─────────────────────────────────────────────── */
.city-tags { display: flex; flex-wrap: wrap; gap: var(--space-2); justify-content: center; }
.city-tag { display: inline-flex; align-items: center; gap: var(--space-1); padding: var(--space-2) var(--space-3); background: var(--green-50); border: 1px solid var(--green-100); border-radius: var(--radius-pill); font-size: var(--text-sm); font-weight: 600; color: var(--green-700); text-decoration: none; transition: background var(--dur-fast) var(--ease-out), border-color var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out), transform var(--dur-fast) var(--ease-spring); }
.city-tag:hover { background: var(--green-800); border-color: var(--green-800); color: var(--white); transform: translateY(-2px); }
.city-tag svg { width: 12px; height: 12px; flex-shrink: 0; }

/* ── FAQ ───────────────────────────────────────────────────── */
.faq-list { display: flex; flex-direction: column; gap: var(--space-3); }
.faq-item { border: 1px solid var(--grey-100); border-radius: var(--radius-md); background: var(--white); overflow: hidden; transition: box-shadow var(--dur-base) var(--ease-out), border-color var(--dur-base) var(--ease-out); }
.faq-item:hover, .faq-item.open { border-color: var(--green-200); box-shadow: var(--shadow-md); }
.faq-trigger { width: 100%; display: flex; align-items: center; justify-content: space-between; gap: var(--space-4); padding: var(--space-5) var(--space-6); text-align: left; cursor: pointer; background: none; border: none; font-family: var(--font); }
.faq-trigger__q { font-size: var(--text-base); font-weight: 700; color: var(--green-800); letter-spacing: -0.01em; line-height: 1.4; }
.faq-trigger__icon { width: 28px; height: 28px; border-radius: 50%; background: var(--green-50); display: flex; align-items: center; justify-content: center; flex-shrink: 0; transition: background var(--dur-base) var(--ease-out), transform var(--dur-base) var(--ease-spring); color: var(--green-700); }
.faq-item.open .faq-trigger__icon { background: var(--green-800); color: var(--white); transform: rotate(45deg); }
.faq-trigger__icon svg { width: 14px; height: 14px; }
.faq-body { overflow: hidden; display: grid; grid-template-rows: 0fr; transition: grid-template-rows var(--dur-slow) var(--ease-out); }
.faq-item.open .faq-body { grid-template-rows: 1fr; }
.faq-body__inner { overflow: hidden; min-height: 0; }
.faq-body__content { padding: 0 var(--space-6) var(--space-5); font-size: var(--text-base); color: var(--grey-600); line-height: 1.7; }

/* ── CTA Banner ─────────────────────────────────────────────── */
.cta-banner { position: relative; overflow: hidden; }
.cta-banner__bg { position: absolute; inset: 0; background: #133117; }
.cta-banner__circle { position: absolute; border-radius: 50%; background: rgba(255,255,255,0.04); pointer-events: none; }
.cta-banner__circle--1 { width: 400px; height: 400px; top: -100px; right: -100px; }
.cta-banner__circle--2 { width: 250px; height: 250px; bottom: -80px; left: 30%; background: rgba(13,232,92,0.08); }
.cta-banner__content { position: relative; z-index: 2; padding: clamp(3.5rem, 6vw, 5.5rem) var(--gutter); max-width: var(--max-w); margin-inline: auto; display: flex; align-items: center; justify-content: space-between; gap: var(--space-8); }
.cta-banner__text { flex: 1; }
.cta-banner__actions { display: flex; align-items: center; gap: var(--space-4); flex-shrink: 0; flex-wrap: wrap; }
.cta-phone { display: flex; align-items: center; gap: var(--space-3); color: var(--white); text-decoration: none; font-weight: 700; font-size: var(--text-xl); letter-spacing: -0.02em; transition: color var(--dur-base) var(--ease-out); }
.cta-phone svg { width: 22px; height: 22px; flex-shrink: 0; color: var(--gold); }
.cta-phone:hover { color: var(--gold); }

/* ── Footer ─────────────────────────────────────────────────── */
.footer { background: #133117; color: var(--white); padding: clamp(3rem, 6vw, 5rem) var(--gutter) var(--space-8); }
.footer__grid { max-width: var(--max-w); margin-inline: auto; display: grid; grid-template-columns: 2fr 1fr 1fr 1.5fr; gap: var(--space-12); padding-bottom: var(--space-12); border-bottom: 1px solid rgba(255,255,255,0.08); margin-bottom: var(--space-8); }
.footer__brand p { color: rgba(255,255,255,0.55); font-size: var(--text-sm); line-height: 1.7; margin-top: var(--space-4); max-width: 36ch; }
.footer__col-title { font-size: var(--text-xs); font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; color: rgba(255,255,255,0.4); margin-bottom: var(--space-4); }
.footer__links { display: flex; flex-direction: column; gap: var(--space-3); }
.footer__link { font-size: var(--text-sm); color: rgba(255,255,255,0.6); text-decoration: none; font-weight: 500; transition: color var(--dur-fast) var(--ease-out); }
.footer__link:hover { color: var(--white); }
.footer__contact-item { display: flex; gap: var(--space-3); align-items: flex-start; font-size: var(--text-sm); color: rgba(255,255,255,0.6); margin-bottom: var(--space-3); }
.footer__contact-item svg { width: 16px; height: 16px; flex-shrink: 0; margin-top: 2px; color: var(--gold); }
.footer__bottom { max-width: var(--max-w); margin-inline: auto; display: flex; align-items: center; justify-content: space-between; gap: var(--space-4); flex-wrap: wrap; }
.footer__copy { font-size: var(--text-xs); color: rgba(255,255,255,0.35); }
.footer__legal { display: flex; gap: var(--space-6); }
.footer__legal a { font-size: var(--text-xs); color: rgba(255,255,255,0.35); text-decoration: none; transition: color var(--dur-fast) var(--ease-out); }
.footer__legal a:hover { color: rgba(255,255,255,0.7); }

/* ── Reveal animations ─────────────────────────────────────── */
.js-loaded .reveal { opacity: 0; transform: translateY(28px); transition: opacity var(--dur-slower) var(--ease-out), transform var(--dur-slower) var(--ease-out); }
.reveal.visible { opacity: 1; transform: translateY(0); }
.reveal--delay-1 { transition-delay: 80ms; }
.reveal--delay-2 { transition-delay: 160ms; }
.reveal--delay-3 { transition-delay: 240ms; }
.reveal--delay-4 { transition-delay: 320ms; }
.reveal--delay-5 { transition-delay: 400ms; }
.js-loaded .reveal-left { opacity: 0; transform: translateX(-32px); transition: opacity var(--dur-slower) var(--ease-out), transform var(--dur-slower) var(--ease-out); }
.reveal-left.visible { opacity: 1; transform: translateX(0); }
.js-loaded .reveal-scale { opacity: 0; transform: scale(0.95); transition: opacity var(--dur-slower) var(--ease-out), transform var(--dur-slower) var(--ease-out); }
.reveal-scale.visible { opacity: 1; transform: scale(1); }

/* ── Responsive ────────────────────────────────────────────── */
@media (max-width: 1024px) {
  .services-grid { grid-template-columns: repeat(2, 1fr); }
  .footer__grid  { grid-template-columns: 1fr 1fr; gap: var(--space-8); }
}
@media (max-width: 768px) {
  .hero__grid { grid-template-columns: 1fr; gap: var(--space-10); }
  .hero__right { display: none; }
  .hero__heading { font-size: clamp(2.4rem, 9vw, 3.5rem); }
  .split { grid-template-columns: 1fr; }
  .split--reverse .split__media, .split--reverse .split__text { order: 0; }
  .split__media { aspect-ratio: 16/9; }
  .services-grid { grid-template-columns: 1fr; }
  .cta-banner__content { flex-direction: column; text-align: center; }
  .cta-banner__actions { justify-content: center; }
  .footer__grid { grid-template-columns: 1fr; gap: var(--space-6); }
  .trust-bar__inner { justify-content: center; gap: var(--space-8); }
  .trust-divider { display: none; }
  .nav-links { display: none; }
  .nav-actions .btn { display: none; }
  .hamburger { display: flex; }
}
@media (max-width: 480px) {
  .hero__actions { flex-direction: column; align-items: flex-start; }
  .trust-bar__inner { flex-direction: column; align-items: flex-start; gap: var(--space-4); }
}
