/* ═══════════════════════════════════════════════
   GLOBAL.CSS — Memorygraph shared styles
   Loaded on every page. Page-specific styles
   remain in each template's <style> block.
   ═══════════════════════════════════════════════ */

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

/* ── DESIGN TOKENS ── */
:root{
  --ivory:    #f4ede0;
  --ivory-2:  #ece4d4;
  --ink:      #1a1814;
  --ink-soft: #3a3530;
  --teal:     #1d5959;
  --teal-2:   #2a7575;
  --teal-deep:#0f3838;
  --gold:     #b8965a;
  --gold-2:   #d4a96a;
  --mist:     #8b857a;
  --line:     rgba(26,24,20,.12);
  --line-2:   rgba(26,24,20,.06);
  --serif:    'Cormorant Garamond', Georgia, serif;
  --sans:     'Jost', sans-serif;
}

/* ── BASE ── */
html{scroll-behavior:smooth;}
body{
  background:var(--ivory);
  color:var(--ink);
  font-family:var(--sans);
  font-weight:300;
  overflow-x:hidden;
}
body::before{
  content:'';position:fixed;inset:0;pointer-events:none;z-index:1;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 400 400' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.04'/%3E%3C/svg%3E");
  mix-blend-mode:multiply;opacity:.6;
}
input, textarea, select { cursor: text; }

/* ── NAVIGATION ── */
nav{
  position:fixed;top:0;left:0;width:100%;z-index:100;
  padding:24px 56px;
  display:flex;align-items:center;justify-content:space-between;
  transition:padding .5s,background .5s,transform .4s cubic-bezier(.22,1,.36,1);
}
nav.scrolled{
  padding:14px 56px;
  background:rgba(244,237,224,.92);
  backdrop-filter:blur(16px);
  border-bottom:1px solid var(--line-2);
}
.nav-logo{display:flex;align-items:center;gap:12px;text-decoration:none;color:var(--ink);}
.nav-mark{width:30px;height:24px;}
.nav-mark svg{width:100%;height:100%;}
.nav-wordmark{font-family:var(--serif);font-size:1.15rem;font-weight:500;letter-spacing:.04em;line-height:1;}
.nav-wordmark small{display:block;font-family:var(--sans);font-size:.55rem;letter-spacing:.32em;color:var(--mist);margin-top:4px;}
.nav-links{display:flex;gap:32px;list-style:none;}
.nav-links a{
  font-family:var(--sans);font-size:.7rem;letter-spacing:.22em;
  text-transform:uppercase;color:var(--ink-soft);text-decoration:none;
  transition:color .3s;position:relative;
}
.nav-links a::after{
  content:'';position:absolute;bottom:-4px;left:0;width:0;height:1px;
  background:var(--teal);transition:width .4s;
}
.nav-links a:hover,.nav-links a.active{color:var(--teal);}
.nav-links a:hover::after,.nav-links a.active::after{width:100%;}
.nav-cta{
  font-family:var(--sans);font-size:.7rem;letter-spacing:.22em;
  text-transform:uppercase;background:var(--teal);color:var(--ivory);
  padding:11px 26px;text-decoration:none;transition:all .35s;
  border:1px solid var(--teal);
}
.nav-cta:hover{background:var(--teal-deep);}

/* ── HAMBURGER ── */
.nav-toggle{
  display:none;flex-direction:column;gap:5px;background:none;
  border:none;cursor:pointer;padding:8px;z-index:101;
}
.nav-toggle span{
  display:block;width:22px;height:1.5px;background:var(--ink);
  transition:all .35s cubic-bezier(.22,1,.36,1);
}
.nav-toggle.open span:nth-child(1){transform:rotate(45deg) translate(4px,4px);}
.nav-toggle.open span:nth-child(2){opacity:0;}
.nav-toggle.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px);}

/* ── MOBILE MENU ── */
.mobile-menu{
  position:fixed;inset:0;z-index:99;background:var(--ivory);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:36px;
  opacity:0;visibility:hidden;transition:opacity .4s,visibility .4s;
}
.mobile-menu.open{opacity:1;visibility:visible;}
.mobile-menu a{
  font-family:var(--serif);font-size:clamp(1.8rem,5vw,2.8rem);
  font-weight:300;font-style:italic;color:var(--ink);text-decoration:none;transition:color .3s;
}
.mobile-menu a:hover{color:var(--teal);}
.mobile-menu-cta{
  font-family:var(--sans)!important;font-size:.7rem!important;
  font-style:normal!important;letter-spacing:.22em;text-transform:uppercase;
  background:var(--teal);color:var(--ivory)!important;padding:14px 32px;margin-top:12px;
}
.mobile-menu-social{display:flex;gap:24px;margin-top:8px;}
.mobile-menu-social a{
  font-family:var(--sans)!important;font-size:.62rem!important;
  font-style:normal!important;letter-spacing:.22em;text-transform:uppercase;
  color:var(--mist)!important;
}

