/* =============================================================
   CARPINTERÍA EMPIRE — styles.css v2 — 2026-06-02
   ============================================================= */

/* =============================================================
   1. TOKENS
   ============================================================= */
:root {
  --bg:           #0f0a05;
  --bg-2:         #181008;
  --bg-3:         #221608;
  --bg-card:      #2a1c0b;
  --cream:        #f5ead6;
  --cream-2:      #dcc9a8;
  --cream-3:      #8a7455;
  --accent:       #c9a04f;
  --accent-2:     #a67c32;
  --accent-hi:    #e8c578;
  --accent-glow:  rgba(201,160,79,0.28);
  --line:         rgba(201,160,79,0.13);
  --line-soft:    rgba(201,160,79,0.06);

  --serif: 'Cormorant Garamond', Georgia, serif;
  --sans:  'Inter', system-ui, sans-serif;

  --ease-out:    cubic-bezier(0.16, 1, 0.3, 1);
  --ease-soft:   cubic-bezier(0.25, 0.46, 0.45, 0.94);
  --ease-bounce: cubic-bezier(0.34, 1.56, 0.64, 1);

  --nav-h:  72px;
  --gutter: clamp(1.25rem, 5vw, 3rem);
  --radius: 14px;
}

/* =============================================================
   2. RESET
   ============================================================= */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; overflow-x: clip; -webkit-text-size-adjust: 100%; }
@media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } }
body {
  font-family: var(--sans);
  font-size: 16px;
  line-height: 1.65;
  background: var(--bg);
  color: var(--cream-2);
  overflow-x: clip;
  overscroll-behavior-y: none;
  -webkit-font-smoothing: antialiased;
}
img, svg, video { display: block; max-width: 100%; }
img { height: auto; }
button { font: inherit; color: inherit; cursor: pointer; border: 0; background: none; }
a { color: inherit; text-decoration: none; }
p { text-wrap: pretty; }
h1, h2, h3 { text-wrap: balance; line-height: 1.06; letter-spacing: -0.02em; }
ul { list-style: none; }
::selection { background: var(--accent); color: var(--bg); }
:focus-visible { outline: 2px solid var(--accent); outline-offset: 3px; border-radius: 4px; }

/* =============================================================
   3. VIEW TRANSITIONS (smooth page changes)
   ============================================================= */
@view-transition { navigation: auto; }
::view-transition-old(root) { animation: vtOut .45s var(--ease-out); }
::view-transition-new(root) { animation: vtIn  .45s var(--ease-out); }
@keyframes vtOut { to   { opacity: 0; transform: translateY(-10px) scale(.98); } }
@keyframes vtIn  { from { opacity: 0; transform: translateY(12px) scale(.98); } }

/* =============================================================
   4. UTILITIES
   ============================================================= */
.skip-link {
  position: fixed; top: -100px; left: 1rem;
  padding: .5rem 1.2rem; background: var(--cream); color: var(--bg);
  font-size: .85rem; font-weight: 600; border-radius: 8px; z-index: 9999;
}
.skip-link:focus { top: 1rem; }

.container { width: 100%; max-width: 1220px; margin-inline: auto; padding-inline: var(--gutter); }

.section-eyebrow {
  font-size: .72rem; font-weight: 600; letter-spacing: .2em;
  text-transform: uppercase; color: var(--accent); margin-bottom: .9rem;
}

.section-heading {
  font-family: var(--serif);
  font-size: clamp(2rem, 4vw, 3.4rem);
  font-weight: 400; color: var(--cream); line-height: 1.08;
}
.section-heading em { font-style: italic; color: var(--accent); }

.section-header { text-align: center; max-width: 640px; margin: 0 auto 4.5rem; }

/* Scroll progress bar */
.progress-bar {
  position: fixed; top: 0; left: 0; z-index: 999;
  height: 2px; width: 0%;
  background: linear-gradient(90deg, var(--accent-2), var(--accent-hi));
  transition: width .1s linear;
  pointer-events: none;
}

/* =============================================================
   5. SPLASH (index.html only)
   ============================================================= */
.splash {
  position: fixed; inset: 0; z-index: 10000;
  background: var(--bg);
  display: flex; align-items: center; justify-content: center;
  flex-direction: column; gap: .8rem;
  animation: splashKill .01s 4.5s forwards;
}
@keyframes splashKill { to { opacity: 0; pointer-events: none; } }
.splash.is-out { opacity: 0; pointer-events: none; transition: opacity .6s var(--ease-out); }

.splash-letters {
  display: flex; gap: .1em;
  font-family: var(--serif);
  font-size: clamp(3.5rem, 12vw, 9rem);
  font-weight: 600; letter-spacing: .12em;
  color: var(--accent);
}
.splash-letters span {
  display: inline-block;
  opacity: 0; transform: translateY(50px);
  animation: splashLetter .7s var(--ease-out) forwards;
}
.splash-letters span:nth-child(1){animation-delay:.05s}
.splash-letters span:nth-child(2){animation-delay:.13s}
.splash-letters span:nth-child(3){animation-delay:.21s}
.splash-letters span:nth-child(4){animation-delay:.29s}
.splash-letters span:nth-child(5){animation-delay:.37s}
.splash-letters span:nth-child(6){animation-delay:.45s}
@keyframes splashLetter { to { opacity: 1; transform: translateY(0); } }

.splash-sub {
  font-size: .7rem; letter-spacing: .4em; text-transform: uppercase;
  color: var(--cream-3);
  opacity: 0; animation: splashSub .6s .8s var(--ease-out) forwards;
}
@keyframes splashSub { to { opacity: 1; } }

.splash-line {
  width: 0; height: 1px;
  background: linear-gradient(90deg, transparent, var(--accent), transparent);
  animation: splashLine .8s 1s var(--ease-out) forwards;
  margin-top: .4rem;
}
@keyframes splashLine { to { width: 180px; } }

/* =============================================================
   6. CURSOR
   ============================================================= */
@media (hover: hover) and (pointer: fine) {
  .cursor { position: fixed; inset: 0; z-index: 9000; pointer-events: none; }
  .cursor-dot, .cursor-ring {
    position: absolute; top: 0; left: 0; border-radius: 50%;
    opacity: 0; transition: opacity .3s; will-change: transform;
  }
  .cursor-dot  { width: 6px; height: 6px; background: var(--accent); }
  .cursor-ring { width: 38px; height: 38px; border: 1.5px solid rgba(201,160,79,.45); transition: opacity .3s, width .25s var(--ease-out), height .25s var(--ease-out); }
  .cursor.is-ready .cursor-dot,
  .cursor.is-ready .cursor-ring { opacity: 1; }
  .cursor.is-hover .cursor-ring { width: 56px; height: 56px; border-color: var(--accent); background: rgba(201,160,79,.05); }
}

