/* =============================================
   CSS CUSTOM PROPERTIES
============================================= */
:root {
  /* === Brand palette (premium off-white + orange) === */
  --off-white: #FAF7F2;
  --white: #FFFFFF;
  --terracotta: #F97316;       /* primary orange accent */
  --terracotta-rgb: 249, 115, 22;
  --terracotta-light: #FB923C;
  --terracotta-dark: #EA580C;
  --terracotta-btn: #C2410C;   /* WCAG AA-safe orange for white-text buttons (5.2:1) */
  --terracotta-btn-rgb: 194, 65, 12;
  --terracotta-btn-hover: #9A3412; /* darker still on hover/focus, 7.3:1 */
  --sage: #F59E0B;             /* secondary accent (warm amber) — overridable via Customizer */
  --sage-text: #92400E;        /* WCAG-safe dark amber for small text/labels that use the secondary accent (6.6:1 on off-white) */
  --charcoal: #1F2937;         /* primary text */
  --charcoal-light: #4B5563;   /* secondary text */
  --charcoal-rgb: 31, 41, 55;
  --border: rgba(31,41,55,0.08);
  --header-h: 72px;

  /* === Surfaces & depth === */
  --surface: #FFFFFF;
  --surface-glass: rgba(255,255,255,0.6);
  --surface-glass-strong: rgba(255,255,255,0.78);
  --shadow-color: 31, 41, 55;
  --shadow-sm: 0 2px 8px rgba(var(--shadow-color), 0.06);
  --shadow-md: 0 8px 24px rgba(var(--shadow-color), 0.08), 0 2px 6px rgba(var(--shadow-color), 0.05);
  --shadow-lg: 0 24px 64px rgba(var(--shadow-color), 0.12), 0 8px 24px rgba(var(--shadow-color), 0.06);
  --shadow-orange: 0 12px 32px rgba(var(--terracotta-rgb), 0.28);
  --shadow-orange-lg: 0 20px 48px rgba(var(--terracotta-rgb), 0.35);

  /* === Gradients === */
  --gradient-warm: linear-gradient(135deg, #FFF7ED 0%, #FAF7F2 50%, #FFEDD5 100%);
  --gradient-orange: linear-gradient(135deg, #F97316 0%, #FB923C 50%, #F59E0B 100%);
  --gradient-orange-soft: linear-gradient(135deg, rgba(249,115,22,0.12) 0%, rgba(245,158,11,0.08) 100%);
  --gradient-mesh: radial-gradient(at 20% 20%, rgba(249,115,22,0.15) 0px, transparent 50%),
                   radial-gradient(at 80% 0%, rgba(245,158,11,0.12) 0px, transparent 50%),
                   radial-gradient(at 50% 100%, rgba(249,115,22,0.08) 0px, transparent 50%);

  /* === Motion === */
  --ease-smooth: cubic-bezier(0.16, 1, 0.3, 1);
  --ease-bounce: cubic-bezier(0.34, 1.56, 0.64, 1);
  --dur-fast: 0.25s;
  --dur-medium: 0.45s;
  --dur-slow: 0.8s;

  /* === Radii === */
  --radius-sm: 12px;
  --radius-md: 20px;
  --radius-lg: 28px;
  --radius-pill: 100px;
}

/* =============================================
   RESET & BASE
============================================= */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; font-size: 16px; }

body {
  font-family: 'Inter', 'Outfit', sans-serif;
  background: var(--off-white);
  color: var(--charcoal);
  line-height: 1.7;
  overflow-x: hidden;
}

@media (hover: hover) { body { cursor: none; } }

a { color: inherit; text-decoration: none; }
img, video, iframe { display: block; max-width: 100%; }
ul { list-style: none; }

/* =============================================
   CUSTOM CURSOR
============================================= */
#custom-cursor {
  position: fixed;
  top: 0; left: 0;
  width: 40px; height: 40px;
  border: 1.5px solid var(--terracotta);
  border-radius: 50%;
  pointer-events: none;
  z-index: 99999;
  transform: translate(-50%, -50%);
  will-change: transform;
  transition: width 0.3s ease, height 0.3s ease, background 0.3s ease, border-color 0.3s ease;
  display: flex; align-items: center; justify-content: center;
}

#custom-cursor.cursor-dot {
  width: 10px; height: 10px;
  background: var(--terracotta);
  border: none;
}

#custom-cursor.cursor-expand {
  width: 80px; height: 80px;
  background: rgba(var(--terracotta-rgb), 0.08);
}

#cursor-text {
  position: fixed;
  top: 0; left: 0;
  font-size: 0.52rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--terracotta-btn);
  pointer-events: none;
  z-index: 100000;
  transform: translate(-50%, -50%);
  will-change: transform;
  opacity: 0;
  transition: opacity 0.2s ease;
}

#cursor-text.visible { opacity: 1; }

@media (hover: none) {
  #custom-cursor, #cursor-text { display: none; }
}

/* =============================================
   HEADER
============================================= */
#main-header {
  position: fixed;
  top: 0; left: 0; right: 0;
  height: var(--header-h);
  z-index: 1000;
  background: rgba(250,247,242,0.72);
  backdrop-filter: blur(20px) saturate(1.4);
  -webkit-backdrop-filter: blur(20px) saturate(1.4);
  border-bottom: 1px solid rgba(31,41,55,0.06);
  display: flex; align-items: center;
  transform: translateY(0);
  transition: transform 0.4s var(--ease-smooth), box-shadow 0.4s ease, background 0.4s ease;
}

#main-header.scrolled {
  background: rgba(250,247,242,0.88);
  box-shadow: 0 8px 32px rgba(var(--shadow-color), 0.07);
}

#main-header.hidden { transform: translateY(-100%); }

.header-container {
  width: 100%;
  max-width: 1320px;
  margin: 0 auto;
  padding: 0 clamp(24px, 5vw, 72px);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
}

.brand {
  display: flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
}

.brand-logo {
  height: 34px;
  width: auto;
  display: block;
}

.brand-logotext {
  height: 20px;
  width: auto;
  display: block;
}

.brand-title {
  font-family: 'Outfit', sans-serif;
  font-weight: 700;
  font-size: 1.2rem;
  color: var(--charcoal);
  letter-spacing: 0.02em;
}

.brand-subtext {
  font-size: 0.58rem;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--sage-text);
}

.main-nav {
  display: flex;
  align-items: center;
  gap: 28px;
}

.nav-link {
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--charcoal);
  position: relative;
  padding-bottom: 2px;
}

.nav-link::after {
  content: '';
  position: absolute;
  bottom: -2px; left: 0;
  width: 100%; height: 1.5px;
  background: var(--terracotta);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.3s cubic-bezier(0.25,0.46,0.45,0.94);
}

.nav-link:hover::after { transform: scaleX(1); }
.nav-link.active::after { transform: scaleX(1); }

/* Buttons */
.magnetic-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  font-weight: 600;
  font-size: 0.875rem;
  letter-spacing: 0.04em;
  padding: 13px 28px;
  border-radius: 100px;
  cursor: none;
  border: none;
  transition: transform var(--dur-fast) var(--ease-smooth), box-shadow var(--dur-fast) var(--ease-smooth), background var(--dur-fast) ease;
  text-decoration: none;
  will-change: transform;
  position: relative;
  transform: translateY(0) scale(1);
  perspective: 600px;
}

.btn-primary {
  background: linear-gradient(135deg, var(--terracotta-btn) 0%, var(--terracotta-btn-hover) 100%);
  color: var(--white);
  box-shadow: var(--shadow-orange);
}

.btn-primary:hover,
.btn-primary:focus-visible {
  transform: translateY(-4px) scale(1.035);
  box-shadow: var(--shadow-orange-lg);
  background: linear-gradient(135deg, var(--terracotta-btn-hover) 0%, var(--terracotta-btn) 100%);
}

.btn-primary:active { transform: translateY(-1px) scale(1.01); }

.btn-secondary {
  background: rgba(255,255,255,0.12);
  color: var(--white);
  border: 1.5px solid rgba(255,255,255,0.5);
  backdrop-filter: blur(8px);
}

.btn-secondary:hover,
.btn-secondary:focus-visible {
  background: rgba(255,255,255,0.22);
  border-color: rgba(255,255,255,0.8);
  transform: translateY(-4px) scale(1.035);
}

.btn-outline {
  background: var(--white);
  color: var(--charcoal);
  border: 1.5px solid var(--border);
  box-shadow: var(--shadow-sm);
}

.btn-outline:hover,
.btn-outline:focus-visible {
  border-color: var(--terracotta-btn);
  color: var(--terracotta-btn);
  transform: translateY(-4px) scale(1.035);
  box-shadow: var(--shadow-md);
}

/* Visible keyboard focus ring on every interactive element (WCAG) */
.magnetic-btn:focus-visible,
.nav-link:focus-visible,
.service-card:focus-visible,
.pricing-card:focus-visible,
.bento-item:focus-visible,
a:focus-visible,
button:focus-visible,
input:focus-visible,
textarea:focus-visible,
select:focus-visible,
summary:focus-visible {
  outline: 2.5px solid var(--terracotta-btn);
  outline-offset: 3px;
  border-radius: 8px;
}

/* Mobile hamburger */
.mobile-menu-btn {
  display: none;
  flex-direction: column;
  gap: 5px;
  cursor: none;
  padding: 4px;
}

.mobile-menu-btn span {
  display: block;
  width: 24px; height: 1.5px;
  background: var(--charcoal);
  transform-origin: center;
  transition: transform 0.35s ease, opacity 0.35s ease;
}

.mobile-menu-btn.open span:nth-child(1) { transform: translateY(6.5px) rotate(45deg); }
.mobile-menu-btn.open span:nth-child(2) { opacity: 0; }
.mobile-menu-btn.open span:nth-child(3) { transform: translateY(-6.5px) rotate(-45deg); }

/* Mobile overlay */
.mobile-overlay {
  position: fixed;
  inset: 0;
  background: var(--charcoal);
  z-index: 998;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 36px;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.4s ease;
}

.mobile-overlay.open { opacity: 1; pointer-events: all; }

.mobile-overlay .nav-link {
  color: var(--white);
  font-size: 1.6rem;
  font-family: 'Outfit', sans-serif;
  font-weight: 600;
}

@media (max-width: 900px) { .main-nav { display: none; } .mobile-menu-btn { display: flex; } }
@media (max-width: 600px) {
  .brand-subtext { display: none; }
  .brand-logo { height: 26px !important; width: auto !important; }
  .brand-logotext { height: 15px !important; width: auto !important; }
  .brand { gap: 6px !important; }
  .header-container { padding: 0 16px !important; gap: 10px !important; }
  
  /* Landing page fixes so buttons are visible */
  .hero-content h1 { font-size: 2.1rem !important; margin-bottom: 12px !important; line-height: 1.1 !important; }
  .hero-subtitle { font-size: 0.9rem !important; margin-bottom: 20px !important; line-height: 1.5 !important; }
  .hero-content { padding-top: calc(var(--header-h) + 10px) !important; }
  .hero-section { min-height: 560px !important; }
  .hero-ctas { gap: 12px !important; }
  .hero-ctas .magnetic-btn { width: 100%; font-size: 0.875rem !important; padding: 14px 24px !important; }
}

