/* ============================================================
   Essex Solar Films — Main Stylesheet
   Design system: dark theme, Montserrat + Open Sans
   ============================================================ */

/* ── Google Fonts ── */
@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@400;600;700;800&family=Open+Sans:wght@400;500;600&display=swap');

/* ── Design Tokens ── */
:root {
  /* Surfaces */
  --bg-primary:    #0A1118;
  --bg-surface:    #111D2A;
  --bg-elevated:   #162636;
  --border:        #1E3448;

  /* Text */
  --text-primary:  #E8F0F8;
  --text-secondary:#8CA0B4;
  --text-muted:    #5A6E82;

  /* Brand accents */
  --accent-cyan:   #6EDCDC;
  --accent-gold:   #F0C800;
  --ocean-teal:    #4A8FA8;
  --ice-blue:      #B4F0F0;

  /* Interactive */
  --cta-primary:   #2864B4;
  --cta-hover:     #3A7AD4;
  --success:       #34D399;
  --error:         #F87171;
  --warning:       #F59E0B;

  /* Deep brand */
  --brand-navy:    #0D2137;
  --deep-navy:     #0A1628;
  --midnight-blue: #142F4E;

  /* Typography */
  --font-heading:  'Montserrat', sans-serif;
  --font-body:     'Open Sans', sans-serif;

  /* Spacing */
  --section-pad:   6rem 3rem;
  --section-pad-sm:4rem 1.5rem;
  --max-width:     1200px;

  /* Radius */
  --r-sm:  6px;
  --r-md:  8px;
  --r-lg:  10px;
  --r-xl:  12px;
  --r-2xl: 14px;
  --r-3xl: 16px;

  /* Nav height */
  --nav-h: 72px;

  /* Transitions */
  --t-fast: 0.2s ease;
  --t-med:  0.35s cubic-bezier(0.4,0,0.2,1);
}

/* ── Reset ── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  background: var(--bg-primary);
  color: var(--text-primary);
  font-family: var(--font-body);
  font-size: 16px;
  line-height: 1.6;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}

/* Subtle noise texture overlay */
body::before {
  content: '';
  position: fixed;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.025'/%3E%3C/svg%3E");
  pointer-events: none;
  z-index: 9999;
}

img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
ul { list-style: none; }
button { font-family: inherit; cursor: pointer; border: none; background: none; }

/* Skip to content (accessibility) */
.skip-link {
  position: absolute;
  top: -100%;
  left: 1rem;
  padding: 0.75rem 1.5rem;
  background: var(--cta-primary);
  color: #fff;
  border-radius: 0 0 var(--r-md) var(--r-md);
  font-family: var(--font-heading);
  font-weight: 600;
  z-index: 10000;
  transition: top var(--t-fast);
}
.skip-link:focus { top: 0; }

/* Focus ring */
*:focus-visible {
  outline: 2px solid var(--accent-cyan);
  outline-offset: 3px;
  border-radius: 4px;
}

/* ── Navigation ── */
.site-nav {
  position: fixed;
  top: 0;
  width: 100%;
  height: var(--nav-h);
  z-index: 1000;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 3rem;
  background: rgba(10,17,24,0.6);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border-bottom: 1px solid transparent;
  transition: background var(--t-med), border-color var(--t-med);
}
.site-nav.scrolled {
  background: rgba(10,17,24,0.92);
  border-color: var(--border);
}

.nav-logo {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  flex-shrink: 0;
}
.nav-logo img {
  height: 36px;
  width: auto;
}

.nav-menu {
  display: flex;
  align-items: center;
  gap: 2rem;
}

.nav-links {
  display: flex;
  align-items: center;
  gap: 1.75rem;
}
.nav-links li { position: relative; }
.nav-links a {
  color: var(--text-secondary);
  font-size: 0.875rem;
  font-weight: 500;
  transition: color var(--t-fast);
  position: relative;
  padding-bottom: 2px;
  white-space: nowrap;
}
.nav-links a::after {
  content: '';
  position: absolute;
  bottom: -4px;
  left: 0;
  width: 0;
  height: 2px;
  background: var(--accent-cyan);
  transition: width 0.3s;
}
.nav-links a:hover,
.nav-links a.active { color: var(--text-primary); }
.nav-links a:hover::after,
.nav-links a.active::after { width: 100%; }

/* Solutions dropdown */
.has-dropdown > a {
  display: inline-flex;
  align-items: center;
  vertical-align: middle;
  gap: 0.25rem;
}
.has-dropdown > a::before {
  content: '';
  order: 2;
  flex-shrink: 0;
  width: 0;
  height: 0;
  border: 4px solid transparent;
  border-top-color: currentColor;
  transition: transform var(--t-fast);
}
.has-dropdown:hover > a::before { transform: rotate(180deg); }
/* Invisible bridge fills gap between nav item and dropdown panel */
.has-dropdown::after {
  content: '';
  position: absolute;
  top: 100%;
  left: -10px;
  right: -10px;
  height: 18px;
}
.dropdown {
  display: none;
  position: absolute;
  top: calc(100% + 12px);
  left: 50%;
  transform: translateX(-50%);
  min-width: 240px;
  background: var(--bg-elevated);
  border: 1px solid var(--border);
  border-radius: var(--r-xl);
  padding: 0.5rem;
  box-shadow: 0 20px 40px rgba(0,0,0,0.4);
}
.has-dropdown:hover .dropdown,
.has-dropdown:focus-within .dropdown { display: block; }
.dropdown a {
  display: block;
  padding: 0.625rem 1rem;
  font-size: 0.875rem;
  color: var(--text-secondary);
  border-radius: var(--r-md);
  transition: background var(--t-fast), color var(--t-fast);
}
.dropdown a::after { display: none; }
.dropdown a:hover { background: rgba(110,220,220,0.06); color: var(--accent-cyan); }

/* Nav CTA button */
.nav-cta {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  padding: 0.625rem 1.375rem;
  background: var(--cta-primary);
  color: #fff !important;
  border-radius: var(--r-lg);
  font-family: var(--font-heading);
  font-weight: 600;
  font-size: 0.875rem;
  white-space: nowrap;
  transition: background var(--t-fast), transform var(--t-fast), box-shadow var(--t-fast);
}
.nav-cta:hover {
  background: var(--cta-hover);
  transform: translateY(-1px);
  box-shadow: 0 4px 20px rgba(40,100,180,0.35);
}
.nav-cta::after { display: none !important; }

/* Hamburger */
.nav-hamburger {
  display: none;
  flex-direction: column;
  justify-content: space-between;
  width: 24px;
  height: 18px;
  cursor: pointer;
}
.nav-hamburger span {
  display: block;
  height: 2px;
  background: var(--text-primary);
  border-radius: 2px;
  transition: transform 0.3s, opacity 0.3s;
  transform-origin: center;
}
.nav-hamburger.open span:nth-child(1) { transform: translateY(8px) rotate(45deg); }
.nav-hamburger.open span:nth-child(2) { opacity: 0; }
.nav-hamburger.open span:nth-child(3) { transform: translateY(-8px) rotate(-45deg); }

/* Mobile nav overlay */
.mobile-nav {
  display: none;
  position: fixed;
  top: var(--nav-h);
  left: 0;
  right: 0;
  bottom: 0;
  background: var(--bg-primary);
  border-top: 1px solid var(--border);
  padding: 2rem 1.5rem;
  overflow-y: auto;
  z-index: 999;
  flex-direction: column;
  gap: 0.25rem;
}
.mobile-nav.open { display: flex; }
.mobile-nav a {
  display: block;
  padding: 0.875rem 1rem;
  color: var(--text-secondary);
  font-size: 1rem;
  font-weight: 500;
  border-radius: var(--r-md);
  border-bottom: 1px solid var(--border);
  transition: color var(--t-fast), background var(--t-fast);
}
.mobile-nav a:hover { color: var(--accent-cyan); background: rgba(110,220,220,0.04); }
.mobile-nav .mobile-section-label {
  font-family: var(--font-heading);
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  padding: 1.25rem 1rem 0.375rem;
}
.mobile-nav .mobile-cta {
  margin-top: 1.5rem;
  display: block;
  padding: 1rem;
  background: var(--cta-primary);
  color: #fff;
  text-align: center;
  border-radius: var(--r-lg);
  font-family: var(--font-heading);
  font-weight: 600;
  border-bottom: none;
}
.mobile-nav .mobile-cta:hover { background: var(--cta-hover); }

/* ── Buttons ── */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 1rem 2rem;
  border-radius: var(--r-lg);
  font-family: var(--font-heading);
  font-weight: 600;
  font-size: 1rem;
  cursor: pointer;
  transition: transform var(--t-fast), box-shadow var(--t-fast), background var(--t-fast), border-color var(--t-fast);
  white-space: nowrap;
}
.btn:hover { transform: translateY(-2px); }

.btn-primary {
  background: var(--cta-primary);
  color: #fff;
  border: none;
}
.btn-primary:hover {
  background: var(--cta-hover);
  box-shadow: 0 8px 28px rgba(40,100,180,0.35);
}

.btn-secondary {
  background: transparent;
  color: var(--accent-cyan);
  border: 1.5px solid rgba(110,220,220,0.3);
}
.btn-secondary:hover {
  border-color: var(--accent-cyan);
  background: rgba(110,220,220,0.06);
}

.btn-gold {
  background: var(--accent-gold);
  color: var(--deep-navy);
  border: none;
  font-weight: 700;
}
.btn-gold:hover {
  background: #FFD426;
  box-shadow: 0 8px 28px rgba(240,200,0,0.2);
}

.btn-ghost {
  background: transparent;
  color: var(--text-secondary);
  border: 1px solid var(--border);
}
.btn-ghost:hover {
  color: var(--text-primary);
  border-color: var(--text-secondary);
  background: rgba(255,255,255,0.03);
}

.btn-sm { padding: 0.625rem 1.25rem; font-size: 0.875rem; }
.btn-lg { padding: 1.125rem 2.5rem; font-size: 1.0625rem; }