/* =============================================================
   7. NAV
   ============================================================= */
.nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 1000;
  transition: background .4s, border-bottom .4s;
}
.nav.is-scrolled {
  background: rgba(15,10,5,.93);
  backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px);
  border-bottom: 1px solid var(--line);
}
.nav-inner { display: flex; align-items: center; justify-content: space-between; height: var(--nav-h); }
.nav-logo { display: flex; flex-direction: column; gap: .1rem; line-height: 1; }
.nav-logo-main { font-family: var(--serif); font-size: 1.55rem; font-weight: 600; letter-spacing: .14em; color: var(--accent); transition: color .3s; }
.nav-logo-sub  { font-size: .52rem; letter-spacing: .32em; text-transform: uppercase; color: var(--cream-3); }
.nav-logo:hover .nav-logo-main { color: var(--accent-hi); }

.nav-links { display: none; gap: 2rem; align-items: center; }
.nav-links a {
  font-size: .84rem; letter-spacing: .05em; color: var(--cream-2);
  position: relative; padding-bottom: 3px;
  transition: color .3s;
}
.nav-links a::after {
  content: ''; position: absolute; bottom: 0; left: 0;
  width: 0; height: 1px; background: var(--accent);
  transition: width .35s var(--ease-out);
}
.nav-links a:hover { color: var(--cream); }
.nav-links a:hover::after { width: 100%; }
.nav-links a[aria-current="page"] { color: var(--accent); }
.nav-links a[aria-current="page"]::after { width: 100%; }

.nav-cta {
  padding: .52rem 1.35rem !important;
  background: var(--accent) !important; color: var(--bg) !important;
  border-radius: 7px; font-weight: 600; font-size: .82rem !important;
  transition: background .3s, transform .25s var(--ease-bounce) !important;
}
.nav-cta:hover { background: var(--accent-hi) !important; transform: translateY(-2px); }
.nav-cta::after { display: none !important; }

.nav-hamburger { display: flex; flex-direction: column; gap: 5px; padding: 4px; width: 34px; }
.nav-hamburger span { display: block; height: 1.5px; background: var(--cream); border-radius: 2px; transition: transform .35s var(--ease-out), opacity .2s; }
.nav-hamburger[aria-expanded="true"] span:nth-child(1) { transform: translateY(6.5px) rotate(45deg); }
.nav-hamburger[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
.nav-hamburger[aria-expanded="true"] span:nth-child(3) { transform: translateY(-6.5px) rotate(-45deg); }

.nav-mobile {
  background: rgba(15,10,5,.97); backdrop-filter: blur(24px);
  border-top: 1px solid var(--line); max-height: 0; overflow: hidden;
  transition: max-height .45s var(--ease-out);
}
.nav-mobile.is-open { max-height: 380px; }
.nav-mobile ul { padding: 1.5rem var(--gutter) 2rem; display: flex; flex-direction: column; gap: 1.2rem; }
.nav-mobile a { font-family: var(--serif); font-size: 1.5rem; color: var(--cream); letter-spacing: .02em; transition: color .3s; }
.nav-mobile a:hover { color: var(--accent); }
.nav-mobile a[aria-current="page"] { color: var(--accent); }

@media (min-width: 960px) {
  .nav-links { display: flex; }
  .nav-hamburger { display: none; }
}

/* =============================================================
   8. BUTTONS
   ============================================================= */
.btn {
  display: inline-flex; align-items: center; justify-content: center;
  gap: .5rem; padding: .9rem 2.1rem; border-radius: 9px;
  font-family: var(--sans); font-size: .88rem; font-weight: 600;
  letter-spacing: .04em; cursor: pointer; white-space: nowrap;
  transition: transform .3s var(--ease-bounce), background .3s, color .3s, box-shadow .3s;
}
.btn:hover { transform: translateY(-3px); }
.btn:active { transform: translateY(0) scale(.98); }

.btn-primary { background: var(--accent); color: var(--bg); box-shadow: 0 4px 22px rgba(201,160,79,.32); }
.btn-primary:hover { background: var(--accent-hi); box-shadow: 0 8px 32px rgba(201,160,79,.48); }

.btn-ghost { background: transparent; color: var(--cream); border: 1.5px solid rgba(244,234,211,.28); }
.btn-ghost:hover { border-color: var(--accent); color: var(--accent); background: rgba(201,160,79,.05); }

.btn-outline { background: transparent; color: var(--accent); border: 1.5px solid var(--accent); padding: .75rem 1.8rem; }
.btn-outline:hover { background: var(--accent); color: var(--bg); }

.btn-full { width: 100%; }
.btn-lg { padding: 1.05rem 2.6rem; font-size: .95rem; }

/* =============================================================
   9. HERO INDEX
   ============================================================= */
.hero-index {
  position: relative; min-height: 100vh; min-height: 100svh;
  display: flex; align-items: center; justify-content: center;
  overflow: hidden; background-color: var(--bg);
  background-image:
    radial-gradient(ellipse 100% 80% at 50% 40%, rgba(201,160,79,.09) 0%, transparent 60%),
    repeating-linear-gradient(180deg, transparent 0px, transparent 2px, rgba(201,160,79,.016) 2px, rgba(201,160,79,.016) 3px),
    repeating-linear-gradient(88deg, rgba(201,160,79,.007) 0px, rgba(201,160,79,.02) 35px, rgba(201,160,79,.007) 70px);
}
.hero-grain {
  position: absolute; inset: 0; z-index: 1; pointer-events: none; opacity: .04;
  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='.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size: 256px;
}
.hero-vignette {
  position: absolute; inset: 0; z-index: 2; pointer-events: none;
  background: radial-gradient(ellipse at center, transparent 30%, rgba(15,10,5,.5) 75%, rgba(15,10,5,.9) 100%),
              linear-gradient(180deg, rgba(15,10,5,.45) 0%, transparent 25%, transparent 72%, rgba(15,10,5,.9) 100%);
}
.hero-glow {
  position: absolute; inset: 0; z-index: 0; pointer-events: none;
  background: radial-gradient(ellipse 65% 55% at 50% 50%, rgba(201,160,79,.07) 0%, transparent 70%);
  animation: glowPulse 7s ease-in-out infinite;
}
@keyframes glowPulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.55;transform:scale(1.12)} }