/* =============================================
   SCROLL REVEAL
============================================= */
.reveal-text .reveal-wrapper {
  display: block;
  overflow: hidden;
}

.reveal-text .reveal-wrapper > * ,
.reveal-text .reveal-wrapper {
  /* fallback: visible by default, JS enhances */
}

.reveal-line {
  display: block;
  transform: translateY(110%);
  transition: transform 0.85s cubic-bezier(0.16, 1, 0.3, 1);
}

.revealed .reveal-line { transform: translateY(0); }

.sr { opacity: 0; transform: translateY(28px); }
.sr.visible {
  opacity: 1;
  transform: translateY(0);
  transition: opacity 0.7s ease, transform 0.7s cubic-bezier(0.16,1,0.3,1);
}

/* =============================================
   HERO
============================================= */
.hero-section {
  position: relative;
  width: 100%;
  height: 100svh;
  min-height: 600px;
  overflow: hidden;
  display: flex;
  align-items: center;
  background: linear-gradient(135deg, #111827 0%, #1F2937 55%, #7C2D12 100%);
}

/* Curved section divider — bridges the hero into the lighter sections
   below with a soft organic curve instead of a hard edge. */
.section-divider {
  position: absolute;
  bottom: -1px;
  left: 0;
  width: 100%;
  height: clamp(48px, 7vw, 110px);
  z-index: 3;
  display: block;
  pointer-events: none;
}

.section-divider svg {
  display: block;
  width: 100%;
  height: 100%;
}

.video-wrapper {
  position: absolute;
  top: -60px; left: 0; right: 0; bottom: -60px;
  z-index: 0;
  transform: translate3d(0, var(--scroll-offset, 0px), 0);
  will-change: transform;
}

.hero-video {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.desktop-video { display: block; }
.mobile-video  { display: none;  }

@media (max-width: 768px) {
  .desktop-video { display: none;  }
  .mobile-video  { display: block; }
}

.video-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(31,41,55,0.80) 0%, rgba(31,41,55,0.46) 55%, rgba(var(--terracotta-btn-rgb),0.22) 100%);
}

/* =============================================
   HERO — FLOATING 3D BLOBS & ANIMATED MESH
   (the signature visual moment of the redesign)
============================================= */
.hero-blobs {
  position: absolute;
  inset: 0;
  z-index: 1;
  overflow: hidden;
  pointer-events: none;
  mix-blend-mode: normal;
}

.hero-blob {
  position: absolute;
  border-radius: 50%;
  filter: blur(14px);
  opacity: 0.6;
  will-change: transform;
  animation: blobFloat 16s var(--ease-smooth) infinite;
}

.hero-blob--1 {
  width: 420px; height: 420px;
  top: -8%; right: 6%;
  background: radial-gradient(circle at 35% 30%, rgba(251,146,60,0.55), rgba(249,115,22,0.18) 60%, transparent 75%);
  animation-duration: 18s;
}

.hero-blob--2 {
  width: 280px; height: 280px;
  bottom: 8%; right: 22%;
  background: radial-gradient(circle at 40% 35%, rgba(245,158,11,0.5), rgba(217,119,6,0.15) 60%, transparent 75%);
  animation-duration: 14s;
  animation-delay: -4s;
}

.hero-blob--3 {
  width: 200px; height: 200px;
  top: 22%; left: 4%;
  background: radial-gradient(circle at 35% 30%, rgba(249,115,22,0.4), transparent 72%);
  animation-duration: 20s;
  animation-delay: -9s;
}

.hero-blob--4 {
  width: 130px; height: 130px;
  bottom: 26%; left: 14%;
  background: radial-gradient(circle at 40% 35%, rgba(255,255,255,0.22), transparent 72%);
  animation-duration: 12s;
  animation-delay: -2s;
}

@keyframes blobFloat {
  0%   { transform: translate3d(0, 0, 0) scale(1); }
  25%  { transform: translate3d(-18px, 22px, 0) scale(1.06); }
  50%  { transform: translate3d(14px, -16px, 0) scale(0.96); }
  75%  { transform: translate3d(-10px, -24px, 0) scale(1.04); }
  100% { transform: translate3d(0, 0, 0) scale(1); }
}

/* Abstract layered 3D shape cluster — a small geometric signature
   echoing the studio/production-house brand, built from CSS only
   (no extra image requests) */
.hero-shape-cluster {
  position: absolute;
  z-index: 1;
  top: 14%;
  right: 8%;
  width: 200px;
  height: 200px;
  pointer-events: none;
  display: none; /* shown on larger viewports only, see media query below */
}

.hero-shape {
  position: absolute;
  border-radius: 32%;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  box-shadow: 0 20px 40px -12px rgba(0,0,0,0.25), inset 0 1px 1px rgba(255,255,255,0.25);
  animation: shapeDrift 10s ease-in-out infinite;
  opacity: 0.8;
}

.hero-shape--a {
  width: 130px; height: 130px;
  top: 0; right: 30px;
  background: linear-gradient(145deg, rgba(251,146,60,0.28) 0%, rgba(249,115,22,0.06) 100%);
  border: 1px solid rgba(255,255,255,0.18);
  border-radius: 38% 62% 55% 45% / 48% 42% 58% 52%;
  transform: rotate(-8deg);
  animation-delay: 0s;
}

.hero-shape--b {
  width: 80px; height: 80px;
  top: 78px; right: 138px;
  background: linear-gradient(145deg, rgba(255,255,255,0.22) 0%, rgba(255,255,255,0.02) 100%);
  border: 1px solid rgba(255,255,255,0.22);
  border-radius: 50% 50% 45% 55% / 55% 45% 55% 45%;
  transform: rotate(10deg);
  animation-delay: -3s;
}

.hero-shape--c {
  width: 50px; height: 50px;
  top: 138px; right: 64px;
  background: linear-gradient(145deg, rgba(245,158,11,0.32) 0%, rgba(245,158,11,0.04) 100%);
  border: 1px solid rgba(255,255,255,0.16);
  border-radius: 50%;
  animation-delay: -6s;
}

@keyframes shapeDrift {
  0%, 100% { transform: translateY(0) rotate(var(--r, 0deg)); }
  50%      { transform: translateY(-14px) rotate(var(--r, 0deg)); }
}

@media (min-width: 1100px) {
  .hero-shape-cluster { display: block; }
}

/* Respect motion preferences */
@media (prefers-reduced-motion: reduce) {
  .hero-blob, .hero-shape { animation: none; }
}

.hero-content {
  position: relative;
  z-index: 2;
  width: 100%;
  max-width: 1320px;
  margin: 0 auto;
  padding: var(--header-h) clamp(24px,5vw,72px) 0;
}

.hero-content h1 {
  font-family: 'Outfit', sans-serif;
  font-weight: 700;
  font-size: clamp(2.6rem, 6vw, 5rem);
  line-height: 1.06;
  letter-spacing: -0.02em;
  color: var(--white);
  max-width: 820px;
  margin-bottom: 28px;
}

.hero-subtitle {
  font-weight: 300;
  font-size: clamp(1rem, 1.5vw, 1.15rem);
  color: rgba(255,255,255,0.76);
  max-width: 560px;
  line-height: 1.75;
  margin-bottom: 44px;
}

.hero-ctas {
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
  margin-bottom: 20px;
}

.hero-ctas .magnetic-btn {
  font-size: 0.9375rem;
  padding: 16px 36px;
}

.btn-hero-primary {
  font-size: 1rem !important;
  font-weight: 700;
  box-shadow: var(--shadow-orange-lg), 0 0 0 0 rgba(var(--terracotta-rgb), 0.5);
  animation: ctaPulse 2.8s ease-in-out infinite;
}

.btn-hero-primary:hover,
.btn-hero-primary:focus-visible {
  animation-play-state: paused;
}

@keyframes ctaPulse {
  0%, 100% { box-shadow: var(--shadow-orange-lg), 0 0 0 0 rgba(var(--terracotta-rgb), 0.45); }
  50%      { box-shadow: var(--shadow-orange-lg), 0 0 0 14px rgba(var(--terracotta-rgb), 0); }
}

@media (prefers-reduced-motion: reduce) {
  .btn-hero-primary { animation: none; }
}

.hero-trust-line {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 0.8125rem;
  color: rgba(255,255,255,0.7);
  letter-spacing: 0.01em;
}

.hero-trust-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: #4ADE80;
  box-shadow: 0 0 0 3px rgba(74,222,128,0.25);
  flex-shrink: 0;
}

/* Scroll indicator */
.scroll-hint {
  position: absolute;
  bottom: 36px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 2;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  animation: hintFade 0.8s ease 2s both;
}

.scroll-hint span {
  font-size: 0.6rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.45);
  font-weight: 500;
}

.scroll-hint-arrow {
  width: 18px; height: 18px;
  border-right: 1.5px solid rgba(255,255,255,0.45);
  border-bottom: 1.5px solid rgba(255,255,255,0.45);
  transform: rotate(45deg);
  animation: arrowBounce 1.6s ease-in-out infinite;
}

@keyframes arrowBounce {
  0%,100% { transform: rotate(45deg) translateY(0); opacity: 0.45; }
  50%      { transform: rotate(45deg) translateY(5px); opacity: 0.9; }
}

@keyframes hintFade { from { opacity:0; transform: translateX(-50%) translateY(10px); } to { opacity:1; transform: translateX(-50%) translateY(0); } }

/* =============================================
   MARQUEE
============================================= */
.marquee-wrapper {
  width: 100%;
  height: 76px;
  overflow: hidden;
  background: var(--off-white);
  border-top: 1px solid rgba(var(--charcoal-rgb),0.07);
  border-bottom: 1px solid rgba(var(--charcoal-rgb),0.07);
  display: flex;
  align-items: center;
}

/*
  Two identical spans (Set A + Set B) placed side-by-side.
  Animating -50% moves exactly one full set width to the left.
  When Set A exits, Set B is already in its place — seamless loop.
*/
.marquee-track {
  display: flex;
  flex-wrap: nowrap;
  width: max-content;
  will-change: transform;
  animation: marqueeLoop 28s linear infinite;
}

.marquee-wrapper:hover .marquee-track {
  animation-play-state: paused;
}