/* ── Layout Utilities ── */
.container {
  max-width: var(--max-width);
  margin-inline: auto;
  padding-inline: 3rem;
}
section { padding: var(--section-pad); }

.section-label {
  display: inline-flex;
  align-items: center;
  gap: 0.75rem;
  font-family: var(--font-heading);
  font-weight: 600;
  font-size: 0.75rem;
  color: var(--accent-cyan);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  margin-bottom: 1rem;
}
.section-label::before {
  content: '';
  width: 28px;
  height: 2px;
  background: var(--accent-cyan);
  flex-shrink: 0;
}

.section-title {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: clamp(1.75rem, 4vw, 2.625rem);
  line-height: 1.15;
  letter-spacing: -0.02em;
  margin-bottom: 1rem;
}

.section-desc {
  color: var(--text-secondary);
  font-size: 1.0625rem;
  max-width: 560px;
  line-height: 1.7;
  margin-bottom: 3rem;
}

.text-cyan  { color: var(--accent-cyan); }
.text-gold  { color: var(--accent-gold); }
.gradient-text {
  background: linear-gradient(135deg, var(--accent-cyan), var(--ocean-teal));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* ── Hero Sections ── */
.hero {
  min-height: 100vh;
  display: flex;
  align-items: center;
  padding: calc(var(--nav-h) + 5rem) 3rem 5rem;
  position: relative;
  overflow: hidden;
}

/* Decorative glows */
.hero::before {
  content: '';
  position: absolute;
  top: -200px; right: -200px;
  width: 700px; height: 700px;
  background: radial-gradient(circle, rgba(110,220,220,0.055) 0%, transparent 70%);
  pointer-events: none;
}
.hero::after {
  content: '';
  position: absolute;
  bottom: -100px; left: -150px;
  width: 500px; height: 500px;
  background: radial-gradient(circle, rgba(40,100,180,0.045) 0%, transparent 70%);
  pointer-events: none;
}

.hero-inner {
  max-width: var(--max-width);
  margin-inline: auto;
  width: 100%;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4rem;
  align-items: center;
  position: relative;
  z-index: 2;
}

.hero-content { max-width: 600px; }

.hero-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.375rem 1rem;
  background: rgba(110,220,220,0.08);
  border: 1px solid rgba(110,220,220,0.18);
  border-radius: 100px;
  font-size: 0.8125rem;
  font-weight: 500;
  color: var(--accent-cyan);
  margin-bottom: 1.75rem;
}
.hero-badge-dot {
  width: 6px; height: 6px;
  background: var(--accent-cyan);
  border-radius: 50%;
  animation: pulse-dot 2s infinite;
}
@keyframes pulse-dot {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.35; }
}

.hero h1 {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: clamp(2.25rem, 5vw, 3.5rem);
  line-height: 1.1;
  letter-spacing: -0.025em;
  margin-bottom: 1.5rem;
}

.hero-lead {
  color: var(--text-secondary);
  font-size: 1.125rem;
  line-height: 1.75;
  margin-bottom: 2.5rem;
  max-width: 520px;
}

.hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  align-items: center;
  margin-bottom: 2rem;
}

.hero-trust {
  font-size: 0.8125rem;
  color: var(--text-muted);
}
.hero-trust span { color: var(--accent-cyan); }

/* Hero visual placeholder */
.hero-visual {
  width: 100%;
  aspect-ratio: 4/3;
  background: linear-gradient(135deg, var(--bg-surface), var(--bg-elevated));
  border: 1px solid var(--border);
  border-radius: var(--r-3xl);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 1rem;
  position: relative;
  overflow: hidden;
}
.hero-visual::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(110,220,220,0.03), rgba(40,100,180,0.04));
}
.hero-visual-label {
  font-size: 0.8125rem;
  color: var(--text-muted);
  position: relative;
  z-index: 1;
  text-align: center;
  padding: 0 1rem;
}
.hero-visual-icon {
  width: 64px; height: 64px;
  border: 2px solid var(--border);
  border-radius: var(--r-xl);
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: 1fr 1fr;
  gap: 4px;
  padding: 8px;
  position: relative;
  z-index: 1;
}
.hero-visual-icon span { border-radius: 3px; }
.hero-visual-icon span:nth-child(1) { background: rgba(110,220,220,0.18); }
.hero-visual-icon span:nth-child(2) { background: rgba(110,220,220,0.09); }
.hero-visual-icon span:nth-child(3) { background: rgba(74,143,168,0.22); }
.hero-visual-icon span:nth-child(4) { background: rgba(40,100,180,0.18); }

/* Sub-page hero (shorter) */
.hero-sub {
  min-height: 50vh;
  padding: calc(var(--nav-h) + 4rem) 3rem 4rem;
}
.hero-sub .hero-inner {
  grid-template-columns: 1fr;
  max-width: 800px;
  justify-items: start;
}

/* Page intro variants */
.page-intro {
  min-height: auto;
  padding: calc(var(--nav-h) + 3.5rem) 3rem 3.5rem;
}
.page-intro .hero-inner {
  max-width: var(--max-width);
  align-items: stretch;
  gap: 2rem;
}
.page-intro p:last-child,
.page-intro ul:last-child { margin-bottom: 0; }

.page-intro .hero-content {
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
}

.page-intro .hero-badge {
  align-self: flex-start;
}

.contact-page-start {
  padding-top: calc(var(--nav-h) + 3rem);
}

.page-intro-about .hero-inner,
.page-intro-solutions .hero-inner,
.page-intro-audience .hero-inner,
.page-intro-detail .hero-inner {
  grid-template-columns: minmax(0, 1.15fr) minmax(280px, 0.85fr);
}

.page-intro-faq .hero-inner {
  grid-template-columns: minmax(0, 1fr) minmax(300px, 0.9fr);
}

.intro-panel {
  background: linear-gradient(180deg, rgba(16,26,35,0.88), rgba(11,18,24,0.98));
  border: 1px solid var(--border);
  border-radius: var(--r-2xl);
  padding: 1.5rem;
  box-shadow: 0 24px 50px rgba(0,0,0,0.24);
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
}

.page-intro-about {
  min-height: 58vh;
}

.page-intro-about .hero-content {
  max-width: 640px;
}

.page-intro-about .intro-panel {
  background: linear-gradient(180deg, rgba(17,31,40,0.9), rgba(12,22,30,0.98));
  border-color: rgba(110,220,220,0.16);
}

.page-intro-about .intro-panel::before,
.page-intro-faq .intro-panel::before,
.page-intro-solutions .intro-panel::before,
.page-intro-audience .intro-panel::before,
.page-intro-detail .intro-panel::before {
  content: '';
  display: block;
  width: 4rem;
  height: 2px;
  margin-bottom: 1.1rem;
  background: linear-gradient(90deg, var(--accent-cyan), transparent);
}

.page-intro-faq {
  min-height: 52vh;
}

.page-intro-faq .hero-content {
  max-width: 680px;
}

.page-intro-faq .intro-panel {
  padding: 1.35rem;
  background: rgba(14,24,32,0.92);
}

.page-intro-faq .intro-link-list {
  gap: 0.625rem;
}

.page-intro-solutions .hero-content {
  max-width: 620px;
}

.page-intro-solutions .intro-panel {
  background: linear-gradient(180deg, rgba(13,24,33,0.9), rgba(10,18,26,0.98));
}

.page-intro-solutions .intro-link-list a {
  padding-block: 1rem;
}

.page-intro-audience {
  min-height: 56vh;
}

.page-intro-audience .hero-content {
  max-width: 630px;
}

.page-intro-audience .intro-panel {
  padding: 1.6rem;
  background: linear-gradient(180deg, rgba(14,25,34,0.9), rgba(12,21,29,0.98));
}

.page-intro-audience .intro-proof {
  gap: 0.75rem;
}

.page-intro-audience .intro-proof-item {
  background: rgba(255,255,255,0.03);
}

.page-intro-detail {
  min-height: 54vh;
}

.page-intro-detail .hero-inner {
  grid-template-columns: minmax(0, 1.2fr) minmax(260px, 0.8fr);
  gap: 2.5rem;
}

.page-intro-detail .hero-content {
  max-width: 600px;
}

.page-intro-detail .intro-panel {
  padding: 1.35rem;
  background: rgba(13,22,30,0.94);
}

.page-intro-detail .intro-bullet-list {
  gap: 0.65rem;
}

.page-intro-detail .intro-bullet-list li {
  padding: 0.85rem 0.95rem;
}

.intro-panel-title {
  font-family: var(--font-heading);
  font-size: 1rem;
  font-weight: 700;
  margin-bottom: 0.9rem;
}

.intro-stat-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0.875rem;
  margin-top: 1.75rem;
}

.intro-stat {
  padding: 1rem 1.1rem;
  border-radius: var(--r-xl);
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(110,220,220,0.12);
}

.intro-stat strong {
  display: block;
  font-family: var(--font-heading);
  font-size: 1.45rem;
  line-height: 1;
  color: var(--text-primary);
  margin-bottom: 0.35rem;
}

.intro-stat span {
  color: var(--text-secondary);
  font-size: 0.875rem;
  line-height: 1.5;
}

