/* ═══════════════════════════════════════════════════════════════
   SEAMLESS EDGE — MASTER CSS v6 (Feminine Premium Tech Edition)
   Tokens sourced externally from root-variables.css
   ═══════════════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,600;0,700;1,400;1,600&family=Outfit:wght@300;400;500;600;700;800&display=swap');

/* ─── RESET ─── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; font-size:16px; overflow-x: hidden; }
body {
  font-family: var(--f-body);
  color: var(--ink-600);
  background: var(--white);
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
  max-width: 100vw;
}
img { display:block; max-width:100%; height:auto; }
a   { color:var(--primary-blue); text-decoration:none; transition:color var(--e-fast); }
a:hover { color:var(--primary-pink); }
ul  { list-style:none; }
button { cursor:pointer; font-family:inherit; }

/* ─── TYPOGRAPHY ─── */
h1,h2,h3,h4,h5,h6 {
  font-family: var(--f-display);
  font-weight: 700;
  line-height: 1.15;
  color: var(--midnight-900);
  letter-spacing: -.01em;
}
h1 { font-size: clamp(2.4rem, 5vw, 4.2rem); }
h2 { font-size: clamp(1.9rem, 3.5vw, 3rem);  }
h3 { font-size: clamp(1.2rem, 2vw, 1.65rem); }
h4 { font-size: 1.15rem; font-family:var(--f-body); font-weight:700; }
p  { line-height: 1.8; color: var(--ink-500); }

/* Eyebrow - Updated to soft elegant pink */
.eyebrow {
  display: inline-block;
  font-family: var(--f-body);
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--primary-pink);
  position: relative;
  padding: 0 var(--s4);
}
.eyebrow::before, .eyebrow::after {
  content:'';
  position:absolute; top:50%; transform:translateY(-50%);
  width:20px; height:1px;
  background: var(--primary-pink); opacity:.55;
}
.eyebrow::before { right:100%; }
.eyebrow::after  { left:100%;  }

/* Brand rule - Updated to Feminine Gradient */
.gold-rule, .brand-rule {
  width:52px; height:3px;
  background: var(--g-feminine);
  border-radius:2px;
  margin: var(--s4) auto 0;
  box-shadow: var(--glow-pink-xs);
}
.gold-rule.left, .brand-rule.left { margin-left:0; }

/* Section header */
.section-header { text-align:center; margin-bottom: var(--s12); }
.section-header h2 {
  color: var(--midnight-800);
  margin: var(--s3) 0 var(--s2);
}
.section-header p {
  max-width: 580px;
  margin: var(--s4) auto 0;
  font-size: 1.05rem;
  color: var(--ink-500);
}

/* Utils */
.text-gold  { color:var(--primary-blue)!important; }
.text-white { color:var(--white)!important; }
.text-muted { color:var(--ink-400)!important; }
.text-center{ text-align:center; }

/* ─── LAYOUT ─── */
.container {
  width: 100%;
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 0 var(--s6);
  min-width: 0;
  box-sizing: border-box;
}
.section    { padding: var(--s20) 0; }
.section-sm { padding: var(--s12) 0; }
.bg-light   { background: var(--primary-gray); }
.bg-white   { background: var(--white); }
.mt-6       { margin-top: var(--s6); }
.mt-8       { margin-top: var(--s8); }

/* ═══════════════════════════════════════════════════════════════
   BUTTONS - Elevated with Feminine Gradients
   ═══════════════════════════════════════════════════════════════ */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--s2);
  padding: .82rem 2.2rem;
  border: none;
  border-radius: var(--r);
  font-family: var(--f-body);
  font-size: .92rem;
  font-weight: 600;
  letter-spacing: .04em;
  cursor: pointer;
  transition: all var(--e);
  white-space: nowrap;
  position: relative;
  overflow: hidden;
  text-decoration: none;
  -webkit-font-smoothing: antialiased;
}
/* Shimmer sweep */
.btn::after {
  content:'';
  position:absolute; top:-60%; left:-70%;
  width:45%; height:220%;
  background: rgba(255,255,255,.22);
  transform: skewX(-20deg) translateX(0);
  transition: transform .6s ease;
}
.btn:hover::after { transform: skewX(-20deg) translateX(400%); }

/* PRIMARY — Feminine Gradient */
.btn-primary {
  background: var(--g-feminine);
  color: var(--white);
  box-shadow: var(--sh-pink);
  border: 1px solid rgba(255,255,255,.2);
}
.btn-primary:hover {
  transform: translateY(-3px);
  color: var(--white);
  box-shadow: var(--glow-pink), var(--sh-pink);
}

/* SECONDARY — Midnight & Lavender */
.btn-secondary {
  background: var(--midnight-600);
  color: var(--white);
  border: 1px solid var(--midnight-500);
}
.btn-secondary:hover {
  background: var(--midnight-500);
  transform: translateY(-3px);
  box-shadow: var(--glow-purple-sm);
  color: var(--white);
}

/* GHOST — on dark bg */
.btn-ghost {
  background: rgba(255,255,255,.08);
  color: var(--white);
  border: 1.5px solid rgba(255,255,255,.28);
  backdrop-filter: blur(8px);
}
.btn-ghost:hover {
  background: rgba(244,114,182,.14);
  border-color: var(--pink-400);
  color: var(--pink-100);
  box-shadow: var(--glow-pink-sm);
}

/* DARK — on CTA bg */
.btn-dark {
  display: inline-flex;
  align-items: center;
  gap: var(--s2);
  padding: .9rem 2.6rem;
  background: var(--obsidian);
  color: var(--white);
  border: 2px solid var(--obsidian);
  border-radius: var(--r);
  font-family: var(--f-body);
  font-weight: 700;
  font-size: .95rem;
  letter-spacing: .04em;
  cursor: pointer;
  transition: all var(--e);
  text-decoration: none;
  overflow: hidden;
  position: relative;
}
.btn-dark::after {
  content:'';
  position:absolute; top:-60%; left:-70%;
  width:45%; height:220%;
  background: rgba(255,255,255,.14);
  transform: skewX(-20deg);
  transition: transform .6s ease;
}
.btn-dark:hover::after { transform: skewX(-20deg) translateX(400%); }
.btn-dark:hover {
  background: transparent;
  color: var(--white);
  transform: translateY(-3px);
  box-shadow: 0 8px 24px rgba(0,0,0,.2);
  border-color: var(--white);
}
.btn-lg    { padding:1rem 2.8rem; font-size:1rem; }
.btn-sm    { padding:.5rem 1.2rem; font-size:.82rem; }
.btn-block { width:100%; }

/* ═══════════════════════════════════════════════════════════════
   NAVBAR WRAPPER
   ═══════════════════════════════════════════════════════════════ */
.navbar-wrapper {
  position: sticky;
  top: 0;
  z-index: var(--z-nav);
}

/* ─── MAIN NAVBAR ─── */
.navbar-main {
  background: var(--white);
  padding: var(--s3) 0;
  border-bottom: 1px solid rgba(244,114,182,.1);
  transition: padding var(--e), box-shadow var(--e);
}
.navbar-main .container { display:flex; justify-content:space-between; align-items:center; }

.navbar-brand { z-index:calc(var(--z-nav) + 2); }
.navbar-brand .logo {
  display:flex; align-items:center; gap:var(--s3);
  text-decoration:none; transition:opacity var(--e-fast);
}
.navbar-brand .logo:hover { opacity:.85; }
.navbar-brand .logo-image {
  max-height:56px; width:auto; max-width:210px;
  object-fit:contain;
}
.navbar-brand .logo-text {
  font-family:var(--f-display); font-size:1.5rem; font-weight:700;
  color:var(--midnight-800); letter-spacing:-.02em;
}

