@import url('https://fonts.googleapis.com/css2?family=Manrope:wght@400;500;600;700;800&family=Cormorant+Garamond:wght@600;700&family=Plus+Jakarta+Sans:wght@500;600;700;800&display=swap');

:root{
  --bg:#fffafc;
  --bg-soft:#fff4f8;
  --surface:#ffffff;
  --surface-2:rgba(255,255,255,.78);
  --text:#26182b;
  --muted:#6e5b66;

  --primary:#7f1d5a;
  --primary-2:#a61e6a;
  --primary-3:#2f0d46;

  --accent:#f25ca2;
  --accent-2:#ff9a57;
  --accent-3:#f7bfd8;

  --green:#2c7a68;

  --line:rgba(127,29,90,.12);
  --line-strong:rgba(127,29,90,.18);

  --shadow:0 18px 48px rgba(70,17,50,.12);
  --shadow-soft:0 10px 24px rgba(70,17,50,.08);
  --shadow-big:0 26px 70px rgba(53,15,42,.22);

  --radius-xl:34px;
  --radius-lg:28px;
  --radius-md:24px;
  --radius-sm:18px;
  --radius-pill:999px;

  --max:1180px;
  --transition:all .35s ease;
}

*{box-sizing:border-box}

html{
  scroll-behavior:smooth;
}

body{
  margin:0;
  font-family:'Manrope',sans-serif;
  color:var(--text);
  background:
    radial-gradient(circle at top right, rgba(242,92,162,.10), transparent 22%),
    radial-gradient(circle at bottom left, rgba(255,154,87,.10), transparent 20%),
    var(--bg);
  line-height:1.7;
  overflow-x:hidden;
}

a{
  text-decoration:none;
  color:inherit;
}

img{
  max-width:100%;
  display:block;
}

ul{
  margin:0;
  padding:0;
  list-style:none;
}

h1,h2,h3,h4,h5,h6,p{
  margin-top:0;
}

.container{
  width:min(var(--max), calc(100% - 32px));
  margin:0 auto;
}

/* ---------------- TOPBAR ---------------- */

.topbar{
  background:var(--primary-3);
  color:#fff;
  font-size:14px;
}

.topbar-inner{
  min-height:42px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  flex-wrap:wrap;
  padding:8px 0;
}

.topbar-group{
  display:flex;
  align-items:center;
  gap:18px;
  flex-wrap:wrap;
}

.pattern-band{
  height:10px;
  background:
    linear-gradient(90deg,
      #f25ca2 0%, #f25ca2 14%,
      #ff9a57 14%, #ff9a57 28%,
      #8f2c7a 28%, #8f2c7a 42%,
      #f7bfd8 42%, #f7bfd8 56%,
      #2f0d46 56%, #2f0d46 70%,
      #d73b86 70%, #d73b86 84%,
      #ffb17d 84%, #ffb17d 100%);
}

/* ---------------- HEADER ---------------- */

.header{
  position:sticky;
  top:0;
  z-index:100;
  backdrop-filter:blur(14px);
  background:rgba(255,250,252,.84);
  border-bottom:1px solid rgba(127,29,90,.08);
}

.header-inner{
  min-height:82px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
}

.brand{
  display:flex;
  align-items:center;
  gap:14px;
  min-width:0;
}

.logo{
  width:54px;
  height:54px;
  object-fit:contain;
  border-radius:14px;
  background:#fff;
  box-shadow:var(--shadow-soft);
  padding:4px;
}

/* fallback if a page still uses <div class="logo"></div> */
div.logo{
  padding:0;
  background:linear-gradient(135deg,var(--primary),var(--accent));
  position:relative;
  overflow:hidden;
}

div.logo::before,
div.logo::after{
  content:"";
  position:absolute;
  border-radius:999px;
  background:rgba(255,255,255,.92);
}

div.logo::before{
  width:18px;
  height:28px;
  left:10px;
  top:10px;
  transform:rotate(-25deg);
}

div.logo::after{
  width:18px;
  height:28px;
  right:10px;
  top:10px;
  transform:rotate(25deg);
}

.brand-text{
  min-width:0;
}

.brand-text small{
  display:block;
  color:var(--muted);
  font-size:12px;
  line-height:1.35;
  font-weight:700;
  letter-spacing:.04em;
}

.brand-text strong{
  display:block;
  color:var(--primary);
  font-size:18px;
  line-height:1.2;
  font-family:'Plus Jakarta Sans',sans-serif;
}

.nav{
  display:flex;
  align-items:center;
  gap:6px;
  flex-wrap:wrap;
}

.nav a{
  padding:10px 14px;
  border-radius:999px;
  color:#5f4553;
  font-weight:700;
  font-family:'Plus Jakarta Sans',sans-serif;
  font-size:14px;
  transition:var(--transition);
}

.nav a:hover,
.nav a.active{
  background:rgba(127,29,90,.08);
  color:var(--primary);
}

/* ---------------- BUTTONS ---------------- */

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  min-height:48px;
  padding:0 20px;
  border-radius:var(--radius-pill);
  font-weight:800;
  font-family:'Plus Jakarta Sans',sans-serif;
  border:1px solid transparent;
  transition:transform .25s ease, box-shadow .25s ease, background .25s ease, color .25s ease, border-color .25s ease;
  box-shadow:0 10px 24px rgba(127,29,90,.12);
}