.intro-checklist,
.intro-link-list,
.intro-chip-list,
.intro-bullet-list {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.intro-checklist li,
.intro-link-list a,
.intro-bullet-list li {
  border: 1px solid rgba(110,220,220,0.14);
  border-radius: var(--r-xl);
  background: rgba(255,255,255,0.025);
}

.intro-checklist li,
.intro-bullet-list li {
  list-style: none;
  padding: 0.9rem 1rem;
  color: var(--text-secondary);
  line-height: 1.6;
}

.intro-checklist li strong,
.intro-bullet-list li strong {
  color: var(--text-primary);
}

.intro-checklist li {
  display: flex;
  gap: 0.75rem;
  align-items: flex-start;
}

.intro-check {
  width: 1.4rem;
  height: 1.4rem;
  border-radius: 999px;
  flex: 0 0 auto;
  margin-top: 0.1rem;
  border: 1px solid rgba(110,220,220,0.3);
  background: rgba(110,220,220,0.08);
  position: relative;
}

.intro-check::before {
  content: '';
  position: absolute;
  inset: 0;
  margin: auto;
  width: 0.45rem;
  height: 0.45rem;
  border-radius: 999px;
  background: var(--accent-cyan);
}

.intro-chip-list {
  flex-direction: row;
  flex-wrap: wrap;
  margin-top: 1.5rem;
}

.intro-chip {
  display: inline-flex;
  align-items: center;
  padding: 0.55rem 0.9rem;
  border-radius: 999px;
  border: 1px solid rgba(110,220,220,0.18);
  background: rgba(255,255,255,0.03);
  color: var(--text-secondary);
  font-size: 0.8125rem;
  line-height: 1.4;
}

.intro-link-list a {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  padding: 0.95rem 1rem;
  color: var(--text-primary);
  transition: border-color var(--t-fast), background var(--t-fast), transform var(--t-fast);
}

.intro-link-list a span:last-child {
  color: var(--accent-cyan);
  white-space: nowrap;
}

.intro-link-list a:hover {
  border-color: rgba(110,220,220,0.28);
  background: rgba(110,220,220,0.05);
  transform: translateY(-1px);
}

.intro-mini-label {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--text-muted);
  margin-bottom: 1rem;
}

.intro-mini-label::before {
  content: '';
  width: 0.55rem;
  height: 0.55rem;
  border-radius: 999px;
  background: var(--accent-cyan);
  box-shadow: 0 0 0 6px rgba(110,220,220,0.08);
}

.intro-summary {
  color: var(--text-secondary);
  font-size: 0.9375rem;
  line-height: 1.7;
  margin-top: 1rem;
}

.intro-quick-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0.875rem;
  margin-top: 1.5rem;
}

.intro-quick-card {
  border: 1px solid rgba(110,220,220,0.14);
  border-radius: var(--r-xl);
  background: rgba(255,255,255,0.025);
  padding: 1rem;
}

.intro-quick-card h3 {
  font-family: var(--font-heading);
  font-size: 0.95rem;
  margin-bottom: 0.35rem;
}

.intro-quick-card p {
  color: var(--text-secondary);
  font-size: 0.85rem;
  line-height: 1.6;
}

.intro-faq-jump {
  margin-top: 1.5rem;
}

.intro-faq-jump a {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  color: var(--accent-cyan);
  font-weight: 600;
}

.intro-proof {
  display: grid;
  gap: 0.875rem;
  margin-top: 1.5rem;
}

.intro-proof-item {
  padding: 1rem 1.1rem;
  border-radius: var(--r-xl);
  border: 1px solid rgba(110,220,220,0.14);
  background: rgba(255,255,255,0.025);
}

.intro-proof-item strong {
  display: block;
  font-family: var(--font-heading);
  margin-bottom: 0.35rem;
}

.intro-proof-item span {
  color: var(--text-secondary);
  font-size: 0.875rem;
  line-height: 1.6;
}

/* ── Stats / Trust Strip ── */
.trust-strip {
  padding: 2rem 3rem 0;
  margin-top: 0;
  position: relative;
  z-index: 5;
}
.trust-strip + section {
  padding-top: 2.5rem;
}
.trust-strip-inner {
  max-width: var(--max-width);
  margin-inline: auto;
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--r-2xl);
  overflow: hidden;
  box-shadow: 0 20px 40px rgba(0,0,0,0.25);
}
.trust-item {
  padding: 1.75rem 1.5rem;
  text-align: center;
  border-right: 1px solid var(--border);
  transition: background var(--t-fast);
}
.trust-item:last-child { border-right: none; }
.trust-item:hover { background: var(--bg-elevated); }
.trust-icon {
  font-size: 1.5rem;
  margin-bottom: 0.5rem;
  line-height: 1;
}
.trust-title {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 0.875rem;
  margin-bottom: 0.25rem;
  color: var(--accent-cyan);
}
.trust-desc {
  font-size: 0.75rem;
  color: var(--text-muted);
  line-height: 1.4;
}

/* ── Cards ── */
.card {
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--r-2xl);
  padding: 2rem 1.5rem;
  transition: border-color var(--t-med), transform var(--t-med), box-shadow var(--t-med);
  position: relative;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}
.card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: var(--accent-cyan);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--t-med);
}
.card:hover { border-color: rgba(110,220,220,0.2); transform: translateY(-4px); box-shadow: 0 20px 40px rgba(0,0,0,0.3); }
.card:hover::before { transform: scaleX(1); }

.card-icon {
  width: 52px; height: 52px;
  border-radius: var(--r-xl);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 1.25rem;
  font-size: 1.375rem;
  background: rgba(110,220,220,0.09);
}

.card h3 {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 1.0625rem;
  margin-bottom: 0.625rem;
}

.card p {
  color: var(--text-secondary);
  font-size: 0.875rem;
  line-height: 1.65;
  margin-bottom: 0;
  flex: 1;
}

.card-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  align-self: center;
  margin-top: 1.5rem;
  padding: 0.5rem 1.25rem;
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--accent-cyan);
  border: 1.5px solid rgba(110,220,220,0.3);
  border-radius: var(--r-xl);
  transition: border-color var(--t-fast), background var(--t-fast), transform var(--t-fast);
  white-space: nowrap;
}
.card-link:hover {
  border-color: var(--accent-cyan);
  background: rgba(110,220,220,0.06);
  transform: translateY(-1px);
}

/* Solutions grid */
.solutions-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.25rem;
}
.solutions-grid .card:nth-child(4),
.solutions-grid .card:nth-child(5) {
  grid-column: span 1;
}
/* Centre last two if 5 items */
@supports (grid-template-columns: subgrid) {
  /* Modern browsers: handled by grid auto-placement */
}

/* Generic grid */
.grid-2 { display: grid; grid-template-columns: repeat(2,1fr); gap: 1.25rem; }
.grid-3 { display: grid; grid-template-columns: repeat(3,1fr); gap: 1.25rem; }
.grid-4 { display: grid; grid-template-columns: repeat(4,1fr); gap: 1.25rem; }

/* ── Surface Sections ── */
.section-surface {
  background: var(--bg-surface);
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}
.section-elevated { background: var(--bg-elevated); }

/* ── Benefits List ── */
.benefits-list {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  margin-bottom: 2rem;
}
.benefit-item {
  display: flex;
  align-items: flex-start;
  gap: 0.875rem;
  padding: 1rem 1.25rem;
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--r-xl);
  transition: border-color var(--t-fast);
}
.benefit-item:hover { border-color: rgba(110,220,220,0.2); }
.benefit-check {
  width: 20px; height: 20px;
  border-radius: 50%;
  background: rgba(110,220,220,0.12);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  margin-top: 1px;
}
.benefit-check::before {
  content: '';
  width: 7px; height: 7px;
  background: var(--accent-cyan);
  border-radius: 50%;
}
.benefit-item span { font-size: 0.9375rem; color: var(--text-secondary); line-height: 1.5; }

/* ── Use Cases Split ── */
.use-cases-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.5rem;
  margin-bottom: 2rem;
}
.use-case-card {
  background: var(--bg-elevated);
  border: 1px solid var(--border);
  border-radius: var(--r-2xl);
  padding: 1.75rem;
}
.use-case-card h4 {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 0.875rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--accent-cyan);
  margin-bottom: 0.75rem;
}
.use-case-card ul { display: flex; flex-direction: column; gap: 0.5rem; }
.use-case-card li {
  font-size: 0.875rem;
  color: var(--text-secondary);
  padding-left: 1rem;
  position: relative;
}
.use-case-card li::before {
  content: '';
  position: absolute;
  left: 0; top: 50%;
  transform: translateY(-50%);
  width: 5px; height: 5px;
  border-radius: 50%;
  background: var(--ocean-teal);
  opacity: 0.7;
}

/* ── Coverage Map Section ── */
.coverage-map-section {
  display: grid;
  grid-template-columns: 1fr 1.4fr;
  gap: 3rem;
  align-items: start;
  margin-top: 2.5rem;
}
.coverage-map-section--sm {
  grid-template-columns: 180px 1fr;
  gap: 2rem;
  max-width: 820px;
}
.uk-map-wrap { position: relative; }
.uk-map-svg { width: 100%; height: auto; display: block; }

@keyframes pin-ping {
  0%   { r: 3; opacity: 0.7; }
  100% { r: 15; opacity: 0; }
}
.map-pin-ring {
  animation: pin-ping 2.8s ease-out infinite;
  transform-box: fill-box;
  transform-origin: center;
}
.map-pin-ring--national { animation-duration: 3.5s; }