/* Desktop menu */
.navbar-menu { display:flex; align-items:center; gap:var(--s1); }
.navbar-menu > li > a {
  display:block; padding:var(--s2) var(--s3);
  font-size:.875rem; font-weight:500;
  color:var(--ink-700);
  border-radius:var(--r-sm);
  transition:all var(--e);
  position:relative;
}
.navbar-menu > li > a::after {
  content:'';
  position:absolute; bottom:0;
  left:var(--s3); right:var(--s3);
  height:2px; background:var(--g-feminine);
  border-radius:1px;
  transform:scaleX(0); transition:transform var(--e);
  box-shadow:var(--glow-pink-xs);
}
.navbar-menu > li > a:hover { color:var(--midnight-800); }
.navbar-menu > li > a:hover::after { transform:scaleX(1); }

.navbar-menu .btn-cta {
  display:inline-flex; align-items:center;
  padding:.6rem 1.5rem;
  background:var(--g-feminine);
  color:var(--white)!important;
  border-radius:var(--r);
  font-weight:700; font-size:.875rem;
  letter-spacing:.03em;
  box-shadow:var(--sh-pink);
  transition:all var(--e);
  overflow:hidden; position:relative;
}
.navbar-menu .btn-cta::after { display:none; }
.navbar-menu .btn-cta:hover {
  transform:translateY(-2px);
  box-shadow:var(--glow-pink), var(--sh-pink);
}

/* Dropdown */
.dropdown { position:relative; }
.dropdown-menu {
  display:none; position:absolute;
  top:calc(100% + 10px); left:0;
  min-width:228px;
  background:var(--white);
  border-radius:var(--r-md);
  box-shadow:var(--sh-xl), 0 0 0 1px rgba(244,114,182,.1);
  border-top:3px solid var(--primary-pink);
  overflow:hidden;
  z-index:calc(var(--z-nav) + 1);
  animation:dropIn 180ms ease forwards;
}
@keyframes dropIn { from{opacity:0;transform:translateY(-8px)} to{opacity:1;transform:translateY(0)} }
.dropdown:hover .dropdown-menu { display:block; }
.dropdown-menu a {
  display:flex; align-items:center;
  padding:.72rem 1.25rem;
  font-size:.87rem; color:var(--ink-700);
  transition:all var(--e-fast);
  border-bottom:1px solid rgba(0,0,0,.04);
}
.dropdown-menu a:hover { background:var(--pink-50); color:var(--midnight-800); padding-left:1.65rem; }
.dropdown-menu li:last-child a { border-bottom:none; }

/* Hamburger */
.navbar-toggle {
  display: none;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 5px;
  width: 44px;
  height: 44px;
  background: var(--midnight-800);
  border: 2px solid var(--primary-pink);
  border-radius: var(--r-sm);
  padding: 8px;
  cursor: pointer;
  z-index: calc(var(--z-nav) + 10);
  position: relative;
  transition: all var(--e-fast);
  flex-shrink: 0;
}
.navbar-toggle:hover {
  background: var(--midnight-700);
  box-shadow: var(--glow-pink-sm);
}
.navbar-toggle span {
  display: block;
  width: 22px;
  height: 2.5px;
  background: var(--primary-pink);
  border-radius: 2px;
  transition: all var(--e);
  pointer-events: none;
}
.navbar-toggle.active span:nth-child(1) { transform: rotate(45deg) translate(5px, 5px); }
.navbar-toggle.active span:nth-child(2) { opacity: 0; transform: scaleX(0); }
.navbar-toggle.active span:nth-child(3) { transform: rotate(-45deg) translate(5px, -5px); }

/* ═══════════════════════════════════════════════════════════════
   MOBILE ASIDE MENU
   ═══════════════════════════════════════════════════════════════ */
.mobile-aside-menu {
  position:fixed; top:0; left:-100%;
  width:min(85vw, 340px);
  height:100vh; height:100dvh;
  background:var(--g-dark);
  color:var(--white);
  z-index:var(--z-mob);
  overflow-y:auto;
  transition:left var(--e-slow);
  box-shadow:6px 0 50px rgba(0,0,0,.6);
  border-right:1px solid rgba(244,114,182,.12);
}
.mobile-aside-menu.active { left:0; }

.mobile-menu-overlay {
  position:fixed; inset:0;
  background:rgba(2,6,23,.72);
  backdrop-filter:blur(6px);
  z-index:var(--z-ov);
  opacity:0; visibility:hidden;
  transition:all var(--e);
}
.mobile-menu-overlay.active { opacity:1; visibility:visible; }

.mobile-menu-inner {
  padding:64px var(--s6) var(--s10);
  min-height:100%;
  display:flex; flex-direction:column;
}

.mobile-logo-wrapper {
  margin-bottom:var(--s8); text-align:center;
  padding-bottom:var(--s6);
  border-bottom:1px solid rgba(255,255,255,.08);
  position:relative;
}
.mobile-logo-wrapper::after {
  content:'';
  position:absolute; bottom:-1px; left:25%; right:25%;
  height:1px; background:var(--g-feminine);
  box-shadow:var(--glow-pink-xs);
}
.mobile-logo-wrapper .logo {
  display:inline-flex; align-items:center; justify-content:center;
  gap:var(--s3); text-decoration:none;
}
.mobile-logo-wrapper .logo-image {
  max-height:74px; width:auto; max-width:75%;
  background:var(--white);
  border:2px solid var(--primary-pink);
  border-radius:var(--r-md);
  padding:8px; object-fit:contain;
  box-shadow:var(--sh-pink), var(--glow-pink-xs);
}
.mobile-logo-wrapper .logo-text {
  font-family:var(--f-display); font-size:1.6rem; font-weight:700; color:var(--white);
}

.mobile-menu-list { flex:1; }
.mobile-menu-list > li { border-bottom:1px solid rgba(255,255,255,.07); }
.mobile-menu-list > li > a {
  display:block; padding:var(--s4) var(--s2);
  color:rgba(255,255,255,.85);
  font-size:1rem; font-weight:500;
  transition:all var(--e-fast);
}
.mobile-menu-list > li > a:hover { color:var(--pink-300); padding-left:var(--s3); }

.mobile-dropdown .dropdown-toggle {
  display:flex; align-items:center; justify-content:space-between; width:100%;
  color:rgba(255,255,255,.85);
}
.mobile-dropdown .dropdown-toggle i { color:rgba(255,255,255,.35); transition:transform var(--e),color var(--e-fast); font-size:.75rem; }
.mobile-dropdown.active .dropdown-toggle i { transform:rotate(180deg); color:var(--pink-400); }
.mobile-dropdown.active .dropdown-toggle { color:var(--pink-300); }

.mobile-submenu {
  max-height:0; overflow:hidden; padding:0;
  transition:max-height .4s ease;
  background:rgba(255,255,255,.05); border-radius:var(--r);
}
.mobile-dropdown.active .mobile-submenu {
  max-height:600px; padding:var(--s2) 0; margin-bottom:var(--s2);
}
.mobile-submenu a {
  display:block; padding:.6rem 1.3rem;
  color:rgba(255,255,255,.65); font-size:.85rem;
  transition:all var(--e-fast);
}
.mobile-submenu a:hover { color:var(--pink-300); padding-left:1.8rem; }

.btn-cta-mobile {
  display:block; margin-top:var(--s8); padding:.95rem var(--s6);
  background:var(--g-feminine); color:var(--white);
  text-align:center; border-radius:var(--r);
  font-weight:700; font-size:1rem;
  transition:all var(--e); box-shadow:var(--sh-pink);
  position:relative; overflow:hidden; text-decoration:none;
}
.btn-cta-mobile::after {
  content:''; position:absolute; top:-60%; left:-70%;
  width:45%; height:220%;
  background:rgba(255,255,255,.22);
  transform:skewX(-20deg); transition:transform .6s ease;
}
.btn-cta-mobile:hover::after { transform:skewX(-20deg) translateX(400%); }
.btn-cta-mobile:hover {
  transform:translateY(-2px);
  box-shadow:var(--glow-pink), var(--sh-pink);
  color:var(--white);
}