@keyframes marqueeLoop {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

.marquee-item {
  display: inline-block;
  white-space: nowrap;
  flex-shrink: 0;
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: rgba(var(--charcoal-rgb),0.32);
  padding: 0 8px 0 0;
}

.marquee-item em {
  font-style: normal;
  color: rgba(var(--terracotta-btn-rgb),0.5);
}

/* =============================================
   ABOUT
============================================= */
.about-section {
  background: var(--white);
  padding: clamp(80px, 10vw, 130px) clamp(24px,5vw,72px);
}

.about-container {
  max-width: 1320px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 0.9fr 1.1fr;
  gap: clamp(48px, 7vw, 100px);
  align-items: center;
}

/* Arch image */
.arch-mask {
  position: relative;
  border-radius: 52% 52% 0 0 / 44% 44% 0 0;
  overflow: hidden;
  aspect-ratio: 3/4;
  max-width: 420px;
  width: 100%;
  clip-path: inset(0 0 0 0 round 52% 52% 0 0 / 44% 44% 0 0);
  will-change: transform;
  cursor: none;
}

.arch-mask::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 55%, rgba(var(--charcoal-rgb),0.35) 100%);
  pointer-events: none;
}

.parallax-img {
  width: 100%;
  height: 115%;
  object-fit: cover;
  object-position: center top;
  will-change: transform;
  display: block;
}

.about-text-col {
  display: flex;
  flex-direction: column;
  gap: 32px;
}

.about-eyebrow {
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--terracotta-btn);
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 7px 16px 7px 8px;
  border-radius: var(--radius-pill);
  background: var(--gradient-orange-soft);
  border: 1px solid rgba(var(--terracotta-rgb), 0.18);
}

.about-eyebrow::before {
  content: '';
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--gradient-orange);
  flex-shrink: 0;
  box-shadow: 0 0 0 3px rgba(var(--terracotta-rgb), 0.15);
}

.editorial-text {
  font-family: 'Outfit', sans-serif;
  font-weight: 400;
  font-size: clamp(1.35rem, 2.2vw, 1.9rem);
  line-height: 1.55;
  color: var(--charcoal);
}

.about-body-copy {
  font-size: 1rem;
  color: var(--charcoal-light);
  line-height: 1.8;
}

.pillar-row {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.pillar-tag {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 7px 16px;
  border: 1px solid rgba(146,64,14,0.7);
  border-radius: 100px;
  font-size: 0.8125rem;
  font-weight: 500;
  color: var(--charcoal);
  letter-spacing: 0.03em;
}

.about-stats-row {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
  margin-top: 12px;
  padding-top: 28px;
  border-top: 1px solid var(--border);
}

.about-stat {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.about-stat-number {
  font-family: 'Outfit', sans-serif;
  font-weight: 700;
  font-size: clamp(1.6rem, 2.6vw, 2.1rem);
  line-height: 1;
  background: linear-gradient(135deg, var(--terracotta-btn) 0%, var(--terracotta-btn-hover) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: var(--terracotta-btn);
}

.about-stat-label {
  font-size: 0.75rem;
  color: var(--charcoal-light);
  letter-spacing: 0.01em;
  line-height: 1.4;
}

@media (max-width: 640px) {
  .about-stats-row { grid-template-columns: repeat(2, 1fr); gap: 24px 16px; }
}

@media (max-width: 880px) {
  .about-container { grid-template-columns: 1fr; gap: 48px; }
  .arch-mask { max-width: 300px; margin: 0 auto; }
}

/* =============================================
   SERVICES
============================================= */
.services-section {
  background: var(--off-white);
  padding: clamp(80px,10vw,130px) clamp(24px,5vw,72px);
}

.section-header {
  max-width: 1320px;
  margin: 0 auto 56px;
}

.section-header h2 {
  font-family: 'Outfit', sans-serif;
  font-weight: 700;
  font-size: clamp(2rem, 3.5vw, 3.2rem);
  line-height: 1.1;
  color: var(--charcoal);
  letter-spacing: -0.01em;
}

.section-label-tag {
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--terracotta-btn);
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 18px;
  padding: 7px 16px 7px 8px;
  border-radius: var(--radius-pill);
  background: var(--gradient-orange-soft);
  border: 1px solid rgba(var(--terracotta-rgb), 0.18);
}

.section-label-tag::before {
  content: '';
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--gradient-orange);
  flex-shrink: 0;
  box-shadow: 0 0 0 3px rgba(var(--terracotta-rgb), 0.15);
}

.services-matrix {
  max-width: 1320px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
  perspective: 1200px;
}

.service-card {
  background: var(--white);
  padding: clamp(28px, 3vw, 36px);
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 18px;
  position: relative;
  overflow: hidden;
  cursor: none;
  border-radius: var(--radius-md);
  border: 1px solid var(--border);
  box-shadow: var(--shadow-md);
  transition: transform var(--dur-medium) var(--ease-smooth), box-shadow var(--dur-medium) var(--ease-smooth), border-color var(--dur-medium) ease;
  transform: translateY(0) rotateX(0) rotateY(0) scale(1);
  will-change: transform;
}

/* Position child elements relatively so they appear above mouse-glow */
.service-card > * {
  position: relative;
  z-index: 2;
}

.service-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 4px;
  background: var(--gradient-orange);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.45s var(--ease-smooth);
  z-index: 3;
  border-radius: var(--radius-md) var(--radius-md) 0 0;
}

/* Mouse-glow radial gradient overlay */
.service-card::after {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(
    circle 260px at var(--mouse-x, -999px) var(--mouse-y, -999px),
    rgba(var(--terracotta-rgb), 0.10),
    transparent 80%
  );
  opacity: 0;
  transition: opacity 0.4s ease;
  pointer-events: none;
  z-index: 1;
}

.service-card:hover::before,
.service-card.active::before { transform: scaleX(1); }

.service-card:hover::after,
.service-card.active::after { opacity: 1; }

.service-card:hover,
.service-card.active {
  background: var(--white);
  box-shadow: var(--shadow-lg), 0 4px 0 0 rgba(var(--terracotta-rgb), 0.06);
  border-color: rgba(var(--terracotta-rgb), 0.22);
  transform: translateY(-10px) scale(1.025);
  z-index: 4;
}

.service-icon {
  width: 56px; height: 56px;
  border-radius: var(--radius-sm);
  background: var(--gradient-orange-soft);
  border: 1px solid rgba(var(--terracotta-rgb), 0.15);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.6rem;
  flex-shrink: 0;
  box-shadow: 0 4px 12px rgba(var(--terracotta-rgb), 0.1);
  transition: transform 0.5s var(--ease-bounce), background 0.3s ease, box-shadow 0.3s ease;
}

.service-card:hover .service-icon,
.service-card.active .service-icon {
  transform: scale(1.14) rotate(8deg) translateY(-2px);
  background: var(--gradient-orange);
  box-shadow: var(--shadow-orange);
}

.service-card h3 {
  font-family: 'Outfit', sans-serif;
  font-weight: 700;
  font-size: 1.25rem;
  color: var(--charcoal);
  line-height: 1.3;
  transition: color 0.3s ease;
}

.service-card:hover h3,
.service-card.active h3 {
  color: var(--terracotta-btn);
}

/* Service Bullet Items Stagger */
.service-bullets {
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 11px;
  flex: 1;
}

.service-bullets li {
  font-size: 0.85rem;
  color: var(--charcoal-light);
  line-height: 1.5;
  position: relative;
  padding-left: 20px;
  opacity: 0.7;
  transition: opacity 0.4s ease, transform 0.4s var(--ease-smooth);
}

.service-bullets li::before {
  content: '';
  position: absolute;
  left: 2px;
  top: 9px;
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: var(--terracotta);
  opacity: 0.55;
  transition: transform 0.3s ease, opacity 0.3s ease;
}

.service-card:hover .service-bullets li,
.service-card.active .service-bullets li {
  opacity: 1;
  transform: translateX(2px);
}

.service-card:hover .service-bullets li::before,
.service-card.active .service-bullets li::before {
  transform: scale(1.3);
  opacity: 1;
}

/* Staggered Transition Delays */
.service-bullets li:nth-child(1) { transition-delay: 0.02s; }
.service-bullets li:nth-child(2) { transition-delay: 0.04s; }
.service-bullets li:nth-child(3) { transition-delay: 0.06s; }
.service-bullets li:nth-child(4) { transition-delay: 0.08s; }
.service-bullets li:nth-child(5) { transition-delay: 0.1s; }
.service-bullets li:nth-child(6) { transition-delay: 0.12s; }

.service-cta {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 0.85rem;
  font-weight: 700;
  color: var(--terracotta-btn);
  margin-top: auto;
  padding-top: 4px;
  transition: gap 0.25s ease, color 0.25s ease;
}

.service-card:hover .service-cta,
.service-card.active .service-cta {
  gap: 10px;
  color: var(--terracotta-btn-hover);
}

@media (max-width: 1080px) {
  .services-matrix { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 880px) {
  .service-bullets li { opacity: 1; }
}

@media (max-width: 480px) { .services-matrix { grid-template-columns: 1fr; } }

/* =============================================
   STUDIO BENTO GRID
============================================= */
.bento-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  grid-auto-rows: 240px;
  gap: 16px;
}
@media (max-width: 900px) {
  .bento-grid { grid-template-columns: repeat(2, 1fr); grid-auto-rows: auto; }
  .bento-1 { grid-column: 1 / 3 !important; grid-row: auto !important; height: 340px; }
  .bento-2 { grid-column: 1 / 3 !important; grid-row: auto !important; height: 440px; }
  .bento-3 { grid-column: 1 / 2 !important; grid-row: auto !important; height: 260px; }
  .bento-4 { grid-column: 2 / 3 !important; grid-row: auto !important; height: 260px; }
  .bento-5 { grid-column: 1 / 3 !important; grid-row: auto !important; height: 320px; }
  .bento-6 { grid-column: 1 / 3 !important; grid-row: auto !important; height: 400px; }
}
@media (max-width: 600px) {
  .bento-grid { display: flex; flex-direction: column; gap: 16px; }
  .bento-item { width: 100%; height: 300px !important; }
  .bento-2 { height: 400px !important; }
  .bento-6 { height: 400px !important; }
}

.bento-item {
  position: relative;
  border-radius: 24px;
  overflow: hidden;
  background: var(--off-white);
  box-shadow: 0 4px 20px rgba(var(--charcoal-rgb),0.05);
  cursor: none;
}
.bento-img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform 0.8s cubic-bezier(0.25,0.46,0.45,0.94), filter 0.5s ease;
}
.bento-item:hover .bento-img { transform: scale(1.06); }

.bento-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(var(--charcoal-rgb),0.85) 0%, transparent 60%);
  opacity: 0;
  transition: opacity 0.5s ease;
  display: flex;
  align-items: flex-end;
  padding: 24px;
}
.bento-item:hover .bento-overlay { opacity: 1; }

