/* ===========================================================
   WALKING TV FAMILY EXPERIENCE TOURS — Design Tokens & Base
   =========================================================== */

@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,300;0,9..144,400;0,9..144,500;0,9..144,600;0,9..144,700;1,9..144,400;1,9..144,500;1,9..144,600&family=Bebas+Neue&family=Inter:wght@400;500;600;700;800&display=swap');

:root{
  /* ---- Color tokens ---- */
  --void:        #08110D;   /* near-black jungle background */
  --jungle:      #0E2118;   /* deep surface green */
  --jungle-2:    #163B2B;   /* card surface green */
  --jungle-3:    #1F4D3A;   /* elevated surface / borders */
  --emerald:     #2FBF77;   /* bright leaf accent */
  --emerald-dim: #23935D;
  --gold:        #D9A441;   /* premium gold accent */
  --gold-light:  #F1CB7B;
  --ocean:       #1C6E8C;   /* ocean blue accent */
  --ocean-light: #4FB8D6;
  --sand:        #F3ECDA;   /* warm off-white text */
  --sand-dim:    #C9C0A8;   /* muted body text */
  --sand-dim-2:  #8FA095;

  /* ---- Type tokens ---- */
  --font-display: 'Fraunces', serif;
  --font-eyebrow: 'Bebas Neue', sans-serif;
  --font-body: 'Inter', sans-serif;

  /* ---- Layout ---- */
  --container: 1180px;
  --radius: 4px;
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  background:var(--void);
  color:var(--sand);
  font-family:var(--font-body);
  font-size:16px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
ul{ list-style:none; margin:0; padding:0; }
button{ font-family:inherit; cursor:pointer; }
input, select, textarea{ font-family:inherit; }

.container{
  max-width:var(--container);
  margin:0 auto;
  padding:0 24px;
}

/* ---- Texture: fine grain overlay for the "film" feel ---- */
.grain{
  position:fixed; inset:0; pointer-events:none; z-index:999;
  opacity:.035; mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ---- Eyebrow labels ---- */
.eyebrow{
  font-family:var(--font-eyebrow);
  letter-spacing:.18em;
  font-size:15px;
  color:var(--gold-light);
  display:inline-flex;
  align-items:center;
  gap:10px;
  text-transform:uppercase;
}
.eyebrow::before{
  content:'';
  width:8px; height:8px; border-radius:50%;
  background:var(--emerald);
  box-shadow:0 0 0 3px rgba(47,191,119,.18);
}

/* ---- REC indicator (signature motif) ---- */
.rec-tag{
  font-family:var(--font-eyebrow);
  letter-spacing:.2em;
  font-size:13px;
  color:var(--gold-light);
  display:inline-flex; align-items:center; gap:8px;
  border:1px solid rgba(217,164,65,.4);
  padding:6px 14px 6px 10px;
  border-radius:999px;
  background:rgba(217,164,65,.06);
}
.rec-dot{
  width:8px; height:8px; border-radius:50%;
  background:#e6473f;
  box-shadow:0 0 0 3px rgba(230,71,63,.2);
  animation:pulse 1.6s ease-in-out infinite;
}
@keyframes pulse{
  0%,100%{ opacity:1; transform:scale(1); }
  50%{ opacity:.45; transform:scale(.82); }
}

/* ---- Viewfinder corner brackets (signature framing device) ---- */
.viewfinder{ position:relative; }
.viewfinder::before,
.viewfinder::after,
.vf-tl, .vf-tr, .vf-bl, .vf-br{ position:absolute; width:26px; height:26px; pointer-events:none; }
.vf-tl{ top:18px; left:18px; border-top:2px solid var(--gold-light); border-left:2px solid var(--gold-light); }
.vf-tr{ top:18px; right:18px; border-top:2px solid var(--gold-light); border-right:2px solid var(--gold-light); }
.vf-bl{ bottom:18px; left:18px; border-bottom:2px solid var(--gold-light); border-left:2px solid var(--gold-light); }
.vf-br{ bottom:18px; right:18px; border-bottom:2px solid var(--gold-light); border-right:2px solid var(--gold-light); }

.viewfinder-sm .vf-tl, .viewfinder-sm .vf-tr, .viewfinder-sm .vf-bl, .viewfinder-sm .vf-br{
  width:16px; height:16px;
}
.viewfinder-sm .vf-tl, .viewfinder-sm .vf-tr{ top:10px; }
.viewfinder-sm .vf-bl, .viewfinder-sm .vf-br{ bottom:10px; }
.viewfinder-sm .vf-tl, .viewfinder-sm .vf-bl{ left:10px; }
.viewfinder-sm .vf-tr, .viewfinder-sm .vf-br{ right:10px; }

/* ---- Headings ---- */
h1,h2,h3,h4{
  font-family:var(--font-display);
  color:var(--sand);
  margin:0;
  font-weight:600;
  letter-spacing:-.01em;
}
.h-display{
  font-size:clamp(2.6rem, 6vw, 4.6rem);
  line-height:1.04;
  font-weight:600;
  text-wrap:balance;
}
.h-display em{
  font-style:italic;
  font-weight:500;
  color:var(--gold-light);
}
.h-section{
  font-size:clamp(2rem, 4vw, 2.9rem);
  line-height:1.1;
  text-wrap:balance;
}
.lede{
  color:var(--sand-dim);
  font-size:1.08rem;
  max-width:52ch;
  text-wrap:pretty;
}

/* ---- Buttons ---- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  padding:15px 30px;
  border-radius:2px;
  font-family:var(--font-body);
  font-weight:700;
  font-size:.92rem;
  letter-spacing:.02em;
  border:1px solid transparent;
  transition:transform .25s ease, box-shadow .25s ease, background .25s ease, border-color .25s ease, color .25s ease;
  white-space:nowrap;
}
.btn-gold{
  background:linear-gradient(135deg, var(--gold-light), var(--gold));
  color:#1a1206;
  box-shadow:0 8px 24px -8px rgba(217,164,65,.55);
}
.btn-gold:hover{ transform:translateY(-2px); box-shadow:0 12px 28px -8px rgba(217,164,65,.7); }
.btn-outline{
  background:transparent;
  border-color:rgba(243,236,218,.35);
  color:var(--sand);
}
.btn-outline:hover{ border-color:var(--sand); background:rgba(243,236,218,.06); transform:translateY(-2px); }
.btn-ocean{
  background:var(--ocean);
  color:var(--sand);
  box-shadow:0 8px 24px -10px rgba(28,110,140,.7);
}
.btn-ocean:hover{ background:var(--ocean-light); transform:translateY(-2px); }
.btn-block{ width:100%; }
.btn-lg{ padding:18px 36px; font-size:1rem; }

/* ---- Nav ---- */
.site-header{
  position:fixed; top:0; left:0; right:0; z-index:100;
  padding:18px 0;
  transition:background .3s ease, border-color .3s ease;
  border-bottom:1px solid transparent;
}
.site-header.scrolled{
  background:rgba(8,17,13,.88);
  backdrop-filter:blur(10px);
  padding:12px 0;
  border-bottom:1px solid rgba(217,164,65,.15);
}
.site-header .container{ display:flex; align-items:center; justify-content:space-between; gap:24px; }
.logo{ display:flex; align-items:center; gap:10px; }
.logo-mark{ width:38px; height:38px; }
.logo-text{ font-family:var(--font-display); font-weight:600; font-size:1.05rem; color:var(--sand); line-height:1.1; }
.logo-text span{ display:block; font-family:var(--font-eyebrow); letter-spacing:.16em; font-size:.62rem; color:var(--gold-light); }

.nav-links{ display:flex; align-items:center; gap:34px; }
.nav-links a{
  font-size:.88rem; font-weight:600; letter-spacing:.02em;
  color:var(--sand-dim); position:relative; padding:4px 0;
  transition:color .2s ease;
}
.nav-links a:hover, .nav-links a.active{ color:var(--sand); }
.nav-links a.active::after{
  content:''; position:absolute; left:0; right:0; bottom:-6px; height:2px;
  background:linear-gradient(90deg, var(--gold), var(--emerald));
}
.nav-actions{ display:flex; align-items:center; gap:16px; }

.nav-toggle{
  display:none; flex-direction:column; gap:5px; background:none; border:none; padding:6px;
}
.nav-toggle span{ width:24px; height:2px; background:var(--sand); transition:.3s; }

.mobile-menu{
  position:fixed; inset:0; background:var(--void); z-index:150;
  display:flex; flex-direction:column; padding:26px 24px;
  transform:translateX(100%); transition:transform .35s cubic-bezier(.65,0,.35,1);
}
.mobile-menu.open{ transform:translateX(0); }
.mobile-menu-top{ display:flex; justify-content:space-between; align-items:center; margin-bottom:50px; }
.mobile-menu a{ font-family:var(--font-display); font-size:2rem; padding:14px 0; border-bottom:1px solid var(--jungle-3); color:var(--sand); }
.mobile-close{ background:none; border:none; color:var(--sand); font-size:1.8rem; }

/* ---- Sections ---- */
section{ position:relative; }
.section-pad{ padding:110px 0; }
.section-pad-sm{ padding:70px 0; }
.bg-jungle{ background:var(--jungle); }
.bg-void{ background:var(--void); }

.divider-wave{ display:block; width:100%; height:60px; }

/* ---- Cards ---- */
.card{
  background:var(--jungle-2);
  border:1px solid rgba(217,164,65,.14);
  border-radius:var(--radius);
  overflow:hidden;
  transition:transform .3s ease, border-color .3s ease, box-shadow .3s ease;
}
.card:hover{ transform:translateY(-6px); border-color:rgba(217,164,65,.4); box-shadow:0 20px 40px -20px rgba(0,0,0,.6); }

.tag-pill{
  font-family:var(--font-eyebrow); letter-spacing:.12em; font-size:.72rem;
  color:var(--void); background:var(--gold-light);
  padding:5px 12px; border-radius:999px; display:inline-block;
}

/* ---- Footer ---- */
.site-footer{ background:var(--void); border-top:1px solid rgba(217,164,65,.15); padding:70px 0 30px; }
.footer-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1.2fr; gap:40px; }
.footer-grid h4{ font-family:var(--font-eyebrow); letter-spacing:.14em; font-size:.85rem; color:var(--gold-light); margin-bottom:18px; text-transform:uppercase; }
.footer-grid a{ color:var(--sand-dim); font-size:.92rem; display:block; padding:6px 0; transition:color .2s; }
.footer-grid a:hover{ color:var(--emerald); }
.footer-bottom{ margin-top:60px; padding-top:26px; border-top:1px solid var(--jungle-3); display:flex; justify-content:space-between; flex-wrap:wrap; gap:12px; color:var(--sand-dim-2); font-size:.82rem; }
.social-row{ display:flex; gap:14px; margin-top:16px; }
.social-row a{
  width:38px; height:38px; border-radius:50%; border:1px solid rgba(243,236,218,.25);
  display:flex; align-items:center; justify-content:center; transition:.25s;
}
.social-row a:hover{ border-color:var(--gold); background:rgba(217,164,65,.1); transform:translateY(-3px); }

/* ---- WhatsApp Floating Button ---- */
.wa-float{
  position:fixed; bottom:26px; right:26px; z-index:200;
  width:60px; height:60px; border-radius:50%;
  background:#25D366; display:flex; align-items:center; justify-content:center;
  box-shadow:0 10px 30px -6px rgba(37,211,102,.6);
  transition:transform .25s ease;
}
.wa-float:hover{ transform:scale(1.08); }
.wa-float svg{ width:30px; height:30px; color:var(--void); }
.wa-ping{
  position:absolute; inset:0; border-radius:50%; background:#25D366;
  animation:wa-pulse 2.2s ease-out infinite;
}
@keyframes wa-pulse{
  0%{ transform:scale(1); opacity:.55; }
  100%{ transform:scale(1.8); opacity:0; }
}

/* ---- Forms ---- */
.field{ margin-bottom:22px; }
.field label{
  display:block; font-family:var(--font-eyebrow); letter-spacing:.1em; font-size:.78rem;
  color:var(--gold-light); text-transform:uppercase; margin-bottom:8px;
}
.field input, .field select, .field textarea{
  width:100%; padding:14px 16px; background:var(--void);
  border:1px solid rgba(243,236,218,.18); border-radius:2px;
  color:var(--sand); font-size:.96rem; transition:border-color .2s ease, background .2s ease;
}
.field input:focus, .field select:focus, .field textarea:focus{
  outline:none; border-color:var(--emerald); background:#0c1a13;
}
.field input::placeholder, .field textarea::placeholder{ color:var(--sand-dim-2); }
.field-row{ display:grid; grid-template-columns:1fr 1fr; gap:20px; }

/* Visible keyboard focus everywhere */
a:focus-visible, button:focus-visible, input:focus-visible, select:focus-visible, textarea:focus-visible{
  outline:2px solid var(--emerald); outline-offset:3px;
}

/* ---- Utility ---- */
.grid-2{ display:grid; grid-template-columns:1fr 1fr; gap:50px; align-items:center; }
.grid-3{ display:grid; grid-template-columns:repeat(3,1fr); gap:28px; }
.grid-4{ display:grid; grid-template-columns:repeat(4,1fr); gap:22px; }
.center{ text-align:center; margin-left:auto; margin-right:auto; justify-content:center; }
.lede-full{ max-width:none; }
.container--narrow{ max-width:640px; margin-inline:auto; }
.mt-8{ margin-top:8px;} .mt-12{margin-top:12px;} .mt-16{margin-top:16px;} .mt-24{margin-top:24px;} .mt-32{margin-top:32px;} .mt-48{margin-top:48px;} .mt-64{margin-top:64px;}
.mb-16{margin-bottom:16px;} .mb-24{margin-bottom:24px;} .mb-40{margin-bottom:40px;} .mb-60{margin-bottom:60px;}
.flex{ display:flex; } .items-center{ align-items:center; } .gap-12{gap:12px;} .gap-16{gap:16px;} .flex-wrap{flex-wrap:wrap;}

/* ---- Reveal utility: content is always visible; retained only as a hook class ---- */
.reveal{ opacity:1; transform:none; }

/* ---- Hero entrance (load-triggered only, never scroll-gated) ---- */
@media (prefers-reduced-motion: no-preference){
  .hero-content{ animation: hero-in .8s ease both; animation-delay:.1s; }
  .hero-content .rec-tag{ animation: hero-in .6s ease both; }
}
@keyframes hero-in{
  from{ opacity:0; transform:translateY(16px); }
  to{ opacity:1; transform:translateY(0); }
}

@media (prefers-reduced-motion: reduce){
  *{ animation-duration:0.001ms !important; animation-iteration-count:1 !important; transition-duration:0.001ms !important; scroll-behavior:auto !important; }
}

/* ---- Hero ---- */
.hero{
  position:relative;
  min-height:100vh;
  display:flex; align-items:center;
  overflow:hidden;
}
.hero-media{ position:absolute; inset:0; z-index:0; }
.hero-video{ width:100%; height:100%; object-fit:cover; }
.hero-fallback{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.hero-video:not([src]),
.hero-video[src=""]{ display:none; }
.hero-scrim{
  position:absolute; inset:0;
  background:
    linear-gradient(180deg, rgba(8,17,13,.55) 0%, rgba(8,17,13,.35) 40%, rgba(8,17,13,.92) 100%),
    linear-gradient(90deg, rgba(8,17,13,.7) 0%, rgba(8,17,13,.15) 50%);
}
.hero-inner{ position:relative; z-index:2; padding:140px 24px 100px; min-height:100vh; display:flex; align-items:center; }
.hero-content{ max-width:680px; }
.scroll-cue{
  position:absolute; bottom:34px; left:50%; transform:translateX(-50%); z-index:3;
  width:26px; height:42px; border:1.5px solid rgba(243,236,218,.5); border-radius:20px;
}
.scroll-cue span{
  position:absolute; top:8px; left:50%; transform:translateX(-50%);
  width:4px; height:8px; border-radius:2px; background:var(--gold-light);
  animation:scrollcue 1.8s ease infinite;
}
@keyframes scrollcue{
  0%{ opacity:1; top:8px; }
  70%{ opacity:0; top:22px; }
  100%{ opacity:0; top:8px; }
}

/* ---- Intro grid ---- */
.intro-grid{ display:grid; grid-template-columns:1fr 1fr; gap:40px; align-items:end; }

/* ---- Card media / body (extends .card) ---- */
.card-media{ aspect-ratio:4/3; overflow:hidden; background:var(--void); }
.card-media img{ width:100%; height:100%; object-fit:cover; transition:transform .5s ease; }
.card:hover .card-media img{ transform:scale(1.06); }
.card-body{ padding:24px; }
.card-title{ font-size:1.3rem; }
.card-text{ color:var(--sand-dim); font-size:.92rem; margin-top:8px; }
.card-cta{ display:flex; align-items:center; justify-content:center; background:linear-gradient(150deg, var(--jungle-3), var(--jungle-2)); min-height:100%; }
.card-cta .card-body{ padding:40px 28px; }

/* ---- Features ---- */
.feature{ text-align:left; }
.feature-icon{ width:40px; height:40px; color:var(--gold-light); margin-bottom:16px; }
.feature-title{ font-family:var(--font-display); font-size:1.15rem; font-weight:600; }
.feature-text{ color:var(--sand-dim); font-size:.92rem; margin-top:8px; }

/* ---- Testimonials ---- */
.testimonial{
  margin:0; padding:28px; background:var(--jungle-2);
  border:1px solid rgba(217,164,65,.18);
  border-top:2px solid var(--gold);
  border-radius:2px;
}
.testimonial p{ font-family:var(--font-display); font-style:italic; font-size:1.05rem; color:var(--sand); line-height:1.5; }
.testimonial cite{ display:block; margin-top:16px; font-style:normal; font-size:.82rem; letter-spacing:.06em; color:var(--gold-light); font-family:var(--font-eyebrow); }
.testimonial cite::before{ content:'— '; }

/* ---- Instagram grid ---- */
.ig-grid img{ aspect-ratio:1/1; object-fit:cover; border-radius:2px; transition:transform .3s ease; }
.ig-grid img:hover{ transform:scale(1.04); }

/* ---- CTA band ---- */
.cta-band{
  padding:100px 0;
  background:
    radial-gradient(60% 100% at 50% 0%, rgba(47,191,119,.14), transparent),
    linear-gradient(180deg, var(--jungle) 0%, var(--void) 100%);
  border-top:1px solid rgba(217,164,65,.18);
  border-bottom:1px solid rgba(217,164,65,.18);
}

@media (max-width:760px){
  .hero-inner{ padding:120px 18px 80px; }
  .intro-grid{ grid-template-columns:1fr; }
}

@media (max-width:980px){
  .grid-3{ grid-template-columns:repeat(2,1fr); }
  .grid-4{ grid-template-columns:repeat(2,1fr); }
  .footer-grid{ grid-template-columns:1fr 1fr; }
  .grid-2{ grid-template-columns:1fr; gap:30px; }
}
@media (max-width:760px){
  .nav-links, .nav-actions .btn-outline{ display:none; }
  .nav-toggle{ display:flex; }
  .section-pad{ padding:70px 0; }
  .grid-3{ grid-template-columns:1fr; }
  .grid-4{ grid-template-columns:1fr 1fr; }
  .field-row{ grid-template-columns:1fr; }
  .footer-grid{ grid-template-columns:1fr 1fr; gap:30px; }
}
@media (max-width:480px){
  .footer-grid{ grid-template-columns:1fr; }
  .grid-4{ grid-template-columns:1fr 1fr; }
}

/* ---- Secondary page hero ---- */
.page-hero{ padding:170px 0 80px; text-align:center; border-bottom:1px solid rgba(217,164,65,.15); }
.page-hero .lede{ margin-inline:auto; }

/* ---- Story image (about page) ---- */
.story-img{ width:100%; border-radius:4px; border:1px solid rgba(217,164,65,.2); }

/* ---- Timeline ---- */
.timeline{ position:relative; padding-left:28px; display:flex; flex-direction:column; gap:44px; }
.timeline::before{ content:''; position:absolute; left:0; top:0; bottom:0; width:2px; background:linear-gradient(to bottom, var(--jungle-3), transparent 95%); }
.timeline-dot{ position:absolute; left:-38px; width:16px; height:16px; border-radius:50%; background:var(--gold); border:3px solid var(--void); box-shadow:0 0 0 2px var(--gold); }
.timeline-item{ position:relative; }
.timeline-title{ font-family:var(--font-display); font-size:1.2rem; }
.timeline-text{ color:var(--sand-dim); margin-top:6px; max-width:56ch; }

@media (max-width:760px){
  .page-hero{ padding:140px 0 60px; }
}

/* ---- Tour blocks ---- */
.tour-grid{ display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:center; }
.tour-grid-rev .tour-info{ order:1; }
.tour-grid-rev .tour-media{ order:2; }
.tour-media{ border-radius:6px; overflow:hidden; border:1px solid rgba(217,164,65,.2); }
.tour-media img{ width:100%; display:block; }
.tour-price{ display:flex; align-items:baseline; gap:8px; flex-wrap:wrap; }
.price-amount{ font-family:var(--font-display); font-size:2.4rem; font-weight:600; color:var(--gold-light); }
.price-unit{ color:var(--sand-dim); font-size:.95rem; }
.price-note{ width:100%; font-size:.76rem; color:var(--sand-dim-2); font-style:italic; margin-top:2px; }

@media (max-width:820px){
  .tour-grid{ grid-template-columns:1fr; gap:30px; }
  .tour-grid-rev .tour-info, .tour-grid-rev .tour-media{ order:initial; }
}

/* ---- Booking page ---- */
.booking-grid{ display:grid; grid-template-columns:1.6fr 1fr; gap:50px; align-items:start; }
.booking-form{ background:var(--jungle-2); border:1px solid rgba(217,164,65,.16); border-radius:6px; padding:40px; }
.form-note{ font-size:.8rem; color:var(--sand-dim-2); margin-top:16px; line-height:1.5; }
.form-note a{ color:var(--emerald); }
.side-card{ background:var(--jungle-2); border:1px solid rgba(217,164,65,.16); border-radius:6px; padding:28px; }
.check-list li{ display:flex; align-items:center; gap:10px; padding:8px 0; color:var(--sand-dim); font-size:.92rem; }
.check-list img{ width:20px; height:20px; color:var(--emerald); flex-shrink:0; }

@media (max-width:900px){
  .booking-grid{ grid-template-columns:1fr; }
  .booking-form{ padding:26px; }
}

/* ---- Gallery: photo grid ---- */
.photo-grid{ display:grid; grid-template-columns:repeat(3,1fr); grid-auto-rows:200px; gap:14px; }
.photo-tile{ position:relative; display:block; border-radius:3px; overflow:hidden; border:1px solid rgba(217,164,65,.15); }
.photo-tile img{ width:100%; height:100%; object-fit:cover; transition:transform .4s ease; }
.photo-tile:hover img{ transform:scale(1.07); }
.tile-tall{ grid-row:span 2; }

/* ---- Gallery: video grid ---- */
.video-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:26px; }
.video-embed{ position:relative; aspect-ratio:16/9; border-radius:4px; overflow:hidden; border:1px solid rgba(217,164,65,.2); background:var(--void); }
.video-embed iframe{ position:absolute; inset:0; width:100%; height:100%; border:0; }
.video-placeholder img:first-child{ width:100%; height:100%; object-fit:cover; }
.play-icon{ position:absolute; top:50%; left:50%; width:56px; height:56px; transform:translate(-50%,-50%); color:var(--sand); filter:drop-shadow(0 6px 16px rgba(0,0,0,.5)); }
.video-title{ font-family:var(--font-display); font-size:1.05rem; }

@media (max-width:900px){
  .photo-grid{ grid-template-columns:repeat(2,1fr); grid-auto-rows:170px; }
  .video-grid{ grid-template-columns:1fr; }
}
@media (max-width:520px){
  .photo-grid{ grid-template-columns:repeat(2,1fr); grid-auto-rows:140px; }
}

/* ---- Contact page ---- */
.contact-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:26px; }
.contact-card{
  display:block; background:var(--jungle-2); border:1px solid rgba(217,164,65,.16); border-radius:6px;
  padding:32px; height:100%; transition:transform .3s ease, border-color .3s ease;
}
.contact-card:hover{ transform:translateY(-4px); border-color:rgba(217,164,65,.4); }
.contact-card-featured{ background:linear-gradient(150deg, rgba(37,211,102,.1), var(--jungle-2)); border-color:rgba(37,211,102,.3); }
.contact-icon{ width:52px; height:52px; border-radius:50%; background:rgba(217,164,65,.1); display:flex; align-items:center; justify-content:center; }
.contact-icon svg{ width:26px; height:26px; color:var(--gold-light); }
.wa-icon{ background:rgba(37,211,102,.14); }
.wa-icon svg{ width:28px; height:28px; }
.contact-link{ display:inline-block; color:var(--gold-light); font-weight:600; font-size:.9rem; }

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