/* ═══════════════════════════════════════════════════════════════
   HERO SECTION
   ═══════════════════════════════════════════════════════════════ */
.hero {
  position:relative; overflow:hidden;
  background:var(--g-hero);
  padding:var(--s20) 0 var(--s24);
  min-height:640px;
  display:flex; align-items:center;
}

/* Grain texture */
.hero::before {
  content:''; position:absolute; inset:0;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.04'/%3E%3C/svg%3E");
  opacity:.45; pointer-events:none; z-index:0;
}
/* Top-right soft pink orb */
.hero::after {
  content:''; position:absolute;
  top:-20%; right:-8%;
  width:680px; height:680px;
  background:radial-gradient(circle, rgba(244,114,182,.14) 0%, rgba(244,114,182,.04) 40%, transparent 68%);
  border-radius:50%; pointer-events:none; z-index:0;
  animation:orbPulse 7s ease-in-out infinite;
}
@keyframes orbPulse {
  0%,100% { transform:scale(1) translate(0,0); }
  50%     { transform:scale(1.12) translate(-18px,18px); }
}
/* Bottom-left lavender orb */
.hero-orb2 {
  position:absolute; bottom:-22%; left:-10%;
  width:520px; height:520px;
  background:radial-gradient(circle, rgba(139,92,246,.22) 0%, transparent 65%);
  border-radius:50%; pointer-events:none; z-index:0;
  animation:orbPulse 9s ease-in-out infinite reverse;
}
.hero .container { position:relative; z-index:2; }

.hero-layout {
  display:grid;
  grid-template-columns:54% 1fr;
  align-items:center;
  gap:var(--s16);
}

/* Animated entrance */
.hero-content { animation:heroIn .9s var(--e-slow) both; }
@keyframes heroIn {
  from { opacity:0; transform:translateY(32px); }
  to   { opacity:1; transform:translateY(0); }
}

.hero-content .eyebrow {
  color:var(--pink-300);
  margin-bottom:var(--s5);
  animation:heroIn .7s .1s both;
}
.hero-content .eyebrow::before,
.hero-content .eyebrow::after { background:var(--pink-300); }

/* BIG headline */
.hero-content h1 {
  font-family:var(--f-display);
  font-size: clamp(2.6rem, 5vw, 4.4rem);
  font-weight: 600;
  color: var(--white);
  line-height: 1.1;
  margin-bottom: var(--s5);
  animation: heroIn .7s .18s both;
}
/* Feminine glowing gradient text for .highlight */
.hero-content h1 .highlight {
  background: var(--g-feminine);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  font-style: italic;
  filter: drop-shadow(0 0 18px rgba(244,114,182,.35));
}

.hero-content p {
  font-size: 1.1rem;
  color: rgba(255,255,255,.75);
  line-height: 1.8;
  margin-bottom: var(--s8);
  max-width: 480px;
  animation: heroIn .7s .28s both;
}

.hero-buttons {
  display:flex; gap:var(--s4); flex-wrap:wrap;
  animation: heroIn .7s .38s both;
}

.hero-trust {
  display:flex; align-items:center; gap:var(--s6);
  margin-top:var(--s10); flex-wrap:wrap;
  animation: heroIn .7s .48s both;
}
.hero-trust-item {
  display:flex; align-items:center; gap:var(--s2);
  font-size:.78rem; font-weight:500;
  color:rgba(255,255,255,.55);
  letter-spacing:.02em;
}
.hero-trust-item i { color:var(--pink-400); font-size:.8rem; }

/* Hero image */
.hero-image-wrap { position:relative; animation:heroIn .9s .24s both; }
.hero-image-wrap img {
  width:100%;
  border-radius:var(--r-lg);
  box-shadow:var(--sh-xl), 0 0 50px rgba(244,114,182,.14);
  border:1px solid rgba(244,114,182,.18);
  aspect-ratio:4/3; object-fit:cover;
}
/* Decorative feminine frame */
.hero-image-wrap::before {
  content:'';
  position:absolute; top:-12px; left:-12px; right:16px; bottom:16px;
  border:1.5px solid rgba(244,114,182,.3);
  border-radius:var(--r-lg);
  pointer-events:none; z-index:-1;
  box-shadow:inset 0 0 28px rgba(244,114,182,.05);
}
/* Float badge */
.hero-badge {
  position:absolute; bottom:-18px; left:-16px;
  background:var(--g-feminine); color:var(--white);
  padding:var(--s3) var(--s5);
  border-radius:var(--r-md);
  font-weight:700; font-size:.78rem;
  letter-spacing:.06em; text-transform:uppercase;
  box-shadow:var(--sh-pink), var(--glow-pink-xs);
  z-index:3; white-space:nowrap;
}

/* ═══════════════════════════════════════════════════════════════
   PAGE HERO (inner pages)
   ═══════════════════════════════════════════════════════════════ */
.page-hero {
  background:var(--g-hero);
  padding:var(--s20) 0 var(--s16);
  color:var(--white);
  text-align:center;
  position:relative; overflow:hidden;
}
.page-hero::before {
  content:''; position:absolute; inset:0;
  background:
    radial-gradient(circle at 18% 55%, rgba(244,114,182,.12) 0%, transparent 50%),
    radial-gradient(circle at 82% 22%, rgba(139,92,246,.15) 0%, transparent 50%);
  pointer-events:none;
}
/* Glowing top line */
.page-hero::after {
  content:''; position:absolute; top:0; left:12%; right:12%;
  height:2px; background:var(--g-feminine);
  box-shadow:var(--glow-pink);
}
.page-hero .container { position:relative; z-index:1; }

.page-hero h1 {
  color:transparent;
  background:var(--g-feminine);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
  margin-bottom:var(--s4);
  filter:drop-shadow(0 0 22px rgba(244,114,182,.32));
  font-size:clamp(2.2rem, 5vw, 3.6rem);
}
.page-hero p {
  font-size:1.1rem;
  color:rgba(255,255,255,.75);
  max-width:640px; margin:0 auto;
}
.breadcrumb {
  display:flex; justify-content:center; align-items:center;
  gap:var(--s2); font-size:.78rem;
  color:rgba(255,255,255,.45); margin-top:var(--s5);
}
.breadcrumb a { color:var(--pink-400); }
.breadcrumb a:hover { color:var(--pink-200); }
.breadcrumb i { font-size:.58rem; }

/* ═══════════════════════════════════════════════════════════════
   FEATURE CARDS
   ═══════════════════════════════════════════════════════════════ */
.features-section {
  background: var(--white);
  padding: var(--s20) 0;
}

.features-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--s5);
}

.feature-card {
  padding: var(--s8) var(--s6);
  border-radius: var(--r-lg);
  background: var(--white);
  border: 1px solid rgba(0,0,0,.08);
  transition: all var(--e);
  position: relative;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}

/* Animated bottom bar */
.feature-card::before {
  content: '';
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 3px;
  background: var(--g-feminine);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--e);
  box-shadow: var(--glow-pink-xs);
}

/* Ambient top-right glow */
.feature-card::after {
  content: '';
  position: absolute;
  top: -60px; right: -60px;
  width: 130px; height: 130px;
  background: radial-gradient(circle, rgba(244,114,182,.08) 0%, transparent 68%);
  border-radius: 50%;
  transition: all var(--e-slow);
  pointer-events: none;
}

.feature-card:hover {
  transform: translateY(-10px);
  box-shadow: var(--sh-lg), 0 0 36px rgba(244,114,182,.09);
  border-color: rgba(244,114,182,.25);
}
.feature-card:hover::before { transform: scaleX(1); }
.feature-card:hover::after  { transform: scale(3); opacity: .7; }