.hero-particles { position: absolute; inset: 0; z-index: 1; pointer-events: none; overflow: hidden; }
.particle {
  position: absolute; bottom: -10px; border-radius: 50%;
  background: var(--accent); opacity: 0;
  animation: particleRise var(--dur,6s) var(--delay,0s) linear infinite;
}
@keyframes particleRise {
  0%   { transform: translateY(0) translateX(0) scale(1); opacity: 0; }
  10%  { opacity: .75; }
  80%  { opacity: .3; }
  100% { transform: translateY(-115vh) translateX(var(--drift,40px)) scale(.25); opacity: 0; }
}

.hero-index-content {
  position: relative; z-index: 10; text-align: center;
  padding: calc(var(--nav-h) + 3rem) var(--gutter) 5rem;
  max-width: 940px;
}
.hero-eyebrow {
  display: inline-flex; align-items: center; gap: .65rem;
  font-size: .72rem; letter-spacing: .22em; text-transform: uppercase;
  color: var(--accent); font-weight: 600; margin-bottom: 2rem;
}
.eyebrow-dot { display: inline-block; width: 5px; height: 5px; border-radius: 50%; background: var(--accent); animation: dotPulse 2.2s ease-in-out infinite; }
@keyframes dotPulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.35;transform:scale(.55)} }

.hero-title {
  font-family: var(--serif); font-size: clamp(3.2rem, 9vw, 8.5rem);
  font-weight: 400; color: var(--cream); line-height: .97; margin-bottom: 2rem;
}
.hero-title em { font-style: italic; color: var(--accent); display: block; }

.hero-sub { font-size: clamp(.95rem, 1.8vw, 1.18rem); color: var(--cream-3); max-width: 520px; margin: 0 auto 3rem; }

.hero-actions { display: flex; gap: 1rem; justify-content: center; flex-wrap: wrap; }

.hero-scroll {
  position: absolute; bottom: 2.5rem; left: 50%; transform: translateX(-50%);
  z-index: 10; display: flex; flex-direction: column; align-items: center; gap: .4rem; opacity: .45;
}
.hero-scroll-line { display: block; width: 1px; height: 50px; background: linear-gradient(180deg, var(--accent), transparent); animation: scrollLine 2.2s ease-in-out infinite; }
@keyframes scrollLine { 0%,100%{transform:scaleY(1);transform-origin:top;opacity:1} 50%{transform:scaleY(.35);transform-origin:bottom;opacity:.35} }
.hero-scroll-label { font-size: .6rem; letter-spacing: .22em; text-transform: uppercase; color: var(--cream-3); }

/* =============================================================
   10. PAGE HERO (inner pages — nosotros, galería, etc.)
   ============================================================= */
.page-hero {
  position: relative; padding: calc(var(--nav-h) + 5rem) var(--gutter) 5rem;
  text-align: center; overflow: hidden;
  background:
    radial-gradient(ellipse 80% 60% at 50% 60%, rgba(201,160,79,.08) 0%, transparent 65%),
    repeating-linear-gradient(180deg, transparent 0px, transparent 3px, rgba(201,160,79,.014) 3px, rgba(201,160,79,.014) 4px),
    var(--bg);
}
.page-hero-grain {
  position: absolute; inset: 0; pointer-events: none; opacity: .035; z-index: 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='.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size: 256px;
}
.page-hero-content { position: relative; z-index: 2; max-width: 740px; margin: 0 auto; }
.page-hero-eyebrow { display: block; font-size: .7rem; letter-spacing: .22em; text-transform: uppercase; color: var(--accent); margin-bottom: .9rem; font-weight: 600; }
.page-hero-title {
  font-family: var(--serif); font-size: clamp(2.8rem, 7vw, 6rem);
  font-weight: 400; color: var(--cream); line-height: 1;
}
.page-hero-title em { font-style: italic; color: var(--accent); }
.page-hero-sub { margin-top: 1.4rem; font-size: 1.05rem; color: var(--cream-3); max-width: 480px; margin-inline: auto; }

/* gold line under page hero */
.page-hero::after {
  content: ''; display: block;
  width: 64px; height: 2px;
  background: linear-gradient(90deg, var(--accent), var(--accent-2));
  margin: 2.2rem auto 0;
}

/* =============================================================
   11. MARQUEE
   ============================================================= */
.marquee-wrap { overflow: hidden; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); background: var(--bg-2); padding: .85rem 0; }
.marquee-track { display: flex; white-space: nowrap; animation: marqueeScroll 32s linear infinite; will-change: transform; }
.marquee-track:hover { animation-play-state: paused; }
.marquee-track span { font-family: var(--serif); font-size: clamp(.9rem,1.5vw,1.05rem); font-style: italic; color: var(--cream-3); padding: 0 1.5rem; transition: color .3s; }
.marquee-track span:hover { color: var(--accent); }
.m-sep { color: var(--accent) !important; font-style: normal !important; font-size: .68rem !important; padding: 0 .5rem !important; opacity: .65; }
@keyframes marqueeScroll { 0%{transform:translateX(0)} 100%{transform:translateX(-50%)} }

/* =============================================================
   12. HOME — FEATURES STRIP
   ============================================================= */
.features { padding: 5.5rem 0; background: var(--bg-2); position: relative; }
.features::before { content:''; position:absolute; inset:0; background: radial-gradient(ellipse 70% 50% at 70% 50%, rgba(201,160,79,.05) 0%, transparent 60%); pointer-events:none; }
.features-grid { display: grid; grid-template-columns: 1fr; gap: 2px; background: var(--line); }
.feature-item { background: var(--bg-3); padding: 2.4rem 2rem; display: flex; flex-direction: column; gap: .8rem; position: relative; overflow: hidden; transition: background .35s; }
.feature-item::after { content:''; position:absolute; top:0;left:0; width:100%;height:2px; background:linear-gradient(90deg,var(--accent),transparent); transform:scaleX(0); transform-origin:left; transition:transform .45s var(--ease-out); }
.feature-item:hover { background: var(--bg-card); }
.feature-item:hover::after { transform: scaleX(1); }
.feature-icon { font-size: 2.2rem; }
.feature-item h3 { font-family: var(--serif); font-size: 1.3rem; color: var(--cream); font-weight: 500; }
.feature-item p { font-size: .9rem; color: var(--cream-2); }
@media(min-width:540px){ .features-grid{grid-template-columns:1fr 1fr} }
@media(min-width:960px){ .features-grid{grid-template-columns:repeat(4,1fr)} }