.bento-title {
  color: #fff;
  font-family: 'Outfit', sans-serif;
  font-size: 1.2rem;
  font-weight: 600;
  transform: translateY(10px);
  transition: transform 0.4s ease;
}
.bento-item:hover .bento-title { transform: translateY(0); }
.bento-item:hover .bento-desc { transform: translateY(0) !important; }

.bento-1 { grid-column: 1 / 3; grid-row: 1 / 3; }
.bento-2 { grid-column: 3 / 5; grid-row: 1 / 4; }
.bento-3 { grid-column: 1 / 2; grid-row: 3 / 4; }
.bento-4 { grid-column: 2 / 3; grid-row: 3 / 4; }
.bento-5 { grid-column: 1 / 3; grid-row: 4 / 6; }
.bento-6 { grid-column: 3 / 5; grid-row: 4 / 6; }

/* =============================================
   HORIZONTAL SCROLL PRICING
============================================= */
.horizontal-scroll-section {
  height: 300vh;
  background: var(--white);
}

.horizontal-sticky-wrapper {
  position: sticky;
  top: 0;
  height: 100vh;
  overflow: hidden;
  display: flex;
  align-items: center;
}

.horizontal-scroll-container {
  display: flex;
  gap: 32px;
  padding: 0 clamp(24px,5vw,72px);
  align-items: stretch;
  will-change: transform;
  transition: transform 0.12s linear;
}

/* Intro panel */
.horizontal-intro {
  min-width: clamp(300px, 34vw, 460px);
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 28px;
  padding-right: 16px;
}

.horizontal-intro h2 {
  font-family: 'Outfit', sans-serif;
  font-weight: 700;
  font-size: clamp(2rem, 3.5vw, 3.2rem);
  line-height: 1.1;
  color: var(--charcoal);
  letter-spacing: -0.01em;
}

.horizontal-intro > p {
  font-size: 1rem;
  color: var(--charcoal-light);
  line-height: 1.7;
  max-width: 340px;
}

.amenities-list {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px 20px;
}

.amenity {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 0.8rem;
  color: var(--charcoal-light);
  font-weight: 500;
}

.tick {
  width: 18px; height: 18px;
  border-radius: 50%;
  background: rgba(var(--terracotta-rgb), 0.1);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  font-size: 0.6rem;
  color: var(--terracotta-btn);
  font-weight: 700;
  position: relative;
}

.tick::after { content: '✓'; }

/* Pricing cards */
.pricing-card {
  min-width: clamp(280px, 32vw, 420px);
  flex-shrink: 0;
  background: var(--off-white);
  border: 1px solid var(--border);
  border-radius: 20px;
  padding: clamp(28px, 3vw, 40px);
  display: flex;
  flex-direction: column;
  gap: 20px;
  cursor: none;
  transition: transform var(--dur-medium) var(--ease-smooth), box-shadow var(--dur-medium) var(--ease-smooth);
  align-self: center;
}

.pricing-card:hover {
  transform: translateY(-8px) scale(1.015);
  box-shadow: var(--shadow-lg);
}

.master-card {
  background: var(--charcoal);
  border-color: var(--charcoal);
  transform: scale(1.04);
}

.master-card:hover { transform: scale(1.055) translateY(-8px); }

.badge {
  display: inline-block;
  background: var(--terracotta-btn-hover);
  color: var(--white);
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 5px 13px;
  border-radius: 100px;
  margin-bottom: 4px;
  box-shadow: 0 4px 12px rgba(var(--terracotta-rgb), 0.3);
}

.package-time {
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--terracotta-btn);
  display: block;
}

.master-card .package-time { color: rgba(255,255,255,0.55); }

.package-price {
  font-family: 'Outfit', sans-serif;
  font-weight: 700;
  font-size: clamp(2.4rem, 4vw, 3.2rem);
  color: var(--charcoal);
  line-height: 1;
}

.master-card .package-price { color: var(--white); }

.package-desc {
  font-size: 0.875rem;
  font-style: italic;
  color: var(--charcoal-light);
  line-height: 1.55;
  flex: 1;
}

.master-card .package-desc { color: rgba(255,255,255,0.65); }

.book-btn {
  display: block;
  text-align: center;
  padding: 13px 24px;
  border-radius: 100px;
  font-size: 0.875rem;
  font-weight: 600;
  background: linear-gradient(135deg, var(--terracotta-btn) 0%, var(--terracotta-btn-hover) 100%);
  color: var(--white);
  transition: box-shadow var(--dur-fast) var(--ease-smooth), transform var(--dur-fast) var(--ease-smooth);
}

.book-btn:hover,
.book-btn:focus-visible {
  box-shadow: var(--shadow-orange-lg);
  transform: translateY(-3px) scale(1.03);
}

/* Horizontal scroll progress */
.scroll-progress {
  position: absolute;
  bottom: 40px;
  left: clamp(24px,5vw,72px);
  right: clamp(24px,5vw,72px);
  height: 2px;
  background: var(--border);
  border-radius: 100px;
  overflow: hidden;
}

.scroll-progress-fill {
  height: 100%;
  background: var(--terracotta);
  width: 0%;
  border-radius: 100px;
  transition: width 0.1s linear;
}

/* Mobile fallback */
@media (max-width: 768px) {
  .horizontal-scroll-section { height: auto; }
  .horizontal-sticky-wrapper { position: static; height: auto; padding: clamp(60px,10vw,100px) 0; display: block; }
  .horizontal-scroll-container {
    display: flex;
    flex-direction: column;
    gap: 0;
    padding: 0 clamp(24px,5vw,40px);
    overflow: visible;
  }
  .horizontal-intro { min-width: auto; padding-right: 0; margin-bottom: 40px; }
  .pricing-card { min-width: auto; align-self: auto; }
  .pricing-card + .pricing-card { margin-top: 20px; }
  .master-card { transform: none; }
  .scroll-progress { display: none; }
}

/* =============================================
   CONTACT / FOOTER
============================================= */
.main-footer {
  background: var(--gradient-warm);
  border-top: 1px solid var(--border);
  padding: clamp(80px,10vw,130px) clamp(24px,5vw,72px) 0;
  position: relative;
  overflow: hidden;
}

.main-footer::before {
  content: '';
  position: absolute;
  top: -6%;
  left: -6%;
  width: 380px;
  height: 380px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(var(--terracotta-rgb),0.08), transparent 70%);
  pointer-events: none;
  z-index: 0;
}

.contact-header-block {
  max-width: 760px;
  margin: 0 auto clamp(48px, 6vw, 72px);
  text-align: center;
  position: relative;
  z-index: 1;
}

.contact-header-block .section-label-tag { justify-content: center; }

.contact-main-heading {
  font-family: 'Outfit', sans-serif;
  font-weight: 700;
  font-size: clamp(2rem, 4vw, 3rem);
  color: var(--charcoal);
  line-height: 1.15;
  margin-bottom: 16px;
}

.contact-main-sub {
  font-size: 1.0625rem;
  color: var(--charcoal-light);
  line-height: 1.7;
  max-width: 560px;
  margin: 0 auto;
}

.footer-matrix {
  max-width: 1320px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(48px,7vw,100px);
  position: relative;
  z-index: 1;
}

/* Contact info cards (icon + label + value) */
.contact-info-cards {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.contact-info-card {
  display: flex;
  align-items: flex-start;
  gap: 16px;
  padding: 18px 20px;
  border-radius: var(--radius-md);
  background: var(--surface-glass-strong);
  backdrop-filter: blur(12px) saturate(1.3);
  -webkit-backdrop-filter: blur(12px) saturate(1.3);
  border: 1px solid rgba(255,255,255,0.6);
  box-shadow: var(--shadow-sm);
  text-decoration: none;
  transition: transform var(--dur-fast) var(--ease-smooth), box-shadow var(--dur-fast) var(--ease-smooth), border-color var(--dur-fast) ease;
}

a.contact-info-card:hover,
a.contact-info-card:focus-visible {
  transform: translateY(-4px) translateX(2px);
  box-shadow: var(--shadow-md);
  border-color: rgba(var(--terracotta-rgb), 0.25);
}

.contact-info-icon {
  width: 44px;
  height: 44px;
  border-radius: var(--radius-sm);
  background: var(--gradient-orange-soft);
  border: 1px solid rgba(var(--terracotta-rgb), 0.15);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--terracotta-btn);
  flex-shrink: 0;
  transition: transform var(--dur-fast) var(--ease-bounce), background var(--dur-fast) ease;
}

.contact-info-card:hover .contact-info-icon {
  transform: scale(1.1) rotate(-6deg);
  background: linear-gradient(135deg, var(--terracotta-btn) 0%, var(--terracotta-btn-hover) 100%);
  color: #fff;
}

.contact-info-text {
  display: flex;
  flex-direction: column;
  gap: 3px;
  min-width: 0;
}

.contact-info-label {
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--terracotta-btn);
}

.contact-info-value {
  font-size: 0.9375rem;
  color: var(--charcoal);
  line-height: 1.5;
  word-break: break-word;
}

.contact-info-card--static { cursor: default; }

