/* =========================================
   DIGITAL AFFINE — Shared Stylesheet
   Palette: deep teal + warm gold on dark navy
   ========================================= */

:root{
  /* Core palette */
  --navy:        #0a1628;
  --navy-2:      #112038;
  --navy-3:      #1a2e4a;
  --teal:        #1d8a9a;
  --teal-deep:   #155e6b;
  --teal-bright: #2dd4bf;
  --gold:        #d4a574;
  --gold-bright: #f4c977;
  --gold-deep:   #a87a3a;
  --cream:       #f5ede0;
  --cream-soft:  #d8cdb8;
  --muted:       #7a8aa3;
  --line:        rgba(212, 165, 116, 0.18);
  --line-strong: rgba(212, 165, 116, 0.35);

  /* Type */
  --serif: 'Fraunces', Georgia, serif;
  --sans:  'Inter', -apple-system, sans-serif;
  --mono:  'JetBrains Mono', monospace;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;background:var(--navy)}
body{
  font-family:var(--sans);
  background:var(--navy);
  color:var(--cream);
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  font-weight:300;
}

/* Subtle starfield + grain (nod to astrology) */
body::before{
  content:"";
  position:fixed;inset:0;
  background-image:
    radial-gradient(1px 1px at 20% 30%, rgba(244,201,119,.4), transparent),
    radial-gradient(1px 1px at 80% 60%, rgba(45,212,191,.3), transparent),
    radial-gradient(1px 1px at 40% 80%, rgba(244,201,119,.3), transparent),
    radial-gradient(1px 1px at 60% 20%, rgba(255,255,255,.2), transparent),
    radial-gradient(2px 2px at 90% 90%, rgba(244,201,119,.15), transparent);
  background-size:300px 300px, 250px 250px, 200px 200px, 350px 350px, 400px 400px;
  pointer-events:none;
  z-index:0;
  opacity:.6;
}
body::after{
  content:"";
  position:fixed;inset:0;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2'/><feColorMatrix values='0 0 0 0 0.95 0 0 0 0 0.85 0 0 0 0 0.6 0 0 0 0.04 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
  pointer-events:none;
  z-index:1;
  mix-blend-mode:screen;
}

img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}

/* Typography */
.serif{font-family:var(--serif)}
.mono{
  font-family:var(--mono);
  font-size:.74rem;
  text-transform:uppercase;
  letter-spacing:.14em;
  color:var(--gold);
}

/* Layout */
.wrap{
  max-width:1320px;
  margin:0 auto;
  padding:0 2rem;
  position:relative;
  z-index:2;
}

/* ============ NAV ============ */
nav.site-nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  padding:1.1rem 2rem;
  backdrop-filter:blur(14px);
  background:rgba(10,22,40,.78);
  border-bottom:1px solid transparent;
  transition:border-color .3s, padding .3s;
}
nav.site-nav.scrolled{
  border-bottom-color:var(--line);
  padding:.7rem 2rem;
}
.nav-inner{
  max-width:1320px;margin:0 auto;
  display:flex;justify-content:space-between;align-items:center;
}
.logo{
  font-family:var(--serif);font-weight:600;font-size:1.5rem;
  font-style:italic;letter-spacing:-.02em;color:var(--cream);
  display:flex;align-items:baseline;gap:.45rem;
}
.logo .dot{
  width:8px;height:8px;border-radius:50%;
  background:var(--gold);
  display:inline-block;
  box-shadow:0 0 14px var(--gold-bright);
}
.nav-links{
  display:flex;gap:2.2rem;align-items:center;list-style:none;
}
.nav-links a{
  font-family:var(--mono);font-size:.72rem;
  text-transform:uppercase;letter-spacing:.13em;
  color:var(--cream-soft);
  position:relative;transition:color .25s;
}
.nav-links a:hover,.nav-links a.active{color:var(--gold-bright)}
.nav-links a:not(.btn)::after{
  content:"";position:absolute;bottom:-5px;left:0;
  width:0;height:1px;background:var(--gold);transition:width .3s;
}
.nav-links a:not(.btn):hover::after,.nav-links a.active::after{width:100%}
.btn{
  padding:.6rem 1.2rem;
  border:1px solid var(--gold);
  border-radius:999px;color:var(--gold)!important;
  transition:all .3s;
}
.btn:hover{
  background:var(--gold);color:var(--navy)!important;
  box-shadow:0 0 24px rgba(244,201,119,.4);
}
.btn::after{display:none!important}