/* =============================================================
   13. HOME — GALLERY PREVIEW
   ============================================================= */
.home-gallery { padding: 7rem 0; background: var(--bg); }
.home-gallery-grid { display: grid; grid-template-columns: 1fr; gap: 1.2rem; }
.hg-item { position: relative; overflow: hidden; border-radius: var(--radius); border: 1px solid var(--line); background: var(--bg-3); cursor: pointer; }
.hg-item img { width: 100%; aspect-ratio: 4/3; object-fit: cover; display: block; transition: transform .6s var(--ease-soft), filter .4s; }
.hg-item:hover img { transform: scale(1.06); filter: brightness(1.06) saturate(1.1); }
.hg-item figcaption { position: absolute; bottom: 0; left: 0; right: 0; padding: 1.5rem 1.2rem .9rem; background: linear-gradient(0deg, rgba(15,10,5,.92) 0%, transparent 100%); opacity: 0; transform: translateY(8px); transition: opacity .35s, transform .35s var(--ease-out); }
.hg-item:hover figcaption { opacity: 1; transform: translateY(0); }
.hg-item figcaption p { font-family: var(--serif); font-size: 1.1rem; color: var(--cream); }
.hg-item figcaption span { font-size: .7rem; letter-spacing: .16em; text-transform: uppercase; color: var(--accent); }
@media(min-width:720px){ .home-gallery-grid{grid-template-columns:1fr 1fr} }
@media(min-width:960px){ .home-gallery-grid{grid-template-columns:repeat(4,1fr)} }

/* =============================================================
   14. HOME — STATS BANNER
   ============================================================= */