.contact-whatsapp-btn {
  width: 100%;
  justify-content: center;
  background: linear-gradient(135deg, #15803D 0%, #166534 100%);
  color: #fff;
  box-shadow: 0 12px 32px rgba(21,128,61,0.32);
}

.contact-whatsapp-btn:hover,
.contact-whatsapp-btn:focus-visible {
  background: linear-gradient(135deg, #14532D 0%, #15803D 100%);
  box-shadow: 0 20px 48px rgba(21,128,61,0.45);
  transform: translateY(-4px) scale(1.02);
}

.contact-social-row {
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
}

.contact-social-label {
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--charcoal-light);
}

.contact-social-icons {
  display: flex;
  gap: 10px;
}

/* FAQ accordion (below the contact form) */
.contact-faq-block {
  max-width: 880px;
  margin: clamp(64px, 8vw, 100px) auto 0;
  position: relative;
  z-index: 1;
}

.contact-faq-header {
  text-align: center;
  margin-bottom: 36px;
}

.contact-faq-header .section-label-tag { justify-content: center; }

.contact-faq-header h3 {
  font-family: 'Outfit', sans-serif;
  font-weight: 700;
  font-size: clamp(1.5rem, 2.5vw, 2rem);
  color: var(--charcoal);
}

.contact-faq-accordion {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.contact-faq-item {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: 4px 24px;
  box-shadow: var(--shadow-sm);
  transition: box-shadow var(--dur-fast) ease, border-color var(--dur-fast) ease;
}

.contact-faq-item:hover { border-color: rgba(var(--terracotta-rgb), 0.2); }

.contact-faq-item[open] { box-shadow: var(--shadow-md); border-color: rgba(var(--terracotta-rgb), 0.25); }

.contact-faq-item summary {
  padding: 20px 36px 20px 0;
  font-family: 'Outfit', sans-serif;
  font-weight: 600;
  font-size: 1rem;
  color: var(--charcoal);
  cursor: pointer;
  list-style: none;
  position: relative;
}

.contact-faq-item summary::-webkit-details-marker { display: none; }

.contact-faq-item summary::after {
  content: '';
  position: absolute;
  right: 4px;
  top: 50%;
  width: 14px;
  height: 14px;
  margin-top: -7px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23C2410C' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-size: contain;
  transition: transform var(--dur-fast) var(--ease-smooth);
}

.contact-faq-item[open] summary::after { transform: rotate(180deg); }

.contact-faq-answer {
  padding: 0 0 22px;
  color: var(--charcoal-light);
  font-size: 0.9375rem;
  line-height: 1.7;
}

.contact-faq-answer p:not(:last-child) { margin-bottom: 12px; }

/* Full-width Google Map */
.contact-map-section {
  max-width: 1320px;
  margin: clamp(64px, 8vw, 100px) auto 0;
  position: relative;
  z-index: 1;
}

.contact-map-wrap {
  position: relative;
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-lg);
  border: 1px solid var(--border);
  aspect-ratio: 21/9;
  background: var(--white);
}

.contact-map-wrap iframe {
  width: 100%;
  height: 100%;
  border: 0;
  filter: saturate(0.92) contrast(1.02);
}

.contact-map-wrap .map-overlay-btn {
  position: absolute;
  bottom: 20px;
  right: 20px;
  background: var(--surface-glass-strong);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border: 1px solid var(--border);
  padding: 11px 22px;
  border-radius: var(--radius-pill);
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--charcoal);
  display: flex;
  align-items: center;
  gap: 8px;
  box-shadow: var(--shadow-md);
  transition: transform var(--dur-fast) var(--ease-smooth), background var(--dur-fast) ease, color var(--dur-fast) ease;
  text-decoration: none;
  z-index: 10;
}

.contact-map-wrap .map-overlay-btn:hover,
.contact-map-wrap .map-overlay-btn:focus-visible {
  background: linear-gradient(135deg, var(--terracotta-btn) 0%, var(--terracotta-btn-hover) 100%);
  color: #fff;
  transform: translateY(-3px) scale(1.04);
}

@media (max-width: 700px) {
  .contact-map-wrap { aspect-ratio: 4/5; }
}

/* Form */
.contact-form-col h2,
.contact-form-heading {
  font-family: 'Outfit', sans-serif;
  font-weight: 700;
  font-size: clamp(1.5rem, 2.5vw, 2rem);
  color: var(--charcoal);
  line-height: 1.2;
  margin-bottom: 32px;
}

.contact-form { display: flex; flex-direction: column; gap: 30px; }

.input-group { position: relative; }

.input-group input,
.input-group textarea,
.input-group select {
  width: 100%;
  background: transparent;
  border: none;
  border-bottom: 1px solid rgba(var(--charcoal-rgb),0.22);
  padding: 12px 0 10px;
  font-family: inherit;
  font-size: 0.9375rem;
  color: var(--charcoal);
  outline: none;
  transition: border-color 0.3s ease;
  appearance: none;
  -webkit-appearance: none;
}

.input-group textarea { resize: vertical; min-height: 90px; }

.input-group input:focus,
.input-group textarea:focus,
.input-group select:focus { border-color: var(--terracotta-btn); }

.input-group label {
  position: absolute;
  top: 12px; left: 0;
  font-size: 0.875rem;
  color: rgba(var(--charcoal-rgb),0.45);
  font-weight: 400;
  pointer-events: none;
  transition: top 0.25s ease, font-size 0.25s ease, color 0.25s ease;
}

.input-group:focus-within label,
.input-group.filled label {
  top: -10px;
  font-size: 0.68rem;
  color: var(--terracotta-btn);
  letter-spacing: 0.08em;
  font-weight: 600;
  text-transform: uppercase;
}

.submit-btn {
  width: 100%;
  justify-content: center;
  padding: 15px 32px;
  font-size: 0.9375rem;
}

/* Contact info */
.contact-info-col {
  display: flex;
  flex-direction: column;
  gap: 28px;
}

.footer-brand-block { display: flex; flex-direction: column; gap: 12px; }
.footer-brand-logo-wrap { display: flex; align-items: center; gap: 10px; }
.footer-brand-logo { height: 38px; width: auto; display: block; }
.footer-brand-text-img { height: 20px; width: auto; display: block; }
.footer-tagline { font-size: 0.78rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--sage-text); font-weight: 500; margin-top: 0; }

.info-block h3 {
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--terracotta-btn);
  margin-bottom: 8px;
}

.info-block p { font-size: 0.9375rem; color: var(--charcoal-light); line-height: 1.6; }

.map-container {
  border-radius: 14px;
  overflow: hidden;
  aspect-ratio: 16/9;
  border: 1px solid var(--border);
  background: var(--off-white);
}

.map-container iframe { width: 100%; height: 100%; border: 0; }

.info-links { display: flex; flex-direction: column; gap: 12px; }

.social-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 42px;
  height: 42px;
  border-radius: 50%;
  background: var(--white);
  border: 1px solid var(--border);
  color: var(--terracotta-btn);
  transition: transform var(--dur-fast) var(--ease-bounce), box-shadow var(--dur-fast) ease, background var(--dur-fast) ease, color var(--dur-fast) ease;
}

.social-link:hover,
.social-link:focus-visible {
  transform: translateY(-4px) scale(1.08) rotate(-6deg);
  background: linear-gradient(135deg, var(--terracotta-btn) 0%, var(--terracotta-btn-hover) 100%);
  color: #fff;
  box-shadow: var(--shadow-orange);
}

.hotline {
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--charcoal);
  letter-spacing: 0.04em;
  transition: color 0.2s ease;
  display: inline-block;
}

.hotline:hover { color: var(--terracotta-btn); }

/* Footer bottom */
.footer-bottom {
  max-width: 1320px;
  margin: 56px auto 0;
  padding: 24px 0 32px;
  border-top: 1px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 12px;
}

.footer-bottom p { font-size: 0.8125rem; color: rgba(var(--charcoal-rgb),0.5); }

.footer-tagline-bottom { font-size: 0.8125rem; color: rgba(var(--charcoal-rgb),0.5); font-style: italic; }

@media (max-width: 880px) { .footer-matrix { grid-template-columns: 1fr; } }

/* =============================================
   MISC
============================================= */
::selection { background: rgba(var(--terracotta-rgb), 0.18); color: var(--charcoal); }
/* Note: the single comprehensive :focus-visible ring (using the
   accessible --terracotta-btn token) is defined once, near the button
   system, so every interactive element gets a consistent, WCAG-safe
   keyboard focus indicator without being overridden here. */

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: 0.01ms !important; transition-duration: 0.01ms !important; }
  .reveal-line { transform: none !important; }
  .sr { opacity: 1 !important; transform: none !important; }
}

/* =============================================
   ABOUT ARCH — overlay pills
============================================= */
.arch-mask-wrapper { position: relative; z-index: 1; }
.creative-pill {
  position: absolute;
  background: rgba(255,255,255,0.85);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border: 1px solid rgba(255,255,255,0.8);
  border-radius: 100px;
  padding: 12px 24px 12px 12px;
  display: flex;
  align-items: center;
  gap: 16px;
  box-shadow: 0 16px 32px rgba(var(--charcoal-rgb),0.12);
  z-index: 10;
  transform: translateY(0);
  transition: transform 0.4s ease, box-shadow 0.4s ease;
}
.creative-pill:hover {
  transform: translateY(-5px);
  box-shadow: 0 20px 40px rgba(var(--charcoal-rgb),0.18);
}
.pill-left {
  top: 15%;
  left: -20%;
  animation: floatPill 5s ease-in-out infinite;
}
.pill-right {
  bottom: 15%;
  right: -20%;
  animation: floatPill 6s ease-in-out infinite reverse;
}
.cp-icon {
  width: 52px; height: 52px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--terracotta) 0%, #f09433 100%);
  color: white;
  display: flex; align-items: center; justify-content: center;
  font-size: 1.4rem;
  box-shadow: 0 6px 16px rgba(var(--terracotta-btn-rgb),0.3);
  flex-shrink: 0;
}
.cp-text { display: flex; flex-direction: column; line-height: 1.2; }
.cp-title { font-weight: 800; font-family: 'Outfit', sans-serif; font-size: 1.1rem; color: var(--charcoal); }
.cp-sub { font-size: 0.75rem; color: var(--charcoal-light); font-weight: 600; letter-spacing: 0.05em; text-transform: uppercase; margin-top: 2px; }

@keyframes floatPill {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-12px); }
}

@media (max-width: 900px) {
  .pill-left { left: -5%; }
  .pill-right { right: -5%; }
}
@media (max-width: 480px) {
  .pill-left { top: 10%; left: -2%; right: auto; padding: 8px 16px 8px 8px; }
  .pill-right { bottom: 10%; right: -2%; left: auto; padding: 8px 16px 8px 8px; }
  .cp-icon { width: 40px; height: 40px; font-size: 1rem; }
  .cp-title { font-size: 0.95rem; }
  .cp-sub { font-size: 0.65rem; }
}

/* Mobile gallery grid fix */
@media (max-width: 768px) {
  .footer-bottom { flex-direction: column; text-align: center; }
}

/* =============================================
   LIGHTBOX PREVIEW MODAL
============================================= */
.lightbox {
  position: fixed;
  inset: 0;
  background: rgba(26, 37, 53, 0.93); /* Deep Charcoal overlay */
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.4s cubic-bezier(0.25, 1, 0.5, 1), backdrop-filter 0.4s ease;
}

.lightbox.open {
  opacity: 1;
  pointer-events: all;
}

.lightbox-content {
  position: relative;
  max-width: 80vw;
  max-height: 80vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 20px;
}

.lightbox-content img {
  max-width: 100%;
  max-height: 70vh;
  object-fit: contain;
  border-radius: 16px;
  box-shadow: 0 30px 80px rgba(0, 0, 0, 0.5);
  transform: scale(0.92);
  opacity: 0;
  transition: transform 0.45s cubic-bezier(0.34, 1.56, 0.64, 1), opacity 0.35s ease;
  border: 1px solid rgba(255, 255, 255, 0.1);
}

.lightbox.open .lightbox-content img.loaded {
  transform: scale(1);
  opacity: 1;
}

#lightbox-caption {
  font-family: 'Outfit', sans-serif;
  color: var(--white);
  font-size: 1.1rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  text-shadow: 0 2px 10px rgba(0, 0, 0, 0.3);
  opacity: 0;
  transform: translateY(10px);
  transition: transform 0.4s ease 0.15s, opacity 0.4s ease 0.15s;
}