/* Icon square */
.feature-icon {
  width: 72px;
  height: 72px;
  border-radius: var(--r-md);
  background: linear-gradient(135deg, rgba(244,114,182,.12) 0%, rgba(244,114,182,.06) 100%);
  border: 1px solid rgba(244,114,182,.22);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.75rem;
  color: var(--primary-pink);
  margin-bottom: var(--s5);
  transition: all var(--e);
  flex-shrink: 0;
}

.feature-card:hover .feature-icon {
  background: var(--g-feminine);
  color: var(--white);
  border-color: transparent;
  transform: scale(1.1) rotate(-5deg);
  box-shadow: var(--sh-pink), var(--glow-pink-xs);
}

.feature-card h3 {
  font-size: 1.18rem;
  font-weight: 700;
  color: var(--midnight-800);
  margin-bottom: var(--s3);
  line-height: 1.3;
}

.feature-card p {
  font-size: .875rem;
  color: var(--ink-500);
  line-height: 1.8;
  flex: 1;
}

/* Tablet: 2 columns */
@media (max-width: 992px) {
  .features-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--s5);
  }
}

/* Mobile: 2 columns always */
@media (max-width: 768px) {
  .features-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--s4);
  }
  .feature-card {
    padding: var(--s6) var(--s5);
  }
  .feature-icon {
    width: 58px;
    height: 58px;
    font-size: 1.45rem;
    margin-bottom: var(--s4);
  }
  .feature-card h3 { font-size: 1.05rem; }
  .feature-card p  { font-size: .82rem; }
}

/* Small phones: still 2 columns but tighter */
@media (max-width: 400px) {
  .features-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--s3);
  }
  .feature-card { padding: var(--s5) var(--s4); }
  .feature-icon { width: 50px; height: 50px; font-size: 1.25rem; }
  .feature-card h3 { font-size: .95rem; }
}

/* ═══════════════════════════════════════════════════════════════
   SERVICE CARDS
   ═══════════════════════════════════════════════════════════════ */
.services-section { background:var(--primary-gray); padding:var(--s20) 0; }
.services-detailed-section { background:var(--primary-gray); padding:var(--s20) 0; }

.services-grid {
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(290px, 1fr));
  gap:var(--s6);
}

.service-card {
  background:var(--white);
  border-radius:var(--r-lg);
  overflow:hidden;
  box-shadow:var(--sh-sm);
  border:1px solid rgba(0,0,0,.06);
  transition:all var(--e);
  display:flex; flex-direction:column;
  position:relative;
}
/* Top sweep */
.service-card::after {
  content:'';
  position:absolute; top:0; left:0; right:0;
  height:3px; background:var(--g-feminine);
  transform:scaleX(0); transform-origin:left;
  transition:transform var(--e);
  box-shadow:var(--glow-pink-xs); z-index:2;
}
.service-card:hover {
  transform:translateY(-10px);
  box-shadow:var(--sh-xl), 0 0 40px rgba(244,114,182,.12);
  border-color:rgba(244,114,182,.2);
}
.service-card:hover::after { transform:scaleX(1); }

.service-card-image {
  height:200px; overflow:hidden;
  background:var(--g-dark);
  position:relative; flex-shrink:0;
  display:block;
}
.service-card-image img {
  width:100%; height:100%;
  object-fit:cover; transition:transform .7s ease;
}
.service-card:hover .service-card-image img { transform:scale(1.08); }

.service-card-image .icon-fallback {
  width:100%; height:100%;
  display:flex; align-items:center; justify-content:center;
  font-size:3.5rem; color:var(--primary-pink); opacity:.85;
}

.service-card-body {
  padding:var(--s6); flex:1;
  display:flex; flex-direction:column;
}
.service-card-body h3 {
  font-size:1.15rem; color:var(--midnight-800);
  margin-bottom:var(--s3);
  transition:color var(--e-fast);
}
.service-card:hover .service-card-body h3 { color:var(--primary-purple); }
.service-card-body p {
  font-size:.875rem; color:var(--ink-500);
  line-height:1.75; flex:1; margin-bottom:var(--s5);
}
.service-card-footer {
  padding-top:var(--s4);
  border-top:1px solid rgba(0,0,0,.06);
  margin-top:auto;
}
.service-card-footer a {
  display:inline-flex; align-items:center; gap:var(--s2);
  font-size:.875rem; font-weight:600;
  color:var(--midnight-800);
  transition:all var(--e-fast);
}
.service-card-footer a i { font-size:.7rem; transition:transform var(--e-fast); }
.service-card-footer a:hover { color:var(--primary-purple); }
.service-card-footer a:hover i { transform:translateX(4px); }

/* Service detail list */
.service-detail {
  display:grid; grid-template-columns:auto 1fr;
  gap:var(--s6); align-items:start;
  padding:var(--s8);
  background:var(--white);
  border-radius:var(--r-lg);
  box-shadow:var(--sh-sm);
  border:1px solid rgba(0,0,0,.06);
  border-left:4px solid transparent;
  transition:all var(--e);
  margin-bottom:var(--s6);
}
.service-detail:hover {
  border-left-color:var(--primary-pink);
  box-shadow:var(--sh-lg), 0 0 28px rgba(244,114,182,.08);
  transform:translateX(5px);
}
.service-detail:last-child { margin-bottom:0; }

.service-icon {
  width:70px; height:70px;
  border-radius:var(--r-md);
  background:rgba(244,114,182,.08);
  border:1px solid rgba(244,114,182,.2);
  display:flex; align-items:center; justify-content:center;
  font-size:1.9rem; color:var(--primary-pink); flex-shrink:0;
}
.service-content h3 { color:var(--midnight-800); margin-bottom:var(--s3); }
.service-content p { color:var(--ink-500); line-height:1.8; margin-bottom:var(--s5); }

/* ═══════════════════════════════════════════════════════════════
   TESTIMONIALS
   ═══════════════════════════════════════════════════════════════ */
.testimonials-section { background:var(--white); padding:var(--s20) 0; }

.testimonials-grid {
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(300px, 1fr));
  gap:var(--s6);
}

.testimonial-card {
  padding:var(--s8);
  border-radius:var(--r-lg);
  background:linear-gradient(148deg, var(--pink-50) 0%, var(--white) 100%);
  border:1px solid rgba(244,114,182,.15);
  position:relative; overflow:hidden;
  transition:all var(--e);
}
/* Giant quote mark */
.testimonial-card::before {
  content:'\201C';
  position:absolute; top:0; left:var(--s5);
  font-family:var(--f-display);
  font-size:8rem; line-height:1;
  color:var(--primary-pink); opacity:.08;
  pointer-events:none; transition:opacity var(--e);
}
.testimonial-card:hover {
  transform:translateY(-6px);
  box-shadow:var(--sh-md), 0 0 28px rgba(244,114,182,.1);
  border-color:rgba(244,114,182,.3);
}
.testimonial-card:hover::before { opacity:.15; }

.testimonial-stars {
  display:flex; gap:3px; margin-bottom:var(--s4);
}
.testimonial-stars i {
  color:var(--primary-pink); font-size:.9rem;
  filter:drop-shadow(0 0 3px rgba(244,114,182,.55));
}
.testimonial-text {
  font-size:.93rem; font-style:italic;
  color:var(--ink-700); line-height:1.85;
  margin-bottom:var(--s5); position:relative; z-index:1;
}
.testimonial-author { display:flex; align-items:center; gap:var(--s3); }
.testimonial-avatar {
  width:48px; height:48px; border-radius:var(--r-full);
  overflow:hidden; border:2px solid var(--primary-pink);
  flex-shrink:0; background:var(--midnight-800);
  display:flex; align-items:center; justify-content:center;
  font-family:var(--f-display); font-weight:700;
  font-size:1.2rem; color:var(--pink-200);
  box-shadow:0 0 10px rgba(244,114,182,.25);
}
.testimonial-avatar img { width:100%; height:100%; object-fit:cover; }
.testimonial-author-info strong { display:block; font-size:.88rem; font-weight:700; color:var(--midnight-800); }
.testimonial-author-info span { font-size:.77rem; color:var(--ink-400); }