.btn:hover{
  transform:translateY(-2px);
}

.btn-primary{
  background:linear-gradient(135deg,var(--primary),var(--primary-2));
  color:#fff;
}

.btn-primary:hover{
  box-shadow:0 16px 28px rgba(127,29,90,.22);
}

.btn-accent{
  background:linear-gradient(135deg,var(--accent),#ff7bb6);
  color:#fff;
}

.btn-accent:hover{
  box-shadow:0 16px 28px rgba(242,92,162,.22);
}

.btn-secondary{
  background:#fff;
  color:var(--primary);
  border-color:rgba(127,29,90,.16);
  box-shadow:none;
}

/* ---------------- HERO / PAGE HERO ---------------- */

.hero,
.page-hero{
  position:relative;
  padding:86px 0 68px;
}

.hero::before,
.page-hero::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at right top, rgba(242,92,162,.16), transparent 28%),
    radial-gradient(circle at left bottom, rgba(255,154,87,.16), transparent 22%);
  pointer-events:none;
}

.hero-grid,
.page-hero-grid{
  display:grid;
  grid-template-columns:1.02fr .98fr;
  gap:34px;
  align-items:center;
}

.kicker{
  display:inline-flex;
  align-items:center;
  padding:9px 14px;
  border-radius:999px;
  background:rgba(127,29,90,.08);
  color:var(--primary);
  font-size:12px;
  font-weight:800;
  letter-spacing:.08em;
  text-transform:uppercase;
  margin-bottom:16px;
  font-family:'Plus Jakarta Sans',sans-serif;
}

.hero h1,
.page-hero-copy h1{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(42px,6vw,72px);
  line-height:1.02;
  letter-spacing:-.02em;
  max-width:720px;
  margin:0 0 18px;
}

.hero p,
.page-hero-copy p{
  color:var(--muted);
  font-size:18px;
  max-width:640px;
  margin:0 0 24px;
}

.hero-actions,
.cta-actions{
  display:flex;
  gap:14px;
  flex-wrap:wrap;
  margin-top:18px;
}

.hero-badges,
.hero-ribbon{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}

.hero-badges{
  margin-top:18px;
  margin-bottom:14px;
}

.badge,
.mini-badge{
  display:inline-flex;
  align-items:center;
  min-height:36px;
  padding:0 14px;
  border-radius:999px;
  background:#fff;
  border:1px solid rgba(127,29,90,.12);
  box-shadow:var(--shadow-soft);
  color:var(--primary);
  font-weight:800;
  font-size:13px;
  font-family:'Plus Jakarta Sans',sans-serif;
}