.lightbox.open #lightbox-caption {
  opacity: 1;
  transform: translateY(0);
}

/* Close & Nav buttons */
.lightbox-close {
  position: absolute;
  top: 30px;
  right: 40px;
  background: transparent;
  border: none;
  font-size: 3rem;
  color: rgba(255, 255, 255, 0.65);
  cursor: pointer;
  transition: color 0.3s ease, transform 0.3s ease;
  line-height: 1;
  z-index: 10010;
}

.lightbox-close:hover {
  color: var(--terracotta-btn);
  transform: scale(1.1) rotate(90deg);
}

.lightbox-prev,
.lightbox-next {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.12);
  width: 60px;
  height: 60px;
  border-radius: 50%;
  color: var(--white);
  font-size: 1.4rem;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all 0.3s cubic-bezier(0.25, 1, 0.5, 1);
  z-index: 10005;
}

.lightbox-prev { left: 40px; }
.lightbox-next { right: 40px; }

.lightbox-prev:hover,
.lightbox-next:hover {
  background: linear-gradient(135deg, var(--terracotta-btn) 0%, var(--terracotta-btn-hover) 100%);
  border-color: var(--terracotta-btn);
  color: var(--white);
  box-shadow: 0 10px 24px rgba(var(--terracotta-rgb), 0.4);
}

.lightbox-prev:hover { transform: translateY(-50%) scale(1.08) translateX(-4px); }
.lightbox-next:hover { transform: translateY(-50%) scale(1.08) translateX(4px); }

/* Responsive Lightbox */
@media (max-width: 768px) {
  .lightbox-content { max-width: 90vw; }
  .lightbox-close { top: 20px; right: 24px; font-size: 2.6rem; }
  .lightbox-prev, .lightbox-next {
    width: 48px;
    height: 48px;
    font-size: 1.1rem;
    background: rgba(26, 37, 53, 0.7);
    border-color: rgba(255, 255, 255, 0.15);
  }
  .lightbox-prev { left: 16px; }
  .lightbox-next { right: 16px; }
  .lightbox-prev:hover { transform: translateY(-50%) scale(1.05) translateX(-2px); }
  .lightbox-next:hover { transform: translateY(-50%) scale(1.05) translateX(2px); }
}


/* =============================================
   PAGE LOADER
============================================= */
#page-loader {
  position: fixed;
  inset: 0;
  z-index: 99999;
  background: var(--off-white);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: 0;
  transition: opacity 0.6s ease, visibility 0.6s ease;
  opacity: 1;
  visibility: visible;
}

#page-loader.loader-done {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}

.loader-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
}

.loader-logo {
  width: 60px;
  height: 60px;
  object-fit: contain;
  margin-bottom: 8px;
  animation: loaderLogoIn 0.6s cubic-bezier(0.16,1,0.3,1) both;
}

@keyframes loaderLogoIn {
  from { opacity: 0; transform: translateY(-12px); }
  to   { opacity: 1; transform: translateY(0); }
}

.loader-label {
  font-size: 0.68rem;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(var(--charcoal-rgb),0.4);
  margin-top: 8px;
}

/* Loading spinner (exact from spec) */
.loadingspinner {
  --square: 26px;
  --offset: 30px;
  --duration: 2.4s;
  --delay: 0.2s;
  --timing-function: ease-in-out;
  --in-duration: 0.4s;
  --in-delay: 0.1s;
  --in-timing-function: ease-out;
  width: calc(3 * var(--offset) + var(--square));
  height: calc(2 * var(--offset) + var(--square));
  padding: 0;
  margin: 10px auto 8px;
  position: relative;
}

.loadingspinner div {
  display: inline-block;
  background: var(--terracotta);
  border: none;
  border-radius: 2px;
  width: var(--square);
  height: var(--square);
  position: absolute;
  padding: 0;
  margin: 0;
}

.loadingspinner #square1 {
  left: calc(0 * var(--offset)); top: calc(0 * var(--offset));
  animation:
    square1     var(--duration)    var(--delay)             var(--timing-function)    infinite,
    squarefadein var(--in-duration) calc(1 * var(--in-delay)) var(--in-timing-function) both;
}
.loadingspinner #square2 {
  left: calc(0 * var(--offset)); top: calc(1 * var(--offset));
  animation:
    square2     var(--duration)    var(--delay)             var(--timing-function)    infinite,
    squarefadein var(--in-duration) calc(1 * var(--in-delay)) var(--in-timing-function) both;
}
.loadingspinner #square3 {
  left: calc(1 * var(--offset)); top: calc(1 * var(--offset));
  animation:
    square3     var(--duration)    var(--delay)             var(--timing-function)    infinite,
    squarefadein var(--in-duration) calc(2 * var(--in-delay)) var(--in-timing-function) both;
}
.loadingspinner #square4 {
  left: calc(2 * var(--offset)); top: calc(1 * var(--offset));
  animation:
    square4     var(--duration)    var(--delay)             var(--timing-function)    infinite,
    squarefadein var(--in-duration) calc(3 * var(--in-delay)) var(--in-timing-function) both;
}
.loadingspinner #square5 {
  left: calc(3 * var(--offset)); top: calc(1 * var(--offset));
  animation:
    square5     var(--duration)    var(--delay)             var(--timing-function)    infinite,
    squarefadein var(--in-duration) calc(4 * var(--in-delay)) var(--in-timing-function) both;
}

@keyframes square1 {
  0%     { left: calc(0 * var(--offset)); top: calc(0 * var(--offset)); }
  8.333% { left: calc(0 * var(--offset)); top: calc(1 * var(--offset)); }
  100%   { left: calc(0 * var(--offset)); top: calc(1 * var(--offset)); }
}
@keyframes square2 {
  0%     { left: calc(0 * var(--offset)); top: calc(1 * var(--offset)); }
  8.333% { left: calc(0 * var(--offset)); top: calc(2 * var(--offset)); }
  16.67% { left: calc(1 * var(--offset)); top: calc(2 * var(--offset)); }
  25.00% { left: calc(1 * var(--offset)); top: calc(1 * var(--offset)); }
  83.33% { left: calc(1 * var(--offset)); top: calc(1 * var(--offset)); }
  91.67% { left: calc(1 * var(--offset)); top: calc(0 * var(--offset)); }
  100%   { left: calc(0 * var(--offset)); top: calc(0 * var(--offset)); }
}
@keyframes square3 {
  0%,100% { left: calc(1 * var(--offset)); top: calc(1 * var(--offset)); }
  16.67%  { left: calc(1 * var(--offset)); top: calc(1 * var(--offset)); }
  25.00%  { left: calc(1 * var(--offset)); top: calc(0 * var(--offset)); }
  33.33%  { left: calc(2 * var(--offset)); top: calc(0 * var(--offset)); }
  41.67%  { left: calc(2 * var(--offset)); top: calc(1 * var(--offset)); }
  66.67%  { left: calc(2 * var(--offset)); top: calc(1 * var(--offset)); }
  75.00%  { left: calc(2 * var(--offset)); top: calc(2 * var(--offset)); }
  83.33%  { left: calc(1 * var(--offset)); top: calc(2 * var(--offset)); }
  91.67%  { left: calc(1 * var(--offset)); top: calc(1 * var(--offset)); }
}
@keyframes square4 {
  0%     { left: calc(2 * var(--offset)); top: calc(1 * var(--offset)); }
  33.33% { left: calc(2 * var(--offset)); top: calc(1 * var(--offset)); }
  41.67% { left: calc(2 * var(--offset)); top: calc(2 * var(--offset)); }
  50.00% { left: calc(3 * var(--offset)); top: calc(2 * var(--offset)); }
  58.33% { left: calc(3 * var(--offset)); top: calc(1 * var(--offset)); }
  100%   { left: calc(3 * var(--offset)); top: calc(1 * var(--offset)); }
}
@keyframes square5 {
  0%     { left: calc(3 * var(--offset)); top: calc(1 * var(--offset)); }
  50.00% { left: calc(3 * var(--offset)); top: calc(1 * var(--offset)); }
  58.33% { left: calc(3 * var(--offset)); top: calc(0 * var(--offset)); }
  66.67% { left: calc(2 * var(--offset)); top: calc(0 * var(--offset)); }
  75.00% { left: calc(2 * var(--offset)); top: calc(1 * var(--offset)); }
  100%   { left: calc(2 * var(--offset)); top: calc(1 * var(--offset)); }
}
@keyframes squarefadein {
  0%   { transform: scale(0.75); opacity: 0; }
  100% { transform: scale(1);    opacity: 1; }
}

/* =============================================
   OUR CLIENTS SECTION
============================================= */
.clients-section {
  background: var(--off-white);
  padding: clamp(80px, 10vw, 130px) clamp(24px, 5vw, 72px);
  border-top: 1px solid var(--border);
}

.clients-inner {
  max-width: 1320px;
  margin: 0 auto;
}

.clients-header {
  margin-bottom: clamp(48px, 6vw, 72px);
  max-width: 680px;
}

.clients-header h2 {
  font-family: 'Outfit', sans-serif;
  font-weight: 700;
  font-size: clamp(2rem, 3.5vw, 3.2rem);
  line-height: 1.1;
  color: var(--charcoal);
  letter-spacing: -0.01em;
}

.clients-sub {
  font-size: 1rem;
  color: var(--charcoal-light);
  line-height: 1.75;
  margin-top: 14px;
  max-width: 560px;
}

/* ── Clients horizontal infinite marquee ── */
.clients-marquee-wrap {
  width: 100%;
  overflow: hidden;
  position: relative;
  /* soft edge fade */
  -webkit-mask-image: linear-gradient(to right, transparent 0%, black 8%, black 92%, transparent 100%);
          mask-image: linear-gradient(to right, transparent 0%, black 8%, black 92%, transparent 100%);
}

/*
  The track contains TWO identical sets of logos back-to-back.
  We animate from 0 → -50% so the second set slides in perfectly
  as the first set exits — creating a gapless loop.
*/
.clients-marquee-track {
  display: flex;
  flex-wrap: nowrap;           /* never wrap */
  width: max-content;          /* shrink-wrap to content */
  will-change: transform;
  animation: clientsLoop 28s linear infinite;
}

/* Pause on hover */
.clients-marquee-wrap:hover .clients-marquee-track {
  animation-play-state: paused;
}

@keyframes clientsLoop {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

/* Individual logo card */
.client-logo-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 20px 52px;
  flex-shrink: 0;               /* never shrink */
  cursor: default;
  transition: transform 0.3s ease;
}

.client-logo-item:hover {
  transform: translateY(-4px);
}

.client-logo-item img {
  height: 60px;
  width: auto;
  max-width: 150px;
  object-fit: contain;
  display: block;
  filter: grayscale(100%) opacity(0.5);
  transition: filter 0.35s ease;
}

