/* ═══════════════════════════════════════════════════════════════
   MUZE TUBYINE — White · Emerald Green · Gold Edition
   Palette: Clean white + deep emerald greens + warm gold accents
   Fonts: Playfair Display (display) + Plus Jakarta Sans (body) + DM Mono (labels)
═══════════════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,600;0,700;0,900;1,400;1,600;1,700&family=Plus+Jakarta+Sans:wght@300;400;500;600;700;800&family=DM+Mono:wght@400;500&display=swap');

/* ─── DESIGN TOKENS ─── */
:root {
  /* Emerald greens */
  --g1:  #F5FBF7;
  --g2:  #EAF5EE;
  --g3:  #D4EDD9;
  --g4:  #A8D8B4;
  --g5:  #5FBD82;
  --g6:  #0F7A45;
  --g7:  #0A5C33;
  --g8:  #083D22;
  --g9:  #052918;
  --g10: #031A0F;

  /* Gold / warm accents */
  --gold1: #FFFBF0;
  --gold2: #FFF3CC;
  --gold3: #FFE080;
  --gold4: #F5C842;
  --gold5: #E8A800;
  --gold6: #C8831A;
  --gold7: #A05E10;
  --gold8: #7A3F08;

  /* Neutrals */
  --white:    #FFFFFF;
  --off:      #FAFAF8;
  --cream:    #F5FBF7;
  --gray1:    #F2F4F2;
  --gray2:    #E4E8E4;
  --gray3:    #C8D0C8;
  --gray4:    #8A9A8A;
  --gray5:    #4A5A4A;
  --dark:     #0A1F0F;
  --darker:   #052918;

  /* Semantic roles */
  --bg:          var(--white);
  --bg2:         var(--cream);
  --bg3:         var(--g1);
  --bg4:         var(--g2);
  --bg-dark:     var(--g8);
  --bg-darker:   var(--g9);

  --accent:      var(--g6);
  --accent-lt:   var(--g5);
  --accent-dark: var(--g7);
  --gold:        var(--gold4);
  --gold-lt:     var(--gold3);
  --gold-dark:   var(--gold6);

  --text:        var(--dark);
  --text-mid:    var(--gray5);
  --text-dim:    var(--gray4);

  --border:      rgba(15,122,69,0.18);
  --border-gold: rgba(200,131,26,0.25);
  --border-dim:  rgba(15,122,69,0.09);
  --border-dark: rgba(255,255,255,0.12);

  --glow:        rgba(15,122,69,0.18);
  --glow-gold:   rgba(245,200,66,0.22);

  --br:   3px;
  --ease: cubic-bezier(0.4,0,0.2,1);
  --ease-spring: cubic-bezier(0.34,1.56,0.64,1);
}
/* Hide gallery items with broken/missing images */
.gitem img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.gitem:has(img[src=""]),
.gitem img[src=""] {
  display: none;
}

.gitem {
  overflow: hidden;
}

/* Auto-hide when image fails to load */
.gitem img.img-error {
  display: none;
}

.gitem:has(img.img-error) {
  display: none !important;
  width: 0 !important;
  height: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
}
/* ─── RESET ─── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body {
  font-family: 'Plus Jakarta Sans', sans-serif;
  background: var(--bg);
  color: var(--text);
  overflow-x: hidden;
  line-height: 1.65;
}

/* Subtle warm texture on light bg */
body::before {
  content:'';
  position:fixed; inset:0; pointer-events:none; z-index:0;
  background:
    radial-gradient(ellipse 70% 50% at 10% 10%, rgba(245,200,66,0.05) 0%, transparent 60%),
    radial-gradient(ellipse 60% 60% at 90% 80%, rgba(15,122,69,0.06) 0%, transparent 55%);
}

::selection { background:var(--gold4); color:var(--dark); }
::-webkit-scrollbar { width:4px; }
::-webkit-scrollbar-track { background:var(--g2); }
::-webkit-scrollbar-thumb { background:var(--g6); border-radius:4px; }

/* ─── PRELOADER ─── */
#preloader {
  position:fixed; inset:0; z-index:9999;
  background:var(--white);
  display:flex; align-items:center; justify-content:center;
  transition:opacity 0.8s var(--ease), visibility 0.8s;
}
#preloader.gone { opacity:0; visibility:hidden; }
.pre-inner { text-align:center; }
.pre-logo { display:flex; align-items:center; justify-content:center; animation:prePulse 1.4s ease-in-out infinite; margin-bottom:1.4rem; }
.pre-logo img { width:76px; height:auto; }
.pre-brand {
  font-family:'Playfair Display', serif; font-style:italic;
  font-size:0.75rem; letter-spacing:8px; color:var(--g6);
  text-transform:uppercase; margin-bottom:1.5rem; opacity:0.9;
}
.pre-bar { width:160px; height:2px; background:var(--g3); margin:0 auto; overflow:hidden; border-radius:2px; }
.pre-fill { height:100%; background:linear-gradient(90deg,var(--g6),var(--gold4)); animation:preLoad 2s ease forwards; }
@keyframes prePulse { 0%,100%{transform:scale(1)} 50%{transform:scale(1.08)} }
@keyframes preLoad { from{width:0} to{width:100%} }

/* ─── NAVIGATION ─── */
nav {
  position:fixed; top:0; width:100%; z-index:1000;
  height:70px; padding:0 3rem;
  display:flex; align-items:center; justify-content:space-between;
  transition:all 0.4s var(--ease);
  background:rgba(255,255,255,0.0);
}
nav.scrolled {
  background:rgba(255,255,255,0.97);
  backdrop-filter:blur(20px);
  border-bottom:1px solid var(--border);
  box-shadow:0 4px 30px rgba(15,122,69,0.08);
}
nav.scrolled::before {
  content:'';
  position:absolute; top:0; left:0; right:0; height:2px;
  background:linear-gradient(90deg, transparent, var(--g6), var(--gold4), var(--g6), transparent);
}

.nav-logo { display:flex; align-items:center; gap:12px; text-decoration:none; }
.logo-drum {
  width:42px; height:42px; border-radius:50%;
  background:linear-gradient(135deg, var(--g7), var(--g6));
  display:flex; align-items:center; justify-content:center;
  overflow:hidden; flex-shrink:0;
  border:1.5px solid var(--border);
  box-shadow:0 0 14px var(--glow);
  font-family:'Playfair Display', serif;
  font-weight:700; font-size:0.85rem;
  color:var(--white); letter-spacing:0.5px;
}
.logo-drum img { width:100%; height:100%; object-fit:cover; display:block; border-radius:50%; }
.logo-drum img[src=""], .logo-drum img:not([src]) { display:none; }
.logo-words { line-height:1.2; }
.logo-name {
  font-family:'Playfair Display', serif; font-weight:700;
  font-size:1.05rem; color:var(--g7); display:block; letter-spacing:0.5px;
}
.logo-tag { font-size:0.55rem; color:var(--text-dim); letter-spacing:2.5px; text-transform:uppercase; font-family:'DM Mono', monospace; }

/* Nav scrolled — logo text dark */
nav.scrolled .logo-name { color:var(--g7); }

/* Hero nav — logo text white (on dark photo) */
nav:not(.scrolled) .logo-name { color:var(--white); }
nav:not(.scrolled) .logo-tag { color:rgba(255,255,255,0.6); }

.nav-links { display:flex; align-items:center; gap:0; list-style:none; }
.nav-links a {
  font-size:0.67rem; letter-spacing:1.5px; text-transform:uppercase;
  font-weight:500; color:var(--text-mid); text-decoration:none;
  padding:0.5rem 0.8rem; transition:color 0.2s;
  position:relative; isolation:isolate;
}
nav:not(.scrolled) .nav-links a { color:rgba(255,255,255,0.85); }
.nav-links a:hover { color:var(--g6); }
nav:not(.scrolled) .nav-links a:hover { color:var(--gold4); }

.nav-links li:last-child { isolation:isolate; margin-left:0.5rem; }
.nav-cta {
  display:inline-block;
  background:var(--g6) !important;
  color:var(--white) !important;
  border:1px solid var(--g6) !important;
  border-radius:2px !important;
  padding:0.42rem 1.1rem !important;
  font-weight:600 !important;
  font-size:0.67rem !important;
  letter-spacing:1.5px !important;
  text-transform:uppercase !important;
  text-decoration:none !important;
  position:relative !important;
  overflow:hidden !important;
  isolation:isolate !important;
  transition:all 0.3s !important;
  white-space:nowrap;
}
.nav-cta::before {
  content:'';
  position:absolute !important; top:0 !important; left:0 !important;
  width:100% !important; height:100% !important; z-index:-1 !important;
  background:linear-gradient(135deg, var(--gold5), var(--gold6));
  transform:translateX(-102%);
  transition:transform 0.32s var(--ease);
  border-radius:inherit !important;
}
.nav-cta::after { display:none !important; }
.nav-cta:hover { color:var(--white) !important; border-color:var(--gold5) !important; }
.nav-cta:hover::before { transform:translateX(0) !important; }

.hamburger { display:none; background:none; border:none; cursor:pointer; flex-direction:column; gap:5px; padding:5px; }
.hamburger span { display:block; width:22px; height:1.5px; background:var(--g6); border-radius:1px; transition:all 0.3s; }
nav:not(.scrolled) .hamburger span { background:var(--white); }
.hamburger.open span:nth-child(1) { transform:rotate(45deg) translate(5px,5px); }
.hamburger.open span:nth-child(2) { opacity:0; }
.hamburger.open span:nth-child(3) { transform:rotate(-45deg) translate(5px,-5px); }

/* ─── HERO ─── */
.hero {
  min-height:100vh; position:relative;
  display:flex; align-items:center; justify-content:center;
  text-align:center; overflow:hidden; padding:100px 2rem 80px;
}
.hero-slideshow { position:absolute; inset:0; z-index:0; }
.slide {
  position:absolute; inset:0;
  background-size:cover; background-position:center;
  opacity:0; transition:opacity 1s ease; will-change:opacity,transform;
}
.slide.active { opacity:1; animation:kenBurns 8s ease-in-out forwards; }
@keyframes kenBurns { from{transform:scale(1)} to{transform:scale(1.07)} }

.hero-overlay {
  position:absolute; inset:0; z-index:1;
  background:
    linear-gradient(to bottom, rgba(3,20,10,0.80) 0%, rgba(3,20,10,0.55) 30%, rgba(3,20,10,0.70) 65%, rgba(3,20,10,0.95) 100%),
    linear-gradient(to right, rgba(3,20,10,0.35) 0%, transparent 60%);
}