/* ── FOOTER ── */
footer{background:var(--ink);color:var(--ivory);padding:60px 56px 36px;}
.footer-inner{display:flex;justify-content:space-between;align-items:center;margin-bottom:40px;flex-wrap:wrap;gap:24px;}
.footer-logo{display:flex;align-items:center;gap:12px;}
.footer-links-row{display:flex;gap:32px;flex-wrap:wrap;}
.footer-links-row a{
  font-family:var(--sans);font-size:.68rem;letter-spacing:.18em;
  text-transform:uppercase;color:rgba(244,237,224,.45);text-decoration:none;transition:color .3s;
}
.footer-links-row a:hover{color:var(--gold);}
.footer-bottom{
  border-top:1px solid rgba(244,237,224,.08);padding-top:24px;
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px;
}
.footer-copy{font-family:var(--sans);font-size:.65rem;color:rgba(244,237,224,.3);}

/* ── REVEAL ANIMATIONS ── */
.reveal{
  opacity:0;transform:translateY(36px);
  transition:opacity .9s cubic-bezier(.22,1,.36,1),transform .9s cubic-bezier(.22,1,.36,1);
}
.reveal.visible{opacity:1;transform:translateY(0);}
.reveal-d1{transition-delay:.12s;}
.reveal-d2{transition-delay:.24s;}
.reveal-d3{transition-delay:.38s;}
.gsap-reveal{opacity:0;transform:translateY(36px);}

/* ── SKIP LINK ── */
.skip-link{
  position:absolute;top:-100%;left:16px;z-index:10001;
  background:var(--teal);color:var(--ivory);padding:12px 24px;
  font-family:var(--sans);font-size:.8rem;text-decoration:none;transition:top .3s;
}
.skip-link:focus{top:16px;}

/* ── WHATSAPP FLOAT ── */
.whatsapp-float{
  position:fixed;bottom:32px;right:32px;z-index:200;
  width:58px;height:58px;border-radius:50%;background:#25d366;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 8px 28px rgba(37,211,102,.35);text-decoration:none;
  animation:pulse 2.5s ease-in-out infinite;
}
.whatsapp-float svg{width:30px;height:30px;color:#fff;}
@keyframes pulse{
  0%,100%{box-shadow:0 8px 28px rgba(37,211,102,.35);}
  50%{box-shadow:0 8px 28px rgba(37,211,102,.6),0 0 0 14px rgba(37,211,102,.05);}
}

/* ── COMMON BUTTONS ── */
.btn-primary{
  font-family:var(--sans);font-size:.7rem;letter-spacing:.22em;
  text-transform:uppercase;padding:15px 36px;text-decoration:none;
  transition:all .35s;display:inline-block;border:1px solid;
}
.btn-outline{
  font-family:var(--sans);font-size:.7rem;letter-spacing:.22em;
  text-transform:uppercase;padding:15px 36px;text-decoration:none;
  transition:all .35s;display:inline-block;
  border:1px solid rgba(244,237,224,.25);color:var(--ivory);background:transparent;
}
.btn-outline:hover{border-color:var(--gold);color:var(--gold);}
.btn-gold{
  font-family:var(--sans);font-size:.7rem;letter-spacing:.28em;
  text-transform:uppercase;background:var(--gold);color:var(--teal-deep);
  padding:17px 44px;text-decoration:none;transition:all .35s;
  display:inline-block;border:1px solid var(--gold);
}
.btn-gold:hover{background:var(--gold-2);}

/* ── SHARED EYEBROW ── */
.eyebrow{
  font-family:var(--sans);font-size:.6rem;letter-spacing:.38em;
  text-transform:uppercase;color:var(--teal);margin-bottom:16px;
  display:flex;align-items:center;gap:14px;
}
.eyebrow::before{content:'';width:30px;height:1px;background:var(--teal);}
.section-h{
  font-family:var(--serif);font-size:clamp(2.4rem,4.5vw,4.4rem);
  font-weight:300;line-height:1.08;color:var(--ink);
}
.section-h em{font-style:italic;color:var(--teal);}

/* ── MOBILE STICKY CTA ── */
.mobile-cta-bar{
  display:none;position:fixed;bottom:0;left:0;right:0;z-index:190;
  background:rgba(26,24,20,.97);backdrop-filter:blur(12px);
  padding:14px 20px;
  transform:translateY(100%);transition:transform .4s cubic-bezier(.22,1,.36,1);
}
.mobile-cta-bar.visible{transform:translateY(0);}
.mobile-cta-bar-inner{display:flex;align-items:center;justify-content:space-between;gap:12px;}
.mobile-cta-bar-text{font-family:var(--sans);font-size:.62rem;letter-spacing:.15em;text-transform:uppercase;color:rgba(244,237,224,.6);}
.mobile-cta-bar a{
  font-family:var(--sans);font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;
  background:var(--gold);color:var(--teal-deep);padding:11px 24px;text-decoration:none;
  white-space:nowrap;transition:background .3s;
}
.mobile-cta-bar a:hover{background:var(--gold-2);}

/* ── RESPONSIVE — SHARED NAV BREAKPOINT ── */
@media (max-width:980px){
  nav{padding:16px 20px;}
  nav.scrolled{padding:12px 20px;}
  .nav-links{display:none;}
  .nav-cta{display:none;}
  .nav-toggle{display:flex;}
  footer{padding:40px 24px 28px;}
  .mobile-cta-bar{display:block;}
  .whatsapp-float{bottom:80px;}
}