.client-logo-item:hover img {
  filter: grayscale(0%) opacity(1);
}

.client-logo-item span {
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.07em;
  color: rgba(var(--charcoal-rgb),0.38);
  white-space: nowrap;
  text-align: center;
  transition: color 0.3s ease;
}

.client-logo-item:hover span {
  color: var(--terracotta-btn);
}

/* =============================================
   TESTIMONIALS SECTION
============================================= */
.testimonials-section {
  background: var(--gradient-warm);
  padding: clamp(80px,10vw,130px) clamp(24px,5vw,72px);
  position: relative;
  overflow: hidden;
}

.testimonials-section::before {
  content: '';
  position: absolute;
  top: -10%;
  right: -8%;
  width: 420px;
  height: 420px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(var(--terracotta-rgb),0.10), transparent 70%);
  pointer-events: none;
}

.testimonials-inner {
  max-width: 1320px;
  margin: 0 auto;
  position: relative;
  z-index: 1;
}

.testimonials-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
  perspective: 1200px;
}

.testimonial-card {
  background: var(--surface-glass-strong);
  backdrop-filter: blur(16px) saturate(1.3);
  -webkit-backdrop-filter: blur(16px) saturate(1.3);
  border: 1px solid rgba(255,255,255,0.6);
  border-radius: var(--radius-md);
  padding: 36px 32px;
  box-shadow: var(--shadow-md);
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 20px;
  transition: transform var(--dur-medium) var(--ease-smooth), box-shadow var(--dur-medium) var(--ease-smooth);
}

.testimonial-card:hover {
  transform: translateY(-10px) scale(1.02) rotateX(2deg);
  box-shadow: var(--shadow-lg);
}

.testimonial-quote-mark {
  color: rgba(var(--terracotta-rgb), 0.28);
}

.testimonial-quote {
  margin: 0;
  font-size: 1rem;
  line-height: 1.7;
  color: var(--charcoal);
  font-style: normal;
  flex: 1;
}

.testimonial-author {
  display: flex;
  align-items: center;
  gap: 14px;
  margin: 0;
  padding-top: 16px;
  border-top: 1px solid rgba(var(--charcoal-rgb), 0.08);
}

.testimonial-avatar {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  object-fit: cover;
  flex-shrink: 0;
  box-shadow: 0 2px 8px rgba(var(--shadow-color), 0.12);
}

.testimonial-avatar--initial {
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, var(--terracotta-btn) 0%, var(--terracotta-btn-hover) 100%);
  color: #fff;
  font-family: 'Outfit', sans-serif;
  font-weight: 700;
  font-size: 1.1rem;
}

.testimonial-author-info {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.testimonial-author-name {
  font-family: 'Outfit', sans-serif;
  font-weight: 600;
  font-size: 0.9375rem;
  color: var(--charcoal);
}

.testimonial-author-role {
  font-size: 0.8125rem;
  color: var(--charcoal-light);
}

@media (max-width: 1000px) {
  .testimonials-grid { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 640px) {
  .testimonials-grid { grid-template-columns: 1fr; }
}

/* =============================================
   CAREERS SECTION
============================================= */
.careers-section {
  background: var(--off-white);
  padding: clamp(80px, 10vw, 130px) clamp(24px, 5vw, 72px);
  position: relative;
}

.careers-inner {
  max-width: 1320px;
  margin: 0 auto;
}

.careers-header {
  margin-bottom: clamp(48px, 6vw, 72px);
  max-width: 680px;
}

.careers-header h2 {
  font-family: 'Outfit', sans-serif;
  font-weight: 700;
  font-size: clamp(2rem, 3.5vw, 3.2rem);
  line-height: 1.1;
  color: var(--charcoal);
  letter-spacing: -0.01em;
}

.careers-sub {
  font-size: 1rem;
  color: var(--charcoal-light);
  line-height: 1.75;
  margin-top: 14px;
  max-width: 560px;
}

/* 2-column grid */
.careers-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px;
}

.career-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 20px;
  padding: clamp(24px, 3vw, 36px);
  display: flex;
  flex-direction: column;
  gap: 16px;
  transition: transform 0.3s ease, box-shadow 0.3s ease, border-color 0.3s ease;
  position: relative;
  overflow: hidden;
}

.career-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: var(--terracotta);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.career-card:hover::before { transform: scaleX(1); }

.career-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 16px 48px rgba(var(--charcoal-rgb),0.1);
  border-color: rgba(var(--terracotta-btn-rgb),0.15);
}

.career-card-icon {
  width: 52px; height: 52px;
  border-radius: 14px;
  background: rgba(var(--terracotta-btn-rgb),0.08);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.5rem;
  flex-shrink: 0;
}

.career-card-body {
  display: flex;
  flex-direction: column;
  gap: 8px;
  flex: 1;
}

.career-tag {
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--terracotta-btn);
}

.career-title {
  font-family: 'Outfit', sans-serif;
  font-weight: 600;
  font-size: 1.1rem;
  color: var(--charcoal);
  line-height: 1.3;
}

.career-desc {
  font-size: 0.875rem;
  color: var(--charcoal-light);
  line-height: 1.65;
}

.career-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 4px;
}

.career-badge {
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  padding: 4px 12px;
  border-radius: 100px;
}

.career-badge--type {
  background: #FEF3C7;
  color: #92400E;
  border: 1px solid rgba(146,64,14,0.18);
}

.career-badge--loc {
  background: rgba(var(--charcoal-rgb),0.06);
  color: var(--charcoal-light);
  border: 1px solid var(--border);
}

.career-apply-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 0.8rem;
  font-weight: 700;
  color: var(--terracotta-btn);
  letter-spacing: 0.03em;
  transition: gap 0.25s ease, color 0.25s ease;
  text-decoration: none;
  margin-top: auto;
  padding-top: 8px;
  border-top: 1px solid var(--border);
}

.career-apply-btn:hover {
  gap: 10px;
  color: var(--terracotta-btn-hover);
}

/* Open application CTA */
.careers-open-cta {
  margin-top: clamp(48px, 6vw, 72px);
  padding: clamp(32px, 4vw, 48px) clamp(28px, 4vw, 48px);
  background: var(--charcoal);
  border-radius: 20px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 32px;
  flex-wrap: wrap;
}

.careers-open-cta p {
  font-size: clamp(1rem, 1.8vw, 1.25rem);
  color: rgba(255,255,255,0.85);
  font-weight: 400;
  line-height: 1.5;
  flex: 1;
  min-width: 240px;
}

.careers-open-cta .magnetic-btn {
  flex-shrink: 0;
  font-size: 0.9rem;
  padding: 13px 28px;
  white-space: nowrap;
}

@media (max-width: 768px) {
  .careers-grid { grid-template-columns: 1fr; }
  .careers-open-cta { flex-direction: column; text-align: center; }
  .careers-open-cta .magnetic-btn { width: 100%; justify-content: center; }
}

/* =============================================
   WORDPRESS CORE COMPATIBILITY
   (added during theme conversion — does not alter
   original design, only maps WP-generated markup
   onto the existing classes/selectors above)
============================================= */

/* WP core image alignment / caption classes */
.alignleft { float: left; margin: 0 24px 16px 0; }
.alignright { float: right; margin: 0 0 16px 24px; }
.aligncenter { display: block; margin: 0 auto 16px; }
.wp-caption, .wp-block-image figcaption, .alignleft, .alignright, .aligncenter { max-width: 100%; }
.wp-caption-text, figcaption { font-size: 0.8rem; color: var(--charcoal-light); margin-top: 6px; }
.gallery { display: flex; flex-wrap: wrap; gap: 12px; }
.gallery-item { margin: 0; }
.gallery-item img { border-radius: 12px; }
.bypostauthor { display: block; }
.sticky { }
.screen-reader-text {
  border: 0; clip: rect(1px,1px,1px,1px); clip-path: inset(50%);
  height: 1px; margin: -1px; overflow: hidden; padding: 0;
  position: absolute !important; width: 1px; word-wrap: normal !important;
}
.screen-reader-text:focus {
  background-color: var(--white); border-radius: 4px; box-shadow: 0 0 4px rgba(0,0,0,0.3);
  clip: auto !important; clip-path: none; color: var(--charcoal); display: block;
  font-size: 0.875rem; font-weight: 600; height: auto; left: 6px; line-height: normal;
  padding: 12px 18px; text-decoration: none; top: 6px; width: auto; z-index: 100000;
}

/* Skip link */
.skip-link {
  left: -9999px; position: absolute; top: -9999px;
}
.skip-link:focus { left: 6px; top: 6px; z-index: 100000; }

/* wp_nav_menu wraps the same markup we already style —
   make sure submenu (if editor adds children) degrades gracefully */
.main-nav .sub-menu, .mobile-overlay .sub-menu { display: none; }
.main-nav ul { display: contents; }

/* WordPress core block / editor default content inside the_content() on
   inner pages (page.php, single.php) — keeps long-form content readable
   while matching the brand fonts/colors used across the static design */
.wp-content-area {
  max-width: 760px;
  margin: 0 auto;
  padding: clamp(120px, 14vw, 160px) clamp(24px, 5vw, 72px) clamp(80px, 8vw, 120px);
}
.wp-content-area h1 { font-family:'Outfit',sans-serif; font-weight:700; font-size:clamp(2rem,4vw,3rem); color:var(--charcoal); margin-bottom:20px; line-height:1.15; }
.wp-content-area h2 { font-family:'Outfit',sans-serif; font-weight:700; font-size:clamp(1.5rem,3vw,2.1rem); color:var(--charcoal); margin:36px 0 16px; line-height:1.25; }
.wp-content-area h3 { font-family:'Outfit',sans-serif; font-weight:600; font-size:1.3rem; color:var(--charcoal); margin:28px 0 12px; }
.wp-content-area p { margin-bottom:18px; color:var(--charcoal-light); font-size:1rem; line-height:1.8; }
.wp-content-area ul, .wp-content-area ol { margin: 0 0 18px 1.4em; color: var(--charcoal-light); }
.wp-content-area li { margin-bottom: 8px; }
.wp-content-area a { color: var(--terracotta-btn); text-decoration: underline; text-decoration-color: rgba(var(--terracotta-btn-rgb),0.35); }
.wp-content-area a:hover { text-decoration-color: var(--terracotta-btn); }
.wp-content-area img { border-radius: 16px; margin: 24px 0; }
.wp-content-area blockquote {
  border-left: 3px solid var(--terracotta);
  padding: 4px 0 4px 24px;
  margin: 28px 0;
  font-style: italic;
  color: var(--charcoal);
  font-size: 1.1rem;
}
.wp-content-area table { width:100%; border-collapse:collapse; margin-bottom:24px; }
.wp-content-area table th, .wp-content-area table td { padding:12px 16px; border:1px solid var(--border); text-align:left; }
.wp-content-area table th { background: rgba(var(--terracotta-btn-rgb),0.06); font-weight:600; }
.wp-content-area .page-title, .wp-content-area .entry-title {
  font-family:'Outfit',sans-serif; font-weight:700; font-size:clamp(2rem,4vw,3rem); color:var(--charcoal); margin-bottom:16px;
}
.wp-content-area .entry-meta {
  font-size: 0.8rem; letter-spacing:0.04em; text-transform:uppercase; color: var(--sage-text);
  font-weight: 600; margin-bottom: 28px; display:flex; gap:10px; flex-wrap:wrap;
}
.wp-content-area .entry-thumbnail { margin-bottom: 32px; }
.wp-content-area .entry-thumbnail img { width:100%; height:auto; border-radius:20px; }
.wp-content-area .post-list { display:flex; flex-direction:column; gap:40px; }
.wp-content-area .post-list article { padding-bottom:32px; border-bottom:1px solid var(--border); }
.wp-content-area .post-list .entry-title a { text-decoration:none; color:var(--charcoal); }
.wp-content-area .post-list .entry-title a:hover { color: var(--terracotta-btn); }
.wp-content-area .pagination, .wp-content-area .nav-links {
  display:flex; gap:12px; justify-content:space-between; margin-top:40px; flex-wrap:wrap;
}
.wp-content-area .pagination a, .wp-content-area .pagination span,
.wp-content-area .nav-links a, .wp-content-area .nav-links span {
  padding:10px 18px; border:1px solid var(--border); border-radius:100px; font-size:0.85rem; font-weight:600;
}
.wp-content-area .pagination .current, .wp-content-area .nav-links .current {
  background: linear-gradient(135deg, var(--terracotta-btn) 0%, var(--terracotta-btn-hover) 100%); color:#fff; border-color: var(--terracotta-btn);
}