.hero-pattern {
  position:absolute; inset:0; z-index:2; pointer-events:none;
  background-image:
    repeating-linear-gradient(0deg, transparent, transparent 70px, rgba(15,122,69,0.03) 70px, rgba(15,122,69,0.03) 71px),
    repeating-linear-gradient(90deg, transparent, transparent 70px, rgba(245,200,66,0.02) 70px, rgba(245,200,66,0.02) 71px);
}

.hero-orb1 {
  position:absolute; top:-10%; left:-5%; width:500px; height:500px;
  border-radius:50%; z-index:2; pointer-events:none;
  background:radial-gradient(circle, rgba(245,200,66,0.10) 0%, transparent 70%);
}
.hero-orb2 {
  position:absolute; bottom:-10%; right:-5%; width:450px; height:450px;
  border-radius:50%; z-index:2; pointer-events:none;
  background:radial-gradient(circle, rgba(15,122,69,0.12) 0%, transparent 70%);
}

.hero-particles { position:absolute; inset:0; z-index:3; pointer-events:none; overflow:hidden; }
.particle {
  position:absolute; border-radius:50%;
  animation:floatP linear infinite; opacity:0;
}
@keyframes floatP {
  0%   { transform:translateY(110vh) rotate(0deg); opacity:0; }
  6%   { opacity:0.7; }
  94%  { opacity:0.2; }
  100% { transform:translateY(-10vh) rotate(720deg); opacity:0; }
}

.hero-content { position:relative; z-index:6; max-width:880px; width:100%; }

.hero-ornament {
  display:flex; align-items:center; justify-content:center;
  gap:12px; margin-bottom:2rem;
}
.orn-line { width:55px; height:1px; background:linear-gradient(90deg, transparent, var(--gold4)); }
.orn-line.r { background:linear-gradient(90deg, var(--gold4), transparent); }
.orn-gem {
  width:10px; height:10px; transform:rotate(45deg);
  background:linear-gradient(135deg, var(--gold4), var(--gold6));
  box-shadow:0 0 16px var(--glow-gold);
}

.hero-eyebrow {
  display:flex; gap:0.75rem; justify-content:center;
  flex-wrap:wrap; margin-bottom:1.4rem;
}
.rw-pill {
  display:inline-flex; align-items:center; gap:6px;
  padding:0.3rem 1rem; border-radius:30px;
  font-size:0.63rem; letter-spacing:2.5px; text-transform:uppercase; font-weight:600;
  background:rgba(15,122,69,0.25); border:1px solid rgba(95,189,130,0.55); color:#FFFFFF;
  -webkit-text-fill-color: #FFFFFF;
  font-family:'DM Mono', monospace;
}
.est-pill {
  display:inline-flex; align-items:center; gap:6px;
  padding:0.3rem 1rem; border-radius:30px;
  font-size:0.63rem; letter-spacing:2.5px; text-transform:uppercase;
  background:rgba(245,200,66,0.15); border:1px solid rgba(245,200,66,0.45); color:#FFE080;
  -webkit-text-fill-color: #FFE080;
  font-family:'DM Mono', monospace;
}

.hero-h1 {
  font-family:'Playfair Display', serif; font-weight:900;
  font-size:clamp(4rem,11vw,8.5rem);
  line-height:0.92; color:#FFFFFF;
  margin-bottom:0.5rem; letter-spacing:-2px;
  text-shadow:0 4px 60px rgba(0,0,0,0.5);
}
.hero-h1 em {
  font-style:italic;
  color:#F5C842;
  -webkit-text-fill-color: #F5C842;
  text-shadow:0 0 60px rgba(245,200,66,0.4);
}

.hero-sub {
  font-family:'Playfair Display', serif; font-style:italic; font-weight:400;
  font-size:clamp(1rem,2.5vw,1.6rem);
  color:#F5C842;
  -webkit-text-fill-color: #F5C842;
  margin-bottom:1.1rem; letter-spacing:4px; opacity:0.95;
  text-transform:uppercase;
  text-shadow: 0 2px 20px rgba(245,200,66,0.3);
}

.hero-desc {
  font-size:0.93rem; color:rgba(255,255,255,0.85);
  -webkit-text-fill-color: rgba(255,255,255,0.85);
  max-width:560px; margin:0 auto 2.5rem; line-height:1.88; font-weight:300;
  text-shadow: 0 1px 8px rgba(0,0,0,0.4);
}

.hero-actions { display:flex; gap:0.9rem; justify-content:center; flex-wrap:wrap; margin-bottom:3.5rem; }