/* ═══════════════════════════════════════════════════════════════
   STATS — DARK PRESTIGE
   ═══════════════════════════════════════════════════════════════ */
.stats-section {
  background:var(--g-dark);
  padding:var(--s16) 0;
  position:relative; overflow:hidden;
}
/* Central ambient glow */
.stats-section::before {
  content:''; position:absolute;
  top:50%; left:50%; transform:translate(-50%,-50%);
  width:900px; height:280px;
  background:radial-gradient(ellipse, rgba(244,114,182,.15) 0%, transparent 65%);
  pointer-events:none;
}
/* Top border */
.stats-section::after {
  content:''; position:absolute; top:0; left:0; right:0;
  height:2px; background:var(--g-feminine);
  box-shadow:var(--glow-pink);
}

.stats-grid {
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(170px, 1fr));
  gap:var(--s8); text-align:center;
  position:relative; z-index:1;
}
.stat-item { padding:var(--s6) var(--s4); }

/* Gradient text + glow */
.stat-number {
  display:block;
  font-family:var(--f-display);
  font-size:clamp(2.8rem, 5vw, 4rem);
  font-weight:700;
  background:var(--g-feminine);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
  line-height:1;
  margin-bottom:var(--s3);
  filter:drop-shadow(0 0 14px rgba(244,114,182,.45));
}
.stat-label {
  font-size:.9rem;
  color:rgba(255,255,255,.75);
  font-weight:400; letter-spacing:.03em;
}
.stats-grid > .stat-item:not(:last-child) {
  border-right:1px solid rgba(255,255,255,.1);
}

/* ═══════════════════════════════════════════════════════════════
   CTA SECTION
   ═══════════════════════════════════════════════════════════════ */
.cta-section {
  padding:var(--s20) 0;
  text-align:center;
  background:var(--g-feminine);
  position:relative; overflow:hidden;
}
/* Diagonal light */
.cta-section::before {
  content:''; position:absolute; top:-50%; left:-8%;
  width:45%; height:200%;
  background:rgba(255,255,255,.08);
  transform:skewX(-14deg); pointer-events:none;
}
/* Subtle dots */
.cta-section::after {
  content:''; position:absolute; inset:0;
  background-image:radial-gradient(circle, rgba(0,0,0,.15) 1px, transparent 1px);
  background-size:22px 22px; pointer-events:none;
}
.cta-section .container { position:relative; z-index:1; }

.cta-section h2 {
  color: var(--white);
  margin-bottom:var(--s4);
  font-size:clamp(2rem, 4vw, 3rem);
  text-shadow: 0 2px 4px rgba(0,0,0,.15);
}
.cta-section p {
  color: rgba(255,255,255,.9);
  font-size:1.1rem;
  max-width:540px;
  margin:0 auto var(--s8);
  font-weight:500;
}

/* ═══════════════════════════════════════════════════════════════
   FORMS
   ═══════════════════════════════════════════════════════════════ */
.form-group { margin-bottom:var(--s5); }
.form-group label {
  display:block; margin-bottom:var(--s2);
  font-weight:600; font-size:.875rem;
  color:var(--ink-700); letter-spacing:.01em;
}
.form-group input,
.form-group textarea,
.form-group select {
  width:100%; padding:.82rem 1rem;
  border:1.5px solid rgba(0,0,0,.12);
  border-radius:var(--r);
  font-family:var(--f-body); font-size:.92rem;
  color:var(--ink-800); background:var(--white);
  transition:all var(--e-fast); outline:none;
}
.form-group input:focus,
.form-group textarea:focus,
.form-group select:focus {
  border-color:var(--primary-pink);
  box-shadow:0 0 0 3px rgba(244,114,182,.14), var(--glow-pink-xs);
}
.form-group input::placeholder,
.form-group textarea::placeholder { color:var(--ink-300); }
.form-group textarea { resize:vertical; min-height:130px; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:var(--s5); }

/* ═══════════════════════════════════════════════════════════════
   CONTACT
   ═══════════════════════════════════════════════════════════════ */
.contact-grid {
  display:grid; grid-template-columns:3fr 2fr;
  gap:var(--s8); align-items:start;
}
.contact-form-wrapper,
.contact-info-wrapper {
  background:var(--white); border-radius:var(--r-lg);
  padding:var(--s10); box-shadow:var(--sh-md);
  border:1px solid rgba(0,0,0,.06);
}
.contact-info-wrapper { display:flex; flex-direction:column; }

.contact-info-card {
  display:flex; align-items:flex-start; gap:var(--s4);
  padding:var(--s5) 0;
  border-bottom:1px solid rgba(0,0,0,.06);
  transition:all var(--e-fast);
}
.contact-info-card:last-child { border-bottom:none; }
.contact-info-card:hover .icon-circle {
  background:var(--g-feminine); color:var(--white);
  border-color:transparent;
  box-shadow:var(--sh-pink), var(--glow-pink-xs);
  transform:translateY(-2px) scale(1.06);
}

.icon-circle {
  width:44px; height:44px; border-radius:var(--r-full);
  background:rgba(244,114,182,.07); color:var(--primary-pink);
  display:flex; align-items:center; justify-content:center;
  font-size:.95rem; flex-shrink:0;
  border:1px solid rgba(244,114,182,.15);
  transition:all var(--e);
}
.info-content h4 {
  font-size:.88rem; font-weight:700;
  color:var(--midnight-800); margin-bottom:var(--s1);
  font-family:var(--f-body);
}
.info-content p, .info-content a { font-size:.86rem; color:var(--ink-500); }
.info-content a:hover { color:var(--primary-purple); }

/* ═══════════════════════════════════════════════════════════════
   ABOUT
   ═══════════════════════════════════════════════════════════════ */
.about-section { padding:var(--s20) 0; }
.about-flow-container { display:block; }
.about-flow-container::after { content:''; display:table; clear:both; }

.about-image-float {
  float:right; width:44%;
  margin-left:var(--s10); margin-bottom:var(--s8);
  position:relative;
}
.about-image-float img {
  width:100%; border-radius:var(--r-lg);
  box-shadow:var(--sh-xl), 0 0 40px rgba(244,114,182,.1);
  border:1px solid rgba(244,114,182,.14);
}
.about-image-float::before {
  content:'';
  position:absolute; bottom:-14px; right:-14px; left:14px; top:14px;
  border:1.5px solid rgba(244,114,182,.28);
  border-radius:var(--r-lg); z-index:-1;
  box-shadow:var(--glow-pink-xs);
}

.about-text h2 { color:var(--midnight-800); margin-bottom:var(--s6); }
.about-text h3 {
  color:var(--midnight-700); margin-top:var(--s8); margin-bottom:var(--s4);
  font-size:1.4rem; padding-bottom:var(--s3);
  border-bottom:2px solid rgba(244,114,182,.2);
  display:flex; align-items:center; gap:var(--s3);
}
.about-text h3::after {
  content:''; flex:1; height:1px;
  background:linear-gradient(90deg, rgba(244,114,182,.2), transparent);
}
.about-text p { color:var(--ink-500); line-height:1.85; margin-bottom:var(--s5); }