/* Breadcrumbs (Rank Math / custom fallback) */
.skenllp-breadcrumbs {
  max-width: 1320px; margin: 0 auto;
  padding: calc(var(--header-h) + 24px) clamp(24px,5vw,72px) 0;
  font-size: 0.8rem; color: var(--charcoal-light);
}
.skenllp-breadcrumbs a { color: var(--charcoal-light); text-decoration:underline; text-decoration-color:transparent; transition: text-decoration-color .2s ease; }
.skenllp-breadcrumbs a:hover { color: var(--terracotta-btn); text-decoration-color: var(--terracotta-btn); }
.skenllp-breadcrumbs .sep { margin: 0 8px; opacity: 0.5; }

/* Comments (comments.php) */
.comments-area { max-width: 760px; margin: 60px auto 0; padding: 0 clamp(24px,5vw,72px); }
.comments-title, .comment-reply-title { font-family:'Outfit',sans-serif; font-weight:700; font-size:1.5rem; color:var(--charcoal); margin-bottom:24px; }
.comment-list { list-style:none; margin:0 0 32px; }
.comment-list .comment { padding: 20px 0; border-bottom: 1px solid var(--border); }
.comment-list .comment-author { font-weight:600; color: var(--charcoal); font-size:0.95rem; }
.comment-list .comment-metadata { font-size:0.75rem; color: var(--charcoal-light); margin-bottom:8px; }
.comment-list .comment-content p { color: var(--charcoal-light); font-size:0.9375rem; line-height:1.7; }
.comment-respond .comment-form input,
.comment-respond .comment-form textarea {
  width:100%; padding:14px 16px; border:1px solid var(--border); border-radius:10px;
  font-family:'Inter',sans-serif; font-size:0.9375rem; margin-bottom:14px; background:var(--white);
}
.comment-respond .comment-form textarea { resize: vertical; min-height:120px; }
.comment-respond .form-submit input[type="submit"] {
  display:inline-flex; align-items:center; gap:8px; font-weight:600; font-size:0.875rem;
  letter-spacing:0.04em; padding:13px 26px; border-radius:100px; cursor:pointer; border:none;
  background: linear-gradient(135deg, var(--terracotta-btn) 0%, var(--terracotta-btn-hover) 100%); color:#fff; box-shadow: var(--shadow-orange);
  transition: box-shadow var(--dur-fast) var(--ease-smooth), transform var(--dur-fast) var(--ease-smooth);
}
.comment-respond .form-submit input[type="submit"]:hover { box-shadow: var(--shadow-orange-lg); transform: translateY(-3px) scale(1.03); }

/* 404 page */
.error-404-wrap {
  min-height: 70vh; display:flex; flex-direction:column; align-items:center; justify-content:center;
  text-align:center; padding: calc(var(--header-h) + 40px) 24px 80px;
}
.error-404-wrap .error-code {
  font-family:'Outfit',sans-serif; font-weight:700; font-size:clamp(4rem,12vw,8rem); color:var(--terracotta); line-height:1;
}
.error-404-wrap h1 { font-family:'Outfit',sans-serif; font-weight:700; font-size:clamp(1.5rem,3vw,2rem); color:var(--charcoal); margin:12px 0 16px; }
.error-404-wrap p { color:var(--charcoal-light); margin-bottom:28px; max-width:480px; }

/* Search form (search.php / searchform.php) */
.skenllp-search-form { display:flex; gap:10px; max-width:560px; margin: 0 auto 40px; }
.skenllp-search-form input[type="search"] {
  flex:1; padding:14px 18px; border:1px solid var(--border); border-radius:100px; font-size:0.9375rem;
}
.skenllp-search-form button {
  border:none; background: linear-gradient(135deg, var(--terracotta-btn) 0%, var(--terracotta-btn-hover) 100%); color:#fff; padding:0 24px; border-radius:100px;
  font-weight:600; cursor:pointer; transition: transform var(--dur-fast) var(--ease-smooth), box-shadow var(--dur-fast) var(--ease-smooth);
}
.skenllp-search-form button:hover { transform: translateY(-2px); box-shadow: var(--shadow-orange); }

/* Sidebar widgets */
.widget-area { display:flex; flex-direction:column; gap:32px; }
.widget { background:var(--white); border:1px solid var(--border); border-radius:16px; padding:28px; }
.widget-title { font-family:'Outfit',sans-serif; font-weight:700; font-size:1.05rem; color:var(--charcoal); margin-bottom:16px; }
.widget ul { display:flex; flex-direction:column; gap:10px; }
.widget a { color: var(--charcoal-light); text-decoration:none; transition:color .2s ease; }
.widget a:hover { color: var(--terracotta-btn); }
.with-sidebar-layout { display:grid; grid-template-columns: 2.2fr 1fr; gap:48px; max-width:1180px; margin:0 auto; padding: calc(var(--header-h) + 40px) clamp(24px,5vw,72px) 80px; align-items:start; }
@media (max-width:900px){ .with-sidebar-layout { grid-template-columns: 1fr; } }

/* Footer widget area (4-col) — sits below the main contact footer in
   a contained, branded strip so widgets never look disconnected from
   the rest of the off-white + orange design system. */
.site-footer-extra {
  background: var(--white);
  border-top: 1px solid var(--border);
}

.footer-widgets-area {
  max-width:1320px; margin:0 auto; padding: 48px clamp(24px,5vw,72px) 8px;
  display:grid; grid-template-columns:repeat(4,1fr); gap:32px;
}
.footer-widgets-area .widget-title {
  color: var(--charcoal);
  font-family: 'Outfit', sans-serif;
  font-weight: 700;
  font-size: 0.95rem;
  letter-spacing: 0.02em;
  margin-bottom: 16px;
  position: relative;
  padding-bottom: 10px;
}
.footer-widgets-area .widget-title::after {
  content: '';
  position: absolute;
  left: 0; bottom: 0;
  width: 28px; height: 2px;
  background: var(--gradient-orange);
  border-radius: 2px;
}
.footer-widgets-area .widget { background:transparent; border:none; padding:0; }
.footer-widgets-area a { color: var(--charcoal-light); text-decoration: none; transition: color var(--dur-fast) ease, padding-left var(--dur-fast) ease; }
.footer-widgets-area a:hover { color: var(--terracotta-btn); padding-left: 4px; }
@media (max-width:900px){ .footer-widgets-area { grid-template-columns:repeat(2,1fr); } }
@media (max-width:600px){ .footer-widgets-area { grid-template-columns:1fr; } }

/* Footer menu */
.footer-menu-wrap {
  max-width: 1320px;
  margin: 0 auto;
  padding: 8px clamp(24px,5vw,72px) 40px;
}
.footer-widgets-area + .footer-menu-wrap {
  border-top: 1px solid var(--border);
  margin-top: 24px;
  padding-top: 24px;
}
.footer-menu { display:flex; flex-wrap:wrap; gap:24px; list-style:none; }
.footer-menu a { color: var(--charcoal-light); font-size:0.875rem; text-decoration: none; transition: color var(--dur-fast) ease; }
.footer-menu a:hover { color: var(--terracotta-btn); }

/* Portfolio CPT archive/single grid */
.portfolio-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; max-width:1320px; margin:0 auto; padding: calc(var(--header-h) + 40px) clamp(24px,5vw,72px) 80px; }
.portfolio-card { border-radius:20px; overflow:hidden; background:var(--white); border:1px solid var(--border); transition:transform .3s ease, box-shadow .3s ease; }
.portfolio-card:hover { transform:translateY(-6px); box-shadow:0 16px 48px rgba(var(--charcoal-rgb),0.12); }
.portfolio-card img { width:100%; aspect-ratio:4/3; object-fit:cover; }
.portfolio-card .portfolio-card-body { padding:20px; }
.portfolio-card h3 { font-family:'Outfit',sans-serif; font-weight:600; font-size:1.1rem; color:var(--charcoal); margin-bottom:6px; }
.portfolio-card p { font-size:0.875rem; color:var(--charcoal-light); }
@media (max-width:900px){ .portfolio-grid { grid-template-columns:repeat(2,1fr); } }
@media (max-width:600px){ .portfolio-grid { grid-template-columns:1fr; } }

/* Lazysizes / native lazy-load helper */
img[loading="lazy"] { background: rgba(var(--charcoal-rgb),0.04); }

/* Reduced-motion safety (WP customizer "disable animations" toggle) */
body.skenllp-reduce-motion .reveal-line,
body.skenllp-reduce-motion .sr,
body.skenllp-reduce-motion * { transition: none !important; animation: none !important; }

/* FAQ accordion (template-faq.php) */
.skenllp-faq-item summary::-webkit-details-marker { display: none; }
.skenllp-faq-item summary { position: relative; padding-right: 28px; }
.skenllp-faq-item summary::after {
  content: '+'; position: absolute; right: 0; top: 0; font-size: 1.3rem; color: var(--terracotta-btn);
  transition: transform 0.3s ease;
}
.skenllp-faq-item[open] summary::after { transform: rotate(45deg); }