.mini-badge{
  min-height:32px;
  font-size:12px;
  color:#6a4161;
}

.hero-scroll-cue{
  display:inline-flex;
  align-items:center;
  gap:10px;
  margin-top:18px;
  color:#775867;
  font-size:13px;
  font-weight:800;
  font-family:'Plus Jakarta Sans',sans-serif;
  letter-spacing:.08em;
  text-transform:uppercase;
}

.wheel{
  width:24px;
  height:38px;
  border-radius:999px;
  border:2px solid rgba(127,29,90,.28);
  position:relative;
}

.wheel::after{
  content:"";
  position:absolute;
  left:50%;
  top:6px;
  width:4px;
  height:7px;
  margin-left:-2px;
  border-radius:999px;
  background:var(--primary);
  animation:scrollCue 1.6s ease-in-out infinite;
}

.visual-wrap{
  position:relative;
  min-height:590px;
  perspective:1000px;
  animation:floatSoft 6.5s ease-in-out infinite;
}

.visual-main{
  position:absolute;
  inset:0 38px 62px 0;
  border-radius:34px;
  overflow:hidden;
  box-shadow:var(--shadow-big);
  background:
    linear-gradient(180deg, rgba(0,0,0,.18), rgba(0,0,0,.26)),
    url("images/TEP-STUDIO__MG_0050-scaled.jpg.jpeg") center/cover no-repeat;
  transform:translateZ(0);
}

.visual-main::after{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at top right, rgba(242,92,162,.30), transparent 22%),
    linear-gradient(135deg, rgba(47,13,70,.26), rgba(47,13,70,.04));
}

.mini-tile,
.page-hero-tag{
  position:absolute;
  z-index:2;
  padding:13px 18px;
  border-radius:18px;
  background:rgba(255,255,255,.16);
  backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,.22);
  color:#fff;
  font-weight:800;
  font-family:'Plus Jakarta Sans',sans-serif;
  font-size:12px;
  letter-spacing:.12em;
  text-transform:uppercase;
}

.mini-tile{
  right:0;
  bottom:18px;
  width:210px;
  min-height:92px;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  padding:18px;
  border-radius:22px;
  background:rgba(255,255,255,.78);
  border:1px solid rgba(255,255,255,.55);
  box-shadow:var(--shadow);
  color:var(--primary);
  font-size:22px;
  letter-spacing:0;
  text-transform:none;
  animation:floatTile 5.5s ease-in-out infinite;
}

.page-hero-tag{
  left:22px;
  top:22px;
}

.float-card{
  position:absolute;
  left:-26px;
  bottom:84px;
  width:280px;
  padding:20px;
  border-radius:24px;
  background:rgba(255,255,255,.76);
  border:1px solid rgba(255,255,255,.6);
  backdrop-filter:blur(16px);
  box-shadow:var(--shadow);
}

.float-card small,
.news-meta,
.program-meta{
  display:block;
  margin-bottom:8px;
  color:var(--primary);
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.08em;
  font-family:'Plus Jakarta Sans',sans-serif;
  font-size:11px;
}

.float-card h3,
.feature-caption h3,
.impact-copy h3,
.page-hero-caption h3,
.gallery-caption h3{
  font-family:'Cormorant Garamond',serif;
  line-height:1.02;
  margin:0 0 10px;
}

.float-card h3{
  font-size:30px;
}

.float-card p{
  font-size:14px;
  color:var(--muted);
  margin:0;
}

/* ---------------- PAGE HERO IMAGE ---------------- */

.page-hero-image{
  position:relative;
  min-height:590px;
  border-radius:34px;
  overflow:hidden;
  box-shadow:var(--shadow-big);
  background:
    linear-gradient(180deg, rgba(0,0,0,.18), rgba(0,0,0,.30)),
    url("images/TEP-STUDIO__MG_0043-2-scaled.jpg.jpeg") center/cover no-repeat;
}