.map-key {
  display: flex;
  gap: 1.25rem;
  margin-top: 0.875rem;
  justify-content: center;
}
.map-key-item {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  font-size: 0.8rem;
  color: var(--text-muted);
}
.map-key-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
}
.map-key-dot--primary { background: #6EDCDC; }
.map-key-dot--national { background: #2864B4; }

/* Coverage area lists */
.coverage-areas {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 1rem;
}
.coverage-area {
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--r-xl);
  padding: 1.125rem 1.25rem;
}
.coverage-area--national {
  grid-column: 1 / -1;
  background: rgba(40,100,180,0.05);
  border-color: rgba(40,100,180,0.2);
}
.coverage-area-hd {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin-bottom: 0.75rem;
}
.coverage-area-hd h3 {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 0.9375rem;
  color: var(--text-primary);
}
.coverage-pin {
  width: 9px;
  height: 9px;
  border-radius: 50%;
  flex-shrink: 0;
}
.coverage-pin--primary { background: #6EDCDC; box-shadow: 0 0 6px rgba(110,220,220,0.5); }
.coverage-pin--national { background: #2864B4; box-shadow: 0 0 6px rgba(40,100,180,0.5); }
.coverage-towns {
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  gap: 0.3rem;
}
.coverage-towns li {
  font-size: 0.78rem;
  color: var(--text-secondary);
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.07);
  border-radius: var(--r-sm);
  padding: 0.2rem 0.55rem;
}
.coverage-national-note {
  color: var(--text-secondary);
  font-size: 0.875rem;
  line-height: 1.6;
}
.coverage-footnote {
  font-size: 0.8125rem;
  color: var(--text-muted);
  margin-top: 1.25rem;
}

/* ── CTA Panel ── */
.cta-panel {
  padding: 5rem 3rem;
  background: linear-gradient(135deg, var(--brand-navy), var(--bg-elevated));
  text-align: center;
  position: relative;
  overflow: hidden;
}
.cta-panel::before {
  content: '';
  position: absolute;
  top: -60%; left: -10%;
  width: 55%; height: 220%;
  background: radial-gradient(ellipse, rgba(110,220,220,0.045) 0%, transparent 70%);
  pointer-events: none;
}
.cta-panel::after {
  content: '';
  position: absolute;
  bottom: -60%; right: -10%;
  width: 55%; height: 220%;
  background: radial-gradient(ellipse, rgba(240,200,0,0.025) 0%, transparent 70%);
  pointer-events: none;
}
.cta-panel-inner { position: relative; z-index: 2; }
.cta-panel h2 {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: clamp(1.75rem, 3.5vw, 2.375rem);
  margin-bottom: 0.75rem;
}
.cta-panel p {
  color: var(--text-secondary);
  font-size: 1.0625rem;
  margin-bottom: 2rem;
  max-width: 560px;
  margin-inline: auto;
  line-height: 1.7;
}
.cta-panel-actions {
  display: flex;
  gap: 1rem;
  justify-content: center;
  flex-wrap: wrap;
}

/* ── Affordability Section ── */
.affordability-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4rem;
  align-items: center;
}
.affordability-copy h2 {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: clamp(1.75rem, 3vw, 2.25rem);
  line-height: 1.2;
  margin-bottom: 1.25rem;
}
.affordability-copy p {
  color: var(--text-secondary);
  font-size: 1rem;
  line-height: 1.75;
  margin-bottom: 1.25rem;
}
.affordability-visual {
  background: var(--bg-elevated);
  border: 1px solid var(--border);
  border-radius: var(--r-2xl);
  padding: 2rem;
}
.affordability-item {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 0.875rem 0;
  border-bottom: 1px solid var(--border);
}
.affordability-item:last-child { border-bottom: none; }
.aff-bar-wrap {
  flex: 1;
  height: 8px;
  background: var(--bg-primary);
  border-radius: 4px;
  overflow: hidden;
}
.aff-bar {
  height: 100%;
  border-radius: 4px;
  background: linear-gradient(90deg, var(--accent-cyan), var(--ocean-teal));
}
.aff-label { font-size: 0.8125rem; color: var(--text-secondary); min-width: 120px; }
.aff-value { font-family: var(--font-heading); font-weight: 700; font-size: 0.875rem; color: var(--text-primary); min-width: 60px; text-align: right; }

/* ── Audience Split (Home) ── */
.audience-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.5rem;
}
.audience-card {
  background: var(--bg-elevated);
  border: 1px solid var(--border);
  border-radius: var(--r-2xl);
  padding: 2.5rem;
  transition: border-color var(--t-med), transform var(--t-med);
  display: flex;
  flex-direction: column;
}
.audience-card:hover { border-color: rgba(110,220,220,0.2); transform: translateY(-3px); }
.audience-card-icon { font-size: 2.5rem; margin-bottom: 1rem; }
.audience-card h3 {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: 1.25rem;
  margin-bottom: 0.75rem;
}
.audience-card p {
  color: var(--text-secondary);
  font-size: 0.9375rem;
  line-height: 1.7;
  margin-bottom: 0;
  flex: 1;
}
.audience-card .btn { margin-top: 1.5rem; width: 100%; justify-content: center; }

/* ── Sectors List ── */
.sectors-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  margin-bottom: 2rem;
}
.sector-tag {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.625rem 1.125rem;
  background: var(--bg-elevated);
  border: 1px solid var(--border);
  border-radius: 100px;
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--text-secondary);
  transition: border-color var(--t-fast), color var(--t-fast);
}
.sector-tag:hover { border-color: rgba(110,220,220,0.3); color: var(--accent-cyan); }
.sector-tag::before {
  content: '';
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--accent-cyan);
  opacity: 0.5;
}

/* ── Features Grid (replaces sector tag cloud) ── */
.features-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  overflow: hidden;
  margin-top: 2.5rem;
}
.feature-cell {
  padding: 1.75rem;
  border-right: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  transition: background var(--t-fast);
}
.feature-cell:nth-child(3n) { border-right: none; }
.feature-cell:hover { background: rgba(110,220,220,0.04); }
.feature-cell-icon {
  width: 1.25rem;
  height: 1.25rem;
  color: var(--accent-cyan);
  margin-bottom: 0.75rem;
  flex-shrink: 0;
}
.feature-cell-header {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin-bottom: 0.5rem;
}
.feature-cell h3 {
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--text-primary);
  margin: 0;
}
.feature-cell p {
  font-size: 0.8rem;
  color: var(--text-secondary);
  line-height: 1.6;
  margin: 0;
}
.features-grid--5col { grid-template-columns: repeat(5, 1fr); }
.features-grid--5col .feature-cell:nth-child(3n) { border-right: 1px solid var(--border); }
.features-grid--5col .feature-cell:nth-child(5n) { border-right: none; }

@media (max-width: 768px) {
  .features-grid { grid-template-columns: repeat(2, 1fr); }
  .feature-cell:nth-child(3n) { border-right: 1px solid var(--border); }
  .feature-cell:nth-child(2n) { border-right: none; }
  .features-grid--5col { grid-template-columns: repeat(2, 1fr); }
  .features-grid--5col .feature-cell:nth-child(5n) { border-right: 1px solid var(--border); }
  .features-grid--5col .feature-cell:nth-child(2n) { border-right: none; }
}
@media (max-width: 480px) {
  .features-grid { grid-template-columns: 1fr; }
  .feature-cell:nth-child(2n) { border-right: none; }
  .feature-cell { border-right: none; }
  .features-grid--5col { grid-template-columns: 1fr; }
}

/* ── FAQ Accordion ── */
.faq-list {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  max-width: 800px;
}
.faq-item {
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--r-xl);
  overflow: hidden;
  transition: border-color var(--t-fast);
}
.faq-item.open { border-color: rgba(110,220,220,0.25); }
.faq-question {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 1.25rem 1.5rem;
  background: none;
  color: var(--text-primary);
  font-family: var(--font-heading);
  font-weight: 600;
  font-size: 1rem;
  text-align: left;
  cursor: pointer;
  transition: color var(--t-fast);
}
.faq-question:hover { color: var(--accent-cyan); }
.faq-chevron {
  width: 20px; height: 20px;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}
.faq-chevron::before {
  content: '';
  border: 5px solid transparent;
  border-top-color: currentColor;
  margin-top: 4px;
  transition: transform 0.3s;
}
.faq-item.open .faq-chevron::before { transform: rotate(180deg); margin-top: -4px; }
.faq-answer {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.4s ease, padding 0.3s ease;
}
.faq-item.open .faq-answer { max-height: 400px; }
.faq-answer-inner {
  padding: 0 1.5rem 1.25rem;
  color: var(--text-secondary);
  font-size: 0.9375rem;
  line-height: 1.75;
  border-top: 1px solid var(--border);
  padding-top: 1rem;
}

/* ── Contact Form ── */
.contact-grid-layout {
  display: grid;
  grid-template-columns: 3fr 2fr;
  gap: 4rem;
  align-items: start;
}
.form-group { margin-bottom: 1.25rem; }
.form-group label {
  display: block;
  font-family: var(--font-heading);
  font-weight: 600;
  font-size: 0.8125rem;
  color: var(--text-primary);
  margin-bottom: 0.5rem;
}
.form-group input,
.form-group select,
.form-group textarea {
  width: 100%;
  padding: 0.875rem 1.125rem;
  background: var(--bg-elevated);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  color: var(--text-primary);
  font-family: var(--font-body);
  font-size: 0.9375rem;
  transition: border-color var(--t-fast), box-shadow var(--t-fast);
  outline: none;
  -webkit-appearance: none;
}
.form-group input::placeholder,
.form-group textarea::placeholder { color: var(--text-muted); }
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
  border-color: var(--accent-cyan);
  box-shadow: 0 0 0 3px rgba(110,220,220,0.1);
}
.form-group textarea { resize: vertical; min-height: 120px; }
.form-group select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' fill='%235A6E82' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 1rem center;
  padding-right: 2.5rem;
  cursor: pointer;
}
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.form-note { font-size: 0.8125rem; color: var(--text-muted); margin-top: 0.5rem; }
.form-success, .form-error {
  padding: 1rem 1.25rem;
  border-radius: var(--r-md);
  font-size: 0.9375rem;
  font-weight: 500;
  margin-bottom: 1.25rem;
  display: none;
}
.form-success { background: rgba(52,211,153,0.1); border: 1px solid rgba(52,211,153,0.25); color: var(--success); }
.form-error   { background: rgba(248,113,113,0.1); border: 1px solid rgba(248,113,113,0.25); color: var(--error); }

.contact-info-block { display: flex; flex-direction: column; gap: 0.75rem; }
.contact-detail-item {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 1rem 1.25rem;
  background: var(--bg-elevated);
  border: 1px solid var(--border);
  border-radius: var(--r-xl);
  transition: border-color var(--t-fast);
}
.contact-detail-item:hover { border-color: rgba(110,220,220,0.2); }
.contact-detail-icon {
  width: 40px; height: 40px;
  background: rgba(110,220,220,0.08);
  border-radius: var(--r-lg);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.125rem;
  flex-shrink: 0;
}
.contact-detail-icon svg {
  width: 18px;
  height: 18px;
}
.contact-detail-icon--whatsapp {
  color: #25D366;
}
.contact-detail-label {
  font-size: 0.6875rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  color: var(--text-muted);
  margin-bottom: 0.125rem;
}
.contact-detail-value { font-size: 0.9375rem; font-weight: 500; }
.contact-detail-value a { color: var(--accent-cyan); transition: opacity var(--t-fast); }
.contact-detail-value a:hover { opacity: 0.8; }

