/* =====================================================================
   TOUT BAGAY PATWA — Cultural Landing Page Stylesheet
   Design system: Madras plaid + Caribbean sunset palette
   Author: Tout Bagay Patwa digital team
   Structure: 1) Tokens  2) Base  3) Layout  4) Components  5) Sections
              6) Motion  7) Responsive
   ===================================================================== */

/* ============================ 1. DESIGN TOKENS ====================== */
:root,
[data-theme="light"] {
  /* ---- Fluid type scale ---- */
  --text-xs:   clamp(0.75rem, 0.7rem + 0.25vw, 0.875rem);
  --text-sm:   clamp(0.875rem, 0.8rem + 0.35vw, 1rem);
  --text-base: clamp(1rem, 0.95rem + 0.25vw, 1.125rem);
  --text-lg:   clamp(1.125rem, 1rem + 0.75vw, 1.5rem);
  --text-xl:   clamp(1.5rem, 1.2rem + 1.25vw, 2.25rem);
  --text-2xl:  clamp(2rem, 1.2rem + 2.5vw, 3.5rem);
  --text-3xl:  clamp(2.5rem, 1rem + 4vw, 5rem);
  --text-hero: clamp(2.75rem, 0.5rem + 7vw, 7rem);

  /* ---- Spacing (4px base) ---- */
  --space-1: 0.25rem;  --space-2: 0.5rem;  --space-3: 0.75rem;
  --space-4: 1rem;     --space-5: 1.25rem; --space-6: 1.5rem;
  --space-8: 2rem;     --space-10: 2.5rem; --space-12: 3rem;
  --space-16: 4rem;    --space-20: 5rem;   --space-24: 6rem;
  --space-32: 8rem;

  /* ---- Caribbean Sunset / Madras Palette ---- */
  --c-coral:    #e8442e;   /* flamboyant red */
  --c-coral-dk: #b8281a;
  --c-orange:   #f08a1d;   /* marigold */
  --c-gold:     #f5b720;   /* sun gold */
  --c-pink:     #e23b86;   /* madras hot pink */
  --c-magenta:  #b5267d;
  --c-green:    #1f8a52;   /* tropical green */
  --c-teal:     #0e8a8a;
  --c-purple:   #6c3aa6;   /* royal purple */
  --c-cream:    #fdf6ea;

  /* ---- Surfaces (warm cream) ---- */
  --color-bg:            #fdf6ea;
  --color-surface:       #fffaf2;
  --color-surface-2:     #fffdf9;
  --color-surface-offset:#f6ead6;
  --color-surface-deep:  #2a1410;   /* dark warm brown for contrast sections */

  /* ---- Text ---- */
  --color-text:        #2a1813;
  --color-text-muted:  #7a5c4f;
  --color-text-faint:  #b39b8e;
  --color-text-inverse:#fdf6ea;

  /* ---- Roles ---- */
  --color-primary:       var(--c-coral);
  --color-primary-hover: var(--c-coral-dk);
  --color-accent:        var(--c-teal);
  --color-border:        #e7d6bf;
  --color-divider:       #efe2cc;

  /* ---- Radius / shadow / motion ---- */
  --radius-sm: 0.5rem; --radius-md: 0.875rem; --radius-lg: 1.25rem;
  --radius-xl: 1.75rem; --radius-full: 9999px;
  --shadow-sm: 0 1px 3px rgba(70,30,10,0.08);
  --shadow-md: 0 8px 24px rgba(70,30,10,0.12);
  --shadow-lg: 0 20px 50px rgba(70,30,10,0.18);
  --shadow-warm: 0 12px 40px rgba(232,68,46,0.22);
  --transition: 220ms cubic-bezier(0.16,1,0.3,1);

  /* ---- Widths ---- */
  --content-narrow: 680px;
  --content-default: 1080px;
  --content-wide: 1280px;

  /* ---- Fonts ---- */
  --font-display: 'Clash Display', 'Georgia', serif;
  --font-script:  'Caveat', cursive;
  --font-body:    'General Sans', 'Helvetica Neue', sans-serif;

  /* ---- Madras gradient ---- */
  --grad-sunset: linear-gradient(120deg, var(--c-coral), var(--c-orange) 45%, var(--c-gold));
  --grad-madras: linear-gradient(90deg, var(--c-pink), var(--c-orange), var(--c-gold), var(--c-green), var(--c-teal), var(--c-purple));
}