.page-hero-image.programs{
  background:
    linear-gradient(180deg, rgba(0,0,0,.18), rgba(0,0,0,.30)),
    url("images/6-1080x540-1-570x416.jpeg") center/cover no-repeat;
}

.page-hero-image.events{
  background:
    linear-gradient(180deg, rgba(0,0,0,.18), rgba(0,0,0,.30)),
    url("images/TEP-STUDIO__MG_0050-scaled.jpg.jpeg") center/cover no-repeat;
}

.page-hero-image.stories{
  background:
    linear-gradient(180deg, rgba(0,0,0,.18), rgba(0,0,0,.30)),
    url("images/DSC00457-scaled-1-270x416.jpeg") center/cover no-repeat;
}

.page-hero-image.contact{
  background:
    linear-gradient(180deg, rgba(0,0,0,.18), rgba(0,0,0,.30)),
    url("images/TEP-STUDIO__MG_0043-2-scaled.jpg.jpeg") center/cover no-repeat;
}

.page-hero-image.involved{
  background:
    linear-gradient(180deg, rgba(0,0,0,.18), rgba(0,0,0,.30)),
    url("images/6-1080x540-1-570x416.jpeg") center/cover no-repeat;
}

.page-hero-caption{
  position:absolute;
  left:24px;
  right:24px;
  bottom:24px;
  z-index:2;
  padding:22px;
  border-radius:22px;
  background:rgba(255,255,255,.18);
  color:#fff;
  backdrop-filter:blur(14px);
  border:1px solid rgba(255,255,255,.22);
}

.page-hero-caption h3{
  font-size:32px;
  margin-bottom:8px;
}

.page-hero-caption p{
  margin:0;
  color:rgba(255,255,255,.94);
  max-width:520px;
}

/* ---------------- SECTIONS ---------------- */

.section{
  padding:86px 0;
  position:relative;
}

.band{
  background:linear-gradient(180deg, rgba(255,255,255,.6), rgba(255,244,248,.92));
}

.section-head{
  display:grid;
  grid-template-columns:1.2fr .9fr;
  gap:28px;
  align-items:end;
  margin-bottom:30px;
}

.section-head h2{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(32px,4vw,48px);
  line-height:1.08;
  margin:0;
}

.section-head p{
  color:var(--muted);
  margin:0;
}

/* ---------------- GRID SYSTEMS ---------------- */

.grid-2{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:24px;
  align-items:start;
}

.grid-3{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
}

.grid-4,
.counter-grid,
.logo-strip,
.steps-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:18px;
}

/* ---------------- CARDS ---------------- */

.card,
.counter-card,
.logo-pill,
.testimonial-card{
  background:#fff;
  border:1px solid rgba(127,29,90,.08);
  border-radius:24px;
  box-shadow:var(--shadow-soft);
}

.card{
  padding:26px;
}

.icon,
.step-number{
  width:58px;
  height:58px;
  display:grid;
  place-items:center;
  border-radius:18px;
  background:linear-gradient(135deg,var(--primary),var(--accent));
  color:#fff;
  font-size:26px;
  font-weight:900;
  margin-bottom:14px;
  font-family:'Plus Jakarta Sans',sans-serif;
}

.step-number{
  width:46px;
  height:46px;
  border-radius:16px;
  font-size:18px;
}

.card h3,
.news-card h3{
  font-size:28px;
  line-height:1.12;
  margin:0 0 12px;
  font-family:'Cormorant Garamond',serif;
}

.card p,
.counter-card p{
  margin:0;
  color:var(--muted);
}

.news-link{
  color:var(--primary);
  font-weight:800;
  font-family:'Plus Jakarta Sans',sans-serif;
}

/* ---------------- PRIORITY LIST ---------------- */

.priority-list{
  display:grid;
  gap:16px;
}

.priority-item{
  display:grid;
  grid-template-columns:58px 1fr;
  gap:14px;
  padding:18px;
  background:#fff;
  border-radius:20px;
  border:1px solid rgba(127,29,90,.08);
  box-shadow:var(--shadow-soft);
}