.contact-coverage-card {
  margin-top: 2rem;
  padding: 1.5rem;
  background: linear-gradient(135deg, rgba(17,29,42,0.92), rgba(20,38,57,0.9));
  border: 1px solid var(--border);
  border-radius: var(--r-2xl);
}

.contact-coverage-head {
  display: grid;
  grid-template-columns: minmax(0, 280px) 1fr;
  gap: 1.5rem;
  align-items: end;
  margin-bottom: 1.5rem;
}

.contact-coverage-head .section-label {
  margin-bottom: 0.75rem;
}

.contact-coverage-head h3 {
  font-family: var(--font-heading);
  font-size: 1.625rem;
  line-height: 1.1;
}

.contact-coverage-head p {
  color: var(--text-secondary);
  font-size: 0.9375rem;
  line-height: 1.7;
  max-width: 640px;
}

.contact-coverage-areas {
  grid-template-columns: repeat(4, 1fr);
}

/* ── Gallery Coming Soon ── */
.coming-soon-container {
  text-align: center;
  padding: 5rem 2rem;
  max-width: 600px;
  margin-inline: auto;
}
.coming-soon-icon {
  font-size: 4rem;
  margin-bottom: 1.5rem;
  opacity: 0.6;
}
.coming-soon-container h2 {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: 2rem;
  margin-bottom: 1rem;
}
.coming-soon-container p { color: var(--text-secondary); font-size: 1rem; line-height: 1.7; margin-bottom: 2rem; }
.coming-soon-filter-preview {
  display: flex;
  gap: 0.5rem;
  justify-content: center;
  flex-wrap: wrap;
  margin-bottom: 2.5rem;
  opacity: 0.35;
}
.filter-pill {
  padding: 0.375rem 0.875rem;
  border: 1px solid var(--border);
  border-radius: 100px;
  font-size: 0.8125rem;
  color: var(--text-muted);
  cursor: default;
}

/* ── Values List ── */
.values-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.25rem;
}
.value-item {
  padding: 1.75rem;
  background: var(--bg-elevated);
  border: 1px solid var(--border);
  border-radius: var(--r-2xl);
  transition: border-color var(--t-fast), transform var(--t-fast);
}
.value-item:hover { border-color: rgba(110,220,220,0.2); transform: translateX(3px); }
.value-item h4 {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 0.9375rem;
  margin-bottom: 0.5rem;
  color: var(--accent-cyan);
}
.value-item p { color: var(--text-secondary); font-size: 0.875rem; line-height: 1.6; }

/* ── Footer ── */
.site-footer {
  background: var(--bg-primary);
  border-top: 1px solid var(--border);
  padding: 4rem 3rem 2rem;
}
.footer-inner {
  max-width: var(--max-width);
  margin-inline: auto;
}
.footer-grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1.2fr;
  gap: 3rem;
  margin-bottom: 3rem;
}
.footer-brand-logo { margin-bottom: 1rem; }
.footer-brand-logo img { height: 32px; width: auto; }
.footer-brand p {
  color: var(--text-secondary);
  font-size: 0.875rem;
  line-height: 1.65;
  max-width: 300px;
  margin-bottom: 1.25rem;
}
.footer-cta-inline {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  padding: 0.625rem 1.25rem;
  background: var(--cta-primary);
  color: #fff;
  border-radius: var(--r-lg);
  font-family: var(--font-heading);
  font-weight: 600;
  font-size: 0.8125rem;
  transition: background var(--t-fast), transform var(--t-fast);
}
.footer-cta-group {
  display: flex;
  gap: 0.75rem;
  flex-wrap: wrap;
}
.footer-cta-inline:hover { background: var(--cta-hover); transform: translateY(-1px); }
.footer-cta-inline--secondary {
  background: transparent;
  color: var(--accent-cyan);
  border: 1px solid rgba(110,220,220,0.3);
}
.footer-cta-inline--secondary:hover {
  background: rgba(110,220,220,0.06);
}

.footer-col h4 {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 0.8125rem;
  color: var(--text-primary);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin-bottom: 1rem;
}
.footer-col a, .footer-col span {
  display: block;
  color: var(--text-secondary);
  font-size: 0.875rem;
  padding: 0.25rem 0;
  transition: color var(--t-fast);
}
.footer-col a:hover { color: var(--accent-cyan); }
.footer-contact-list {
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
}
.footer-contact-item {
  display: flex;
  align-items: center;
  gap: 0.7rem;
  padding: 0.15rem 0;
}
.footer-contact-item span {
  display: inline-flex;
  align-items: center;
  padding: 0;
}
.footer-contact-icon {
  width: 1.1rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--accent-cyan);
  flex: 0 0 auto;
}
.footer-contact-icon svg {
  width: 0.95rem;
  height: 0.95rem;
}
.footer-contact-icon--whatsapp {
  color: #25D366;
}
.footer-contact-divider {
  width: 100%;
  height: 1px;
  margin: 0.9rem 0 0.7rem;
  background: linear-gradient(90deg, rgba(110,220,220,0.18), rgba(110,220,220,0.04));
}
.footer-location {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

.footer-bottom {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 1rem;
  padding-top: 1.5rem;
  border-top: 1px solid var(--border);
}
.footer-bottom p { color: var(--text-muted); font-size: 0.8125rem; }
.footer-legal {
  display: flex;
  gap: 1.5rem;
  flex-wrap: wrap;
}
.footer-legal a {
  color: var(--text-muted);
  font-size: 0.8125rem;
  transition: color var(--t-fast);
}
.footer-legal a:hover { color: var(--accent-cyan); }

/* ── Cookie Consent Banner ── */
.cookie-banner {
  position: fixed;
  bottom: 1.5rem;
  left: 50%;
  transform: translateX(-50%);
  width: calc(100% - 3rem);
  max-width: 700px;
  background: var(--bg-elevated);
  border: 1px solid var(--border);
  border-radius: var(--r-2xl);
  padding: 1.25rem 1.5rem;
  display: flex;
  align-items: center;
  gap: 1.5rem;
  z-index: 5000;
  box-shadow: 0 20px 40px rgba(0,0,0,0.5);
  transition: opacity 0.4s, transform 0.4s;
}
.cookie-banner.hidden { opacity: 0; pointer-events: none; transform: translateX(-50%) translateY(20px); }
.cookie-text { flex: 1; font-size: 0.875rem; color: var(--text-secondary); line-height: 1.5; }
.cookie-text a { color: var(--accent-cyan); text-decoration: underline; }
.cookie-actions { display: flex; gap: 0.75rem; flex-shrink: 0; }

/* ── Breadcrumb ── */
.breadcrumb {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.8125rem;
  color: var(--text-muted);
  margin-bottom: 1.5rem;
  flex-wrap: wrap;
}
.breadcrumb a { color: var(--text-secondary); transition: color var(--t-fast); }
.breadcrumb a:hover { color: var(--accent-cyan); }
.breadcrumb-sep { color: var(--text-muted); }
.breadcrumb span:last-child { color: var(--text-primary); }

/* ── Legal Pages ── */
.legal-content {
  max-width: 800px;
  margin: 0 auto;
}
.legal-content h2 {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 1.375rem;
  margin: 2rem 0 0.75rem;
  color: var(--text-primary);
}
.legal-content h3 {
  font-family: var(--font-heading);
  font-weight: 600;
  font-size: 1.0625rem;
  margin: 1.5rem 0 0.5rem;
  color: var(--text-secondary);
}
.legal-content p, .legal-content li {
  color: var(--text-secondary);
  font-size: 0.9375rem;
  line-height: 1.8;
  margin-bottom: 0.75rem;
}
.legal-content ul, .legal-content ol {
  padding-left: 1.5rem;
  list-style: disc;
  margin-bottom: 1rem;
}
.legal-content ol { list-style: decimal; }
.legal-content a { color: var(--accent-cyan); text-decoration: underline; }
.legal-date {
  display: inline-block;
  padding: 0.375rem 0.875rem;
  background: rgba(110,220,220,0.08);
  border-radius: 100px;
  font-size: 0.8125rem;
  color: var(--accent-cyan);
  margin-bottom: 2rem;
}

/* ── Sitemap Page ── */
.sitemap-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2rem;
}
.sitemap-col h3 {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 0.9375rem;
  color: var(--accent-cyan);
  margin-bottom: 1rem;
  padding-bottom: 0.5rem;
  border-bottom: 1px solid var(--border);
}
.sitemap-col a {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.375rem 0;
  color: var(--text-secondary);
  font-size: 0.875rem;
  transition: color var(--t-fast);
}
.sitemap-col a::before { content: '→'; opacity: 0.4; font-size: 0.75rem; }
.sitemap-col a:hover { color: var(--accent-cyan); }

/* ── Expectation block ── */
.expectation-block {
  background: rgba(110,220,220,0.04);
  border: 1px solid rgba(110,220,220,0.12);
  border-left: 3px solid var(--accent-cyan);
  border-radius: 0 var(--r-xl) var(--r-xl) 0;
  padding: 1.25rem 1.5rem;
  margin: 2rem 0;
}
.expectation-block p {
  color: var(--text-secondary);
  font-size: 0.9375rem;
  line-height: 1.75;
}

/* ── Scroll Reveal Animations ── */
.reveal {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity 0.65s ease, transform 0.65s ease;
}
.reveal.revealed {
  opacity: 1;
  transform: translateY(0);
}
.reveal-delay-1 { transition-delay: 0.1s; }
.reveal-delay-2 { transition-delay: 0.2s; }
.reveal-delay-3 { transition-delay: 0.3s; }
.reveal-delay-4 { transition-delay: 0.4s; }