.menu-btn{
  display:none;background:none;border:none;
  font-size:1.6rem;color:var(--cream);cursor:pointer;
}

/* ============ PAGE HEADER (sub-pages) ============ */
.page-head{
  padding:9rem 0 4rem;
  border-bottom:1px solid var(--line);
  position:relative;
}
.page-head .crumb{margin-bottom:1.4rem}
.page-head .crumb a{color:var(--muted);transition:color .2s}
.page-head .crumb a:hover{color:var(--gold)}
.page-head h1{
  font-family:var(--serif);
  font-weight:300;
  font-size:clamp(2.6rem,7vw,5.5rem);
  line-height:.95;
  letter-spacing:-.03em;
  color:var(--cream);
  max-width:18ch;
  margin-bottom:1.6rem;
}
.page-head h1 em{
  font-style:italic;
  background:linear-gradient(120deg,var(--gold-bright),var(--teal-bright));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.page-head .lede{
  font-family:var(--serif);
  font-size:1.25rem;color:var(--cream-soft);
  max-width:38em;
  font-weight:300;
  line-height:1.55;
}

/* ============ SECTION ============ */
section{padding:6rem 0;position:relative}
.section-head{
  display:grid;grid-template-columns:1fr 2fr;gap:3rem;
  margin-bottom:4rem;align-items:end;
  border-bottom:1px solid var(--line);padding-bottom:2rem;
}
.section-head .num{
  font-family:var(--serif);font-style:italic;font-weight:300;
  font-size:5rem;line-height:.8;
  background:linear-gradient(135deg,var(--gold-bright),var(--teal));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.section-head .kicker{display:block;margin-bottom:1rem}
.section-head h2{
  font-family:var(--serif);font-weight:400;
  font-size:clamp(2rem,4.5vw,3.4rem);line-height:1.05;
  letter-spacing:-.02em;color:var(--cream);
}
.section-head h2 em{color:var(--gold-bright);font-style:italic;font-weight:300}

/* ============ BUTTONS / CTA ============ */
.cta{
  display:inline-flex;align-items:center;gap:.6rem;
  padding:1rem 2rem;
  background:var(--gold);color:var(--navy);
  font-family:var(--mono);font-size:.78rem;
  text-transform:uppercase;letter-spacing:.14em;
  border:none;border-radius:999px;cursor:pointer;
  transition:all .3s ease;
  box-shadow:0 8px 30px -8px rgba(244,201,119,.4);
}
.cta:hover{
  background:var(--gold-bright);
  transform:translateY(-2px);
  box-shadow:0 14px 40px -10px rgba(244,201,119,.55);
}
.cta svg{transition:transform .3s}
.cta:hover svg{transform:translateX(4px)}

.cta-ghost{
  background:transparent;color:var(--gold);
  border:1px solid var(--gold);
  box-shadow:none;
}
.cta-ghost:hover{background:var(--gold);color:var(--navy)}

/* ============ FOOTER ============ */
footer{
  background:var(--navy-2);
  border-top:1px solid var(--line);
  padding:5rem 0 2rem;
  position:relative;z-index:2;
}
.foot-grid{
  display:grid;
  grid-template-columns:2fr 1fr 1fr 1.2fr;
  gap:3rem;margin-bottom:3rem;
}
.foot-brand h3{
  font-family:var(--serif);font-style:italic;font-weight:500;
  font-size:1.7rem;color:var(--cream);margin-bottom:1rem;
}
.foot-brand h3 .dot{
  width:8px;height:8px;border-radius:50%;
  background:var(--gold);display:inline-block;
  margin:0 .15rem;
  box-shadow:0 0 12px var(--gold-bright);
}
.foot-brand p{
  color:var(--muted);font-size:.92rem;line-height:1.7;
  max-width:32em;
}
.foot-col h4{
  font-family:var(--mono);
  font-size:.72rem;text-transform:uppercase;letter-spacing:.14em;
  color:var(--gold);margin-bottom:1.2rem;
}
.foot-col ul{list-style:none;display:grid;gap:.7rem}
.foot-col a{
  color:var(--cream-soft);font-size:.92rem;
  transition:color .2s,padding-left .2s;
}
.foot-col a:hover{color:var(--gold-bright);padding-left:.3rem}
.foot-social{
  display:flex;gap:.7rem;margin-top:1rem;
}
.foot-social a{
  width:38px;height:38px;border-radius:50%;
  border:1px solid var(--line-strong);
  display:flex;align-items:center;justify-content:center;
  color:var(--cream-soft);
  transition:all .3s;
}
.foot-social a:hover{
  background:var(--gold);color:var(--navy);
  border-color:var(--gold);
  transform:translateY(-3px);
}
.foot-social svg{width:18px;height:18px}
.foot-bottom{
  padding-top:2rem;border-top:1px solid var(--line);
  display:flex;justify-content:space-between;align-items:center;
  flex-wrap:wrap;gap:1rem;
  font-family:var(--mono);font-size:.7rem;
  text-transform:uppercase;letter-spacing:.12em;
  color:var(--muted);
}
.foot-bottom a{color:var(--muted)}
.foot-bottom a:hover{color:var(--gold)}

/* ============ IMAGE PLACEHOLDER ============ */
.img-placeholder{
  background:
    repeating-linear-gradient(
      45deg,
      rgba(212,165,116,.04),
      rgba(212,165,116,.04) 12px,
      rgba(212,165,116,.08) 12px,
      rgba(212,165,116,.08) 24px
    ),
    var(--navy-3);
  border:1px dashed var(--line-strong);
  border-radius:14px;
  display:flex;align-items:center;justify-content:center;
  flex-direction:column;
  color:var(--gold);
  font-family:var(--mono);font-size:.7rem;
  text-transform:uppercase;letter-spacing:.13em;
  padding:2rem;text-align:center;
  min-height:240px;
  position:relative;overflow:hidden;
}
.img-placeholder::before{
  content:"⬚";font-size:3rem;
  display:block;margin-bottom:.6rem;
  font-family:serif;color:var(--gold-deep);
  line-height:1;
}
.img-placeholder span{display:block;margin-top:.4rem;color:var(--cream-soft);text-transform:none;letter-spacing:.05em;font-size:.68rem;line-height:1.5}

/* ============ IMG SLOT (real <img> with placeholder fallback) ============
   Drop a real image into /assets/ with the right filename and it renders.
   If the file is missing, the dashed placeholder background shows through. */
.img-slot{
  position:relative;
  margin:0;padding:0;
  border-radius:14px;
  overflow:hidden;
  background:
    repeating-linear-gradient(
      45deg,
      rgba(212,165,116,.04),
      rgba(212,165,116,.04) 12px,
      rgba(212,165,116,.08) 12px,
      rgba(212,165,116,.08) 24px
    ),
    var(--navy-3);
  border:1px solid var(--line);
  min-height:240px;
  display:block;
}
.img-slot img{
  display:block;
  width:100%;height:100%;
  object-fit:cover;
  position:absolute;inset:0;
  transition:transform .6s ease;
}
.img-slot:hover img{transform:scale(1.04)}
.img-slot::after{
  content:attr(data-fallback);
  position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;
  flex-direction:column;
  color:var(--gold);
  font-family:var(--mono);font-size:.7rem;
  text-transform:uppercase;letter-spacing:.13em;
  text-align:center;padding:1.5rem;
  pointer-events:none;
  border:1px dashed var(--line-strong);
  border-radius:14px;
  z-index:0;
}
.img-slot img{z-index:1}
.img-slot.broken img{display:none}

/* ============ FORM ELEMENTS ============ */
input,select,textarea{
  width:100%;padding:.95rem 1rem;
  background:var(--navy-2);
  border:1px solid var(--line-strong);
  border-radius:8px;
  color:var(--cream);
  font-family:var(--sans);font-size:.95rem;
  outline:none;
  transition:border-color .3s,background .3s;
}
input::placeholder,textarea::placeholder{color:var(--muted)}
input:focus,select:focus,textarea:focus{
  border-color:var(--gold);
  background:var(--navy-3);
}
label.field{display:block;margin-bottom:1.2rem}
label.field .lbl{
  display:block;
  font-family:var(--mono);font-size:.7rem;
  text-transform:uppercase;letter-spacing:.13em;
  color:var(--gold);margin-bottom:.5rem;
}

/* ============ REVEAL ============ */
.reveal{opacity:0;transform:translateY(24px);transition:all .9s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:translateY(0)}

::selection{background:var(--gold);color:var(--navy)}

/* Custom scrollbar */
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-track{background:var(--navy)}
::-webkit-scrollbar-thumb{background:var(--teal-deep);border-radius:5px}
::-webkit-scrollbar-thumb:hover{background:var(--teal)}

/* ============ LOGO IMAGE ============ */
/*  We ship two transparent-background variants of the logo:
    - logo-white.png : cream mark on transparent (for dark navy nav/footer)
    - logo-gold.png  : gold mark on transparent (for hover state)
    No CSS filters are used because the source PNG has an opaque dark
    background — filters would render it as a solid white rectangle.    */
.logo{
  position:relative;
  display:inline-block;
  line-height:0;          /* prevents extra inline whitespace */
}
.logo-img{
  height:38px;width:auto;display:block;
  transition:opacity .3s, transform .3s;
}
.logo-img-base{position:relative;z-index:1}
.logo-img-hover{
  position:absolute !important;
  top:0;left:0;
  opacity:0;
  pointer-events:none;
  z-index:2;
}
.logo:hover .logo-img-base{opacity:0}
.logo:hover .logo-img-hover{opacity:1;transform:rotate(-3deg)}
.foot-brand .logo-img{height:46px;margin-bottom:1.2rem}

/* ============ FLOATING WHATSAPP BUTTON ============ */
.wa-float{
  position:fixed;
  bottom:24px;left:24px;
  z-index:60;
  display:flex;align-items:center;gap:.6rem;
  background:#25D366;
  color:#fff;
  padding:.85rem 1.3rem .85rem 1rem;
  border-radius:999px;
  box-shadow:0 10px 30px -8px rgba(37,211,102,.55),
             0 0 0 0 rgba(37,211,102,.45);
  font-family:var(--mono);font-size:.74rem;
  text-transform:uppercase;letter-spacing:.12em;
  font-weight:500;
  transition:transform .3s, box-shadow .3s;
  animation:wa-pulse 2.6s infinite;
}
.wa-float:hover{
  transform:translateY(-3px) scale(1.04);
  box-shadow:0 16px 40px -10px rgba(37,211,102,.7),
             0 0 0 0 rgba(37,211,102,0);
  color:#fff;
}
.wa-float .wa-icon{
  width:28px;height:28px;border-radius:50%;
  background:#fff;color:#25D366;
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
}
.wa-float .wa-icon svg{width:18px;height:18px}
@keyframes wa-pulse{
  0%{box-shadow:0 10px 30px -8px rgba(37,211,102,.55), 0 0 0 0 rgba(37,211,102,.45)}
  70%{box-shadow:0 10px 30px -8px rgba(37,211,102,.55), 0 0 0 14px rgba(37,211,102,0)}
  100%{box-shadow:0 10px 30px -8px rgba(37,211,102,.55), 0 0 0 0 rgba(37,211,102,0)}
}

/* ============ MODAL ============ */
.modal{
  position:fixed;inset:0;z-index:200;
  background:rgba(10,22,40,.78);
  backdrop-filter:blur(8px);
  display:none;align-items:center;justify-content:center;
  padding:1rem;
  opacity:0;transition:opacity .3s;
}
.modal.open{display:flex;opacity:1}
.modal-content{
  background:linear-gradient(180deg, var(--navy-2), var(--navy-3));
  border:1px solid var(--gold);
  border-radius:18px;
  width:100%;max-width:560px;
  max-height:90vh;overflow-y:auto;
  transform:scale(.95);transition:transform .3s;
  box-shadow:0 30px 80px -20px rgba(0,0,0,.7);
}
.modal.open .modal-content{transform:scale(1)}
.modal-head{
  padding:1.4rem 1.8rem;
  border-bottom:1px solid var(--line);
  display:flex;justify-content:space-between;align-items:center;
}
.modal-head h3{
  font-family:var(--serif);font-weight:500;
  font-size:1.4rem;color:var(--cream);
  letter-spacing:-.01em;
}
.modal-close{
  background:none;border:none;
  color:var(--muted);font-size:1.7rem;line-height:1;
  cursor:pointer;width:32px;height:32px;
  display:flex;align-items:center;justify-content:center;
  border-radius:50%;
  transition:all .3s;
}
.modal-close:hover{background:var(--navy);color:var(--gold)}
.modal-body{padding:1.8rem}

/* ============ MORE MOBILE HARDENING ============ */
@media(max-width: 768px){
  body{font-size:.95rem}
  .wrap{padding:0 1.2rem}
  nav.site-nav{padding:.9rem 1.2rem}
  nav.site-nav.scrolled{padding:.6rem 1.2rem}
  .logo{font-size:1.2rem}
  .logo-img{height:32px}
  .nav-links{padding:1.5rem 1.2rem}
  .nav-links a{font-size:.78rem}
  .nav-links .btn{align-self:flex-start;margin-top:.5rem}

  .page-head{padding:6rem 0 2.5rem}
  .page-head h1{font-size:clamp(2rem,8vw,3rem)!important}
  .page-head .lede{font-size:1rem}

  .section-head{margin-bottom:2.5rem;padding-bottom:1.5rem}
  .section-head .num{font-size:2.6rem}
  .section-head h2{font-size:clamp(1.6rem,7vw,2.2rem)!important}

  .cta{padding:.85rem 1.4rem;font-size:.72rem}

  .wa-float{
    bottom:16px;left:16px;
    padding:.7rem 1.1rem .7rem .85rem;
    font-size:.7rem;
  }
  .wa-float .wa-icon{width:24px;height:24px}

  footer{padding:3.5rem 0 1.5rem}
  .foot-grid{margin-bottom:2rem}

  .modal-content{max-height:85vh}
  .modal-head{padding:1.1rem 1.4rem}
  .modal-body{padding:1.4rem}

  /* Stop horizontal overflow from gradient blobs */
  body{overflow-x:hidden}
}

@media(max-width: 480px){
  .wa-float{
    padding:.6rem .85rem .6rem .6rem;
    font-size:.65rem;letter-spacing:.1em;
  }
  .wa-float-text{display:none}
  .wa-float .wa-icon{width:30px;height:30px;margin:0}
  .wa-float .wa-icon svg{width:20px;height:20px}
}

/* ============ RESPONSIVE ============ */
@media(max-width: 900px){
  .wrap{padding:0 1.4rem}
  .menu-btn{display:block}
  .nav-links{
    display:none;
    position:absolute;top:100%;left:0;right:0;
    background:var(--navy-2);
    flex-direction:column;
    padding:2rem;gap:1.4rem;
    border-bottom:1px solid var(--line);
  }
  .nav-links.open{display:flex}
  .section-head{grid-template-columns:1fr;gap:1rem}
  .section-head .num{font-size:3rem}
  .foot-grid{grid-template-columns:1fr 1fr;gap:2rem}
  .foot-brand{grid-column:1/-1}
  section{padding:4rem 0}
  .page-head{padding:7rem 0 3rem}
}
@media(max-width: 560px){
  .foot-grid{grid-template-columns:1fr}
  .foot-bottom{flex-direction:column;text-align:center}
}