.values-list { margin:var(--s5) 0; }
.values-list li {
  display:flex; align-items:flex-start; gap:var(--s3);
  padding:var(--s3) 0;
  border-bottom:1px solid rgba(0,0,0,.06);
}
.values-list li:last-child { border-bottom:none; }
.values-list li i { color:var(--primary-pink); margin-top:4px; flex-shrink:0; filter:drop-shadow(0 0 4px rgba(244,114,182,.4)); }
.values-list li span { color:var(--ink-500); line-height:1.7; font-size:.93rem; }
.values-list li strong { color:var(--midnight-800); }

/* ═══════════════════════════════════════════════════════════════
   TEAM
   ═══════════════════════════════════════════════════════════════ */
.team-section { padding:var(--s20) 0; background:var(--primary-gray); }
.team-grid { display:grid; grid-template-columns:repeat(auto-fill, minmax(320px, 1fr)); gap:var(--s8); }

.team-card {
  background:var(--white); border-radius:var(--r-lg);
  overflow:hidden; box-shadow:var(--sh-md);
  border:1px solid rgba(0,0,0,.06);
  transition:all var(--e);
  display:flex; flex-direction:column; position:relative;
}
/* Shimmer top bar */
.team-card::before {
  content:''; position:absolute; top:0; left:0; right:0;
  height:3px; background:var(--g-feminine);
  box-shadow:var(--glow-pink-xs); z-index:2;
}
.team-card:hover {
  transform:translateY(-12px);
  box-shadow:var(--sh-xl), 0 0 50px rgba(244,114,182,.1);
  border-color:rgba(244,114,182,.22);
}

.team-image-wrapper {
  width:100%; height:340px; overflow:hidden;
  background:var(--g-dark); position:relative;
}
.team-image {
  width:100%; height:100%;
  object-fit:contain; background:#fdf2f8; /* Soft pink bg for team */
  transition:transform .6s ease;
}
.team-card:hover .team-image { transform:scale(1.04); }

.team-image-placeholder {
  width:100%; height:100%;
  display:flex; align-items:center; justify-content:center;
  font-size:5rem; color:var(--primary-pink);
}
.team-content { padding:var(--s8); flex:1; display:flex; flex-direction:column; }
.team-content h3 { font-size:1.5rem; color:var(--midnight-800); text-align:center; margin-bottom:var(--s2); }
.team-position {
  text-align:center;
  background:var(--g-feminine);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent;
  background-clip:text;
  font-weight:700; font-size:.78rem;
  letter-spacing:.1em; text-transform:uppercase;
  margin-bottom:var(--s5);
  filter:drop-shadow(0 0 6px rgba(244,114,182,.3));
}
.team-bio { color:var(--ink-500); font-size:.88rem; line-height:1.85; flex:1; margin-bottom:var(--s6); text-align:justify; }
.team-contact {
  display:flex; justify-content:center; gap:var(--s3);
  padding-top:var(--s5); border-top:1px solid rgba(0,0,0,.06); margin-top:auto;
}
.team-contact a {
  width:40px; height:40px; border-radius:var(--r-full);
  background:var(--ink-50); color:var(--midnight-800);
  display:flex; align-items:center; justify-content:center;
  font-size:.88rem; border:1px solid rgba(0,0,0,.08);
  transition:all var(--e); text-decoration:none;
}
.team-contact a:hover {
  background:var(--g-feminine); color:var(--white);
  border-color:transparent;
  transform:translateY(-3px);
  box-shadow:var(--sh-pink), var(--glow-pink-xs);
}

/* ═══════════════════════════════════════════════════════════════
   FAQ
   ═══════════════════════════════════════════════════════════════ */
.faq-section { padding:var(--s20) 0; }
.faq-item {
  background:var(--white); border:1px solid rgba(0,0,0,.07);
  border-radius:var(--r-md);
  padding:var(--s6) var(--s7);
  margin-bottom:var(--s4);
  transition:all var(--e);
  border-left:4px solid transparent;
}
.faq-item:hover {
  border-left-color:var(--primary-pink);
  box-shadow:var(--sh-md), 0 0 18px rgba(244,114,182,.06);
  transform:translateX(4px);
}
.faq-item h3 {
  font-size:1.02rem; font-weight:600; color:var(--midnight-800);
  cursor:pointer; margin-bottom:var(--s3);
  display:flex; align-items:center; gap:var(--s3);
  font-family:var(--f-body);
}
.faq-item h3 i { color:var(--primary-pink); font-size:.8rem; flex-shrink:0; filter:drop-shadow(0 0 4px rgba(244,114,182,.4)); }
.faq-item p { font-size:.9rem; color:var(--ink-500); line-height:1.8; }

/* ═══════════════════════════════════════════════════════════════
   CALCULATOR
   ═══════════════════════════════════════════════════════════════ */
.calculator-section { padding:var(--s20) 0; background:var(--primary-gray); }
.calculator-wrapper { display:grid; grid-template-columns:1fr 1fr; gap:var(--s8); align-items:start; }
.calculator-form, .calculator-results {
  background:var(--white); border-radius:var(--r-lg);
  padding:var(--s8); box-shadow:var(--sh-md);
  border:1px solid rgba(0,0,0,.06);
}
.calculator-form h3, .calculator-results h3 {
  font-size:1.3rem; color:var(--midnight-800);
  margin-bottom:var(--s6); padding-bottom:var(--s4);
  border-bottom:2px solid rgba(244,114,182,.15);
  font-family:var(--f-body); font-weight:700;
}

.slider { 
  width:100%; height:5px; border-radius:3px; background:rgba(0,0,0,.1); 
  outline:none; appearance: none; -webkit-appearance:none; margin-top:var(--s3); 
}
.slider::-webkit-slider-thumb { 
  appearance: none; -webkit-appearance:none; width:20px; height:20px; 
  border-radius:50%; background:var(--g-feminine); cursor:pointer; 
  box-shadow:var(--sh-pink); border:2px solid var(--white); 
}
.slider::-moz-range-thumb { 
  appearance: none; width:20px; height:20px; border-radius:50%; 
  background:var(--g-feminine); cursor:pointer; border:2px solid var(--white); 
  box-shadow:var(--sh-pink); 
}

.result-card {
  background:var(--g-dark);
  border-radius:var(--r); padding:var(--s5);
  margin-bottom:var(--s4); text-align:center;
  border:1px solid rgba(244,114,182,.16);
  position:relative; overflow:hidden;
}
.result-card::after {
  content:''; position:absolute; top:0; left:0; right:0;
  height:2px; background:var(--g-feminine); box-shadow:var(--glow-pink-xs);
}
.result-card label {
  display:block; font-size:.72rem; font-weight:700;
  letter-spacing:.1em; text-transform:uppercase;
  color:rgba(255,255,255,.5); margin-bottom:var(--s2);
}
.result-value {
  font-family:var(--f-display); font-size:2.3rem; font-weight:700;
  background:var(--g-feminine);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent;
  background-clip:text; line-height:1;
  filter:drop-shadow(0 0 10px rgba(244,114,182,.35));
}
/* Fixed Container Aspect Ratio Bug to completely prevent overlap */
.chart-container { position:relative; width: 100%; max-width: 300px; aspect-ratio: 1/1; margin:var(--s8) auto; }

/* ═══════════════════════════════════════════════════════════════
   LEGAL PAGES
   ═══════════════════════════════════════════════════════════════ */