/* ── Responsive ── */
@media (max-width: 1200px) {
  .container, section { padding-inline: 2rem; }
  .hero { padding-inline: 2rem; }
  .trust-strip { padding-inline: 2rem; }
  .site-nav { padding-inline: 2rem; }
  .site-footer { padding-inline: 2rem; }
  .cta-panel { padding-inline: 2rem; }
  .hero-inner { gap: 2.5rem; }
}

@media (max-width: 1024px) {
  .footer-grid { grid-template-columns: 1fr 1fr; }
  .solutions-grid { grid-template-columns: repeat(2,1fr); }
  .hero-inner { grid-template-columns: 1fr; }
  .page-intro .hero-inner { grid-template-columns: 1fr; }
  .hero-visual { display: none; }
  .hero-content { max-width: 100%; }
  .affordability-grid { grid-template-columns: 1fr; gap: 2rem; }
  .trust-strip-inner { grid-template-columns: repeat(3,1fr); }
  .trust-item:nth-child(4) { border-top: 1px solid var(--border); }
  .trust-item:nth-child(5) { border-top: 1px solid var(--border); }
  .values-grid { grid-template-columns: repeat(2,1fr); }
  .sitemap-grid { grid-template-columns: repeat(2,1fr); }
  .intro-panel { order: 2; }
  .contact-coverage-areas { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 768px) {
  :root { --section-pad: 4rem 1.5rem; --nav-h: 64px; }
  .container, section { padding-inline: 1.5rem; }
  .hero { padding-inline: 1.5rem; padding-top: calc(var(--nav-h) + 3rem); }
  .page-intro { padding-top: calc(var(--nav-h) + 2.5rem); padding-bottom: 3rem; }
  .trust-strip { padding-inline: 1.5rem; margin-top: 2rem; }
  .trust-strip-inner { grid-template-columns: repeat(2,1fr); }
  .trust-item:nth-child(3) { border-top: 1px solid var(--border); }
  .trust-item:nth-child(4) { border-top: 1px solid var(--border); }
  .trust-item:nth-child(5) { grid-column: span 2; border-top: 1px solid var(--border); border-right: none; }
  .nav-menu { display: none; }
  .nav-hamburger { display: flex; }
  .site-nav { padding-inline: 1.5rem; }
  .site-footer { padding-inline: 1.5rem; }
  .cta-panel { padding-inline: 1.5rem; }
  .solutions-grid { grid-template-columns: 1fr; }
  .grid-2, .grid-3, .grid-4 { grid-template-columns: 1fr; }
  .use-cases-grid { grid-template-columns: 1fr; }
  .audience-grid { grid-template-columns: 1fr; }
  .contact-grid-layout { grid-template-columns: 1fr; gap: 2rem; }
  .contact-coverage-head { grid-template-columns: 1fr; align-items: start; }
  .form-row { grid-template-columns: 1fr; }
  .footer-grid { grid-template-columns: 1fr; gap: 2rem; }
  .footer-bottom { flex-direction: column; align-items: flex-start; }
  .coverage-map-section { grid-template-columns: 1fr; }
  .uk-map-wrap { max-width: 320px; margin: 0 auto; }
  .coverage-areas { grid-template-columns: 1fr; }
  .cookie-banner { flex-direction: column; align-items: flex-start; left: 1rem; right: 1rem; width: auto; transform: none; }
  .cookie-banner.hidden { transform: translateY(20px); }
  .values-grid { grid-template-columns: 1fr; }
  .sitemap-grid { grid-template-columns: 1fr; }
  .intro-stat-grid, .intro-quick-grid { grid-template-columns: 1fr; }
  .contact-coverage-areas { grid-template-columns: 1fr; }
}

@media (max-width: 480px) {
  .hero h1 { font-size: 2rem; }
  .hero-actions { flex-direction: column; align-items: flex-start; }
  .cta-panel-actions { flex-direction: column; align-items: center; }
  .trust-strip-inner { grid-template-columns: 1fr; }
  .trust-item { border-right: none; border-top: 1px solid var(--border); }
  .trust-item:first-child { border-top: none; }
  .btn { width: 100%; justify-content: center; }
  .hero-actions .btn { width: auto; }
  .intro-chip-list { flex-direction: column; }
  .intro-link-list a { flex-direction: column; align-items: flex-start; }
}

/* ── Print ── */
@media print {
  .site-nav, .cookie-banner, .nav-hamburger, .mobile-nav { display: none; }
  body { background: white; color: black; }
  .section-title, .hero h1 { color: black; }
}

/* ═══════════════════════════════════════════════
   TABBED HERO
   ═══════════════════════════════════════════════ */

.hero-tabs {
  padding: 0;
  margin: 0;
}

/* ── Banner container — true full-bleed, behind nav ── */
.ht-banner {
  position: relative;
  overflow: hidden;
  min-height: 100vh;
}

/* ── Background layers ── */
.ht-bg {
  position: absolute;
  inset: 0;
  opacity: 0;
  transition: opacity 1.5s cubic-bezier(0.4,0,0.2,1);
  will-change: opacity;
}
.ht-bg--active { opacity: 1; }

/* Tab 1 — Frosted / soft drifting orbs */
.ht-bg--frosted { background: #070e18; }
.ht-orb {
  position: absolute;
  border-radius: 50%;
  filter: blur(72px);
  will-change: transform;
}
.ht-orb--1 {
  width: 580px; height: 580px;
  background: radial-gradient(circle, rgba(110,220,220,0.55) 0%, transparent 65%);
  top: -160px; left: -100px;
  animation: ht-orb1 20s ease-in-out infinite;
}
.ht-orb--2 {
  width: 480px; height: 480px;
  background: radial-gradient(circle, rgba(40,100,220,0.6) 0%, transparent 65%);
  top: 40px; right: -100px;
  animation: ht-orb2 26s ease-in-out infinite;
}
.ht-orb--3 {
  width: 380px; height: 380px;
  background: radial-gradient(circle, rgba(74,143,200,0.5) 0%, transparent 65%);
  bottom: 40px; left: 35%;
  animation: ht-orb3 18s ease-in-out infinite;
}
@keyframes ht-orb1 {
  0%   { transform: translate(0,0) scale(1); }
  25%  { transform: translate(90px,-60px) scale(1.12); }
  50%  { transform: translate(40px,70px) scale(0.9); }
  75%  { transform: translate(-40px,20px) scale(1.06); }
  100% { transform: translate(0,0) scale(1); }
}
@keyframes ht-orb2 {
  0%   { transform: translate(0,0) scale(1); }
  33%  { transform: translate(-70px,50px) scale(1.1); }
  66%  { transform: translate(40px,-70px) scale(0.92); }
  100% { transform: translate(0,0) scale(1); }
}
@keyframes ht-orb3 {
  0%   { transform: translate(0,0) scale(1); }
  40%  { transform: translate(-60px,-40px) scale(1.14); }
  80%  { transform: translate(70px,30px) scale(0.88); }
  100% { transform: translate(0,0) scale(1); }
}

/* Tab 2 — Solar tint / golden-hour glass */
.ht-bg--solar {
  background:
    linear-gradient(120deg, #06101b 0%, #0b1725 40%, #142235 70%, #1a2230 100%);
}
.ht-solar-glow {
  position: absolute; inset: -6%;
  background:
    radial-gradient(ellipse 86% 72% at 70% 32%, rgba(255,186,84,0.30) 0%, transparent 62%),
    radial-gradient(ellipse 62% 52% at 86% 64%, rgba(255,140,54,0.16) 0%, transparent 60%),
    radial-gradient(ellipse 95% 85% at 16% 88%, rgba(120,180,235,0.14) 0%, transparent 66%);
  animation: ht-solar-pulse 13s ease-in-out infinite alternate;
}
.ht-solar-band {
  position: absolute; inset: 0;
  overflow: hidden;
}
.ht-solar-band::before {
  content: '';
  position: absolute;
  inset: -12%;
  background:
    radial-gradient(ellipse 48% 38% at 72% 36%, rgba(255,220,165,0.12) 0%, transparent 72%),
    radial-gradient(ellipse 40% 34% at 24% 72%, rgba(175,210,245,0.10) 0%, transparent 74%);
  filter: blur(16px);
  animation: ht-solar-caustic 18s ease-in-out infinite alternate;
}
.ht-solar-band::after {
  content: '';
  position: absolute;
  inset: -18%;
  background-image: radial-gradient(rgba(255,255,255,0.045) 0.6px, transparent 0.8px);
  background-size: 2.6px 2.6px;
  mix-blend-mode: soft-light;
  opacity: 0.14;
  animation: ht-solar-grain 22s linear infinite;
}
@keyframes ht-solar-pulse {
  from { opacity: 0.62; transform: translate3d(-1.5%, 0, 0) scale(1); }
  to   { opacity: 0.9;  transform: translate3d(1.5%, -1.2%, 0) scale(1.04); }
}
@keyframes ht-solar-caustic {
  from { transform: translate3d(-1.5%, 1%, 0) scale(1);    opacity: 0.55; }
  to   { transform: translate3d(1.5%, -1%, 0) scale(1.05); opacity: 0.82; }
}
@keyframes ht-solar-grain {
  from { transform: translate3d(0, 0, 0); }
  to   { transform: translate3d(-18px, 14px, 0); }
}

/* Tab 3 — Privacy & Specialist / frosted glass atmosphere */
.ht-bg--reeded {
  background:
    radial-gradient(ellipse 120% 90% at 78% 22%, rgba(70,165,210,0.12) 0%, transparent 60%),
    radial-gradient(ellipse 95% 85% at 18% 80%, rgba(20,120,200,0.14) 0%, transparent 62%),
    linear-gradient(140deg, #040b14 0%, #071a2a 52%, #030d17 100%);
}
.ht-reeded-light {
  position: absolute; inset: -8%;
  background:
    radial-gradient(ellipse 72% 62% at 32% 48%, rgba(120,210,245,0.20) 0%, transparent 66%),
    radial-gradient(ellipse 54% 48% at 82% 34%, rgba(90,175,230,0.15) 0%, transparent 64%),
    linear-gradient(
      112deg,
      transparent 34%,
      rgba(180,235,255,0.08) 49%,
      transparent 64%
    );
  mix-blend-mode: screen;
  animation: ht-reeded-glow 16s ease-in-out infinite alternate;
}
.ht-reeded-strips {
  position: absolute; inset: 0;
  background:
    repeating-linear-gradient(
      90deg,
      rgba(195,235,255,0)      0px,
      rgba(195,235,255,0)      8px,
      rgba(195,235,255,0.04)   8px,
      rgba(195,235,255,0.04)   9px,
      rgba(195,235,255,0)      9px,
      rgba(195,235,255,0)      18px
    ),
    linear-gradient(
      102deg,
      transparent 40%,
      rgba(150,225,255,0.07) 50%,
      transparent 60%
    );
  opacity: 0.6;
  mix-blend-mode: screen;
  animation: ht-reeded-shift 18s ease-in-out infinite alternate;
}
@keyframes ht-reeded-glow {
  from { transform: translate3d(-2%, 0%, 0) scale(1);      opacity: 0.62; }
  to   { transform: translate3d(2%, -1.5%, 0) scale(1.04); opacity: 0.9; }
}
@keyframes ht-reeded-shift {
  from { background-position: 0 0, -120% 0; }
  to   { background-position: 18px 0, 120% 0; }
}

/* Tab 4 — Online Estimate / emerald clarity */
.ht-bg--estimate {
  background:
    linear-gradient(136deg, #020d12 0%, #041723 48%, #03111b 100%);
}
.ht-estimate-glow {
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 76% 82% at 70% 36%, rgba(0,205,190,0.36) 0%, transparent 60%),
    radial-gradient(ellipse 56% 56% at 12% 74%, rgba(0,145,225,0.28) 0%, transparent 56%),
    radial-gradient(ellipse 42% 40% at 90% 80%, rgba(0,186,168,0.2) 0%, transparent 52%);
  animation: ht-estimate-breathe 13s ease-in-out infinite alternate;
}
.ht-estimate-sweep {
  position: absolute;
  inset: -8%;
  overflow: hidden;
  pointer-events: none;
  filter: blur(18px);
}
.ht-estimate-sweep::before {
  content: '';
  position: absolute;
  inset: -16%;
  background:
    linear-gradient(
      116deg,
      transparent 16%,
      rgba(142,255,236,0.08) 27%,
      rgba(112,246,224,0.20) 36%,
      rgba(104,238,220,0.24) 42%,
      rgba(125,248,231,0.10) 49%,
      transparent 62%
    ),
    linear-gradient(
      118deg,
      transparent 34%,
      rgba(98,216,255,0.07) 44%,
      rgba(88,205,248,0.16) 51%,
      rgba(112,225,255,0.09) 57%,
      transparent 68%
    ),
    linear-gradient(
      114deg,
      transparent 54%,
      rgba(120,245,234,0.06) 62%,
      rgba(128,248,236,0.14) 68%,
      transparent 76%
    );
  mix-blend-mode: screen;
  opacity: 0.74;
  animation: ht-estimate-beam-drift 20s ease-in-out infinite alternate;
}
.ht-estimate-sweep::after {
  content: '';
  position: absolute;
  inset: -20%;
  background-image: radial-gradient(rgba(214,255,248,0.045) 0.6px, transparent 0.8px);
  background-size: 2.4px 2.4px;
  mix-blend-mode: soft-light;
  opacity: 0.15;
  animation: ht-estimate-grain 26s linear infinite;
}
@keyframes ht-estimate-breathe {
  from { opacity: 0.62; transform: translate3d(-1%, 0, 0) scale(1); }
  to   { opacity: 0.92; transform: translate3d(1.2%, -1%, 0) scale(1.04); }
}
@keyframes ht-estimate-beam-drift {
  from { transform: translate3d(-1.8%, 1.2%, 0) scale(1.01); }
  to   { transform: translate3d(1.8%, -1.2%, 0) scale(1.06); }
}
@keyframes ht-estimate-grain {
  from { transform: translate3d(0, 0, 0); }
  to   { transform: translate3d(-16px, 12px, 0); }
}

/* ── Static top-left label ── */
.ht-static {
  position: absolute;
  top: calc(var(--nav-h) + 2.5rem);
  left: 3rem;
  max-width: 260px;
  z-index: 2;
}
.ht-static-eyebrow {
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--accent-cyan);
  margin-bottom: 0.65rem;
}
.ht-static p {
  font-size: 0.83rem;
  color: rgba(232,240,248,0.45);
  line-height: 1.65;
  margin: 0;
}

/* ── Slides ── */
.ht-slides-wrap {
  position: absolute;
  top: var(--nav-h);
  left: 0; right: 0;
  bottom: 3.75rem;
  z-index: 2;
}
.ht-slide {
  position: absolute;
  top: 50%;
  right: 3rem;
  max-width: 540px;
  text-align: right;
  opacity: 0;
  transform: translateY(calc(-50% + 28px));
  transition: opacity 0.5s ease, transform 0.5s ease;
  pointer-events: none;
}
.ht-slide--active {
  opacity: 1;
  transform: translateY(-50%);
  pointer-events: auto;
}
.ht-slide--exit {
  opacity: 0;
  transform: translateY(calc(-50% - 22px));
  transition: opacity 0.4s ease, transform 0.4s ease;
}
.ht-slide h1 {
  font-size: clamp(1.9rem, 3.6vw, 3rem);
  font-weight: 300;
  color: var(--text-primary);
  line-height: 1.14;
  margin: 0 0 1rem;
  letter-spacing: -0.025em;
}
.ht-slide p {
  font-size: 0.975rem;
  color: rgba(232,240,248,0.6);
  line-height: 1.7;
  margin: 0 0 1.5rem;
}
.ht-slide-actions {
  display: flex;
  gap: 0.75rem;
  justify-content: flex-end;
}
.ht-slide--left {
  right: auto;
  left: 3rem;
  text-align: left;
}
.ht-slide--left .ht-slide-actions { justify-content: flex-start; }

/* ── Tab bar ── */
.ht-tabbar {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 3.75rem;
  display: flex;
  align-items: stretch;
  background: rgba(6,13,22,0.75);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border-top: 1px solid rgba(255,255,255,0.06);
  border-radius: 0;
  z-index: 3;
}
.ht-tab-indicator {
  position: absolute;
  top: 0; height: 100%;
  background: rgba(110,220,220,0.07);
  border-top: 2px solid var(--accent-cyan);
  transition: left 0.42s cubic-bezier(0.4,0,0.2,1), width 0.42s cubic-bezier(0.4,0,0.2,1);
  pointer-events: none;
}
.ht-tab {
  flex: 1;
  background: none;
  border: none;
  cursor: pointer;
  font-family: var(--font-body);
  font-size: 0.78rem;
  font-weight: 500;
  color: rgba(140,160,180,0.65);
  padding: 0 0.75rem;
  transition: color 0.2s ease;
  position: relative;
  z-index: 1;
  white-space: nowrap;
}
.ht-tab--active { color: var(--text-primary); }
.ht-tab:hover:not(.ht-tab--active) { color: rgba(232,240,248,0.85); }

/* ── Responsive ── */
@media (max-width: 960px) {
  .ht-slide { max-width: 420px; }
  .ht-tab { font-size: 0.72rem; }
}
@media (max-width: 700px) {
  .ht-banner { min-height: 100vh; }
  .ht-static { display: none; }
  .ht-slides-wrap {
    top: var(--nav-h); left: 0; right: 0; bottom: 3.75rem;
  }
  .ht-slide {
    right: 1.5rem; left: 1.5rem;
    max-width: 100%;
    text-align: left;
    transform: translateY(calc(-50% + 28px));
  }
  .ht-slide--active { transform: translateY(-50%); }
  .ht-slide--exit   { transform: translateY(calc(-50% - 22px)); }
  .ht-slide h1 { font-size: 1.7rem; }
  .ht-slide-actions { justify-content: flex-start; flex-wrap: wrap; }
  .ht-tabbar {
    height: auto;
    overflow-x: auto;
    scrollbar-width: none;
  }
  .ht-tabbar::-webkit-scrollbar { display: none; }
  .ht-tab { padding: 1rem 1rem; font-size: 0.72rem; flex-shrink: 0; }
  .ht-tab-indicator { display: none; }
}

/* ═══════════════════════════════════════════
   HERO FLOATING VISUALS
   ═══════════════════════════════════════════ */

/* Container — fills banner, pointer-events off */
.ht-visuals {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 2;
}

/* Each visual block — hidden by default, fades in when active */
.ht-vis {
  position: absolute;
  inset: 0;
  opacity: 0;
  transition: opacity 0.55s ease;
}
.ht-vis--active { opacity: 1; }

/* ── Visual 0: Floating film photos (right side) ── */
.htv-filmphotos {
  position: absolute;
  inset: 0;
  pointer-events: none;
}

/* Shared photo base — now a wrapper div */
.htv-fp {
  position: absolute;
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  gap: 0.55rem;
  opacity: 0;
  transition: opacity 0.6s ease;
}
.htv-fp img {
  display: block;
  width: 100%;
  height: auto;
  border-radius: 10px;
}
.htv-fp-label {
  font-family: var(--font-heading);
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(232,240,248,0.6);
}
.ht-vis--0.ht-vis--active .htv-fp--solar   { opacity: 1; transition-delay: 0.05s; }
.ht-vis--0.ht-vis--active .htv-fp--frosted { opacity: 1; transition-delay: 0.18s; }
.ht-vis--0.ht-vis--active .htv-fp--safety  { opacity: 1; transition-delay: 0.30s; }

/* Solar film — foreground, largest, upper-centre of right space */
.htv-fp--solar {
  width: 225px;
  left: 55%;
  top: 18%;
  animation: none;
}
.ht-vis--0.ht-vis--active .htv-fp--solar {
  animation: htv-float-solar 4.8s ease-in-out infinite;
}

/* Frosted vinyl — midground, medium, lower-left of right space */
.htv-fp--frosted {
  width: 188px;
  left: 41%;
  top: 52%;
  animation: none;
}
.ht-vis--0.ht-vis--active .htv-fp--frosted {
  animation: htv-float-frosted 6.1s ease-in-out infinite;
  animation-delay: -1.8s;
}

/* Safety glass — far-right mid */
.htv-fp--safety {
  width: 152px;
  left: 73%;
  top: 36%;
  animation: none;
}
.ht-vis--0.ht-vis--active .htv-fp--safety {
  animation: htv-float-safety 4.2s ease-in-out infinite;
  animation-delay: -2.5s;
}

/* Float keyframes */
@keyframes htv-float-solar {
  0%, 100% { transform: rotate(-5deg) translateY(0px);   }
  50%       { transform: rotate(-6deg) translateY(-16px); }
}
@keyframes htv-float-frosted {
  0%, 100% { transform: rotate(4deg)  translateY(0px);   }
  50%       { transform: rotate(5deg)  translateY(-13px); }
}
@keyframes htv-float-safety {
  0%, 100% { transform: rotate(-2deg) translateY(0px);   }
  50%       { transform: rotate(-3deg) translateY(-20px); }
}

/* ── Visual 1: Resandcomm photo (left side) ── */
.htv-photo {
  position: absolute;
  top: 50%;
  left: 1%;
  transform: translateY(-50%);
}
.htv-photo img {
  display: block;
  width: auto;
  height: auto;
  max-width: 54vw;
  max-height: calc(100vh - var(--nav-h) - 3.75rem - 2rem);
  opacity: 0;
  transform: scale(0.97) translateY(8px);
  transition: opacity 0.65s ease, transform 0.65s ease;
}
.ht-vis--1.ht-vis--active .htv-photo img {
  opacity: 1;
  transform: scale(1) translateY(0);
  transition-delay: 0.1s;
}

/* ── Visual 2: Floating 3D icons (right side) ── */
.htv-icons3d {
  position: absolute;
  inset: 0;
  pointer-events: none;
}

/* Shared icon base */
.htv-icon3d {
  position: absolute;
  display: block;
  opacity: 0;
  transition: opacity 0.6s ease;
}
.ht-vis--2.ht-vis--active .htv-icon3d--privacy { opacity: 1; transition-delay: 0.05s; }
.ht-vis--2.ht-vis--active .htv-icon3d--padlock  { opacity: 1; transition-delay: 0.18s; }
.ht-vis--2.ht-vis--active .htv-icon3d--shield   { opacity: 1; transition-delay: 0.30s; }

/* Privacy figure — foreground, largest, upper-left of cluster */
.htv-icon3d--privacy {
  width: 220px;
  left: 58%;
  top: 11%;
  animation: none;
}
.ht-vis--2.ht-vis--active .htv-icon3d--privacy {
  animation: htv-float-privacy 4.6s ease-in-out infinite;
}

/* Padlock — midground, medium, centre of cluster */
.htv-icon3d--padlock {
  width: 172px;
  left: 40%;
  top: 50%;
  filter: blur(0.6px);
  animation: none;
}
.ht-vis--2.ht-vis--active .htv-icon3d--padlock {
  animation: htv-float-padlock 5.9s ease-in-out infinite;
  animation-delay: -1.4s;
}

/* Shield — background, smallest + most blurred, lower-right */
.htv-icon3d--shield {
  width: 146px;
  left: 78%;
  top: 38%;
  filter: blur(1.6px);
  opacity: 0.75;
  animation: none;
}
.ht-vis--2.ht-vis--active .htv-icon3d--shield {
  animation: htv-float-shield 4.0s ease-in-out infinite;
  animation-delay: -2.2s;
}

/* Float keyframes — each has its own rotation + vertical drift */
@keyframes htv-float-privacy {
  0%, 100% { transform: rotate(-6deg) translateY(0px);   }
  50%       { transform: rotate(-7deg) translateY(-18px); }
}
@keyframes htv-float-padlock {
  0%, 100% { transform: rotate(9deg)  translateY(0px);   }
  50%       { transform: rotate(8deg)  translateY(-14px); }
}
@keyframes htv-float-shield {
  0%, 100% { transform: rotate(-3deg) translateY(0px);   }
  50%       { transform: rotate(-4deg) translateY(-22px); }
}

/* ── Visual 3: Statement above, large image below ── */

/* Statement text — centered over the image, slightly larger */
.htv-est-statement {
  position: absolute;
  top: calc(var(--nav-h) + 3rem);
  left: 4%;
  width: 48vw;
  max-width: 750px;
  text-align: center;
  font-family: var(--font-heading);
  font-size: clamp(1.2rem, 2.2vw, 1.8rem);
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: rgba(232,240,248,0.92);
  line-height: 1.25;
  opacity: 0;
  transform: translateY(-6px);
  transition: opacity 0.5s ease, transform 0.5s ease;
}
.ht-vis--3.ht-vis--active .htv-est-statement {
  opacity: 1;
  transform: translateY(0);
  transition-delay: 0.05s;
}

/* Image box — wider, shifted down, with a bottom fade-out */
.htv-est-imgbox {
  position: absolute;
  top: calc(var(--nav-h) + 7rem);
  left: 4%;
  width: 48vw;
  max-width: 750px;
  bottom: calc(3.75rem + 0.75rem);
  opacity: 0;
  transform: translateY(8px);
  transition: opacity 0.65s ease, transform 0.65s ease;
  -webkit-mask-image: linear-gradient(to bottom, black 50%, transparent 100%);
  mask-image: linear-gradient(to bottom, black 50%, transparent 100%);
}
.ht-vis--3.ht-vis--active .htv-est-imgbox {
  opacity: 1;
  transform: translateY(0);
  transition-delay: 0.15s;
}

/* Image fills the box and centers properly */
.htv-calc-img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
  border-radius: 8px;
}

/* ── Responsive ── */
@media (max-width: 960px) {
  .htv-fp--solar        { width: 185px; }
  .htv-fp--frosted      { width: 155px; }
  .htv-fp--safety       { width: 125px; }
  .htv-photo img        { max-width: 44vw; }
  .htv-icon3d--privacy  { width: 175px; }
  .htv-icon3d--padlock  { width: 145px; }
  .htv-icon3d--shield   { width: 115px; }
}
@media (max-width: 820px) {
  .ht-visuals           { display: none; }
}

/* ==========================================
   HERO TAB 4 — ONLINE ESTIMATE MOCKUP LAYOUT
   ========================================== */

.ht-slide--estimate {
  left: auto;
  right: 5.5rem;
  top: 56%;
  width: 31%;
  max-width: 500px;
  text-align: left;
  transform: translateY(-38%);
  z-index: 3;
}

.ht-slide--estimate .ht-slide-actions {
  justify-content: flex-start;
}

.ht-slide-estimate-top {
  display: none;
}

.ht-slide-estimate-copy {
  position: relative;
  z-index: 3;
}

.htv-est-statement {
  top: calc(var(--nav-h) + 10.9rem);
  left: 3.75rem;
  width: 56%;
  max-width: 980px;
  font-size: clamp(0.95rem, 1.35vw, 1.45rem);
  line-height: 1.15;
  letter-spacing: 0.028em;
  white-space: nowrap;
  color: rgba(255,255,255,0.9);
  z-index: 4;
}

.htv-est-imgbox {
  position: absolute;
  top: calc(var(--nav-h) + 13.75rem);
  left: 4.5rem;
  width: 53%;
  max-width: 920px;
  bottom: 5.25rem;
  opacity: 0;
  transform: translateY(8px);
  transition: opacity 0.65s ease, transform 0.65s ease;
  -webkit-mask-image: linear-gradient(to bottom, black 62%, transparent 100%);
  mask-image: linear-gradient(to bottom, black 62%, transparent 100%);
}

.ht-vis--3.ht-vis--active .htv-est-imgbox {
  opacity: 1;
  transform: translateY(0);
  transition-delay: 0.15s;
}

.htv-calc-img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: left top;
  border-radius: 0;
}

.ht-slide--estimate h1 {
  font-size: clamp(2rem, 3vw, 3.2rem);
  font-weight: 300;
  line-height: 1.08;
  margin-bottom: 1rem;
}

.ht-slide--estimate p {
  font-size: 0.98rem;
  line-height: 1.65;
  max-width: 29rem;
  margin-bottom: 1.75rem;
}

/* Large desktop tuning */
@media (min-width: 1600px) {
  .ht-slide--estimate {
    right: 6.5rem;
    width: 32%;
  }

  .htv-est-imgbox {
    left: 5rem;
    width: 52%;
  }
}

/* Tablet / smaller desktop */
@media (max-width: 1200px) {
  .ht-slide--estimate {
    right: 3rem;
    top: 55%;
    width: 36%;
  }

  .htv-est-statement {
    top: calc(var(--nav-h) + 9.9rem);
    left: 2.8rem;
    width: 50%;
    font-size: clamp(0.82rem, 1.15vw, 1.05rem);
  }

  .htv-est-imgbox {
    left: 2.8rem;
    width: 50%;
    top: calc(var(--nav-h) + 12.2rem);
  }

  .ht-slide--estimate h1 {
    font-size: clamp(1.8rem, 2.7vw, 2.8rem);
  }
}

/* Mobile: stack normally */
@media (max-width: 820px) {
  .ht-slide--estimate {
    left: 1.5rem;
    right: 1.5rem;
    width: auto;
    max-width: none;
    top: 50%;
    transform: translateY(-50%);
  }

  .ht-slide-estimate-top {
    display: block;
    position: static;
    width: auto;
    left: auto;
    top: auto;
    text-align: left;
    white-space: normal;
    font-size: 1.5rem;
    margin-bottom: 1rem;
    transform: none;
    opacity: 1;
  }

  .htv-est-imgbox {
    display: none;
  }
}