.priority-item b{
  width:58px;
  height:58px;
  display:grid;
  place-items:center;
  border-radius:18px;
  background:linear-gradient(135deg,var(--primary),var(--accent));
  color:#fff;
  font-size:22px;
  font-family:'Plus Jakarta Sans',sans-serif;
}

.priority-item p{
  margin:0;
  color:#5e4d58;
  font-weight:600;
}

/* ---------------- IMAGE SPLIT / GLASS ---------------- */

.image-split{
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:30px;
  align-items:stretch;
}

.feature-photo{
  min-height:520px;
  border-radius:30px;
  overflow:hidden;
  position:relative;
  box-shadow:var(--shadow);
  background:
    linear-gradient(180deg, rgba(0,0,0,.08), rgba(0,0,0,.42)),
    url("images/DSC00457-scaled-1-270x416.jpeg") center/cover no-repeat;
}

.feature-caption{
  position:absolute;
  left:24px;
  right:24px;
  bottom:24px;
  padding:22px;
  border-radius:22px;
  background:rgba(255,255,255,.18);
  color:#fff;
  backdrop-filter:blur(14px);
  border:1px solid rgba(255,255,255,.22);
}

.feature-caption h3{
  font-size:28px;
  margin-bottom:8px;
}

.feature-caption p{
  margin:0;
  opacity:.96;
}

.glass-stack{
  display:grid;
  gap:20px;
}

.glass-card{
  min-height:245px;
  padding:28px;
  border-radius:28px;
  background:rgba(255,255,255,.7);
  backdrop-filter:blur(14px);
  border:1px solid rgba(127,29,90,.10);
  box-shadow:var(--shadow-soft);
  position:relative;
  overflow:hidden;
}

.glass-card::before{
  content:"";
  position:absolute;
  inset:auto auto 0 0;
  width:140px;
  height:140px;
  background:radial-gradient(circle, rgba(242,92,162,.16), transparent 70%);
  pointer-events:none;
}

.glass-card h3{
  font-family:'Cormorant Garamond',serif;
  font-size:28px;
  line-height:1.12;
  margin:0 0 12px;
}

.glass-card p{
  color:var(--muted);
  margin:0;
  max-width:460px;
}

/* ---------------- IMPACT ---------------- */

.impact-banner{
  min-height:330px;
  border-radius:32px;
  overflow:hidden;
  position:relative;
  display:flex;
  align-items:end;
  padding:28px;
  box-shadow:var(--shadow);
  background:
    linear-gradient(180deg, rgba(0,0,0,.10), rgba(0,0,0,.42)),
    url("images/6-1080x540-1-570x416.jpeg") center/cover no-repeat;
}

.impact-copy{
  max-width:620px;
  padding:24px;
  border-radius:24px;
  background:rgba(255,255,255,.16);
  backdrop-filter:blur(12px);
  border:1px solid rgba(255,255,255,.22);
  color:#fff;
}

.impact-copy h3{
  font-size:34px;
  margin-bottom:12px;
}

.impact-copy p{
  color:rgba(255,255,255,.92);
  margin-bottom:16px;
}

/* ---------------- COUNTERS ---------------- */

.counter-card{
  padding:26px 22px;
  text-align:center;
  position:relative;
  overflow:hidden;
}

.counter-card::after{
  content:"";
  position:absolute;
  right:-18px;
  bottom:-18px;
  width:120px;
  height:120px;
  border-radius:50%;
  background:rgba(242,92,162,.08);
}

.counter-number{
  font-family:'Cormorant Garamond',serif;
  font-size:54px;
  line-height:.9;
  color:var(--primary);
  margin-bottom:10px;
  position:relative;
  z-index:1;
}

.counter-card p{
  position:relative;
  z-index:1;
  font-weight:700;
}

/* ---------------- NEWS / PROGRAM CARDS ---------------- */

.news-card{
  overflow:hidden;
  padding:0;
  background:#fff;
  border:1px solid rgba(127,29,90,.08);
  border-radius:24px;
  box-shadow:var(--shadow-soft);
}