[data-theme="dark"] {
  --color-bg:            #1a0f0c;
  --color-surface:       #221512;
  --color-surface-2:     #2a1a16;
  --color-surface-offset:#2e1d18;
  --color-surface-deep:  #150b09;
  --color-text:        #f3e6d8;
  --color-text-muted:  #c0a596;
  --color-text-faint:  #8a6f60;
  --color-text-inverse:#1a0f0c;
  --color-primary:       #f5663f;
  --color-primary-hover: #ff7a55;
  --color-accent:        #3fb5b5;
  --color-border:        #3d2820;
  --color-divider:       #34221c;
  --shadow-sm: 0 1px 3px rgba(0,0,0,0.4);
  --shadow-md: 0 8px 24px rgba(0,0,0,0.5);
  --shadow-lg: 0 20px 50px rgba(0,0,0,0.6);
  --shadow-warm: 0 12px 40px rgba(245,102,63,0.28);
}

@media (prefers-color-scheme: dark) {
  :root:not([data-theme]) {
    --color-bg:#1a0f0c; --color-surface:#221512; --color-surface-2:#2a1a16;
    --color-surface-offset:#2e1d18; --color-surface-deep:#150b09;
    --color-text:#f3e6d8; --color-text-muted:#c0a596; --color-text-faint:#8a6f60;
    --color-text-inverse:#1a0f0c; --color-primary:#f5663f; --color-primary-hover:#ff7a55;
    --color-accent:#3fb5b5; --color-border:#3d2820; --color-divider:#34221c;
  }
}

/* ============================ 2. BASE ============================== */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }

html {
  -webkit-text-size-adjust:none; text-size-adjust:none;
  -webkit-font-smoothing:antialiased; -moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility; scroll-behavior:smooth;
  scroll-padding-top:5rem;
}
body {
  min-height:100dvh; line-height:1.65;
  font-family:var(--font-body); font-size:var(--text-base);
  color:var(--color-text); background:var(--color-bg);
  overflow-x:hidden;
}
img,picture,video,svg { display:block; max-width:100%; height:auto; }
ul[role="list"] { list-style:none; }
input,button,textarea,select { font:inherit; color:inherit; }
h1,h2,h3,h4 { text-wrap:balance; line-height:1.1; font-family:var(--font-display); font-weight:600; }
p,li { text-wrap:pretty; }
a { color:inherit; }
button { cursor:pointer; background:none; border:none; }

::selection { background:rgba(232,68,46,0.22); color:var(--color-text); }
:focus-visible { outline:3px solid var(--color-primary); outline-offset:3px; border-radius:var(--radius-sm); }

a,button,input,textarea,select {
  transition:color var(--transition),background var(--transition),
             border-color var(--transition),box-shadow var(--transition),
             transform var(--transition);
}
.sr-only {
  position:absolute; width:1px; height:1px; padding:0; margin:-1px;
  overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0;
}
@media (prefers-reduced-motion:reduce) {
  *,*::before,*::after {
    animation-duration:.01ms !important; animation-iteration-count:1 !important;
    transition-duration:.01ms !important; scroll-behavior:auto !important;
  }
}

/* ============================ 3. LAYOUT ============================ */
.wrap { width:min(100% - 2.5rem, var(--content-default)); margin-inline:auto; }
.wrap--wide { width:min(100% - 2.5rem, var(--content-wide)); }
.wrap--narrow { width:min(100% - 2.5rem, var(--content-narrow)); }
.section { padding-block:clamp(var(--space-16), 9vw, var(--space-32)); position:relative; }
.section--tight { padding-block:clamp(var(--space-12),6vw,var(--space-20)); }

.eyebrow {
  display:inline-flex; align-items:center; gap:var(--space-2);
  font-size:var(--text-sm); font-weight:600; letter-spacing:0.14em;
  text-transform:uppercase; color:var(--color-primary);
}
.eyebrow::before {
  content:""; width:28px; height:3px; border-radius:9999px;
  background:var(--grad-madras);
}
.section-title {
  font-size:var(--text-2xl); margin-block:var(--space-4) var(--space-3);
  letter-spacing:-0.01em;
}
.section-title .kreyol { color:var(--color-primary); }
.section-lead {
  font-size:var(--text-lg); color:var(--color-text-muted);
  max-width:60ch; line-height:1.6;
}