.legal-section { padding:var(--s16) 0; }
.legal-content { max-width:860px; margin:0 auto; line-height:1.9; color:var(--ink-500); }
.legal-content h3 {
  color:var(--midnight-800); font-size:1.15rem; margin-top:var(--s8); margin-bottom:var(--s3);
  font-family:var(--f-body); font-weight:700;
  padding-left:var(--s3); border-left:3px solid var(--primary-pink);
}
.legal-content h4 { color:var(--primary-purple); font-size:.96rem; margin-top:var(--s5); margin-bottom:var(--s3); font-family:var(--f-body); font-weight:600; }
.legal-content p { margin-bottom:var(--s4); font-size:.92rem; }
.legal-content ul { list-style:disc; padding-left:var(--s6); margin:var(--s4) 0; }
.legal-content ul li { margin-bottom:var(--s2); font-size:.92rem; }
.legal-meta { background:var(--pink-50); border-left:4px solid var(--primary-pink); border-radius:0 var(--r) var(--r) 0; padding:var(--s6); margin-bottom:var(--s10); }
.legal-meta p { margin:4px 0; font-size:.88rem; }
.legal-warning { background:#fdf2f8; border-left:4px solid var(--primary-pink); padding:var(--s5); border-radius:0 var(--r) var(--r) 0; margin-bottom:var(--s8); }
.legal-warning h4 { color:var(--pink-700); margin-top:0; }
.legal-contact-grid { display:grid; grid-template-columns:1fr 1fr; gap:var(--s6); margin-top:var(--s5); }
.legal-office-card { background:var(--ink-50); padding:var(--s5); border-radius:var(--r); border:1px solid rgba(0,0,0,.07); }
.legal-office-card h4 { color:var(--midnight-800)!important; margin-top:0!important; }

/* ═══════════════════════════════════════════════════════════════
   ALERTS
   ═══════════════════════════════════════════════════════════════ */
.alert { padding:var(--s4) var(--s5); border-radius:var(--r); margin-bottom:var(--s5); font-size:.88rem; display:flex; align-items:center; gap:var(--s3); }
.alert-success { background:#d1fae5; color:#065f46; border:1px solid #a7f3d0; }
.alert-error   { background:#fee2e2; color:#991b1b; border:1px solid #fca5a5; }

/* ═══════════════════════════════════════════════════════════════
   FOOTER — PREMIUM DARK PRESTIGE
   ═══════════════════════════════════════════════════════════════ */
.footer-wrapper {
  background: var(--g-dark);
  color: var(--white);
  padding: var(--s20) 0 0;
  margin-top: var(--s20);
  position: relative;
  overflow: hidden;
}

/* Glow top border */
.footer-wrapper::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: var(--g-feminine);
  box-shadow: var(--glow-pink);
}

/* Ambient bottom glow */
.footer-wrapper::after {
  content: '';
  position: absolute;
  bottom: -80px; left: 50%;
  transform: translateX(-50%);
  width: 600px; height: 280px;
  background: radial-gradient(ellipse, rgba(244,114,182,.1) 0%, transparent 70%);
  pointer-events: none;
}

/* ── Desktop grid: brand wider, 3 equal cols ── */
.footer-grid {
  display: grid;
  grid-template-columns: 1.5fr 1fr 1fr 1fr;
  gap: 0;
  padding-bottom: var(--s12);
  position: relative;
  z-index: 1;
}

/* Vertical dividers between columns */
.footer-column {
  padding: 0 var(--s8);
  border-right: 1px solid rgba(255,255,255,.06);
}
.footer-column:first-child { padding-left: 0; }
.footer-column:last-child  { padding-right: 0; border-right: none; }

/* Gradient headings */
.footer-column h3,
.footer-column h4 {
  font-family: var(--f-display);
  font-size: 1.1rem;
  font-weight: 600;
  background: var(--g-feminine);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  margin-bottom: var(--s5);
  letter-spacing: .03em;
  position: relative;
  padding-bottom: var(--s3);
}
/* Underline on heading */
.footer-column h3::after,
.footer-column h4::after {
  content: '';
  position: absolute;
  bottom: 0; left: 0;
  width: 30px; height: 2px;
  background: var(--g-feminine);
  border-radius: 1px;
  box-shadow: var(--glow-pink-xs);
}

.footer-column p {
  color: rgba(255,255,255,.6);
  font-size: .875rem;
  line-height: 1.85;
  margin-bottom: var(--s4);
}

.footer-column ul { list-style: none; margin: 0; padding: 0; }
.footer-column ul li { margin-bottom: 10px; }

.footer-column a {
  color: rgba(255,255,255,.6);
  font-size: .875rem;
  text-decoration: none;
  transition: all .18s;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.footer-column li a {
  position: relative;
  padding-left: 14px;
}
.footer-column li a::before {
  content: '›';
  position: absolute;
  left: 0;
  color: var(--primary-pink);
  font-size: 1rem;
  line-height: 1;
  transition: left .18s;
}
.footer-column li a:hover {
  color: var(--pink-300);
  padding-left: 20px;
}
.footer-column li a:hover::before { left: 4px; }

/* Logo */
.footer-logo-wrapper {
  margin-bottom: var(--s5);
  display: flex;
  align-items: center;
}
.footer-logo {
  max-height: 70px;
  width: auto;
  max-width: 200px;
  object-fit: contain;
  /* Show true logo colors — no filter */
  filter: none !important;
  /* White bg pill so logo pops on dark footer */
  background: rgba(255,255,255,.96);
  border-radius: var(--r-md);
  padding: 10px 16px;
  box-shadow: 0 4px 20px rgba(0,0,0,.35), 0 0 0 1px rgba(244,114,182,.2);
}

/* Centre logo on tablet/mobile */
@media (max-width: 992px) {
  .footer-logo-wrapper { justify-content: center; }
}
@media (max-width: 768px) {
  .footer-logo-wrapper { justify-content: center; }
  .footer-logo {
    max-height: 64px;
    max-width: 180px;
  }
}
@media (max-width: 480px) {
  .footer-logo { max-height: 56px; max-width: 160px; padding: 8px 14px; }
}

/* Social icons */
.footer-social {
  display: flex;
  gap: var(--s3);
  margin-top: var(--s5);
  flex-wrap: wrap;
}
.footer-social a {
  width: 38px; height: 38px;
  border-radius: var(--r-full);
  background: rgba(255,255,255,.07);
  color: var(--pink-400);
  font-size: .82rem;
  display: flex; align-items: center; justify-content: center;
  border: 1px solid rgba(244,114,182,.22);
  text-decoration: none;
  transition: all var(--e);
}
.footer-social a:hover {
  background: var(--g-feminine);
  color: var(--white);
  border-color: transparent;
  transform: translateY(-3px);
  box-shadow: var(--sh-pink), var(--glow-pink-xs);
}

/* Footer bottom bar */
.footer-bottom {
  padding: var(--s5) 0;
  border-top: 1px solid rgba(255,255,255,.08);
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--s4);
  position: relative;
  z-index: 1;
}
.footer-copyright p {
  font-size: .78rem;
  color: rgba(255,255,255,.38);
}
.footer-links {
  display: flex;
  gap: var(--s6);
  flex-wrap: wrap;
}
.footer-links a {
  font-size: .78rem;
  color: rgba(255,255,255,.38);
  transition: color .18s;
  text-decoration: none;
}
.footer-links a:hover { color: var(--pink-300); }

/* ── TABLET (992px) — 2+2 grid ── */
@media (max-width: 992px) {
  .footer-grid {
    grid-template-columns: 1fr 1fr;
    gap: var(--s8) var(--s6);
  }
  /* Company info spans full width */
  .footer-column:first-child {
    grid-column: 1 / -1;
    padding: 0;
    border-right: none;
    border-bottom: 1px solid rgba(255,255,255,.06);
    padding-bottom: var(--s6);
    margin-bottom: var(--s2);
  }
  /* Centre the company block */
  .footer-column:first-child { text-align: center; }
  .footer-column:first-child .footer-social { justify-content: center; }
  .footer-column:first-child h3::after,
  .footer-column:first-child h4::after { left: 50%; transform: translateX(-50%); }

  .footer-column:not(:first-child) {
    padding: 0;
    border-right: none;
  }
}

/* ── MOBILE (768px) — premium compact layout ── */
@media (max-width: 768px) {
  .footer-wrapper { padding-top: var(--s12); margin-top: var(--s12); }

  .footer-grid {
    grid-template-columns: 1fr 1fr;  /* Quick Links + Our Services side by side */
    gap: var(--s6) var(--s5);
  }

  /* Company block full width */
  .footer-column:first-child {
    grid-column: 1 / -1;
    text-align: center;
    border-bottom: 1px solid rgba(255,255,255,.07);
    padding-bottom: var(--s6);
    margin-bottom: var(--s2);
  }
  .footer-column:first-child .footer-social { justify-content: center; }
  .footer-column:first-child h3::after,
  .footer-column:first-child h4::after { left: 50%; transform: translateX(-50%); }

  /* Contact block full width at bottom */
  .footer-column:last-child {
    grid-column: 1 / -1;
    border-top: 1px solid rgba(255,255,255,.07);
    padding-top: var(--s5);
    text-align: center;
  }
  .footer-column:last-child h3::after,
  .footer-column:last-child h4::after { left: 50%; transform: translateX(-50%); }
  .footer-column:last-child a { justify-content: center; }

  /* Middle two cols: Quick Links + Our Services — side by side */
  .footer-column:nth-child(2),
  .footer-column:nth-child(3) {
    padding: 0;
  }

  /* Smaller link text on mobile */
  .footer-column a { font-size: .82rem; }
  .footer-column ul li { margin-bottom: 8px; }

  .footer-bottom {
    flex-direction: column;
    text-align: center;
    gap: var(--s3);
  }
  .footer-links { justify-content: center; gap: var(--s4); }
}

/* ── SMALL PHONES (480px) ── */
@media (max-width: 480px) {
  .footer-grid {
    grid-template-columns: 1fr 1fr;  /* Still 2 columns for links */
    gap: var(--s5) var(--s3);
  }
  .footer-column h3,
  .footer-column h4 { font-size: .95rem; }
  .footer-column a  { font-size: .8rem; }
  .footer-social    { justify-content: center; }
  .footer-column li a { padding-left: 12px; }
}

/* ═══════════════════════════════════════════════════════════════
   WHATSAPP
   ═══════════════════════════════════════════════════════════════ */
.whatsapp-widget { position:fixed; bottom:30px; left:30px; z-index:calc(var(--z-nav) - 1); }
.whatsapp-bubble {
  width:58px; height:58px; background:#25d366;
  border-radius:var(--r-full);
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 4px 20px rgba(37,211,102,.48);
  cursor:pointer; transition:all var(--e);
  animation:waPulse 2.5s infinite;
}
.whatsapp-bubble:hover {
  background:#1daf56; transform:scale(1.12);
  box-shadow:0 6px 28px rgba(37,211,102,.65);
  animation:none;
}
@keyframes waPulse {
  0%,100% { box-shadow:0 4px 20px rgba(37,211,102,.48); }
  50%     { box-shadow:0 4px 36px rgba(37,211,102,.72); }
}
.whatsapp-icon { color:var(--white); font-size:30px; display:flex; align-items:center; justify-content:center; width:100%; height:100%; text-decoration:none; }
.whatsapp-tooltip {
  position:absolute; bottom:70px; left:0;
  background:var(--midnight-800); color:var(--white);
  padding:8px 14px; border-radius:var(--r);
  font-size:.78rem; white-space:nowrap;
  opacity:0; visibility:hidden; pointer-events:none;
  transition:all var(--e); line-height:1.4;
  box-shadow:var(--sh-md); border:1px solid rgba(244,114,182,.16);
}
.whatsapp-tooltip::after { content:''; position:absolute; top:100%; left:18px; border:6px solid transparent; border-top-color:var(--midnight-800); }
.whatsapp-widget:hover .whatsapp-tooltip { opacity:1; visibility:visible; bottom:74px; }

/* ═══════════════════════════════════════════════════════════════
   SCROLL REVEAL
   ═══════════════════════════════════════════════════════════════ */
.reveal { opacity:0; transform:translateY(26px); transition:opacity .7s var(--e-slow), transform .7s var(--e-slow); }
.reveal.visible { opacity:1; transform:translateY(0); }
.reveal-delay-1 { transition-delay:.1s; }
.reveal-delay-2 { transition-delay:.2s; }
.reveal-delay-3 { transition-delay:.3s; }

/* ═══════════════════════════════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════════════════════════════ */
@media (min-width: 993px) {
  .navbar-menu  { display: flex !important; }
  .navbar-toggle { display: none !important; }
  .mobile-aside-menu, .mobile-menu-overlay { display: none !important; }
}

@media (max-width: 992px) {
  .navbar-toggle { display: flex !important; }
  .navbar-menu   { display: none; }
  /* Footer grid handled in footer section above */
}

@media (max-width: 768px) {
  h1 { font-size: 2.1rem; }
  h2 { font-size: 1.8rem; }

  .hero { padding: var(--s12) 0; min-height: auto; }
  .hero-layout { grid-template-columns: 1fr; gap: var(--s8); }
  .hero-image-wrap { order: -1; }
  .hero-content p  { max-width: 100%; }
  .hero-buttons    { flex-direction: column; }
  .hero-trust      { display: none; }

  .page-hero { padding: var(--s12) 0 var(--s10); }

  .contact-grid        { grid-template-columns: 1fr; }
  .contact-form-wrapper,
  .contact-info-wrapper { padding: var(--s6); }
  .form-row            { grid-template-columns: 1fr; }
  .calculator-wrapper  { grid-template-columns: 1fr; }

  .about-image-float { float: none; width: 100%; margin-left: 0; margin-bottom: var(--s8); }

  .stats-grid > .stat-item:not(:last-child) { border-right: none; }
  .stats-grid    { grid-template-columns: repeat(2, 1fr); gap: var(--s6); }

  /* Footer handled in footer section above */

  .team-grid     { grid-template-columns: 1fr; }
  .service-detail { grid-template-columns: 1fr; }
  .service-icon  { justify-self: start; }
  .legal-contact-grid { grid-template-columns: 1fr; }
  .section       { padding: var(--s12) 0; }

  .whatsapp-widget { bottom: 20px; left: 20px; }
  .whatsapp-bubble { width: 52px; height: 52px; }
  .whatsapp-icon   { font-size: 26px; }

  /* Services 2 col on mobile */
  .services-grid { grid-template-columns: repeat(2, 1fr); gap: var(--s4); }
  .service-card-image { height: 150px; }
  .service-card-body  { padding: var(--s4); }
  .service-card-body h3 { font-size: 1rem; }
  /* Fixed property warnings here */
  .service-card-body p  { font-size: .82rem; display: -webkit-box; -webkit-line-clamp: 3; line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }
}

@media (max-width: 480px) {
  .container { padding: 0 var(--s4); }
  h1 { font-size: 1.75rem; }
  h2 { font-size: 1.5rem; }

  /* Features stays 2 col even on small phone */
  .features-grid  { grid-template-columns: repeat(2, 1fr); gap: var(--s3); }
  /* Services drops to 1 col only on very small */
  .services-grid  { grid-template-columns: 1fr; }

  .stats-grid     { grid-template-columns: 1fr 1fr; gap: var(--s4); }
  .stat-number    { font-size: 2.4rem; }
  .team-image-wrapper { height: 280px; }
  /* Footer column styles handled in footer section above */
  .mobile-aside-menu { max-width: 290px; }
  .mobile-menu-inner { padding: 56px var(--s5) var(--s8); }
  .btn-lg { padding: .9rem 1.8rem; font-size: .93rem; }
}

@media print {
  .navbar-wrapper, .whatsapp-widget,
  .mobile-aside-menu, .mobile-menu-overlay,
  .cta-section { display:none!important; }
}