.news-card:hover .news-image{
  transform:scale(1.06);
}

.news-image{
  height:290px;
  background-size:cover;
  background-position:center;
  transition:transform .8s ease;
}

.news-content{
  padding:24px;
}

/* ---------------- GALLERY ---------------- */

.gallery-mosaic{
  display:grid;
  grid-template-columns:1.2fr .8fr .8fr;
  gap:18px;
  grid-auto-rows:250px;
}

.gallery-tile{
  position:relative;
  overflow:hidden;
  border-radius:24px;
  box-shadow:var(--shadow-soft);
  background:#ddd;
}

.gallery-tile.large{
  grid-row:span 2;
}

.gallery-tile img{
  width:100%;
  height:100%;
  object-fit:cover;
  transition:transform 1.2s ease, filter .8s ease;
}

.gallery-tile::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,.04), rgba(0,0,0,.52));
}

.gallery-caption{
  position:absolute;
  left:18px;
  right:18px;
  bottom:18px;
  z-index:2;
  color:#fff;
}

.gallery-caption h3{
  font-size:26px;
  margin-bottom:6px;
}

.gallery-caption p{
  margin:0;
  color:rgba(255,255,255,.9);
}

.gallery-tile:hover img{
  transform:scale(1.07);
  filter:saturate(1.06);
}

/* ---------------- TESTIMONIALS ---------------- */

.testimonial-track{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
}

.testimonial-card{
  min-height:280px;
  padding:26px;
  position:relative;
}

.testimonial-card::before{
  content:"“";
  position:absolute;
  right:22px;
  top:12px;
  font-family:'Cormorant Garamond',serif;
  font-size:92px;
  line-height:1;
  color:rgba(127,29,90,.08);
}

.testimonial-card p{
  position:relative;
  z-index:1;
  color:#4f4148;
  font-size:17px;
  margin-bottom:18px;
}

.avatar-row{
  display:flex;
  align-items:center;
  gap:12px;
  position:relative;
  z-index:1;
}

.avatar{
  width:54px;
  height:54px;
  border-radius:50%;
  overflow:hidden;
  background:#f1e4ea;
  flex:0 0 54px;
}

.avatar img{
  width:100%;
  height:100%;
  object-fit:cover;
}

.avatar-row strong{
  display:block;
  color:var(--primary);
}

.avatar-row span{
  color:var(--muted);
  font-size:14px;
}

/* ---------------- LOGO STRIP ---------------- */

.logo-pill{
  min-height:110px;
  display:grid;
  place-items:center;
  padding:16px;
  position:relative;
  overflow:hidden;
}

.logo-pill::after{
  content:"";
  position:absolute;
  right:-18px;
  bottom:-18px;
  width:110px;
  height:110px;
  border-radius:50%;
  background:rgba(242,92,162,.08);
}

.logo-pill img{
  max-height:64px;
  width:auto;
  object-fit:contain;
  filter:saturate(.96);
  position:relative;
  z-index:1;
}

/* ---------------- CTA ---------------- */