.hero-stats {
  display:flex; gap:0; justify-content:center; align-items:center; flex-wrap:wrap;
  padding:1.6rem 2.5rem;
  background:rgba(5,41,24,0.65);
  border:1px solid rgba(15,122,69,0.30);
  border-radius:var(--br); backdrop-filter:blur(12px);
  position:relative; overflow:hidden;
}
.hero-stats::before {
  content:''; position:absolute; top:0; left:0; right:0; height:1px;
  background:linear-gradient(90deg, transparent, var(--g6), var(--gold4), var(--g6), transparent);
}
.hstat { text-align:center; padding:0 2rem; }
.hstat strong {
  font-family:'Playfair Display', serif; font-size:2.1rem; font-weight:700;
  display:block; line-height:1;
  background:linear-gradient(135deg, var(--gold3), var(--gold5));
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
.hstat span { font-size:0.56rem; letter-spacing:2px; text-transform:uppercase; color:var(--g4); font-family:'DM Mono', monospace; }
.hstat-div { width:1px; height:36px; background:rgba(15,122,69,0.3); }

.hero-dots { position:absolute; bottom:2.5rem; left:50%; transform:translateX(-50%); z-index:7; display:flex; gap:6px; align-items:center; }
.dot { width:20px; height:2px; border-radius:1px; background:rgba(255,255,255,0.25); border:none; cursor:pointer; transition:all 0.35s; }
.dot.active { background:var(--gold4); width:42px; }

.scroll-hint { position:absolute; right:2.5rem; bottom:3rem; z-index:7; display:flex; flex-direction:column; align-items:center; gap:10px; }
.scroll-hint span { font-size:0.54rem; letter-spacing:3.5px; text-transform:uppercase; color:var(--gold4); writing-mode:vertical-rl; font-family:'DM Mono', monospace; }
.sh-line { width:1px; height:52px; background:linear-gradient(to bottom, var(--gold4), transparent); animation:shPulse 2.4s ease-in-out infinite; }
@keyframes shPulse { 0%,100%{opacity:0.25} 50%{opacity:1} }

/* ─── BUTTONS ─── */
.btn {
  display:inline-flex; align-items:center; gap:8px;
  padding:0.82rem 1.9rem; border-radius:var(--br);
  font-family:'Plus Jakarta Sans', sans-serif; font-weight:700;
  font-size:0.7rem; letter-spacing:2px; text-transform:uppercase;
  text-decoration:none; border:none; cursor:pointer;
  transition:all 0.28s var(--ease); position:relative; overflow:hidden;
}
.btn-primary {
  background:linear-gradient(135deg, var(--g6), var(--g5));
  color:var(--white);
  box-shadow:0 4px 20px var(--glow);
}
.btn-primary:hover { background:linear-gradient(135deg, var(--g5), var(--g4)); color:var(--dark); transform:translateY(-2px); box-shadow:0 8px 32px var(--glow); }

.btn-danger {
  background:linear-gradient(135deg, #C8831A, #E8A800);
  color:#FFFFFF;
  box-shadow:0 4px 20px rgba(200,131,26,0.35);
}
.btn-danger:hover { background:linear-gradient(135deg, #E8A800, #F5C842); color:#0A1F0F; transform:translateY(-2px); box-shadow:0 8px 28px rgba(200,131,26,0.45); }

.btn-ghost { background:transparent; color:var(--white); border:1px solid rgba(255,255,255,0.35); }
.btn-ghost:hover { background:rgba(255,255,255,0.12); border-color:var(--white); transform:translateY(-2px); }

.btn-outline { background:transparent; color:var(--g6); border:1px solid var(--border); }
.btn-outline:hover { background:var(--g6); color:var(--white); border-color:var(--g6); transform:translateY(-2px); box-shadow:0 8px 24px var(--glow); }

/* ─── SECTIONS ─── */
.section { padding:110px 2rem; position:relative; z-index:2; background:var(--white); }

/* section-dark: light alternating tint — NOT dark green anymore */
.section-dark {
  background:linear-gradient(180deg, var(--g1) 0%, var(--g2) 100%);
  position:relative;
}
.section-dark::before {
  content:''; position:absolute; top:0; left:0; right:0; height:2px;
  background:linear-gradient(90deg, transparent, var(--g6), var(--gold5), var(--g6), transparent);
  opacity:0.35;
}
.section-dark::after {
  content:''; position:absolute; bottom:0; left:0; right:0; height:1px;
  background:linear-gradient(90deg, transparent, var(--border-dim), transparent);
}
/* All text in "section-dark" now uses dark colors (light theme) */
.section-dark .body-text { color:var(--text-mid); }
.section-dark .section-h2 { color:var(--dark); }
.section-dark .section-lead { color:var(--text-mid); }
.section-dark .section-eyebrow { color:var(--g6); }
.section-dark .section-eyebrow::before { background:var(--g6); }

.container { max-width:1260px; margin:0 auto; }

.section-eyebrow {
  font-size:0.58rem; letter-spacing:4px; text-transform:uppercase;
  color:var(--g6); margin-bottom:0.7rem;
  display:flex; align-items:center; gap:12px;
  font-family:'DM Mono', monospace;
}
.section-eyebrow::before { content:''; display:inline-block; width:28px; height:1px; background:var(--g6); }

.section-h2 {
  font-family:'Playfair Display', serif; font-weight:700;
  font-size:clamp(2rem,4.5vw,3.2rem);
  color:var(--dark); line-height:1.1; margin-bottom:0.75rem; letter-spacing:-0.5px;
}
.section-h2 em { font-style:italic; color:var(--gold6); }

.section-lead { font-size:0.92rem; color:var(--text-mid); max-width:560px; line-height:1.85; font-weight:300; }
.section-header { margin-bottom:3.5rem; }
.section-header.center { text-align:center; }
.section-header.center .section-eyebrow { justify-content:center; }
.section-header.center .section-eyebrow::before { display:none; }
.s-line { width:48px; height:2px; background:linear-gradient(90deg, var(--g6), var(--gold4), transparent); margin:1.2rem 0; }

.body-text { font-size:0.91rem; color:var(--text-mid); line-height:1.9; font-weight:300; }
.accent { color:var(--g6); }
.center-action { text-align:center; margin-top:3rem; }

/* ─── ABOUT ─── */
.two-col { display:grid; grid-template-columns:1fr 1.15fr; gap:6rem; align-items:center; }

.visual-stack { position:relative; height:500px; }
.vs-frame-tl, .vs-frame-br { position:absolute; width:36px; height:36px; z-index:3; opacity:0.5; }
.vs-frame-tl { top:-6px; left:-6px; border-top:1.5px solid var(--g6); border-left:1.5px solid var(--g6); }
.vs-frame-br { bottom:48%; right:47%; border-bottom:1.5px solid var(--gold6); border-right:1.5px solid var(--gold6); }

.vs-main {
  position:absolute; top:0; left:0; width:76%; height:83%;
  border-radius:var(--br); overflow:hidden;
  border:1px solid var(--border);
  box-shadow:0 24px 80px rgba(15,122,69,0.15);
}
.vs-main img { width:100%; height:100%; object-fit:cover; display:block; }

.vs-accent {
  position:absolute; bottom:0; right:0; width:50%; height:47%;
  border-radius:var(--br); overflow:hidden;
  border:1px solid var(--border-gold);
  box-shadow:0 12px 50px rgba(0,0,0,0.12);
}
.vs-accent img { width:100%; height:100%; object-fit:cover; display:block; }

.vs-badge {
  position:absolute; top:38%; right:-18px; z-index:4;
  background:linear-gradient(135deg, var(--g6), var(--g7));
  border:1px solid rgba(255,255,255,0.15); padding:1.2rem 1.5rem;
  border-radius:var(--br); text-align:center;
  box-shadow:0 8px 40px rgba(15,122,69,0.35);
}
.vs-badge::before {
  content:''; position:absolute; top:0; left:0; right:0; height:2px;
  background:linear-gradient(90deg, var(--gold4), var(--gold6));
}
.vs-badge strong { font-family:'Playfair Display', serif; font-size:2.3rem; font-weight:700; color:var(--gold4); display:block; line-height:1; }
.vs-badge span { font-size:0.56rem; letter-spacing:2px; text-transform:uppercase; color:var(--g3); font-family:'DM Mono', monospace; }

.mini-cards { display:grid; grid-template-columns:1fr 1fr; gap:0.85rem; margin-top:2rem; }
.mini-card {
  display:flex; gap:1rem; align-items:flex-start;
  background:var(--g1);
  border:1px solid var(--border-dim); padding:1.2rem; border-radius:var(--br);
  transition:all 0.3s var(--ease); position:relative; overflow:hidden;
}
.mini-card::before {
  content:''; position:absolute; top:0; left:0; width:2px; height:100%;
  background:linear-gradient(to bottom, var(--g6), var(--gold5));
  opacity:0; transition:opacity 0.3s;
}
.mini-card:hover { border-color:var(--border); transform:translateY(-2px); box-shadow:0 8px 24px rgba(15,122,69,0.10); }
.mini-card:hover::before { opacity:1; }
.mc-icon { font-size:1.4rem; flex-shrink:0; margin-top:2px; }
.mini-card h4 { font-family:'Playfair Display', serif; font-size:0.95rem; font-weight:700; color:var(--g7); margin-bottom:0.3rem; }
.mini-card p { font-size:0.76rem; color:var(--text-dim); line-height:1.65; }

/* ─── TEAM ─── */
.team-block { margin-top:6rem; }
.team-grid-3 { display:grid; grid-template-columns:repeat(3,1fr); gap:1.8rem; margin-top:2.5rem; }
.team-card-v2 {
  background:var(--white);
  border:1px solid var(--border-dim); border-radius:4px; overflow:hidden;
  transition:all 0.35s var(--ease); display:flex; flex-direction:column;
  position:relative;
  box-shadow:0 2px 12px rgba(15,122,69,0.06);
}
.team-card-v2::after {
  content:''; position:absolute; top:0; left:0; right:0; height:2px;
  background:linear-gradient(90deg, var(--g6), var(--gold4));
  transform:scaleX(0); transform-origin:center; transition:transform 0.4s var(--ease);
}
.team-card-v2:hover { border-color:var(--border); transform:translateY(-5px); box-shadow:0 20px 50px rgba(15,122,69,0.12); }
.team-card-v2:hover::after { transform:scaleX(1); }

.tc-photo-wrap {
  display:flex; align-items:center; justify-content:center; padding:2rem 0;
  background:linear-gradient(180deg, var(--g2) 0%, var(--g1) 100%); flex-shrink:0; overflow:hidden;
  position:relative;
}
.tc-photo-wrap::before {
  content:''; position:absolute; inset:0;
  background:radial-gradient(ellipse 65% 65% at 50% 60%, rgba(245,200,66,0.08), transparent);
  pointer-events:none;
}
.tc-photo { width:140px; height:140px; border-radius:50%; object-fit:cover; object-position:center; display:block; border:2px solid var(--border); transition:transform 0.5s; box-shadow:0 8px 30px rgba(0,0,0,0.1); position:relative; z-index:1; }
.team-card-v2:hover .tc-photo { transform:scale(1.05); }
.tc-photo-placeholder { width:140px; height:140px; border-radius:50%; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:0.5rem; background:linear-gradient(135deg,var(--g3),var(--g2)); border:2px solid var(--border); position:relative; z-index:1; }
.tcp-icon { font-size:2.5rem; }
.tcp-label { font-size:0.58rem; letter-spacing:1.5px; color:var(--text-dim); text-align:center; text-transform:uppercase; font-family:'DM Mono', monospace; }
.tc-info { padding:1.4rem; flex-grow:1; }
.tc-name { font-family:'Playfair Display', serif; font-weight:700; color:var(--dark); font-size:1.15rem; margin-bottom:0.3rem; }
.tc-role-text { font-size:0.66rem; color:var(--gold6); letter-spacing:1.5px; text-transform:uppercase; font-family:'DM Mono', monospace; margin-bottom:0.9rem; }
.tc-bio { font-size:0.81rem; color:var(--text-mid); line-height:1.75; font-weight:300; }

/* ─── SERVICES ─── */
.services-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(290px,1fr)); gap:1.5rem; }
.srv-card {
  background:var(--white);
  border:1px solid var(--border-dim); padding:2.4rem 2rem; border-radius:var(--br);
  position:relative; overflow:hidden; transition:all 0.35s var(--ease);
  box-shadow:0 2px 12px rgba(15,122,69,0.05);
}
.srv-card::after {
  content:''; position:absolute; top:0; left:0; right:0; height:2px;
  background:linear-gradient(90deg, var(--g6), var(--gold4), transparent);
  transform:scaleX(0); transform-origin:left; transition:transform 0.4s;
}
.srv-card:hover { border-color:var(--border); transform:translateY(-6px); box-shadow:0 20px 50px rgba(15,122,69,0.12); }
.srv-card:hover::after { transform:scaleX(1); }
.srv-num { position:absolute; top:1.5rem; right:1.5rem; font-family:'Playfair Display', serif; font-size:3rem; font-weight:900; color:rgba(15,122,69,0.07); line-height:1; }
.srv-icon { font-size:2.2rem; margin-bottom:1.2rem; display:block; }
.srv-card h3 { font-family:'Playfair Display', serif; color:var(--dark); font-size:1.25rem; font-weight:600; margin-bottom:0.65rem; }
.srv-card p { font-size:0.82rem; color:var(--text-mid); line-height:1.75; font-weight:300; }
.srv-tag {
  display:inline-block; margin-top:1.3rem;
  background:rgba(200,131,26,0.10); color:var(--gold7);
  font-size:0.58rem; letter-spacing:2px; text-transform:uppercase;
  padding:0.28rem 0.85rem; border-radius:20px;
  border:1px solid rgba(200,131,26,0.22); font-family:'DM Mono', monospace;
}

/* service cards inside section-dark — now light tinted bg */
.section-dark .srv-card {
  background:var(--white);
  border-color:var(--border-dim);
}
.section-dark .srv-card:hover { background:var(--white); border-color:var(--border); box-shadow:0 20px 50px rgba(15,122,69,0.12); }
.section-dark .srv-card h3 { color:var(--dark); }
.section-dark .srv-card p { color:var(--text-mid); }

.expect-strip {
  margin-top:4rem;
  background:var(--g1);
  border:1px solid var(--border); border-radius:var(--br); padding:2.8rem;
  position:relative; overflow:hidden;
}
.section-dark .expect-strip {
  background:var(--white);
  border-color:var(--border-dim);
}
.section-dark .es-title { color:var(--g6); }
.section-dark .ex-step span { color:rgba(15,122,69,0.12); }
.section-dark .ex-step h4 { color:var(--dark); }
.section-dark .ex-step p { color:var(--text-dim); }
.expect-strip::before {
  content:''; position:absolute; top:0; left:0; right:0; height:2px;
  background:linear-gradient(90deg, transparent, var(--g6), var(--gold4), transparent);
}
.es-title { font-family:'Playfair Display', serif; font-size:1.1rem; font-style:italic; color:var(--g6); margin-bottom:2rem; }
.expect-row { display:flex; align-items:flex-start; flex-wrap:wrap; }
.ex-step { flex:1; min-width:140px; }
.ex-step span { display:block; font-family:'Playfair Display', serif; font-size:2rem; font-weight:900; color:rgba(15,122,69,0.12); line-height:1; margin-bottom:0.5rem; }
.ex-step h4 { font-size:0.88rem; color:var(--dark); margin-bottom:0.3rem; font-weight:600; }
.ex-step p { font-size:0.77rem; color:var(--text-dim); line-height:1.65; }
.ex-arr { padding:0 1.5rem; font-size:1.2rem; color:var(--gray3); align-self:center; margin-top:-0.5rem; }

/* ─── GALLERY ─── */
.filter-row { display:flex; gap:0.5rem; flex-wrap:wrap; margin-bottom:2.5rem; }
.fil {
  background:transparent; border:1px solid var(--border-dim);
  color:var(--text-dim); padding:0.38rem 1.1rem;
  font-size:0.62rem; letter-spacing:2px; text-transform:uppercase;
  cursor:pointer; border-radius:20px; font-family:'DM Mono', monospace;
  transition:all 0.25s;
}
.fil.active, .fil:hover { background:linear-gradient(135deg,var(--g6),var(--gold6)); color:white; border-color:transparent; }

.gallery-masonry { display:grid; grid-template-columns:repeat(4,1fr); grid-auto-rows:200px; gap:8px; }
.gitem { border-radius:var(--br); overflow:hidden; position:relative; cursor:pointer; transition:transform 0.3s; }
.gitem.wide { grid-column:span 2; }
.gitem.tall { grid-row:span 2; }
.gitem:hover { transform:scale(1.02); z-index:2; }
.gitem img { width:100%; height:100%; object-fit:cover; display:block; transition:transform 0.5s; }
.gitem:hover img { transform:scale(1.08); }
.g-overlay {
  position:absolute; inset:0;
  background:linear-gradient(to top, rgba(5,41,24,0.92) 0%, rgba(5,41,24,0.1) 55%, transparent);
  display:flex; align-items:flex-end; justify-content:space-between;
  padding:1.1rem; opacity:0; transition:opacity 0.3s;
}
.gitem:hover .g-overlay { opacity:1; }
.g-info { display:flex; flex-direction:column; gap:2px; }
.g-cat { font-size:0.54rem; letter-spacing:2.5px; text-transform:uppercase; color:var(--gold4); font-family:'DM Mono', monospace; }
.g-ttl { font-family:'Playfair Display', serif; color:var(--white); font-size:0.95rem; font-weight:600; }
.g-zoom { font-size:1.3rem; color:var(--gold4); }

.lightbox { display:none; position:fixed; inset:0; z-index:9999; background:rgba(5,41,24,0.97); backdrop-filter:blur(16px); align-items:center; justify-content:center; padding:2rem; cursor:zoom-out; }
.lightbox.open { display:flex; animation:fadeIn 0.3s ease; }
.lb-close { position:fixed; top:1.5rem; right:2rem; background:none; border:1px solid rgba(255,255,255,0.2); color:var(--gold4); font-size:1rem; cursor:pointer; z-index:10000; width:38px; height:38px; border-radius:50%; display:flex; align-items:center; justify-content:center; transition:all 0.2s; }
.lb-close:hover { background:var(--g6); color:var(--white); }
.lb-inner { max-width:90vw; max-height:88vh; text-align:center; cursor:default; }
.lb-inner img { max-width:100%; max-height:80vh; object-fit:contain; border-radius:var(--br); border:1px solid rgba(255,255,255,0.1); }
.lb-inner p { margin-top:1rem; font-family:'Playfair Display', serif; font-style:italic; color:var(--gold4); font-size:1rem; }

/* ─── PORTFOLIO ─── */
.portfolio-grid { display:grid; grid-template-columns:1.35fr 0.65fr; grid-template-rows:auto auto; gap:1.5rem; }
.port-card {
  background:var(--white);
  border:1px solid var(--border-dim); border-radius:var(--br); overflow:hidden;
  transition:all 0.35s var(--ease);
  box-shadow:0 2px 16px rgba(15,122,69,0.06);
}
.section-dark .port-card {
  background:var(--white);
  border-color:var(--border-dim);
}
.port-card:hover { border-color:var(--border); transform:translateY(-4px); box-shadow:0 20px 50px rgba(15,122,69,0.14); }
.section-dark .port-card:hover { border-color:var(--border); box-shadow:0 20px 50px rgba(15,122,69,0.12); }
.port-card.featured { grid-row:span 2; }
.port-img { overflow:hidden; }
.port-img img { width:100%; height:100%; object-fit:cover; display:block; transition:transform 0.6s var(--ease); }
.port-card:hover .port-img img { transform:scale(1.05); }
.port-img { height:270px; }
.port-img.sm { height:170px; }
.port-card.featured .port-img { height:360px; }
.port-body { padding:1.6rem; }
.port-tag { font-size:0.57rem; letter-spacing:2.5px; text-transform:uppercase; color:var(--g6); display:block; margin-bottom:0.5rem; font-family:'DM Mono', monospace; }
.section-dark .port-tag { color:var(--g6); }
.port-body h3 { font-family:'Playfair Display', serif; color:var(--dark); font-size:1.2rem; font-weight:600; margin-bottom:0.6rem; }
.section-dark .port-body h3 { color:var(--dark); }
.port-body p { font-size:0.82rem; color:var(--text-mid); line-height:1.7; font-weight:300; }
.section-dark .port-body p { color:var(--text-mid); }
.port-meta { display:flex; gap:1rem; margin-top:0.85rem; flex-wrap:wrap; }
.port-meta span { font-size:0.7rem; color:var(--g6); }
.section-dark .port-meta span { color:var(--g6); }

.rm-body { overflow:hidden; transition:max-height 0.45s var(--ease); }
.rm-body.collapsed { max-height:60px; position:relative; }
.rm-body.collapsed::after { content:''; position:absolute; bottom:0; left:0; right:0; height:36px; background:linear-gradient(transparent, var(--white)); pointer-events:none; }
.section-dark .rm-body.collapsed::after { background:linear-gradient(transparent, var(--g1)); }
.rm-btn { background:none; border:none; color:var(--g6); font-size:0.7rem; font-weight:600; cursor:pointer; padding:5px 0 2px; display:inline-flex; align-items:center; gap:4px; margin-top:4px; transition:color 0.2s; }
.section-dark .rm-btn { color:var(--g6); }
.rm-btn:hover { color:var(--gold6); }
.rm-arrow { display:inline-block; transition:transform 0.3s; }
.rm-arrow.open { transform:rotate(180deg); }

.port-video-section { border-top:1px solid var(--border-dim); padding:1.3rem 1.6rem 1.6rem; background:var(--g1); }
.section-dark .port-video-section { background:var(--g1); border-color:var(--border-dim); }
.pvs-label { font-size:0.57rem; letter-spacing:2.5px; text-transform:uppercase; color:var(--text-dim); margin-bottom:0.9rem; font-family:'DM Mono', monospace; }
.section-dark .pvs-label { color:var(--text-dim); }
.pvs-embed { position:relative; padding-bottom:56.25%; height:0; overflow:hidden; border-radius:var(--br); border:1px solid var(--border-dim); background:#000; margin-bottom:0.9rem; }
.pvs-embed iframe { position:absolute; top:0; left:0; width:100%; height:100%; border:none; }
.pvs-link { display:flex; align-items:center; gap:12px; background:var(--g2); border:1px solid var(--border-dim); border-radius:var(--br); padding:10px 14px; text-decoration:none; transition:all 0.25s; }
.section-dark .pvs-link { background:var(--g2); border-color:var(--border-dim); }
.pvs-link:hover { border-color:var(--border); background:var(--g3); transform:translateX(3px); }
.pvs-link-icon { width:36px; height:36px; flex-shrink:0; background:rgba(15,122,69,0.12); border:1px solid var(--border); border-radius:var(--br); display:flex; align-items:center; justify-content:center; font-size:1rem; color:var(--g6); }
.pvs-link-text { flex:1; display:flex; flex-direction:column; gap:2px; }
.pvs-link-title { font-size:0.81rem; font-weight:600; color:var(--dark); }
.section-dark .pvs-link-title { color:var(--dark); }
.pvs-link-sub { font-size:0.67rem; color:var(--text-dim); }
.pvs-link-arrow { font-size:1rem; color:var(--text-dim); flex-shrink:0; transition:transform 0.2s; }
.pvs-link:hover .pvs-link-arrow { transform:translateX(3px); color:var(--g6); }

/* ─── MILESTONES ─── */
.milestones { margin-top:4.5rem; }
.milestone-list { display:flex; flex-direction:column; }
.ms { display:flex; gap:1.8rem; align-items:flex-start; padding:1.4rem 0; border-bottom:1px solid var(--border-dim); transition:background 0.2s; }
.section-dark .ms { border-bottom-color:var(--border-dim); }
.ms:last-child { border-bottom:none; }
.ms:hover { background:rgba(15,122,69,0.03); }
.ms-yr { font-family:'DM Mono', monospace; font-size:0.7rem; font-weight:700; color:var(--g6); letter-spacing:1px; min-width:42px; flex-shrink:0; padding-top:3px; }
.section-dark .ms-yr { color:var(--g6); }
.ms-line { width:1px; background:var(--border); align-self:stretch; flex-shrink:0; }
.section-dark .ms-line { background:var(--border); }
.ms-info h4 { font-size:0.88rem; color:var(--dark); font-weight:500; margin-bottom:0.2rem; }
.section-dark .ms-info h4 { color:var(--dark); }
.ms-info p { font-size:0.77rem; color:var(--text-dim); }
.section-dark .ms-info p { color:var(--text-dim); }

/* ─── EVENTS ─── */
.events-layout { display:grid; grid-template-columns:1.3fr 0.9fr; gap:3.5rem; }
.col-label { font-family:'DM Mono', monospace; font-size:0.6rem; letter-spacing:3px; text-transform:uppercase; color:var(--g6); margin-bottom:1.4rem; display:flex; align-items:center; gap:8px; }
.col-label::before { content:''; width:18px; height:1px; background:var(--g6); }

.event-list { display:flex; flex-direction:column; gap:1rem; }
.ev-card { background:var(--white); border:1px solid var(--border-dim); padding:1.4rem; border-radius:var(--br); display:flex; gap:1.3rem; align-items:flex-start; transition:all 0.3s; box-shadow:0 2px 10px rgba(15,122,69,0.05); }
.ev-card:hover { border-color:var(--border); transform:translateX(5px); box-shadow:0 8px 24px rgba(15,122,69,0.10); }
.ev-date { background:linear-gradient(135deg, var(--g6), var(--g7)); color:var(--white); padding:0.6rem 1rem; border-radius:var(--br); text-align:center; flex-shrink:0; min-width:58px; }
.ev-date strong { font-family:'Playfair Display', serif; font-size:1.7rem; font-weight:700; display:block; line-height:1; color:var(--gold4); }
.ev-date span { font-size:0.54rem; letter-spacing:1.5px; text-transform:uppercase; color:var(--g3); font-family:'DM Mono', monospace; }
.ev-body h4 { font-family:'Playfair Display', serif; color:var(--dark); font-size:1.05rem; font-weight:600; margin-bottom:0.4rem; }
.ev-body p { font-size:0.79rem; color:var(--text-mid); line-height:1.55; font-weight:300; }
.ev-tags { display:flex; gap:0.85rem; margin-top:0.6rem; flex-wrap:wrap; }
.ev-tags span { font-size:0.67rem; color:var(--g6); }

.past-panel { background:var(--white); border:1px solid var(--border-dim); padding:2rem; border-radius:var(--br); box-shadow:0 2px 12px rgba(15,122,69,0.06); }
.past-row { display:flex; justify-content:space-between; align-items:center; padding:0.9rem 0; border-bottom:1px solid var(--border-dim); }
.past-row.last { border-bottom:none; }
.past-row h5 { font-size:0.84rem; color:var(--dark); font-weight:500; margin-bottom:0.1rem; }
.past-row span:first-child { font-size:0.7rem; color:var(--text-dim); }
.yr { font-family:'DM Mono', monospace; font-size:0.68rem; color:var(--g6); font-weight:700; flex-shrink:0; margin-left:0.5rem; }

/* ─── BOOKING ─── */
.book-layout { display:grid; grid-template-columns:1fr 1.2fr; gap:5rem; align-items:start; }
.bq { font-family:'Playfair Display', serif; font-style:italic; font-size:1.2rem; color:var(--dark); line-height:1.65; border-left:2px solid var(--g6); padding-left:1.4rem; margin:2rem 0; }
.contact-pills { display:flex; flex-direction:column; gap:0.85rem; }
.cp { display:flex; gap:1rem; align-items:center; padding:1.1rem 1.3rem; background:var(--g1); border:1px solid var(--border-dim); border-radius:var(--br); transition:border-color 0.25s; }
.cp:hover { border-color:var(--border); box-shadow:0 4px 16px rgba(15,122,69,0.08); }
.cp-icon { width:40px; height:40px; background:rgba(15,122,69,0.10); border:1px solid var(--border); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:0.9rem; flex-shrink:0; }
.cp small { font-size:0.58rem; letter-spacing:1.5px; text-transform:uppercase; color:var(--text-dim); display:block; margin-bottom:2px; font-family:'DM Mono', monospace; }
.cp a, .cp span { font-size:0.87rem; color:var(--dark); text-decoration:none; }
.cp a:hover { color:var(--g6); }
.response-note { margin-top:1.5rem; padding:1rem 1.2rem; background:rgba(15,122,69,0.06); border:1px solid var(--border-dim); border-radius:var(--br); font-size:0.78rem; color:var(--text-mid); line-height:1.65; }

.booking-form { background:var(--white); border:1px solid var(--border-dim); padding:2.5rem; border-radius:var(--br); position:relative; overflow:hidden; box-shadow:0 4px 24px rgba(15,122,69,0.08); }
.booking-form::before { content:''; position:absolute; top:0; left:0; right:0; height:2px; background:linear-gradient(90deg, transparent, var(--g6), var(--gold4), transparent); }
.booking-form h3 { font-family:'Playfair Display', serif; color:var(--dark); font-size:1.35rem; font-weight:600; margin-bottom:1.8rem; }

.fg { margin-bottom:1.1rem; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
label { display:block; font-size:0.6rem; letter-spacing:2px; text-transform:uppercase; color:var(--text-dim); margin-bottom:0.4rem; font-weight:600; font-family:'DM Mono', monospace; }
input, select, textarea { width:100%; padding:0.75rem 1rem; background:var(--g1); border:1px solid var(--border-dim); color:var(--dark); font-family:'Plus Jakarta Sans', sans-serif; font-size:0.87rem; border-radius:var(--br); transition:border-color 0.2s; outline:none; }
input:focus, select:focus, textarea:focus { border-color:var(--g6); background:rgba(15,122,69,0.04); }
select option { background:var(--white); color:var(--dark); }
textarea { resize:vertical; min-height:100px; }
input::placeholder, textarea::placeholder { color:var(--text-dim); opacity:0.6; }
.form-success { text-align:center; padding:2rem; }
.success-icon { font-size:2.5rem; margin-bottom:0.75rem; }
.form-success h4 { font-family:'Playfair Display', serif; color:var(--dark); font-size:1.3rem; margin-bottom:0.5rem; }
.form-success p { font-size:0.85rem; color:var(--text-mid); }

/* ─── BLOG ─── */
.blog-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(310px,1fr)); gap:1.5rem; }
.blog-card { background:var(--white); border:1px solid var(--border-dim); border-radius:var(--br); overflow:hidden; transition:all 0.35s; box-shadow:0 2px 12px rgba(15,122,69,0.05); }
.section-dark .blog-card { background:var(--white); border-color:var(--border-dim); }
.blog-card:hover { border-color:var(--border); transform:translateY(-6px); box-shadow:0 20px 50px rgba(15,122,69,0.12); }
.blog-img { height:185px; display:flex; align-items:center; justify-content:center; font-size:3rem; position:relative; overflow:hidden; }
.blog-img::after { content:''; position:absolute; bottom:0; left:0; right:0; height:60px; background:linear-gradient(to top, var(--white), transparent); pointer-events:none; }
.section-dark .blog-img::after { background:linear-gradient(to top, var(--white), transparent); }
.blog-body { padding:1.6rem; }
.blog-tag { font-size:0.57rem; letter-spacing:2.5px; text-transform:uppercase; color:var(--g6); margin-bottom:0.5rem; display:block; font-family:'DM Mono', monospace; }
.section-dark .blog-tag { color:var(--g6); }
.blog-card h3 { font-family:'Playfair Display', serif; color:var(--dark); font-size:1.1rem; font-weight:600; margin-bottom:0.55rem; line-height:1.35; }
.section-dark .blog-card h3 { color:var(--dark); }
.blog-card p { font-size:0.8rem; color:var(--text-mid); line-height:1.7; margin-bottom:1.2rem; font-weight:300; }
.section-dark .blog-card p { color:var(--text-mid); }
.blog-foot { display:flex; justify-content:space-between; align-items:center; }
.blog-foot span { font-size:0.68rem; color:var(--text-dim); }
.blog-link { font-size:0.68rem; color:var(--g6); text-decoration:none; font-weight:600; letter-spacing:0.5px; transition:color 0.2s; }
.blog-link:hover { color:var(--gold6); }

/* ─── TESTIMONIALS ─── */
.testi-grid-v2 { display:grid; grid-template-columns:repeat(auto-fit,minmax(340px,1fr)); gap:2rem; }
.testi-card-v2 {
  background:var(--white);
  border:1px solid var(--border-dim); border-radius:16px; overflow:hidden;
  transition:all 0.38s var(--ease); display:flex; flex-direction:column;
  position:relative; box-shadow:0 4px 20px rgba(15,122,69,0.07);
}
.testi-card-v2::before {
  content:''; position:absolute; top:0; left:0; right:0; height:2px;
  background:linear-gradient(90deg, var(--g6), var(--gold4), var(--g6));
  transform:scaleX(0); transform-origin:left; transition:transform 0.5s var(--ease);
}
.testi-card-v2:hover { border-color:var(--border); transform:translateY(-6px); box-shadow:0 24px 60px rgba(15,122,69,0.14); }
.testi-card-v2:hover::before { transform:scaleX(1); }

.tc2-header {
  display:flex; align-items:center; gap:1.1rem;
  padding:1.6rem 1.8rem 1.2rem;
  background:linear-gradient(135deg, var(--g1), var(--gold1));
  border-bottom:1px solid var(--border-dim);
  position:relative;
}
.tc2-header::after {
  content:'"'; position:absolute; right:1.4rem; top:0.5rem;
  font-family:'Playfair Display', serif; font-size:5.5rem; line-height:1;
  color:var(--g6); opacity:0.08; pointer-events:none;
}
.tc2-photo { width:68px; height:68px; border-radius:50%; object-fit:cover; object-position:top center; border:2px solid var(--border); flex-shrink:0; box-shadow:0 4px 18px rgba(0,0,0,0.1); transition:transform 0.35s var(--ease); }
.testi-card-v2:hover .tc2-photo { transform:scale(1.06); }
.tc2-meta { flex:1; }
.tc2-name { font-family:'Playfair Display', serif; font-size:1.05rem; font-weight:700; color:var(--dark); line-height:1.25; margin-bottom:0.25rem; }
.tc2-title { font-size:0.7rem; color:var(--gold7); font-family:'DM Mono', monospace; letter-spacing:0.8px; line-height:1.5; }
.tc2-org { font-size:0.68rem; color:var(--g6); font-family:'DM Mono', monospace; letter-spacing:0.5px; margin-top:2px; }
.tc2-stars { color:var(--gold5); font-size:0.78rem; letter-spacing:2px; margin-top:6px; display:block; }

.tc2-body { padding:1.5rem 1.8rem; flex:1; display:flex; flex-direction:column; gap:1.1rem; }
.tc2-q { display:flex; flex-direction:column; gap:0.45rem; }
.tc2-q-label {
  font-size:0.6rem; letter-spacing:2.5px; text-transform:uppercase;
  color:var(--g6); font-family:'DM Mono', monospace;
  display:flex; align-items:center; gap:7px;
}
.tc2-q-label::before { content:''; width:14px; height:1px; background:linear-gradient(90deg, var(--g6), var(--gold4)); }
.tc2-q-text { font-family:'Playfair Display', serif; font-style:italic; font-size:0.92rem; color:var(--dark); line-height:1.78; }
.tc2-q-text.truncated { display:-webkit-box; -webkit-line-clamp:4; -webkit-box-orient:vertical; overflow:hidden; }
.tc2-q-text.expanded { -webkit-line-clamp:unset; overflow:visible; display:block; }
.tc2-divider { width:100%; height:1px; background:var(--border-dim); }

.tc2-footer { padding:0.9rem 1.8rem 1.4rem; display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:0.5rem; }
.tc2-expand-btn { background:none; border:1px solid var(--border-dim); color:var(--g6); font-size:0.65rem; font-family:'DM Mono', monospace; letter-spacing:1.5px; text-transform:uppercase; padding:0.35rem 0.9rem; border-radius:20px; cursor:pointer; transition:all 0.22s; display:flex; align-items:center; gap:5px; }
.tc2-expand-btn:hover { background:var(--g6); color:var(--white); border-color:var(--g6); }
.tc2-expand-arrow { transition:transform 0.3s; display:inline-block; }
.tc2-expand-arrow.open { transform:rotate(180deg); }
.tc2-badge { display:inline-flex; align-items:center; gap:5px; font-size:0.6rem; font-family:'DM Mono', monospace; letter-spacing:1.5px; text-transform:uppercase; color:var(--gold7); background:rgba(200,131,26,0.10); border:1px solid rgba(200,131,26,0.22); padding:0.28rem 0.75rem; border-radius:20px; }

/* ─── PARTNERS ─── */
#partners { padding:90px 2rem; background:var(--white); position:relative; z-index:2; overflow:hidden; }
#partners::before { content:''; position:absolute; top:0; left:0; right:0; height:2px; background:linear-gradient(90deg, transparent, var(--g6), var(--gold4), var(--g6), transparent); }
#partners::after { content:''; position:absolute; bottom:-80px; right:-80px; width:350px; height:350px; border-radius:50%; background:radial-gradient(circle, rgba(245,200,66,0.07), transparent 70%); pointer-events:none; }

.partners-intro { display:flex; align-items:flex-end; justify-content:space-between; margin-bottom:3.5rem; flex-wrap:wrap; gap:1.5rem; }
.partners-intro .section-lead { max-width:480px; }

.partners-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:1.2rem; }
.partner-card {
  background:var(--white);
  border:1px solid var(--border-dim); border-radius:var(--br);
  padding:2rem 1.5rem 1.6rem;
  display:flex; flex-direction:column; align-items:flex-start;
  gap:1rem; text-decoration:none;
  position:relative; overflow:hidden;
  transition:all 0.35s var(--ease);
  box-shadow:0 2px 12px rgba(15,122,69,0.05);
}
.partner-card::before { content:''; position:absolute; top:0; left:0; right:0; height:2px; background:linear-gradient(90deg, var(--g6), var(--gold4)); transform:scaleX(0); transform-origin:left; transition:transform 0.4s var(--ease); }
.partner-card::after { content:''; position:absolute; bottom:-30px; right:-30px; width:120px; height:120px; border-radius:50%; background:radial-gradient(circle, rgba(245,200,66,0.08), transparent 70%); pointer-events:none; opacity:0; transition:opacity 0.3s; }
.partner-card:hover { border-color:var(--border); transform:translateY(-5px); box-shadow:0 20px 50px rgba(15,122,69,0.12); }
.partner-card:hover::before { transform:scaleX(1); }
.partner-card:hover::after { opacity:1; }

.pc-badge { display:inline-flex; align-items:center; justify-content:center; width:52px; height:52px; border-radius:12px; background:linear-gradient(135deg, var(--g2), var(--g3)); border:1px solid var(--border); font-size:1.5rem; flex-shrink:0; transition:transform 0.3s var(--ease); }
.partner-card:hover .pc-badge { transform:scale(1.08) rotate(-4deg); }
.pc-abbr { font-family:'DM Mono', monospace; font-size:0.62rem; letter-spacing:2.5px; text-transform:uppercase; color:var(--g6); margin-bottom:0.3rem; }
.pc-name { font-family:'Playfair Display', serif; font-size:1rem; font-weight:700; color:var(--dark); line-height:1.25; margin-bottom:0.4rem; }
.pc-type { font-size:0.72rem; color:var(--gold6); font-family:'DM Mono', monospace; letter-spacing:1px; }
.pc-link-row { display:flex; align-items:center; gap:6px; margin-top:auto; padding-top:1rem; border-top:1px solid var(--border-dim); width:100%; font-size:0.68rem; color:var(--g6); letter-spacing:0.5px; transition:gap 0.2s, color 0.2s; }
.partner-card:hover .pc-link-row { color:var(--g7); gap:10px; }
.pc-link-row svg { width:12px; height:12px; flex-shrink:0; }

.partner-marquee-wrap { margin-top:3rem; overflow:hidden; padding:1rem 0; border-top:1px solid var(--border-dim); position:relative; }
.partner-marquee-wrap::before, .partner-marquee-wrap::after { content:''; position:absolute; top:0; bottom:0; width:80px; z-index:2; pointer-events:none; }
.partner-marquee-wrap::before { left:0; background:linear-gradient(to right, var(--white), transparent); }
.partner-marquee-wrap::after { right:0; background:linear-gradient(to left, var(--white), transparent); }
.partner-marquee { display:flex; gap:3rem; animation:marqueeScroll 22s linear infinite; width:max-content; }
.partner-marquee:hover { animation-play-state:paused; }
@keyframes marqueeScroll { from{transform:translateX(0)} to{transform:translateX(-50%)} }
.pm-item { display:flex; align-items:center; gap:10px; white-space:nowrap; font-family:'DM Mono', monospace; font-size:0.68rem; letter-spacing:2px; text-transform:uppercase; color:var(--text-dim); opacity:0.7; }
.pm-item span { color:var(--g6); font-weight:700; }
.pm-dot { width:4px; height:4px; border-radius:50%; background:var(--gold5); flex-shrink:0; }

/* ─── CONTACT ─── */
.contact-layout { display:grid; grid-template-columns:1fr 1.2fr; gap:5rem; }
.ci-item { display:flex; gap:1.3rem; align-items:flex-start; padding:1.3rem; border:1px solid var(--border-dim); border-radius:var(--br); margin-bottom:1rem; transition:all 0.25s; background:var(--g1); }
.section-dark .ci-item { background:var(--g1); border-color:var(--border-dim); }
.ci-item:hover { border-color:var(--border); background:var(--g2); box-shadow:0 4px 16px rgba(15,122,69,0.08); }
.ci-ico { width:48px; height:48px; border-radius:50%; background:rgba(15,122,69,0.10); border:1px solid var(--border); display:flex; align-items:center; justify-content:center; font-size:1.1rem; flex-shrink:0; }
.ci-txt h4 { font-size:0.58rem; letter-spacing:2.5px; text-transform:uppercase; color:var(--g6); margin-bottom:0.2rem; font-family:'DM Mono', monospace; }
.section-dark .ci-txt h4 { color:var(--g6); }
.ci-txt a, .ci-txt span { font-size:0.87rem; color:var(--dark); text-decoration:none; display:block; }
.section-dark .ci-txt a, .section-dark .ci-txt span { color:var(--dark); }
.ci-txt a:hover { color:var(--g6); }
.ci-txt p { font-size:0.74rem; color:var(--text-dim); margin-top:2px; }

.social-block { padding:1rem 0; }
.social-block p { font-size:0.7rem; color:var(--text-dim); margin-bottom:0.85rem; }
.social-row { display:flex; gap:0.75rem; flex-wrap:wrap; }
.soc { width:46px; height:46px; border-radius:10px; background:var(--g1); border:1px solid var(--border-dim); display:flex; align-items:center; justify-content:center; text-decoration:none; color:var(--text-mid); font-size:0.85rem; font-weight:700; transition:all 0.25s; }
.soc:hover { transform:translateY(-3px); border-color:var(--border); }
.soc-svg { width:46px; height:46px; border-radius:10px; border:1px solid var(--border-dim); display:flex; align-items:center; justify-content:center; text-decoration:none; transition:all 0.25s; flex-shrink:0; background:var(--g1); }
.soc-svg svg { width:20px; height:20px; display:block; }
.soc-svg:hover { transform:translateY(-3px); border-color:var(--border); }
.soc-svg.ig { background:linear-gradient(135deg,#feda75,#fa7e1e,#d62976,#962fbf,#4f5bd5); border-color:transparent; }
.soc-svg.ig:hover { box-shadow:0 8px 22px rgba(214,41,118,0.35); }
.soc-svg.fb { background:#1877f2; border-color:#1877f2; }
.soc-svg.fb:hover { box-shadow:0 8px 22px rgba(24,119,242,0.3); }
.soc-svg.yt { background:#ff0000; border-color:#ff0000; }
.soc-svg.yt:hover { box-shadow:0 8px 22px rgba(255,0,0,0.3); }
.soc-svg.tk { background:linear-gradient(180deg,#69c9d0,#ee1d52); border-color:transparent; }
.soc-svg.tk:hover { box-shadow:0 8px 22px rgba(238,29,82,0.25); }
.soc-svg.tw { background:#1da1f2; border-color:#1da1f2; }
.soc-svg.tw:hover { box-shadow:0 8px 22px rgba(29,161,242,0.25); }

.map-box { background:var(--g1); border:1px solid var(--border-dim); border-radius:var(--br); height:180px; display:flex; align-items:center; justify-content:center; margin-top:1.3rem; }
.map-inner { text-align:center; display:flex; flex-direction:column; gap:4px; }
.map-inner span { font-size:2rem; }
.map-inner strong { color:var(--dark); font-size:1rem; }
.section-dark .map-inner strong { color:var(--dark); }
.map-inner small { color:var(--text-dim); font-size:0.75rem; }

.contact-right h3 { font-family:'Playfair Display', serif; color:var(--dark); font-size:1.35rem; font-weight:600; margin-bottom:1.8rem; }
.section-dark .contact-right h3 { color:var(--dark); }

/* ─── FOOTER ─── */
footer { background:var(--g8); border-top:2px solid var(--g7); padding:5rem 2rem 2.5rem; position:relative; z-index:2; }
footer::before { content:''; position:absolute; top:0; left:0; right:0; height:2px; background:linear-gradient(90deg, transparent, var(--g6), var(--gold4), var(--g6), transparent); }
.footer-inner { max-width:1260px; margin:0 auto; display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr; gap:3rem; margin-bottom:3.5rem; }
.fb-logo { display:flex; align-items:center; gap:10px; margin-bottom:0.9rem; }
.fb-drum { width:40px; height:40px; background:linear-gradient(135deg,var(--g6),var(--g5)); border-radius:50%; display:flex; align-items:center; justify-content:center; box-shadow:0 0 16px var(--glow); }
.fb-name { font-family:'Playfair Display', serif; font-weight:700; font-size:1.05rem; color:var(--g3); }
.fb-sub { font-size:0.54rem; letter-spacing:2px; text-transform:uppercase; color:var(--g5); font-family:'DM Mono', monospace; }
.footer-brand p { font-size:0.79rem; color:var(--g5); line-height:1.75; margin-top:0.5rem; }
.footer-col h4 { font-family:'DM Mono', monospace; font-size:0.6rem; letter-spacing:2.5px; text-transform:uppercase; color:var(--gold4); margin-bottom:1.2rem; }
.footer-col ul { list-style:none; }
.footer-col li { margin-bottom:0.55rem; }
.footer-col a { text-decoration:none; color:var(--g5); font-size:0.81rem; transition:color 0.2s; }
.footer-col a:hover { color:var(--gold4); }
.footer-bottom { max-width:1260px; margin:0 auto; padding-top:2rem; border-top:1px solid rgba(255,255,255,0.08); display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:0.5rem; }
.footer-bottom p { font-size:0.7rem; color:var(--g5); }

/* ─── ANNOUNCEMENT BAR ─── */
.announce-bar {
  position:fixed; top:0; left:0; right:0; z-index:1001;
  background:linear-gradient(90deg, var(--g7), var(--g6), var(--gold6), var(--g6), var(--g7));
  background-size:300% 100%;
  animation:gradShift 6s ease infinite;
  padding:7px 2rem;
  display:flex; align-items:center; justify-content:center; gap:1rem;
  font-size:0.65rem; letter-spacing:2px; text-transform:uppercase;
  color:var(--white); font-family:'DM Mono', monospace;
}
@keyframes gradShift { 0%,100%{background-position:0% 50%} 50%{background-position:100% 50%} }
.announce-bar .ab-dot { width:6px; height:6px; border-radius:50%; background:var(--gold3); animation:abPulse 1.6s ease-in-out infinite; flex-shrink:0; }
@keyframes abPulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:0.4;transform:scale(0.7)} }
.announce-bar a { color:var(--gold3); text-decoration:none; font-weight:700; border-bottom:1px solid rgba(255,224,128,0.4); padding-bottom:1px; transition:color 0.2s; }
.announce-bar a:hover { color:var(--white); }
.ab-close { position:absolute; right:1.2rem; background:none; border:none; cursor:pointer; color:rgba(255,255,255,0.6); font-size:0.9rem; line-height:1; transition:color 0.2s; padding:0; }
.ab-close:hover { color:var(--white); }
body.has-announce nav { top:32px; }
body.has-announce .hero { padding-top:132px; }

/* ─── NAV ACTIVE INDICATOR ─── */
.nav-links li:not(:last-child) > a { position:relative; }
.nav-links li:not(:last-child) > a::after { content:''; position:absolute; bottom:2px; left:50%; right:50%; height:1.5px; background:linear-gradient(90deg, var(--g6), var(--gold5)); transition:left 0.3s var(--ease), right 0.3s var(--ease); border-radius:1px; max-width:calc(100% - 1.6rem); }
.nav-links li:not(:last-child) > a:hover::after, .nav-links li:not(:last-child) > a.active::after { left:0.8rem; right:0.8rem; }
nav:not(.scrolled) .nav-links li:not(:last-child) > a::after { background:linear-gradient(90deg, rgba(255,255,255,0.6), var(--gold4)); }

/* ─── DONATE OVERLAY ─── */
.donate-overlay { display:none; position:fixed; inset:0; z-index:9000; background:rgba(5,41,24,0.80); backdrop-filter:blur(16px); overflow-y:auto; align-items:stretch; justify-content:center; padding:2rem; }
.donate-overlay.open { display:flex; animation:fadeIn 0.35s ease; }
.do-left { width:360px; flex-shrink:0; background:linear-gradient(170deg, var(--g8) 0%, var(--g7) 55%, var(--g8) 100%); border-right:1px solid rgba(255,255,255,0.10); padding:3rem 2rem; position:relative; display:flex; flex-direction:column; border-radius:16px 0 0 16px; max-height:calc(100vh - 4rem); overflow-y:auto; min-height:0; }
.do-left::before { content:''; position:absolute; top:0; left:0; right:0; height:2px; background:linear-gradient(90deg,transparent,var(--g5),var(--gold4),transparent); }
.do-left-inner { margin-top:2rem; }
.do-close-x { position:absolute; top:1.5rem; left:1.5rem; background:none; border:1px solid rgba(255,255,255,0.2); color:rgba(255,255,255,0.7); font-size:0.9rem; width:34px; height:34px; border-radius:50%; cursor:pointer; display:flex; align-items:center; justify-content:center; transition:all 0.2s; }
.do-close-x:hover { background:var(--g6); color:var(--white); border-color:var(--g6); }
.do-logo { font-size:2.8rem; margin-bottom:1rem; }
.do-left h2 { font-family:'Playfair Display', serif; font-weight:700; font-size:1.7rem; color:var(--white); margin-bottom:0.8rem; line-height:1.15; }
.do-left h2 em { font-style:italic; color:var(--gold4); }
.do-lead { font-size:0.9rem; color:var(--g3); line-height:1.85; margin-bottom:2rem; font-weight:300; }
.do-reasons { display:flex; flex-direction:column; gap:1.25rem; margin-bottom:2rem; }
.do-reason { display:flex; gap:0.9rem; align-items:flex-start; }
.do-reason > span { font-size:1.4rem; flex-shrink:0; margin-top:1px; }
.do-reason strong { display:block; font-size:0.87rem; color:var(--white); margin-bottom:0.2rem; }
.do-reason p { font-size:0.77rem; color:var(--g4); line-height:1.6; }
.do-quote { font-family:'Playfair Display', serif; font-style:italic; font-size:0.93rem; color:var(--gold4); border-left:2px solid var(--gold5); padding-left:1rem; line-height:1.7; margin-top:auto; }

.do-right { position:relative; flex:1; padding:4.5rem 3rem 2.8rem; overflow-y:auto; display:flex; flex-direction:column; justify-content:flex-start; max-width:720px; min-width:320px; max-height:calc(100vh - 4rem); min-height:0; background:#ffffff; color:#111; border-radius:0 16px 16px 0; box-shadow:0 32px 100px rgba(0,0,0,0.2); }
.do-close-mobile { display:none; align-self:flex-end; margin-bottom:1.5rem; background:none; border:1px solid #ccc; color:#666; font-size:0.72rem; letter-spacing:1px; padding:0.4rem 0.9rem; border-radius:20px; cursor:pointer; transition:all 0.2s; }
.do-close-mobile:hover { border-color:#333; color:#111; }
.do-back-home { display:inline-flex; align-items:center; gap:0.4rem; color:#111; font-size:0.92rem; font-weight:700; text-decoration:none; padding:0.7rem 1rem; border:1px solid rgba(0,0,0,0.1); background:#fff; border-radius:999px; box-shadow:0 4px 20px rgba(0,0,0,0.08); position:absolute; top:1.2rem; left:2.5rem; z-index:2; transition:all 0.2s; }
.do-back-home:hover { background:#111; color:#fff; }

.do-step-label { font-size:0.6rem; letter-spacing:3px; text-transform:uppercase; color:var(--g6); margin-bottom:0.75rem; font-family:'DM Mono', monospace; }
.do-step h3 { font-family:'Playfair Display', serif; font-weight:700; font-size:1.5rem; color:black; margin-bottom:1.5rem; }
.do-freq-toggle { display:flex; gap:0; margin-bottom:1.5rem; background:#f2f2f2; border:1px solid #ddd; border-radius:3px; padding:3px; width:fit-content; }
.dft { padding:0.5rem 1.4rem; border:none; border-radius:2px; font-family:'Plus Jakarta Sans',sans-serif; font-weight:700; font-size:0.7rem; letter-spacing:1px; text-transform:uppercase; cursor:pointer; background:transparent; color:#777; transition:all 0.2s; }
.dft.active { background:linear-gradient(135deg, var(--g6), var(--g7)); color:#fff; }

.do-presets { display:grid; grid-template-columns:repeat(3,1fr); gap:0.75rem; margin-bottom:1rem; }
.dpreset { background:#f5fdf8; border:1px solid #c0e8cc; color:black; border-radius:2px; padding:0.88rem 0.5rem; cursor:pointer; font-family:'Playfair Display',serif; font-weight:700; font-size:1.15rem; display:flex; flex-direction:column; align-items:center; gap:2px; transition:all 0.2s; }
.dpreset small { font-size:0.62rem; font-weight:400; color:#555; font-family:'Plus Jakarta Sans',sans-serif; }
.dpreset:hover { border-color:var(--g6); }
.dpreset.active { background:linear-gradient(135deg,var(--g6),var(--g7)); border-color:transparent; color:white; }
.custom-preset { font-size:0.82rem !important; font-family:'Plus Jakarta Sans',sans-serif !important; font-weight:600 !important; color:#888 !important; }
.custom-preset.active { color:white !important; }

.do-custom-wrap { display:flex; align-items:center; background:#f5fdf8; border:1px solid #c0e8cc; border-radius:2px; overflow:hidden; margin-bottom:1.2rem; transition:border-color 0.2s; }
.do-custom-wrap:focus-within { border-color:var(--g6); }
.do-currency { padding:0 1rem; font-family:'Playfair Display',serif; font-size:1.15rem; font-weight:700; color:#555; border-right:1px solid #c0e8cc; background:#e8f5ec; }
.do-custom-wrap input { border:none; background:transparent; font-family:'Playfair Display',serif; font-weight:700; font-size:1.15rem; color:black; padding:0.88rem 1rem; flex:1; }
.do-custom-wrap input:focus { outline:none; }

.do-impact-hint { display:flex; gap:0.75rem; align-items:center; background:#f0faf4; border:1px solid #b8e8c8; border-radius:2px; padding:0.88rem 1rem; margin-bottom:1.5rem; }
.dih-icon { font-size:1.2rem; }
#dihText { font-size:0.8rem; color:#444; line-height:1.5; }
.do-next-btn { width:100%; justify-content:center; font-size:0.85rem; padding:1rem; }

.do-summary-bar { display:flex; justify-content:space-between; align-items:center; background:#f0faf4; border:1px solid #b8e8c8; border-radius:2px; padding:0.88rem 1.2rem; margin-bottom:1.5rem; }
.do-summary-bar span { font-size:0.9rem; color:black; }
.do-summary-bar strong { color:var(--g6); }
.do-edit-btn { background:none; border:none; color:var(--g6); font-size:0.72rem; font-weight:700; cursor:pointer; }

.do-fields { margin-bottom:1.5rem; }
.do-fields .fg { margin-bottom:1.1rem; }
.do-fields label { color:#111; font-weight:800; }
.do-fields input, .do-fields textarea, .do-fields select { background:white; color:black; border:1px solid #ccc; }
.do-fields input:focus, .do-fields textarea:focus, .do-fields select:focus { border-color:var(--g6); }

.do-pay-label { font-size:0.6rem; letter-spacing:2px; text-transform:uppercase; color:#111; margin-bottom:0.75rem; font-weight:800; font-family:'DM Mono', monospace; }
.do-pay-tabs { display:flex; gap:0.75rem; margin-bottom:1.5rem; flex-wrap:wrap; }
.dpt { flex:1; min-width:120px; display:flex; flex-direction:column; align-items:center; gap:6px; background:#f5fdf8; border:1px solid #b8e8c8; color:#1a4a30; border-radius:12px; padding:0.95rem 0.8rem; font-family:'Plus Jakarta Sans',sans-serif; font-weight:700; font-size:0.72rem; letter-spacing:0.8px; cursor:pointer; transition:all 0.22s; }
.dpt span { font-size:1.2rem; }
.dpt:hover { transform:translateY(-1px); border-color:var(--g6); }
.dpt.active { background:var(--g8); border-color:var(--g6); color:#fff; box-shadow:0 8px 30px rgba(15,122,69,0.2); }

.do-pay-panel { background:#f8fdf9; border:1px solid #c0e8cc; border-radius:12px; padding:1.5rem; margin-bottom:1.5rem; }
.pay-instruction { display:flex; flex-direction:column; gap:0.6rem; margin-bottom:1.2rem; }
.pi-step { display:flex; gap:0.85rem; align-items:flex-start; font-size:0.82rem; color:#555; }
.pi-step span { width:22px; height:22px; flex-shrink:0; background:linear-gradient(135deg,var(--g6),var(--gold6)); color:#fff; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:0.65rem; font-weight:800; margin-top:1px; }
.pi-step strong { color:#111; }
.pi-num { color:var(--g6); font-family:'DM Mono', monospace; font-size:0.95rem; }
.pi-copy-row { display:flex; gap:0.75rem; flex-wrap:wrap; }
.pi-copy-box { flex:1; min-width:140px; background:white; border:1px solid #c0e8cc; border-radius:4px; padding:1rem; display:flex; flex-direction:column; gap:3px; }
.pi-copy-box.wide { flex:2; }
.pi-copy-box span { font-size:0.6rem; letter-spacing:2px; text-transform:uppercase; color:#888; }
.pi-copy-box strong { font-family:'DM Mono', monospace; color:var(--g7); font-size:0.9rem; word-break:break-all; }
.do-bank-meta { margin-bottom:1rem; }
.do-bank-meta label { display:block; font-size:0.72rem; font-weight:700; color:#111; margin-bottom:0.35rem; }
.do-bank-meta select { width:100%; padding:0.9rem; border-radius:2px; border:1px solid #ccc; background:white; color:#111; }
.copy-btn { margin-top:0.35rem; align-self:flex-start; background:#e8f5ec; border:1px solid #a0d0b0; color:var(--g7); font-size:0.62rem; letter-spacing:1px; text-transform:uppercase; padding:0.25rem 0.65rem; border-radius:20px; cursor:pointer; font-weight:700; transition:all 0.2s; }
.copy-btn:hover { background:var(--g6); color:#fff; border-color:var(--g6); }
.copy-btn.copied { background:#1a4a2a; border-color:#2d7a4a; color:#5aba82; }
.do-secure-note { text-align:center; font-size:0.72rem; color:#999; margin-top:0.85rem; }
.do-thankyou { text-align:center; padding:2rem 0; }
.dty-anim { font-size:4rem; margin-bottom:1.5rem; animation:heartPop 0.6s cubic-bezier(0.175,0.885,0.32,1.275) both; }
@keyframes heartPop { 0%{transform:scale(0)} 80%{transform:scale(1.2)} 100%{transform:scale(1)} }
.do-thankyou h3 { font-family:'Playfair Display',serif; font-size:2rem; font-weight:700; color:#111; margin-bottom:1rem; }
.do-thankyou p { font-size:0.9rem; color:#555; line-height:1.7; margin-bottom:1.5rem; }
.dty-next { background:#f0faf4; border:1px solid #b8e8c8; border-radius:4px; padding:1.2rem; margin-bottom:1.5rem; text-align:left; }
.dty-next strong { display:block; color:var(--g6); font-size:0.8rem; margin-bottom:0.35rem; }
.dty-next p { font-size:0.8rem; color:#555; line-height:1.6; }
.dty-share p { font-size:0.78rem; color:#888; }

/* ─── FLOATING WHATSAPP ─── */
.wa-float { position:fixed; bottom:5.5rem; right:2.5rem; z-index:499; width:52px; height:52px; border-radius:50%; background:linear-gradient(135deg,#25d366,#128C7E); display:flex; align-items:center; justify-content:center; box-shadow:0 4px 20px rgba(37,211,102,0.4); text-decoration:none; cursor:pointer; transition:all 0.25s var(--ease); animation:waWiggle 4s ease-in-out infinite; }
.wa-float:hover { transform:scale(1.1); box-shadow:0 8px 30px rgba(37,211,102,0.55); animation:none; }
.wa-float svg { width:26px; height:26px; fill:#fff; }
@keyframes waWiggle { 0%,90%,100%{transform:rotate(0deg) scale(1)} 92%{transform:rotate(-8deg) scale(1.05)} 96%{transform:rotate(8deg) scale(1.05)} 98%{transform:rotate(-4deg) scale(1.02)} }
.wa-tooltip { position:absolute; right:62px; top:50%; transform:translateY(-50%); background:var(--g8); color:var(--g3); border:1px solid rgba(15,122,69,0.25); font-size:0.7rem; font-family:'DM Mono', monospace; letter-spacing:1px; padding:5px 10px; border-radius:4px; white-space:nowrap; opacity:0; pointer-events:none; transition:opacity 0.2s; }
.wa-float:hover .wa-tooltip { opacity:1; }

/* ─── BACK TO TOP ─── */
.back-top { position:fixed; bottom:2.5rem; right:2.5rem; z-index:500; width:44px; height:44px; border-radius:50%; background:linear-gradient(135deg,var(--g6),var(--gold6)); color:#fff; border:none; cursor:pointer; font-size:1rem; display:none; align-items:center; justify-content:center; box-shadow:0 4px 20px var(--glow); transition:all 0.25s; }
.back-top:hover { transform:translateY(-3px); box-shadow:0 8px 30px var(--glow); }
.back-top.show { display:flex; }

/* ─── ANIMATIONS ─── */
@keyframes fadeIn { from{opacity:0} to{opacity:1} }
.reveal-up { opacity:0; transform:translateY(36px); transition:opacity 0.75s var(--ease), transform 0.75s var(--ease); transition-delay:var(--d,0s); }
.reveal-left { opacity:0; transform:translateX(-36px); transition:opacity 0.75s var(--ease), transform 0.75s var(--ease); }
.reveal-right { opacity:0; transform:translateX(36px); transition:opacity 0.75s var(--ease), transform 0.75s var(--ease); }
.visible { opacity:1 !important; transform:none !important; }

/* ─── RESPONSIVE ─── */
@media (max-width:1100px) {
  .two-col { grid-template-columns:1fr; gap:4rem; }
  .visual-stack { height:360px; }
  .portfolio-grid { grid-template-columns:1fr 1fr; }
  .port-card.featured { grid-column:span 2; grid-row:auto; }
  .partners-grid { grid-template-columns:repeat(2,1fr); }
}
@media (max-width:900px) {
  nav { padding:0 1.5rem; }
  .nav-links { display:none; flex-direction:column; position:absolute; top:70px; left:0; right:0; background:rgba(255,255,255,0.98); padding:1.5rem 2rem; border-bottom:1px solid var(--border); gap:0.2rem; backdrop-filter:blur(20px); box-shadow:0 8px 30px rgba(15,122,69,0.10); }
  .nav-links a { color:var(--text-mid) !important; }
  .nav-links.open { display:flex; }
  .hamburger { display:flex; }
  .book-layout, .contact-layout, .events-layout { grid-template-columns:1fr; gap:3rem; }
  .gallery-masonry { grid-template-columns:repeat(2,1fr); }
  .gitem.wide { grid-column:span 1; }
  .footer-inner { grid-template-columns:1fr 1fr; gap:2.5rem; }
  .portfolio-grid { grid-template-columns:1fr; }
  .port-card.featured { grid-column:auto; }
  .expect-row { flex-direction:column; gap:1.5rem; }
  .ex-arr { display:none; }
  .team-grid-3 { grid-template-columns:1fr; max-width:480px; margin-left:auto; margin-right:auto; }
  .donate-overlay { flex-direction:column; }
  .do-left { width:100%; padding:2rem 1.5rem; border-right:none; border-bottom:1px solid rgba(255,255,255,0.10); border-radius:16px 16px 0 0; }
  .do-left .do-close-x { display:none; }
  .do-right { padding:2rem 1.5rem; max-width:100%; border-radius:0 0 16px 16px; }
  .do-close-mobile { display:block; }
  .do-reasons { display:grid; grid-template-columns:1fr 1fr; gap:0.85rem; }
  .do-quote { display:none; }
  .do-back-home { left:1.5rem; top:1rem; }
  .partners-grid { grid-template-columns:1fr 1fr; }
}
@media (min-width:600px) and (max-width:900px) {
  .team-grid-3 { grid-template-columns:repeat(2,1fr); max-width:100%; }
}
@media (max-width:600px) {
  .section { padding:75px 1.3rem; }
  .hero { padding:85px 1.3rem 70px; }
  .hero-h1 { font-size:3.2rem; }
  .hero-stats { padding:1rem; }
  .hstat { padding:0 0.75rem; }
  .hstat strong { font-size:1.5rem; }
  .gallery-masonry { grid-template-columns:1fr 1fr; grid-auto-rows:150px; }
  .footer-inner { grid-template-columns:1fr; gap:2rem; }
  .footer-bottom { flex-direction:column; text-align:center; }
  .form-row { grid-template-columns:1fr; }
  .mini-cards { grid-template-columns:1fr; }
  .do-presets { grid-template-columns:repeat(2,1fr); }
  .do-reasons { grid-template-columns:1fr; }
  .pi-copy-row { flex-direction:column; }
  .scroll-hint { display:none; }
  .hero-orb1, .hero-orb2 { display:none; }
  .partners-grid { grid-template-columns:1fr; }
  .testi-grid-v2 { grid-template-columns:1fr; }
  .tc2-header { padding:1.3rem; }
  .tc2-body { padding:1.2rem; }
  .tc2-footer { padding:0.8rem 1.2rem 1.2rem; }
}