.stats-banner { padding: 4.5rem 0; background: var(--bg-2); border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.stats-banner-grid { display: grid; grid-template-columns: repeat(2,1fr); gap: 2px; background: var(--line); }
.stat-item { background: var(--bg-3); padding: 2.5rem 2rem; text-align: center; transition: background .3s; }
.stat-item:hover { background: var(--bg-card); }
.stat-num { display: block; font-family: var(--serif); font-size: clamp(2.6rem, 5vw, 4.2rem); font-weight: 600; color: var(--accent); line-height: 1; }
.stat-label { display: block; font-size: .75rem; letter-spacing: .1em; text-transform: uppercase; color: var(--cream-3); margin-top: .5rem; }
@media(min-width:720px){ .stats-banner-grid{grid-template-columns:repeat(4,1fr)} }

/* =============================================================
   15. HOME — CTA BANNER
   ============================================================= */
.cta-banner {
  padding: 7rem 0; text-align: center; background: var(--bg);
  background-image: radial-gradient(ellipse 60% 50% at 50% 50%, rgba(201,160,79,.07) 0%, transparent 65%);
}
.cta-banner h2 { font-family: var(--serif); font-size: clamp(2rem, 4.5vw, 3.8rem); color: var(--cream); margin-bottom: 1.2rem; }
.cta-banner h2 em { font-style: italic; color: var(--accent); }
.cta-banner p { color: var(--cream-3); max-width: 480px; margin: 0 auto 2.5rem; }
.cta-banner-btns { display: flex; gap: 1rem; justify-content: center; flex-wrap: wrap; }

/* =============================================================
   16. NOSOTROS PAGE
   ============================================================= */
.nosotros-story { padding: 7rem 0; background: var(--bg-2); }
.nosotros-story-grid { display: grid; grid-template-columns: 1fr; gap: 4rem; align-items: center; }
.story-img { border-radius: var(--radius); overflow: hidden; border: 1px solid var(--line); background: var(--bg-3); aspect-ratio: 4/3; display: flex; align-items: center; justify-content: center; }
.story-img-placeholder { font-family: var(--serif); font-size: 1.2rem; font-style: italic; color: var(--cream-3); text-align: center; padding: 2rem; }
.story-text h2 { font-family: var(--serif); font-size: clamp(1.8rem,3.5vw,2.8rem); color: var(--cream); margin-bottom: 1.4rem; }
.story-text h2 em { font-style: italic; color: var(--accent); }
.story-text p { color: var(--cream-2); margin-bottom: 1.1rem; font-size: .97rem; }
@media(min-width:960px){ .nosotros-story-grid{grid-template-columns:1fr 1fr;gap:6rem} }

.nos-stats { padding: 6rem 0; background: var(--bg); }
.nos-stats-grid { display: grid; grid-template-columns: repeat(2,1fr); gap: 2px; background: var(--line); }
.nos-stat { background: var(--bg-3); padding: 3rem 2rem; position: relative; overflow: hidden; transition: background .35s; }
.nos-stat:hover { background: var(--bg-card); }
.nos-stat::before { content:''; position:absolute; bottom:0;left:0;width:100%;height:2px; background:linear-gradient(90deg,var(--accent),transparent); transform:scaleX(0);transform-origin:left; transition:transform .5s var(--ease-out); }
.nos-stat:hover::before { transform:scaleX(1); }
.nos-stat-num { display: block; font-family: var(--serif); font-size: clamp(3rem,6vw,5rem); font-weight: 600; color: var(--accent); line-height: 1; }
.nos-stat-label { display: block; font-size: .78rem; letter-spacing: .1em; text-transform: uppercase; color: var(--cream-3); margin-top: .6rem; }
@media(min-width:720px){ .nos-stats-grid{grid-template-columns:repeat(4,1fr)} }

.nos-valores { padding: 6rem 0; background: var(--bg-2); }
.nos-valores-grid { display: grid; grid-template-columns: 1fr; gap: 1.5rem; }
.valor-card { background: var(--bg-card); border: 1px solid var(--line); border-radius: var(--radius); padding: 2.4rem 2rem; position: relative; overflow: hidden; transition: transform .3s var(--ease-bounce), box-shadow .3s; }
.valor-card:hover { transform: translateY(-5px); box-shadow: 0 16px 48px rgba(0,0,0,.4), 0 0 0 1px rgba(201,160,79,.2); }
.valor-icon { font-size: 2.8rem; margin-bottom: 1rem; }
.valor-card h3 { font-family: var(--serif); font-size: 1.4rem; color: var(--cream); margin-bottom: .8rem; }
.valor-card p { font-size: .92rem; color: var(--cream-2); }
.valor-num { position: absolute; bottom: 1.2rem; right: 1.5rem; font-family: var(--serif); font-size: 5rem; font-weight: 600; color: rgba(201,160,79,.05); line-height: 1; user-select: none; transition: color .4s; }
.valor-card:hover .valor-num { color: rgba(201,160,79,.1); }
@media(min-width:720px){ .nos-valores-grid{grid-template-columns:1fr 1fr} }
@media(min-width:960px){ .nos-valores-grid{grid-template-columns:repeat(4,1fr)} }

/* =============================================================
   17. SERVICIOS PAGE
   ============================================================= */
.servicios-page { padding: 6rem 0; background: var(--bg-2); }
.servicios-page-list { display: flex; flex-direction: column; gap: 3px; background: var(--line); }
.servicio-row {
  background: var(--bg-3); padding: 3rem 2.5rem;
  display: grid; grid-template-columns: 1fr; gap: 2rem;
  position: relative; overflow: hidden; transition: background .35s;
  border-left: 3px solid transparent; transition: border-color .3s, background .35s;
}
.servicio-row:hover { background: var(--bg-card); border-left-color: var(--accent); }
.servicio-row-header { display: flex; align-items: center; gap: 1.2rem; }
.servicio-row-icon { width: 52px; height: 52px; background: rgba(201,160,79,.1); border-radius: 12px; display: flex; align-items: center; justify-content: center; color: var(--accent); flex-shrink: 0; transition: background .35s, transform .35s var(--ease-bounce); }
.servicio-row:hover .servicio-row-icon { background: rgba(201,160,79,.18); transform: scale(1.08); }
.servicio-row-icon svg { width: 26px; height: 26px; }
.servicio-row-title h3 { font-family: var(--serif); font-size: 1.5rem; color: var(--cream); font-weight: 500; }
.servicio-row-title span { font-size: .72rem; letter-spacing: .15em; text-transform: uppercase; color: var(--accent); }
.servicio-row-body p { color: var(--cream-2); font-size: .95rem; line-height: 1.7; margin-bottom: 1.2rem; }
.servicio-row-features { display: flex; flex-wrap: wrap; gap: .5rem; }
.sf-tag { padding: .35rem .9rem; background: rgba(201,160,79,.08); border: 1px solid rgba(201,160,79,.2); border-radius: 100px; font-size: .78rem; color: var(--cream-3); transition: background .3s, color .3s; }
.servicio-row:hover .sf-tag { background: rgba(201,160,79,.12); color: var(--cream-2); }
@media(min-width:960px){ .servicio-row{grid-template-columns:320px 1fr;gap:3rem;align-items:start} }

.proceso { padding: 6rem 0; background: var(--bg); }
.proceso-steps { display: grid; grid-template-columns: 1fr; gap: 2px; background: var(--line); counter-reset: step; }
.paso { background: var(--bg-3); padding: 2.4rem 2.2rem; position: relative; overflow: hidden; transition: background .35s; }
.paso:hover { background: var(--bg-card); }
.paso-num { font-family: var(--serif); font-size: .85rem; font-weight: 600; letter-spacing: .12em; color: var(--accent); margin-bottom: .7rem; }
.paso h3 { font-family: var(--serif); font-size: 1.25rem; color: var(--cream); margin-bottom: .5rem; }
.paso p { font-size: .9rem; color: var(--cream-2); }
.paso-arrow { position: absolute; top: 2rem; right: 2rem; font-size: 1.4rem; color: var(--accent); opacity: .35; transition: opacity .3s, transform .3s var(--ease-bounce); }
.paso:hover .paso-arrow { opacity: .8; transform: translateX(4px); }
@media(min-width:720px){ .proceso-steps{grid-template-columns:1fr 1fr} }
@media(min-width:1024px){ .proceso-steps{grid-template-columns:repeat(5,1fr)} }

/* =============================================================
   18. GALERÍA PAGE
   ============================================================= */
.galeria-page { padding: 5.5rem 0; background: var(--bg); }
.galeria-page-grid { display: grid; grid-template-columns: 1fr; gap: 1.5rem; }
.gal-item {
  position: relative; border-radius: var(--radius); overflow: hidden;
  background: var(--bg-3); border: 1px solid var(--line); cursor: pointer;
  transform-style: preserve-3d;
}
.gal-item::before { content:''; position:absolute; inset:0; z-index:3; background:linear-gradient(0deg,rgba(15,10,5,.88) 0%,transparent 55%); opacity:0; transition:opacity .4s; }
.gal-item:hover::before { opacity:1; }
.gal-item img { width:100%; aspect-ratio:4/3; object-fit:cover; transition:transform .6s var(--ease-soft),filter .4s; }
.gal-item:hover img { transform:scale(1.06); filter:brightness(1.06) saturate(1.12); }
.gal-caption { position:absolute; bottom:0; left:0; right:0; z-index:4; padding:1.8rem 1.4rem .9rem; transform:translateY(10px); opacity:0; transition:transform .4s var(--ease-out),opacity .4s; }
.gal-item:hover .gal-caption { transform:translateY(0); opacity:1; }
.gal-cat { display:block; font-size:.68rem; letter-spacing:.18em; text-transform:uppercase; color:var(--accent); margin-bottom:.3rem; }
.gal-name { display:block; font-family:var(--serif); font-size:1.3rem; color:var(--cream); }
.gal-zoom { position:absolute; top:50%; left:50%; transform:translate(-50%,-50%) scale(0); z-index:5; font-size:2.5rem; color:var(--accent); transition:transform .4s var(--ease-bounce); }
.gal-item:hover .gal-zoom { transform:translate(-50%,-50%) scale(1); }

.gal-item.gal-wide { grid-column: span 1; }

@media(min-width:720px){
  .galeria-page-grid{ grid-template-columns:1fr 1fr; }
  .gal-item.gal-wide{ grid-column:span 2; }
  .gal-item.gal-wide img{ aspect-ratio:16/7; }
}
@media(min-width:960px){ .galeria-page-grid{grid-template-columns:repeat(3,1fr)} .gal-item.gal-wide{grid-column:span 2} }

/* =============================================================
   19. PRECIOS PAGE
   ============================================================= */
.precios-page { padding: 5.5rem 0; background: var(--bg); }

.precios-cat { margin-bottom: 5rem; }
.precios-cat-title {
  font-family: var(--serif); font-size: 1.6rem; color: var(--cream);
  border-bottom: 1px solid var(--line); padding-bottom: 1rem; margin-bottom: 2.5rem;
  display: flex; align-items: center; gap: .8rem;
}
.precios-cat-title span { font-size: 1.8rem; }

.precio-cards { display: grid; grid-template-columns: 1fr; gap: 1.2rem; }
.precio-card {
  background: var(--bg-3); border: 1px solid var(--line); border-radius: var(--radius);
  padding: 2rem 1.8rem; position: relative; overflow: hidden;
  transition: transform .3s var(--ease-bounce), border-color .3s, box-shadow .3s;
}
.precio-card:hover { transform: translateY(-4px); border-color: rgba(201,160,79,.3); box-shadow: 0 14px 44px rgba(0,0,0,.4); }
.precio-card.is-popular {
  border-color: var(--accent);
  box-shadow: 0 0 0 1px var(--accent), 0 12px 40px rgba(201,160,79,.2);
}
.popular-badge {
  position: absolute; top: -1px; right: 1.5rem;
  background: var(--accent); color: var(--bg);
  font-size: .65rem; font-weight: 700; letter-spacing: .12em;
  text-transform: uppercase; padding: .3rem .8rem; border-radius: 0 0 8px 8px;
}
.pc-name { font-family: var(--serif); font-size: 1.15rem; color: var(--cream); margin-bottom: .4rem; }
.pc-price { font-family: var(--serif); font-size: 2.2rem; font-weight: 600; color: var(--accent); line-height: 1.1; margin-bottom: .3rem; }
.pc-price-sub { font-size: .78rem; color: var(--cream-3); margin-bottom: 1.2rem; }
.pc-features { display: flex; flex-direction: column; gap: .5rem; margin-bottom: 1.4rem; }
.pc-feature { font-size: .87rem; color: var(--cream-2); display: flex; align-items: flex-start; gap: .5rem; }
.pc-feature::before { content: '✦'; color: var(--accent); font-size: .6rem; flex-shrink: 0; margin-top: .2rem; }

@media(min-width:720px){ .precio-cards{grid-template-columns:repeat(2,1fr)} }
@media(min-width:960px){ .precio-cards{grid-template-columns:repeat(3,1fr)} }

.precios-nota {
  margin-top: 3rem; padding: 2rem 2.2rem;
  background: var(--bg-3); border: 1px solid var(--line); border-radius: var(--radius);
  border-left: 3px solid var(--accent);
}
.precios-nota p { font-size: .9rem; color: var(--cream-2); }
.precios-nota strong { color: var(--accent); }

/* =============================================================
   20. CONTACTO PAGE
   ============================================================= */
.contacto-page { padding: 6rem 0; background: var(--bg-2); }
.contacto-page-grid { display: grid; grid-template-columns: 1fr; gap: 4.5rem; align-items: start; }
@media(min-width:960px){ .contacto-page-grid{grid-template-columns:1fr 1.2fr;gap:6rem} }

.contact-info-block h2 { font-family: var(--serif); font-size: clamp(1.8rem,3.5vw,2.8rem); color: var(--cream); margin-bottom: 1rem; }
.contact-info-block h2 em { font-style: italic; color: var(--accent); }
.contact-info-block p { color: var(--cream-2); margin-bottom: 2.5rem; }

.contact-datos { display: flex; flex-direction: column; gap: 1rem; margin-bottom: 2.5rem; }
.contact-dato {
  display: flex; align-items: center; gap: .9rem;
  padding: .85rem 1.1rem; background: var(--bg-card);
  border: 1px solid var(--line); border-radius: 10px;
  font-size: .92rem; color: var(--cream-2); transition: border-color .3s, color .3s;
}
.contact-dato:hover { border-color: rgba(201,160,79,.3); color: var(--accent); }
.contact-dato svg { width: 18px; height: 18px; color: var(--accent); flex-shrink: 0; }

.contact-horario {
  padding: 1.4rem 1.6rem; background: var(--bg-card);
  border: 1px solid var(--line); border-radius: 10px; margin-bottom: 2.5rem;
}
.contact-horario h4 { font-size: .72rem; letter-spacing: .16em; text-transform: uppercase; color: var(--accent); margin-bottom: 1rem; }
.horario-row { display: flex; justify-content: space-between; font-size: .88rem; color: var(--cream-2); padding: .35rem 0; border-bottom: 1px solid var(--line-soft); }
.horario-row:last-child { border: none; }
.horario-row span:last-child { color: var(--cream-3); }

.contact-social { display: flex; gap: .75rem; flex-wrap: wrap; }

/* form */
.contact-form-card {
  background: var(--bg-3); border: 1px solid var(--line);
  border-radius: 18px; padding: 2.8rem 2.2rem;
}
.contact-form-card h3 { font-family: var(--serif); font-size: 1.6rem; color: var(--cream); margin-bottom: 1.8rem; }
.contact-form-card h3 em { font-style: italic; color: var(--accent); }
.cf-form { display: flex; flex-direction: column; gap: 1.3rem; }
.cf-row { display: grid; grid-template-columns: 1fr; gap: 1.3rem; }
@media(min-width:540px){ .cf-row{grid-template-columns:1fr 1fr} }
.form-group { display: flex; flex-direction: column; gap: .42rem; }
.form-group label { font-size: .8rem; font-weight: 500; letter-spacing: .06em; text-transform: uppercase; color: var(--cream-3); }
.form-optional { font-weight: 400; text-transform: none; opacity: .6; }
.form-group input, .form-group textarea, .form-group select {
  width: 100%; padding: .88rem 1.1rem;
  background: var(--bg-2); border: 1.5px solid var(--line);
  border-radius: 9px; color: var(--cream);
  font-family: var(--sans); font-size: .92rem;
  transition: border-color .3s, box-shadow .3s;
}
.form-group input::placeholder, .form-group textarea::placeholder { color: var(--cream-3); opacity: .65; }
.form-group input:focus, .form-group textarea:focus, .form-group select:focus { outline: none; border-color: var(--accent); box-shadow: 0 0 0 3px rgba(201,160,79,.12); }
.form-group textarea { resize: vertical; }
.form-group select { appearance: none; -webkit-appearance: none; cursor: pointer; }
.btn-sending-label, .btn-sent-label { display: none; }
.cf-form.is-sending .btn-default-label, .cf-form.is-sending .btn-sent-label { display: none; }
.cf-form.is-sending .btn-sending-label { display: block; }
.cf-form.is-sent .btn-default-label, .cf-form.is-sent .btn-sending-label { display: none; }
.cf-form.is-sent .btn-sent-label { display: block; }
.cf-form.is-sent #form-submit { background: #2d6040; box-shadow: none; pointer-events: none; }
.form-note { font-size: .78rem; color: var(--cream-3); text-align: center; margin-top: .5rem; }

/* =============================================================
   21. SOCIAL BUTTONS
   ============================================================= */
.soc-btn {
  position: relative; display: inline-flex; align-items: center; gap: .65rem;
  padding: .78rem 1.4rem; border-radius: 12px;
  font-size: .84rem; font-weight: 600; letter-spacing: .02em;
  color: var(--cream-2); background: var(--bg-card);
  border: 1.5px solid var(--line); overflow: hidden;
  transition: color .3s, border-color .3s, transform .3s var(--ease-bounce), box-shadow .3s;
}
.soc-btn::before {
  content: ''; position: absolute; inset: 0;
  background: var(--soc-grad, linear-gradient(135deg, rgba(255,255,255,.06), transparent));
  opacity: 0; transition: opacity .35s; pointer-events: none;
}
.soc-btn:hover::before { opacity: 1; }
.soc-btn svg { width: 20px; height: 20px; flex-shrink: 0; transition: transform .35s var(--ease-bounce); }
.soc-btn:hover svg { transform: scale(1.18) rotate(-4deg); }
.soc-btn:hover { transform: translateY(-3px); }

.soc-btn[aria-label="Visitar Instagram"]:hover {
  background: linear-gradient(135deg,#f09433 0%,#e6683c 25%,#dc2743 50%,#cc2366 75%,#bc1888 100%);
  border-color: transparent; color: #fff;
  box-shadow: 0 6px 28px rgba(220,39,67,.42);
}
.soc-btn[aria-label="Visitar TikTok"]:hover {
  background: #010101; border-color: #00f2ea; color: #fff;
  box-shadow: 0 6px 28px rgba(0,242,234,.28), 0 0 0 1px rgba(255,0,80,.28);
}
.soc-btn[aria-label="Visitar Facebook"]:hover {
  background: #1877f2; border-color: transparent; color: #fff;
  box-shadow: 0 6px 28px rgba(24,119,242,.42);
}

/* Footer social */
.footer-social { display: flex; gap: .6rem; }
.footer-social a {
  font-size: .7rem; font-weight: 700; letter-spacing: .12em;
  padding: .52rem 1rem; border: 1.5px solid var(--line);
  border-radius: 8px; color: var(--cream-3);
  transition: border-color .3s, color .3s, background .3s, transform .3s var(--ease-bounce), box-shadow .3s;
}
.footer-social a:hover { transform: translateY(-3px); }
.footer-social a[aria-label="Instagram"]:hover { background:linear-gradient(135deg,#f09433,#dc2743,#bc1888); border-color:transparent; color:#fff; box-shadow:0 4px 18px rgba(220,39,67,.38); }
.footer-social a[aria-label="TikTok"]:hover { background:#010101; border-color:#00f2ea; color:#fff; box-shadow:0 4px 18px rgba(0,242,234,.28); }
.footer-social a[aria-label="Facebook"]:hover { background:#1877f2; border-color:transparent; color:#fff; box-shadow:0 4px 18px rgba(24,119,242,.38); }

/* =============================================================
   22. WHATSAPP FLOAT
   ============================================================= */
.wa-float {
  position: fixed; bottom: 6rem; right: 1.5rem; z-index: 1050;
  display: flex; align-items: center; gap: .7rem;
  background: #25d366; color: #fff;
  padding: .7rem 1.2rem .7rem 1rem; border-radius: 100px;
  font-size: .82rem; font-weight: 600;
  box-shadow: 0 4px 20px rgba(37,211,102,.45);
  transition: transform .3s var(--ease-bounce), box-shadow .3s;
  animation: waPulse 3s ease-in-out 3s infinite;
}
.wa-float:hover { transform: translateY(-3px) scale(1.04); box-shadow: 0 8px 28px rgba(37,211,102,.55); animation: none; }
.wa-float svg { width: 20px; height: 20px; flex-shrink: 0; }
@keyframes waPulse { 0%,100%{box-shadow:0 4px 20px rgba(37,211,102,.45),0 0 0 0 rgba(37,211,102,.3)} 50%{box-shadow:0 4px 20px rgba(37,211,102,.45),0 0 0 10px rgba(37,211,102,0)} }
@media(max-width:540px){ .wa-float span { display: none; } .wa-float { padding: .8rem; border-radius: 50%; width: 52px; height: 52px; justify-content: center; } }

/* =============================================================
   23. VIRTUAL ASSISTANT
   ============================================================= */
.bot-wrap {
  position: fixed; bottom: 1.8rem; right: 1.5rem; z-index: 1100;
  display: flex; flex-direction: column; align-items: flex-end; gap: .8rem;
}
.bot-toggle {
  width: 58px; height: 58px; border-radius: 50%;
  background: var(--accent); color: var(--bg);
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 4px 24px rgba(201,160,79,.45);
  transition: transform .3s var(--ease-bounce), box-shadow .3s;
  animation: botPulse 3.5s ease-in-out 5s infinite;
  position: relative;
}
.bot-toggle:hover { transform: scale(1.1); box-shadow: 0 8px 32px rgba(201,160,79,.55); animation: none; }
@keyframes botPulse { 0%,100%{box-shadow:0 4px 24px rgba(201,160,79,.45),0 0 0 0 rgba(201,160,79,.3)} 50%{box-shadow:0 4px 24px rgba(201,160,79,.45),0 0 0 10px rgba(201,160,79,0)} }
.bot-icon-chat  { width: 24px; height: 24px; transition: opacity .3s, transform .3s; }
.bot-icon-close { width: 20px; height: 20px; position: absolute; opacity: 0; transition: opacity .3s, transform .3s; transform: rotate(-90deg); }
.bot-toggle[aria-expanded="true"] .bot-icon-chat  { opacity: 0; transform: rotate(90deg); }
.bot-toggle[aria-expanded="true"] .bot-icon-close { opacity: 1; transform: rotate(0deg); }
.bot-badge { position: absolute; top: -3px; right: -3px; width: 18px; height: 18px; background: #e04040; border-radius: 50%; font-size: .6rem; font-weight: 700; color: #fff; display: flex; align-items: center; justify-content: center; transition: opacity .3s, transform .3s; }
.bot-toggle[aria-expanded="true"] .bot-badge { opacity: 0; transform: scale(0); }

.bot-panel {
  width: 320px; background: var(--bg-3); border: 1px solid var(--line);
  border-radius: 16px; overflow: hidden;
  box-shadow: 0 20px 60px rgba(0,0,0,.6);
  transform-origin: bottom right; transition: transform .35s var(--ease-out), opacity .3s;
  transform: scale(.85) translateY(10px); opacity: 0; pointer-events: none;
}
.bot-panel.is-open { transform: scale(1) translateY(0); opacity: 1; pointer-events: auto; }
.bot-head { display: flex; align-items: center; gap: .9rem; padding: 1.2rem 1.3rem; background: var(--bg-card); border-bottom: 1px solid var(--line); }
.bot-avatar { font-size: 1.6rem; width: 42px; height: 42px; background: var(--bg-2); border-radius: 50%; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.bot-name { font-weight: 600; font-size: .9rem; color: var(--cream); }
.bot-status { font-size: .75rem; color: var(--cream-3); display: flex; align-items: center; gap: .35rem; }
.bot-dot { width: 6px; height: 6px; background: #4caf70; border-radius: 50%; display: inline-block; animation: dotBlink 2.2s ease-in-out infinite; }
@keyframes dotBlink { 0%,100%{opacity:1} 50%{opacity:.35} }
.bot-messages { max-height: 220px; overflow-y: auto; padding: 1.2rem 1.1rem; display: flex; flex-direction: column; gap: .7rem; scrollbar-width: thin; scrollbar-color: var(--line) transparent; }
.bot-msg { max-width: 90%; padding: .65rem .95rem; border-radius: 12px; font-size: .85rem; line-height: 1.5; animation: msgPop .3s var(--ease-bounce) forwards; }
@keyframes msgPop { from{opacity:0;transform:translateY(8px) scale(.95)} to{opacity:1;transform:translateY(0) scale(1)} }
.bot-in  { background: var(--bg-card); color: var(--cream-2); border-bottom-left-radius: 4px; align-self: flex-start; }
.bot-in strong { color: var(--accent); }
.bot-out { background: var(--accent); color: var(--bg); border-bottom-right-radius: 4px; align-self: flex-end; font-weight: 500; }
.bot-opts { padding: .8rem 1rem 1rem; display: flex; flex-direction: column; gap: .45rem; border-top: 1px solid var(--line); }
.bot-opt { text-align: left; padding: .6rem .9rem; font-size: .8rem; color: var(--cream-2); background: var(--bg-2); border: 1px solid var(--line); border-radius: 8px; transition: background .2s, color .2s, border-color .2s, transform .2s var(--ease-bounce); }
.bot-opt:hover { background: rgba(201,160,79,.1); border-color: rgba(201,160,79,.4); color: var(--accent); transform: translateX(3px); }

/* =============================================================
   24. LIGHTBOX
   ============================================================= */
.lightbox { position: fixed; inset: 0; z-index: 2000; background: rgba(8,5,2,.96); display: flex; align-items: center; justify-content: center; padding: 2rem; opacity: 0; pointer-events: none; transition: opacity .3s; }
.lightbox.is-open { opacity: 1; pointer-events: auto; }
.lightbox img { max-width: 90vw; max-height: 85vh; object-fit: contain; border-radius: 8px; transform: scale(.9); transition: transform .4s var(--ease-out); }
.lightbox.is-open img { transform: scale(1); }
.lightbox-close { position: absolute; top: 1.5rem; right: 1.5rem; font-size: 2rem; color: var(--cream-2); background: rgba(255,255,255,.07); width: 46px; height: 46px; border-radius: 50%; display: flex; align-items: center; justify-content: center; transition: background .2s, color .2s; }
.lightbox-close:hover { background: var(--accent); color: var(--bg); }

/* =============================================================
   25. FOOTER
   ============================================================= */
.footer { background: var(--bg-2); border-top: 1px solid var(--line); padding: 4.5rem 0 2rem; }
.footer-top { display: grid; grid-template-columns: 1fr; gap: 3rem; padding-bottom: 3rem; border-bottom: 1px solid var(--line-soft); }
.footer-logo-text { font-family: var(--serif); font-size: 2.4rem; font-weight: 600; letter-spacing: .16em; color: var(--accent); margin-bottom: .4rem; }
.footer-tagline { font-size: .85rem; color: var(--cream-3); font-style: italic; }
.footer-nav { display: flex; flex-wrap: wrap; gap: .6rem 1.8rem; }
.footer-nav a { font-size: .85rem; color: var(--cream-3); transition: color .3s; }
.footer-nav a:hover { color: var(--accent); }
.footer-follow { font-size: .7rem; letter-spacing: .18em; text-transform: uppercase; color: var(--cream-3); margin-bottom: .8rem; }
.footer-bottom { display: flex; flex-wrap: wrap; justify-content: space-between; align-items: center; gap: .5rem; padding-top: 2rem; }
.footer-bottom p { font-size: .8rem; color: var(--cream-3); }
.footer-made { font-style: italic; }
@media(min-width:720px){ .footer-top{grid-template-columns:1fr auto auto;align-items:start;gap:2rem} }

/* =============================================================
   26. REVEAL ANIMATIONS
   ============================================================= */
.reveal { opacity: 0; transform: translateY(34px); transition: opacity .75s var(--ease-out), transform .75s var(--ease-out); }
.reveal[data-split] { opacity: 1; transform: none; }
.reveal.is-visible { opacity: 1; transform: translateY(0); }
.reveal-left { opacity: 0; transform: translateX(-40px); transition: opacity .75s var(--ease-out), transform .75s var(--ease-out); }
.reveal-left.is-visible { opacity: 1; transform: translateX(0); }
.reveal-right { opacity: 0; transform: translateX(40px); transition: opacity .75s var(--ease-out), transform .75s var(--ease-out); }
.reveal-right.is-visible { opacity: 1; transform: translateX(0); }
.reveal-scale { opacity: 0; transform: scale(.92); transition: opacity .7s var(--ease-out), transform .7s var(--ease-out); }
.reveal-scale.is-visible { opacity: 1; transform: scale(1); }

/* stagger helpers */
.stagger-1 { transition-delay: .08s; }
.stagger-2 { transition-delay: .16s; }
.stagger-3 { transition-delay: .24s; }
.stagger-4 { transition-delay: .32s; }
.stagger-5 { transition-delay: .40s; }

/* =============================================================
   27. REDUCED MOTION
   ============================================================= */
@media (prefers-reduced-motion: reduce) {
  .hero-scroll-line, .marquee-track, .hero-glow, .splash-letters span,
  .splash-sub, .splash-line { animation: none !important; }
  .particle { display: none; }
}

/* =============================================================
   28. MOBILE
   ============================================================= */
@media (max-width: 540px) {
  .hero-actions { flex-direction: column; align-items: center; }
  .hero-actions .btn { width: 100%; max-width: 300px; }
  .bot-panel { width: 290px; }
  .contact-form-card { padding: 1.8rem 1.4rem; }
  .wa-float { bottom: 6.5rem; }
}