.cta{
  padding:36px;
  border-radius:32px;
  background:
    radial-gradient(circle at top right, rgba(255,255,255,.16), transparent 30%),
    linear-gradient(135deg,#5f1456, #8b1d67 52%, #f25ca2 100%);
  color:#fff;
  box-shadow:var(--shadow);
  position:relative;
  overflow:hidden;
}

.cta::after{
  content:"";
  position:absolute;
  inset:auto -30px -30px auto;
  width:180px;
  height:180px;
  border-radius:50%;
  background:radial-gradient(circle, rgba(255,255,255,.16), transparent 70%);
}

.cta h2{
  font-family:'Cormorant Garamond',serif;
  font-size:42px;
  line-height:1.08;
  margin-bottom:12px;
  position:relative;
  z-index:1;
}

.cta p{
  max-width:760px;
  color:rgba(255,255,255,.92);
  position:relative;
  z-index:1;
}

.cta-actions{
  position:relative;
  z-index:1;
}

/* ---------------- FOOTER ---------------- */

.footer{
  background:#210526;
  color:#fff;
  padding:64px 0 26px;
}

.footer-grid{
  display:grid;
  grid-template-columns:1.2fr .8fr .9fr;
  gap:26px;
}

.footer h4{
  font-size:20px;
  margin-bottom:10px;
  font-family:'Plus Jakarta Sans',sans-serif;
}

.footer p,
.footer li,
.footer a{
  color:rgba(255,255,255,.84);
}

.footer li + li{
  margin-top:8px;
}

.copyright{
  margin-top:28px;
  padding-top:18px;
  border-top:1px solid rgba(255,255,255,.10);
  color:rgba(255,255,255,.6);
  font-size:14px;
}

/* ---------------- FORMS ---------------- */

form{
  display:grid;
  gap:16px;
}

input,
textarea,
select{
  width:100%;
  min-height:54px;
  padding:14px 16px;
  border-radius:18px;
  border:1px solid rgba(127,29,90,.14);
  background:rgba(255,255,255,.88);
  color:var(--text);
  font:inherit;
  outline:none;
  transition:border-color .2s ease, box-shadow .2s ease, background .2s ease;
}

textarea{
  min-height:140px;
  resize:vertical;
}

input:focus,
textarea:focus,
select:focus{
  border-color:rgba(127,29,90,.34);
  box-shadow:0 0 0 4px rgba(127,29,90,.08);
  background:#fff;
}

/* ---------------- REVEALS ---------------- */

.reveal-up,
.reveal-up1{
  opacity:0;
  transform:translateY(38px);
  transition:opacity .9s ease, transform .9s ease;
}

.reveal-up1{
  transform:translateY(48px) scale(.985);
}

.reveal-up.is-visible,
.reveal-up1.is-visible{
  opacity:1;
  transform:translateY(0) scale(1);
}

.delay-2{transition-delay:.18s}
.delay-3{transition-delay:.34s}

/* ---------------- MOTION ---------------- */

.hero-badges .badge:nth-child(1){animation:popIn .7s ease .2s both}
.hero-badges .badge:nth-child(2){animation:popIn .7s ease .36s both}
.hero-badges .badge:nth-child(3){animation:popIn .7s ease .52s both}
.hero-ribbon .mini-badge:nth-child(1){animation:popIn .7s ease .64s both}
.hero-ribbon .mini-badge:nth-child(2){animation:popIn .7s ease .78s both}
.hero-ribbon .mini-badge:nth-child(3){animation:popIn .7s ease .92s both}

@keyframes scrollCue{
  0%{transform:translateY(0);opacity:1}
  60%{transform:translateY(11px);opacity:.35}
  100%{transform:translateY(0);opacity:1}
}

@keyframes floatSoft{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-10px)}
}

@keyframes floatTile{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-8px)}
}

@keyframes popIn{
  from{opacity:0; transform:translateY(12px) scale(.96)}
  to{opacity:1; transform:translateY(0) scale(1)}
}

/* ---------------- HELPERS ---------------- */

.text-center{text-align:center}
.mt-0{margin-top:0}
.mb-0{margin-bottom:0}

/* ---------------- MOBILE MENU ---------------- */

.header-actions{
  display:flex;
  align-items:center;
  gap:12px;
}

.menu-toggle{
  display:none;
  width:52px;
  height:52px;
  border:none;
  border-radius:16px;
  background:rgba(127,29,90,.08);
  cursor:pointer;
  padding:0;
  align-items:center;
  justify-content:center;
  flex-direction:column;
  gap:5px;
  transition:var(--transition);
}

.menu-toggle:hover{
  background:rgba(127,29,90,.14);
}

.menu-toggle span{
  display:block;
  width:22px;
  height:2.5px;
  background:var(--primary);
  border-radius:999px;
  transition:transform .25s ease, opacity .25s ease;
}