/* ============================ 4. COMPONENTS ======================== */
.btn {
  display:inline-flex; align-items:center; justify-content:center; gap:var(--space-2);
  padding:var(--space-3) var(--space-6); font-size:var(--text-sm); font-weight:600;
  border-radius:var(--radius-full); text-decoration:none; line-height:1;
  border:2px solid transparent;
}
.btn--primary {
  background:var(--grad-sunset); color:#fff;
  box-shadow:var(--shadow-warm);
}
.btn--primary:hover { transform:translateY(-2px); box-shadow:0 16px 44px rgba(232,68,46,0.34); }
.btn--ghost {
  background:transparent; color:var(--color-text);
  border-color:var(--color-border);
}
.btn--ghost:hover { border-color:var(--color-primary); color:var(--color-primary); transform:translateY(-2px); }
.btn--light { background:#fff; color:var(--c-coral-dk); }
.btn--light:hover { transform:translateY(-2px); box-shadow:var(--shadow-lg); }

/* Madras divider strip */
.madras-strip {
  height:14px; width:100%;
  background-image:url("../img/madras-ribbon.jpg");
  background-size:auto 100%; background-repeat:repeat-x;
}

/* Card */
.card {
  background:var(--color-surface); border:1px solid var(--color-border);
  border-radius:var(--radius-lg); overflow:hidden; position:relative;
  box-shadow:var(--shadow-sm);
}

/* ============================ 5. HEADER =========================== */
.header {
  position:fixed; inset:0 0 auto 0; z-index:100;
  background:color-mix(in oklab, var(--color-bg) 88%, transparent);
  backdrop-filter:blur(14px) saturate(1.2);
  border-bottom:1px solid transparent;
  transition:transform .35s cubic-bezier(0.16,1,0.3,1),
             background .3s, border-color .3s;
}
.header--scrolled { border-bottom-color:var(--color-divider); box-shadow:var(--shadow-sm); }
.header--hidden { transform:translateY(-100%); }
.header__inner {
  display:flex; align-items:center; justify-content:space-between;
  gap:var(--space-4); padding-block:var(--space-3);
}
.brand { display:flex; align-items:center; gap:var(--space-3); text-decoration:none; color:var(--color-text); }
.brand__mark { width:42px; height:42px; flex-shrink:0; }
.brand__name { font-family:var(--font-display); font-weight:600; font-size:var(--text-lg); line-height:1; letter-spacing:-0.01em; }
.brand__tag { display:block; font-family:var(--font-body); font-size:var(--text-xs); color:var(--color-text-muted); letter-spacing:0.06em; font-weight:500; }
.nav { display:flex; align-items:center; gap:var(--space-6); }
.nav a { font-size:var(--text-sm); font-weight:500; text-decoration:none; color:var(--color-text-muted); }
.nav a:hover { color:var(--color-primary); }
.header__actions { display:flex; align-items:center; gap:var(--space-3); }
.icon-btn {
  width:42px; height:42px; display:grid; place-items:center;
  border-radius:var(--radius-full); color:var(--color-text);
  border:1px solid var(--color-border);
}
.icon-btn:hover { color:var(--color-primary); border-color:var(--color-primary); }
.menu-toggle { display:none; }

/* ============================ 6. HERO ============================= */
.hero {
  position:relative; min-height:100svh; display:grid; align-items:center;
  padding-top:6rem; overflow:hidden;
}
.hero__bg {
  position:absolute; inset:0; z-index:0;
}
.hero__bg img { width:100%; height:100%; object-fit:cover; object-position:center; }
.hero__overlay {
  position:absolute; inset:0; z-index:1;
  background:
    linear-gradient(105deg,
      rgba(26,10,8,0.92) 0%,
      rgba(40,16,10,0.78) 38%,
      rgba(40,16,10,0.30) 64%,
      rgba(40,16,10,0.12) 100%);
}
[data-theme="dark"] .hero__overlay {
  background:linear-gradient(105deg, rgba(10,5,4,0.95) 0%, rgba(15,8,6,0.85) 40%, rgba(15,8,6,0.45) 70%, rgba(15,8,6,0.25) 100%);
}
.hero__inner { position:relative; z-index:2; padding-block:var(--space-16); }
.hero__content { max-width:42rem; color:#fff; }
.badge-soon {
  display:inline-flex; align-items:center; gap:var(--space-2);
  padding:var(--space-2) var(--space-4); border-radius:var(--radius-full);
  background:rgba(255,255,255,0.12); border:1px solid rgba(255,255,255,0.28);
  backdrop-filter:blur(6px); font-size:var(--text-sm); font-weight:600;
  letter-spacing:0.08em; text-transform:uppercase; color:#fff;
  margin-bottom:var(--space-6);
}
.badge-soon .dot { width:9px; height:9px; border-radius:50%; background:var(--c-gold); box-shadow:0 0 0 0 rgba(245,183,32,0.7); animation:pulse 2.2s infinite; }
.hero__logo-slot {
  display:inline-flex; align-items:center; gap:var(--space-3);
  margin-bottom:var(--space-6);
}
.hero h1 {
  font-size:var(--text-hero); line-height:1.02; letter-spacing:-0.02em;
  margin-bottom:var(--space-5); color:#fff;
}
.hero h1 .accent {
  background:linear-gradient(110deg, var(--c-gold), var(--c-orange), var(--c-pink));
  -webkit-background-clip:text; background-clip:text; color:transparent;
}
.hero__sub { font-family:var(--font-script); font-size:var(--text-xl); color:var(--c-gold); margin-bottom:var(--space-5); line-height:1.2; }
.hero__lead { font-size:var(--text-lg); color:rgba(255,255,255,0.9); max-width:38rem; margin-bottom:var(--space-8); line-height:1.6; }
.hero__cta { display:flex; flex-wrap:wrap; gap:var(--space-3); align-items:center; }
.hero__scroll {
  position:absolute; left:50%; bottom:var(--space-6); transform:translateX(-50%);
  z-index:3; color:rgba(255,255,255,0.8); font-size:var(--text-xs);
  letter-spacing:0.18em; text-transform:uppercase; text-align:center;
  display:flex; flex-direction:column; align-items:center; gap:var(--space-2);
}
.hero__scroll svg { animation:bob 1.8s ease-in-out infinite; }

/* hero brand logo mark (CMS-replaceable) */
.hero__logo-mark {
  width:74px; height:74px; display:block;
  filter:drop-shadow(0 6px 18px rgba(0,0,0,0.35));
}
@media (max-width:560px){ .hero__logo-mark { width:60px; height:60px; } }

/* ============================ 7. ABOUT =========================== */
.about { background:var(--color-surface); }
.about__grid {
  display:grid; grid-template-columns:1fr 1fr; gap:clamp(var(--space-8),5vw,var(--space-20));
  align-items:center;
}
.about__pillars { display:grid; grid-template-columns:1fr 1fr; gap:var(--space-4); margin-top:var(--space-8); }
.pillar {
  padding:var(--space-5); border-radius:var(--radius-md);
  background:var(--color-surface-2); border:1px solid var(--color-border);
}
.pillar__icon {
  width:46px; height:46px; border-radius:var(--radius-md); display:grid; place-items:center;
  background:var(--grad-sunset); color:#fff; margin-bottom:var(--space-3);
}
.pillar h3 { font-size:var(--text-base); font-family:var(--font-body); font-weight:600; margin-bottom:var(--space-1); }
.pillar p { font-size:var(--text-sm); color:var(--color-text-muted); line-height:1.5; }
.about__media { position:relative; }
.about__media img { border-radius:var(--radius-lg); box-shadow:var(--shadow-lg); width:100%; object-fit:cover; aspect-ratio:4/5; }
.about__media::before {
  content:""; position:absolute; inset:auto -16px -16px auto; width:62%; height:62%;
  background:url("../img/madras-pattern.jpg"); background-size:cover;
  border-radius:var(--radius-lg); z-index:-1; opacity:0.9;
}
.quote-jjt {
  margin-top:var(--space-8); padding:var(--space-5) var(--space-6);
  border-left:4px solid var(--color-primary); background:var(--color-surface-2);
  border-radius:0 var(--radius-md) var(--radius-md) 0;
}
.quote-jjt p { font-style:italic; font-size:var(--text-base); color:var(--color-text); }
.quote-jjt cite { display:block; margin-top:var(--space-2); font-style:normal; font-size:var(--text-sm); color:var(--color-text-muted); font-weight:600; }

/* ============================ 8. KILTI (cards) =================== */
.kilti { background:var(--color-bg); }
.kilti__grid {
  display:grid; grid-template-columns:repeat(3,1fr); gap:var(--space-6);
  margin-top:var(--space-12);
}
.kcard {
  padding:var(--space-8) var(--space-6); border-radius:var(--radius-lg);
  background:var(--color-surface); border:1px solid var(--color-border);
  position:relative; overflow:hidden; box-shadow:var(--shadow-sm);
}
.kcard::before {
  content:""; position:absolute; inset:0 0 auto 0; height:6px; background:var(--grad-madras);
}
.kcard__icon {
  width:58px; height:58px; border-radius:var(--radius-md); display:grid; place-items:center;
  margin-bottom:var(--space-5); color:#fff;
}
.kcard:nth-child(1) .kcard__icon { background:linear-gradient(135deg,var(--c-coral),var(--c-orange)); }
.kcard:nth-child(2) .kcard__icon { background:linear-gradient(135deg,var(--c-pink),var(--c-magenta)); }
.kcard:nth-child(3) .kcard__icon { background:linear-gradient(135deg,var(--c-purple),var(--c-teal)); }
.kcard:nth-child(4) .kcard__icon { background:linear-gradient(135deg,var(--c-green),var(--c-teal)); }
.kcard:nth-child(5) .kcard__icon { background:linear-gradient(135deg,var(--c-gold),var(--c-orange)); }
.kcard:nth-child(6) .kcard__icon { background:linear-gradient(135deg,var(--c-teal),var(--c-purple)); }
.kcard h3 { font-size:var(--text-lg); margin-bottom:var(--space-2); }
.kcard p { font-size:var(--text-sm); color:var(--color-text-muted); line-height:1.6; }
.kcard__soon { display:inline-block; margin-top:var(--space-4); font-size:var(--text-xs); font-weight:600; letter-spacing:0.1em; text-transform:uppercase; color:var(--color-primary); }
.kcard { transition:transform var(--transition),box-shadow var(--transition); }
.kcard:hover { transform:translateY(-6px); box-shadow:var(--shadow-md); }

/* ============================ 9. CHOIR =========================== */
.choir { background:var(--color-surface-deep); color:var(--color-text-inverse); position:relative; overflow:hidden; }
[data-theme="dark"] .choir { background:#0e0705; }
.choir .eyebrow { color:var(--c-gold); }
.choir .eyebrow::before { background:var(--grad-madras); }
.choir__grid { display:grid; grid-template-columns:1.05fr 1fr; gap:clamp(var(--space-8),5vw,var(--space-16)); align-items:center; }
.choir h2 { color:#fff; }
.choir h2 .kreyol { color:var(--c-gold); }
.choir__lead { color:rgba(253,246,234,0.82); font-size:var(--text-lg); margin-block:var(--space-4) var(--space-6); }
.choir__feats { display:grid; gap:var(--space-4); margin-bottom:var(--space-8); }
.choir__feat { display:flex; gap:var(--space-4); align-items:flex-start; }
.choir__feat .ic { flex-shrink:0; width:42px; height:42px; border-radius:var(--radius-md); display:grid; place-items:center; background:rgba(255,255,255,0.08); border:1px solid rgba(255,255,255,0.16); color:var(--c-gold); }
.choir__feat h4 { font-family:var(--font-body); font-weight:600; font-size:var(--text-base); color:#fff; margin-bottom:2px; }
.choir__feat p { font-size:var(--text-sm); color:rgba(253,246,234,0.72); line-height:1.5; }
.choir__gallery { display:grid; grid-template-columns:1fr 1fr; grid-template-rows:auto auto; gap:var(--space-3); }
.choir__gallery img { border-radius:var(--radius-md); box-shadow:var(--shadow-lg); width:100%; height:100%; object-fit:cover; }
.choir__gallery .g-main { grid-column:1 / 3; aspect-ratio:16/10; }
.choir__gallery .g-sm { aspect-ratio:1/1; }

/* ============================ 10. NEWSLETTER ==================== */
.signup { background:var(--color-bg); position:relative; }
.signup__card {
  display:grid; grid-template-columns:1fr 1fr; overflow:hidden;
  border-radius:var(--radius-xl); box-shadow:var(--shadow-lg); border:1px solid var(--color-border);
}
.signup__intro {
  padding:clamp(var(--space-8),4vw,var(--space-16));
  background:var(--surface-deep, #2a1410);
  background-image:linear-gradient(150deg, #3a1c14, #1f0e0a);
  color:#fff; position:relative; overflow:hidden;
}
.signup__intro::after {
  content:""; position:absolute; inset:auto -40px -40px auto; width:200px; height:200px;
  background:url("../img/madras-pattern.jpg"); background-size:cover; border-radius:50%;
  opacity:0.4; filter:blur(1px);
}
.signup__intro h2 { color:#fff; }
.signup__intro h2 .kreyol { color:var(--c-gold); }
.signup__intro .eyebrow { color:var(--c-gold); }
.signup__benefits { list-style:none; margin-top:var(--space-6); display:grid; gap:var(--space-3); }
.signup__benefits li { display:flex; gap:var(--space-3); align-items:center; font-size:var(--text-sm); color:rgba(253,246,234,0.9); }
.signup__benefits svg { flex-shrink:0; color:var(--c-gold); }
.signup__form-wrap { padding:clamp(var(--space-8),4vw,var(--space-16)); background:var(--color-surface); }
.field { margin-bottom:var(--space-4); }
.field label { display:block; font-size:var(--text-sm); font-weight:600; margin-bottom:var(--space-2); }
.field label .opt { color:var(--color-text-faint); font-weight:400; }
.field input[type=email],.field input[type=text] {
  width:100%; padding:var(--space-3) var(--space-4); font-size:var(--text-base);
  border:1.5px solid var(--color-border); border-radius:var(--radius-md);
  background:var(--color-surface-2); color:var(--color-text);
}
.field input:focus { border-color:var(--color-primary); outline:none; box-shadow:0 0 0 3px rgba(232,68,46,0.15); }
.field input.invalid { border-color:var(--c-coral); }
.field .err { display:none; color:var(--c-coral-dk); font-size:var(--text-xs); margin-top:var(--space-1); font-weight:500; }
.field .err.show { display:block; }
.err { display:none; color:var(--c-coral-dk); font-size:var(--text-xs); font-weight:500; }
.err.show { display:block; }
.consent { display:flex; gap:var(--space-3); align-items:flex-start; margin-block:var(--space-5); }
.consent input { margin-top:4px; width:18px; height:18px; accent-color:var(--color-primary); flex-shrink:0; }
.consent label { font-size:var(--text-xs); color:var(--color-text-muted); line-height:1.5; font-weight:400; }
.consent a { color:var(--color-primary); text-decoration:underline; }
.signup__form .btn { width:100%; padding-block:var(--space-4); }
.form-msg { margin-top:var(--space-4); padding:var(--space-3) var(--space-4); border-radius:var(--radius-md); font-size:var(--text-sm); font-weight:500; display:none; }
.form-msg.success { display:block; background:rgba(31,138,82,0.12); color:var(--c-green); border:1px solid rgba(31,138,82,0.3); }
.form-msg.error { display:block; background:rgba(232,68,46,0.1); color:var(--c-coral-dk); border:1px solid rgba(232,68,46,0.3); }
.honeypot { position:absolute; left:-9999px; opacity:0; height:0; width:0; }
.privacy-note { font-size:var(--text-xs); color:var(--color-text-faint); margin-top:var(--space-4); line-height:1.5; }

/* ============================ 11. SOCIAL HUB ==================== */
.social { background:var(--color-surface); }
.social__grid { display:grid; grid-template-columns:repeat(4,1fr); gap:var(--space-5); margin-top:var(--space-12); }
.social-card {
  display:flex; flex-direction:column; gap:var(--space-3); text-decoration:none;
  padding:var(--space-6); border-radius:var(--radius-lg); color:#fff; position:relative;
  overflow:hidden; min-height:180px; justify-content:space-between;
  box-shadow:var(--shadow-sm);
}
.social-card:hover { transform:translateY(-6px); box-shadow:var(--shadow-md); }
.social-card .ic { width:48px; height:48px; }
.social-card h3 { font-family:var(--font-body); font-weight:600; font-size:var(--text-lg); color:#fff; }
.social-card p { font-size:var(--text-sm); color:rgba(255,255,255,0.85); }
.social-card--fb { background:linear-gradient(140deg,#1877f2,#0a47a0); }
.social-card--ig { background:linear-gradient(140deg,#f9ce34,#ee2a7b 45%,#6228d7); }
.social-card--yt { background:linear-gradient(140deg,#ff4e45,#c4302b); }
.social-card--wa { background:linear-gradient(140deg,#25d366,#128c4b); }
.social-card__cta { font-size:var(--text-sm); font-weight:600; display:inline-flex; align-items:center; gap:6px; }

/* ============================ 12. FOOTER ======================== */
.footer { background:var(--color-surface-deep); color:rgba(253,246,234,0.85); padding-block:var(--space-16) var(--space-8); }
[data-theme="dark"] .footer { background:#0e0705; }
.footer__top { display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:var(--space-12); }
.footer__brand .brand__name { color:#fff; }
.footer__brand .brand__tag { color:rgba(253,246,234,0.6); }
.footer p { color:rgba(253,246,234,0.7); font-size:var(--text-sm); max-width:36ch; margin-top:var(--space-4); }
.footer h4 { color:#fff; font-family:var(--font-body); font-size:var(--text-sm); letter-spacing:0.1em; text-transform:uppercase; margin-bottom:var(--space-4); }
.footer ul { list-style:none; display:grid; gap:var(--space-2); }
.footer ul a { color:rgba(253,246,234,0.7); text-decoration:none; font-size:var(--text-sm); }
.footer ul a:hover { color:var(--c-gold); }
.footer__bottom { margin-top:var(--space-12); padding-top:var(--space-6); border-top:1px solid rgba(255,255,255,0.12); display:flex; flex-wrap:wrap; justify-content:space-between; gap:var(--space-4); font-size:var(--text-xs); color:rgba(253,246,234,0.55); }
.footer__bottom a { color:rgba(253,246,234,0.7); text-decoration:none; }
.footer__bottom a:hover { color:var(--c-gold); }

/* ============================ 13. MOTION ======================== */
@keyframes pulse { 0%{box-shadow:0 0 0 0 rgba(245,183,32,0.7);} 70%{box-shadow:0 0 0 10px rgba(245,183,32,0);} 100%{box-shadow:0 0 0 0 rgba(245,183,32,0);} }
@keyframes bob { 0%,100%{transform:translateY(0);} 50%{transform:translateY(6px);} }
.reveal { opacity:0; transform:translateY(28px); transition:opacity .7s cubic-bezier(0.16,1,0.3,1),transform .7s cubic-bezier(0.16,1,0.3,1); }
.reveal.in { opacity:1; transform:none; }
.reveal[data-delay="1"]{transition-delay:.08s;} .reveal[data-delay="2"]{transition-delay:.16s;}
.reveal[data-delay="3"]{transition-delay:.24s;} .reveal[data-delay="4"]{transition-delay:.32s;}
.reveal[data-delay="5"]{transition-delay:.40s;}

/* ============================ 14. RESPONSIVE =================== */
@media (max-width:900px) {
  .nav { display:none; }
  .menu-toggle { display:grid; }
  .about__grid,.choir__grid,.kilti__grid,.signup__card,.footer__top { grid-template-columns:1fr; }
  .kilti__grid { grid-template-columns:1fr 1fr; }
  .social__grid { grid-template-columns:1fr 1fr; }
  .about__media { max-width:480px; margin-inline:auto; }
  .choir__gallery .g-main { grid-column:1 / 3; }
  .signup__intro { order:1; } .signup__form-wrap { order:2; }
}
@media (max-width:560px) {
  .kilti__grid,.social__grid,.about__pillars { grid-template-columns:1fr; }
  .brand__tag { display:none; }
  .brand__name { font-size:var(--text-base); }
  .brand__mark { width:36px; height:36px; }
  .header__actions .btn--primary { padding:var(--space-2) var(--space-4); }
  .hero { min-height:auto; padding-block:7rem 4rem; }
  .hero__cta .btn { width:100%; }
  .footer__bottom { flex-direction:column; }
}

/* Mobile slide-out nav */
.mobile-nav {
  position:fixed; inset:0; z-index:200; background:var(--color-bg);
  display:flex; flex-direction:column; padding:var(--space-6);
  transform:translateX(100%); transition:transform .35s cubic-bezier(0.16,1,0.3,1);
  visibility:hidden;
}
.mobile-nav.open { transform:translateX(0); visibility:visible; }
.mobile-nav__head { display:flex; justify-content:space-between; align-items:center; margin-bottom:var(--space-8); }
.mobile-nav a { font-family:var(--font-display); font-size:var(--text-xl); padding-block:var(--space-3); text-decoration:none; color:var(--color-text); border-bottom:1px solid var(--color-divider); }
.mobile-nav a:hover { color:var(--color-primary); }
.mobile-nav .btn { margin-top:var(--space-6); }