.menu-toggle.active span:nth-child(1){
  transform:translateY(7px) rotate(45deg);
}

.menu-toggle.active span:nth-child(2){
  opacity:0;
}

.menu-toggle.active span:nth-child(3){
  transform:translateY(-7px) rotate(-45deg);
}

.mobile-menu{
  display:none;
  border-top:1px solid rgba(127,29,90,.08);
  background:rgba(255,250,252,.96);
  backdrop-filter:blur(14px);
}

.mobile-menu-inner{
  width:min(var(--max), calc(100% - 32px));
  margin:0 auto;
  padding:14px 0 18px;
  display:grid;
  gap:10px;
}

.mobile-menu a{
  display:block;
  padding:14px 16px;
  border-radius:16px;
  font-weight:700;
  font-family:'Plus Jakarta Sans',sans-serif;
  color:#5f4553;
  background:rgba(255,255,255,.72);
  border:1px solid rgba(127,29,90,.08);
  transition:var(--transition);
}

.mobile-menu a:hover,
.mobile-menu a.active{
  background:rgba(127,29,90,.08);
  color:var(--primary);
}

.mobile-menu .mobile-cta{
  background:linear-gradient(135deg,var(--primary),var(--primary-2));
  color:#fff;
  border:none;
  text-align:center;
}

.mobile-menu.open{
  display:block;
  animation:mobileMenuDrop .25s ease;
}

@keyframes mobileMenuDrop{
  from{
    opacity:0;
    transform:translateY(-8px);
  }
  to{
    opacity:1;
    transform:translateY(0);
  }
}

/* ---------------- RESPONSIVE ---------------- */

@media (max-width:1100px){
  .nav{display:none}
  .menu-toggle{display:flex}
  .header-actions > .btn{display:none}

  .hero-grid,
  .page-hero-grid,
  .image-split,
  .grid-2,
  .grid-3,
  .grid-4,
  .counter-grid,
  .logo-strip,
  .steps-grid,
  .testimonial-track,
  .gallery-mosaic,
  .section-head,
  .footer-grid{
    grid-template-columns:1fr;
  }

  .gallery-tile.large{
    grid-row:span 1;
  }

  .hero h1,
  .page-hero-copy h1{
    font-size:48px;
  }

  .visual-wrap{
    min-height:540px;
  }

  .logo-strip{
    grid-template-columns:repeat(3,1fr);
  }

  .counter-grid{
    grid-template-columns:repeat(2,1fr);
  }

  .testimonial-track{
    grid-template-columns:1fr 1fr;
  }

  .gallery-mosaic{
    grid-template-columns:1fr 1fr;
    grid-auto-rows:230px;
  }
}

@media (max-width:760px){
  .header-inner{
    min-height:74px;
    flex-wrap:nowrap;
    padding:12px 0;
  }

  .brand{
    width:auto;
  }

  .header-actions{
    width:auto;
  }

  .topbar-inner{
    font-size:13px;
  }

  .section,
  .hero,
  .page-hero{
    padding:70px 0;
  }

  .hero h1,
  .page-hero-copy h1{
    font-size:38px;
  }

  .hero p,
  .page-hero-copy p{
    font-size:17px;
  }

  .section-head h2,
  .cta h2{
    font-size:32px;
  }

  .impact-copy h3,
  .feature-caption h3,
  .page-hero-caption h3,
  .gallery-caption h3,
  .float-card h3{
    font-size:28px;
  }

  .visual-wrap{
    min-height:430px;
  }

  .visual-main{
    inset:0 0 70px 0;
  }

  .mini-tile{
    width:auto;
    left:20px;
    right:20px;
    bottom:0;
    font-size:18px;
  }

  .feature-photo,
  .page-hero-image{
    min-height:420px;
  }

  .glass-card h3{
    font-size:24px;
  }

  .counter-number{
    font-size:38px;
  }

  .counter-grid,
  .testimonial-track,
  .logo-strip,
  .gallery-mosaic{
    grid-template-columns:1fr;
  }
}