/* =========================================================
   Durgma Films — Modern 2026 Redesign
   Author: Senior Web Design Team
   Approach: Mobile-first, accessible, cinematic dark theme
   ========================================================= */

:root {
  --bg: #0b0b0f;
  --bg-2: #111117;
  --bg-3: #16161f;
  --surface: #1b1b26;
  --surface-2: #232330;
  --line: rgba(255,255,255,.08);
  --text: #ececf1;
  --muted: #a6a6b3;
  --brand: #e8b84b;        /* cinematic gold */
  --brand-2: #c9922f;
  --accent: #ff3355;       /* dramatic red */
  --accent-2: #6aa7ff;     /* cool blue */
  --shadow: 0 20px 50px rgba(0,0,0,.45);
  --radius-sm: 8px;
  --radius: 14px;
  --radius-lg: 22px;
  --max: 1240px;
  --container-pad: clamp(16px, 4vw, 40px);
  --section-pad: clamp(56px, 9vw, 120px);
  --font-head: "Playfair Display", Georgia, serif;
  --font-body: "Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
}

/* ---------- Reset ---------- */
*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--text);
  background:var(--bg);
  line-height:1.65;
  font-size:16px;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img,svg,video,iframe{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; transition:color .25s ease; }
a:hover{ color:var(--brand); }
button{ font:inherit; cursor:pointer; border:0; background:transparent; color:inherit; }
ul,ol{ margin:0; padding:0; list-style:none; }
h1,h2,h3,h4{ font-family:var(--font-head); font-weight:700; line-height:1.15; margin:0 0 .5em; letter-spacing:.2px; }
h1{ font-size:clamp(2.2rem, 5vw, 4.4rem); }
h2{ font-size:clamp(1.8rem, 3.4vw, 2.8rem); }
h3{ font-size:clamp(1.2rem, 2vw, 1.5rem); font-family:var(--font-body); font-weight:600; }
p{ margin:0 0 1em; color:var(--muted); }

::selection{ background:var(--brand); color:#111; }

.container{ width:100%; max-width:var(--max); margin-inline:auto; padding:0 var(--container-pad); }
.skip-link{ position:absolute; left:-9999px; }
.skip-link:focus{ left:10px; top:10px; background:var(--brand); color:#000; padding:8px 14px; z-index:9999; border-radius:8px; }

/* ---------- Topbar ---------- */
.topbar{
  background:linear-gradient(90deg,#08080c,#121222);
  color:#cfcfda;
  font-size:.85rem;
  border-bottom:1px solid var(--line);
}
.topbar__inner{ display:flex; align-items:center; justify-content:space-between; gap:16px; padding-block:8px; flex-wrap:wrap; }
.topbar__info{ display:flex; flex-wrap:wrap; gap:14px 22px; }
.topbar__info li{ display:inline-flex; align-items:center; gap:8px; }
.topbar__info i{ color:var(--brand); font-size:.85rem; }
.topbar__info a:hover{ color:var(--brand); }
.topbar__addr{ display:none; }
.topbar__social{ display:flex; gap:10px; }
.topbar__social a{
  width:30px; height:30px; border-radius:50%;
  display:inline-flex; align-items:center; justify-content:center;
  background:rgba(255,255,255,.06); border:1px solid var(--line);
  transition:transform .25s ease, background .25s ease, color .25s ease;
  font-size:.8rem;
}
.topbar__social a:hover{ background:var(--brand); color:#111; transform:translateY(-2px); }

@media(min-width:900px){ .topbar__addr{ display:inline-flex; } }

/* ---------- Header / nav ---------- */
.site-header{
  position:sticky; top:0; z-index:1000;
  background:rgba(11,11,15,.78);
  backdrop-filter:blur(18px);
  -webkit-backdrop-filter:blur(18px);
  border-bottom:1px solid var(--line);
  transition:background .3s ease, padding .3s ease;
}
.site-header.scrolled{ background:rgba(7,7,11,.92); }
.site-header__inner{ display:flex; align-items:center; justify-content:space-between; padding-block:14px; gap:16px; }
.brand{ display:flex; align-items:center; gap:12px; }
.brand img{ width:52px; height:52px; border-radius:50%; object-fit:cover; border:1px solid var(--line); background:#fff; }
.brand__text strong{ display:block; font-family:var(--font-head); font-size:1.25rem; color:#fff; letter-spacing:.5px; }
.brand__text em{ display:block; font-style:normal; font-size:.75rem; color:var(--muted); letter-spacing:1.5px; text-transform:uppercase; }

.primary-nav{ display:flex; }
.primary-nav ul{ display:flex; gap:6px; align-items:center; }
.primary-nav a{
  display:inline-block; padding:10px 16px;
  font-weight:500; font-size:.95rem;
  color:#dcdce6; border-radius:999px;
  transition:all .25s ease;
}
.primary-nav a:hover{ color:var(--brand); background:rgba(255,255,255,.04); }
.primary-nav .nav-cta{
  background:linear-gradient(135deg,var(--brand),var(--brand-2));
  color:#141414 !important; font-weight:600;
  padding:10px 22px;
  box-shadow:0 8px 24px rgba(232,184,75,.25);
}
.primary-nav .nav-cta:hover{ transform:translateY(-2px); filter:brightness(1.05); }

.nav-toggle{
  display:none;
  width:44px; height:44px; border-radius:12px;
  background:rgba(255,255,255,.06); border:1px solid var(--line);
  flex-direction:column; align-items:center; justify-content:center; gap:5px;
}
.nav-toggle span{ width:22px; height:2px; background:#fff; border-radius:2px; transition:all .3s ease; }
.nav-toggle[aria-expanded="true"] span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.nav-toggle[aria-expanded="true"] span:nth-child(2){ opacity:0; }
.nav-toggle[aria-expanded="true"] span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

@media(max-width:900px){
  .nav-toggle{ display:flex; }
  .primary-nav{
    position:fixed; inset:72px 0 0 0;
    background:rgba(8,8,12,.97);
    backdrop-filter:blur(20px);
    transform:translateX(100%);
    transition:transform .35s ease;
    padding:30px var(--container-pad);
    overflow-y:auto;
  }
  .primary-nav.open{ transform:translateX(0); }
  .primary-nav ul{ flex-direction:column; gap:6px; align-items:stretch; }
  .primary-nav a{
    display:block; padding:16px 20px;
    border-radius:12px; font-size:1.1rem;
    border:1px solid transparent;
  }
  .primary-nav a:hover{ border-color:var(--line); }
}

/* ---------- Hero ---------- */
.hero{
  position:relative; overflow:hidden;
  min-height:92vh;
  display:grid; place-items:center;
  isolation:isolate;
}
.hero__slides{
  position:absolute; inset:0;
}
.hero__slide{
  position:absolute; inset:0;
  background-size:cover; background-position:center;
  opacity:0; transition:opacity 1.2s ease, transform 8s ease;
  transform:scale(1.08);
}
.hero__slide.active{ opacity:1; transform:scale(1); }
.hero::after{
  content:""; position:absolute; inset:0;
  background:
    radial-gradient(1200px 600px at 70% 20%, rgba(232,184,75,.12), transparent 60%),
    linear-gradient(180deg, rgba(11,11,15,.55) 0%, rgba(11,11,15,.85) 75%, rgba(11,11,15,1) 100%);
  z-index:0;
}
.hero__content{
  position:relative; z-index:2; text-align:center;
  padding:120px 0 80px;
  max-width:960px; margin-inline:auto;
}
.hero__kicker{
  display:inline-block;
  color:var(--brand);
  letter-spacing:5px; font-size:.8rem; text-transform:uppercase;
  margin-bottom:22px;
  padding:7px 18px; border:1px solid rgba(232,184,75,.35);
  border-radius:999px; background:rgba(232,184,75,.06);
}
.hero__title{ color:#fff; margin-bottom:.35em; }
.hero__title span{ color:var(--brand); font-style:italic; }
.hero__sub{ color:#d1d1dc; font-size:clamp(1rem,1.3vw,1.2rem); max-width:640px; margin:0 auto 2.2em; }
.hero__cta{ display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }

.btn{
  display:inline-flex; align-items:center; gap:10px;
  padding:14px 28px; border-radius:999px;
  font-weight:600; font-size:.95rem;
  border:1px solid transparent;
  transition:all .3s ease;
  white-space:nowrap;
}
.btn--primary{
  background:linear-gradient(135deg,var(--brand),var(--brand-2));
  color:#141414;
  box-shadow:0 15px 40px rgba(232,184,75,.28);
}
.btn--primary:hover{ transform:translateY(-3px); color:#141414; filter:brightness(1.06); }
.btn--ghost{
  color:#fff; border-color:rgba(255,255,255,.35);
  backdrop-filter:blur(6px);
}
.btn--ghost:hover{ background:#fff; color:#111; border-color:#fff; }

.hero__scroll{
  position:absolute; bottom:28px; left:50%; transform:translateX(-50%);
  color:#fff; z-index:3; opacity:.7; font-size:.8rem; letter-spacing:2px;
  display:flex; flex-direction:column; align-items:center; gap:8px;
}
.hero__scroll i{ animation:bob 1.8s ease-in-out infinite; }
@keyframes bob{ 0%,100%{ transform:translateY(0); } 50%{ transform:translateY(6px); } }

/* ---------- Section basics ---------- */
section{ padding:var(--section-pad) 0; position:relative; }
.section-head{ text-align:center; max-width:760px; margin:0 auto 56px; }
.section-head .eyebrow{
  display:inline-block; color:var(--brand);
  letter-spacing:4px; text-transform:uppercase; font-size:.75rem; font-weight:600;
  padding:6px 16px; border-radius:999px;
  background:rgba(232,184,75,.08); border:1px solid rgba(232,184,75,.25);
  margin-bottom:16px;
}
.section-head h2{ color:#fff; }
.section-head h2 span{ color:var(--brand); font-style:italic; }
.section-head p{ color:var(--muted); }

/* ---------- About / intro ---------- */
.about{ background:linear-gradient(180deg,var(--bg),var(--bg-2)); }
.about__grid{
  display:grid; gap:clamp(30px, 5vw, 70px);
  grid-template-columns:1fr;
  align-items:center;
}
@media(min-width:900px){ .about__grid{ grid-template-columns:.9fr 1.1fr; } }
.about__media{
  position:relative; border-radius:var(--radius-lg); overflow:hidden;
  aspect-ratio: 4 / 5;
  background:var(--surface); box-shadow:var(--shadow);
}
.about__media img{ width:100%; height:100%; object-fit:contain; padding:30px; background:var(--surface); }
.about__badge{
  position:absolute; left:24px; bottom:24px;
  padding:16px 20px; border-radius:14px;
  background:rgba(0,0,0,.6); backdrop-filter:blur(10px);
  border:1px solid var(--line);
  display:flex; align-items:center; gap:14px;
}
.about__badge strong{ display:block; color:var(--brand); font-size:1.6rem; line-height:1; }
.about__badge span{ font-size:.8rem; color:var(--muted); }
.about__content h2{ color:#fff; }
.about__content h2 span{ color:var(--brand); font-style:italic; }
.about__stats{
  display:grid; grid-template-columns:repeat(3,1fr); gap:20px;
  margin-top:30px;
}
.about__stats .stat{
  background:var(--surface); border:1px solid var(--line);
  border-radius:var(--radius); padding:18px; text-align:center;
}
.about__stats .stat strong{ display:block; font-family:var(--font-head); font-size:1.6rem; color:var(--brand); }
.about__stats .stat span{ font-size:.8rem; color:var(--muted); }

/* ---------- Team ---------- */
.team{ background:var(--bg-2); }
.team__grid{
  display:grid; gap:28px;
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
}
.team__card{
  background:var(--surface); border:1px solid var(--line);
  border-radius:var(--radius-lg); overflow:hidden;
  transition:transform .35s ease, border-color .35s ease, box-shadow .35s ease;
}
.team__card:hover{ transform:translateY(-6px); border-color:rgba(232,184,75,.35); box-shadow:var(--shadow); }
.team__photo{ aspect-ratio:4 / 5; overflow:hidden; background:#000; }
.team__photo img{ width:100%; height:100%; object-fit:cover; transition:transform .8s ease; }
.team__card:hover .team__photo img{ transform:scale(1.06); }
.team__body{ padding:22px 24px; }
.team__body h3{ color:#fff; margin-bottom:4px; }
.team__body .role{ color:var(--brand); font-size:.85rem; letter-spacing:2px; text-transform:uppercase; margin-bottom:10px; }
.team__body p{ color:var(--muted); font-size:.92rem; }

/* ---------- Services ---------- */
.services{ background:linear-gradient(180deg,var(--bg-2),var(--bg)); }
.services__grid{
  display:grid; gap:22px;
  grid-template-columns:repeat(auto-fill,minmax(260px,1fr));
}
.service-card{
  position:relative; overflow:hidden;
  border-radius:var(--radius-lg);
  aspect-ratio: 4 / 3;
  background:#111;
  border:1px solid var(--line);
}
.service-card img{
  width:100%; height:100%; object-fit:cover;
  transition:transform .9s cubic-bezier(.2,.8,.2,1), filter .5s ease;
  filter:saturate(.9) brightness(.85);
}
.service-card:hover img{ transform:scale(1.1); filter:saturate(1.1) brightness(1); }
.service-card::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(180deg, transparent 40%, rgba(0,0,0,.85));
}
.service-card__body{
  position:absolute; inset:auto 0 0 0; padding:22px 24px; z-index:2;
  color:#fff; display:flex; align-items:flex-end; justify-content:space-between; gap:12px;
}
.service-card__body h3{ color:#fff; margin:0; font-family:var(--font-head); font-weight:600; font-size:1.25rem; }
.service-card__body .tag{
  background:var(--brand); color:#141414;
  padding:4px 12px; border-radius:999px; font-size:.75rem; font-weight:600;
}

/* ---------- Courses / education ---------- */
.education{ background:var(--bg-2); }
.edu-grid{
  display:grid; gap:22px;
  grid-template-columns:repeat(auto-fill,minmax(260px,1fr));
}
.edu-card{
  background:var(--surface); border:1px solid var(--line);
  border-radius:var(--radius); overflow:hidden;
  transition:transform .4s ease, border-color .4s ease;
}
.edu-card:hover{ transform:translateY(-5px); border-color:var(--brand); }
.edu-card__img{ aspect-ratio:16/10; overflow:hidden; }
.edu-card__img img{ width:100%; height:100%; object-fit:cover; transition:transform .8s ease; }
.edu-card:hover .edu-card__img img{ transform:scale(1.07); }
.edu-card__body{ padding:18px 22px 22px; }
.edu-card__body h3{ color:#fff; font-size:1.1rem; margin-bottom:6px; }
.edu-card__body p{ margin:0; color:var(--muted); font-size:.88rem; }

/* ---------- Feature (dancing/writing split) ---------- */
.feature{
  display:grid; gap:clamp(26px,4vw,60px);
  grid-template-columns:1fr;
  align-items:center;
}
.feature.is-reverse .feature__media{ order:2; }
@media(min-width:900px){ .feature{ grid-template-columns:1fr 1fr; } }
.feature__media{
  border-radius:var(--radius-lg); overflow:hidden;
  aspect-ratio: 5/4; background:#000;
  box-shadow:var(--shadow);
}
.feature__media img{ width:100%; height:100%; object-fit:cover; }
.feature__body h2{ color:#fff; margin-bottom:.4em; }
.feature__body h2 span{ color:var(--brand); font-style:italic; }
.feature__list{ display:grid; gap:10px; margin-top:18px; }
.feature__list li{
  color:#dcdce6; padding-left:28px; position:relative; font-size:.95rem;
}
.feature__list li::before{
  content:"\f00c"; font-family:"Font Awesome 6 Free"; font-weight:900;
  position:absolute; left:0; top:2px;
  color:var(--brand); font-size:.85rem;
}

/* ---------- Admission banner ---------- */
.admission{
  background:
    linear-gradient(120deg, rgba(11,11,15,.85), rgba(11,11,15,.7)),
    url('../../img/admission.jpg') center/cover no-repeat fixed;
  border-block:1px solid var(--line);
}
.admission__card{
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  padding:clamp(28px,4vw,52px);
  box-shadow:var(--shadow);
  max-width:900px; margin:0 auto;
}
.admission__steps{ display:grid; gap:18px; counter-reset:step; margin-top:24px; }
.admission__steps li{
  counter-increment:step;
  display:grid; grid-template-columns:42px 1fr; gap:16px; align-items:flex-start;
  padding:16px 20px;
  background:var(--surface-2); border-radius:var(--radius);
}
.admission__steps li::before{
  content:counter(step,decimal-leading-zero);
  font-family:var(--font-head); font-weight:700;
  color:var(--brand); font-size:1.2rem;
}
.admission__steps p{ margin:0; color:var(--muted); font-size:.95rem; }

/* ---------- Gallery ---------- */
.gallery{ background:var(--bg); }
.gallery__grid{
  columns: 1;
  column-gap:18px;
}
@media(min-width:640px){ .gallery__grid{ columns:2; } }
@media(min-width:1024px){ .gallery__grid{ columns:3; } }
.gallery__item{
  break-inside:avoid; margin-bottom:18px;
  position:relative; overflow:hidden; border-radius:var(--radius);
  border:1px solid var(--line); display:block;
}
.gallery__item img{
  width:100%; height:auto; display:block;
  transition:transform .8s cubic-bezier(.2,.8,.2,1);
}
.gallery__item:hover img{ transform:scale(1.04); }
.gallery__item::after{
  content:"\f00e"; font-family:"Font Awesome 6 Free"; font-weight:900;
  position:absolute; inset:0;
  display:grid; place-items:center;
  background:linear-gradient(135deg, rgba(0,0,0,.0), rgba(232,184,75,.35));
  color:#fff; font-size:1.5rem;
  opacity:0; transition:opacity .35s ease;
}
.gallery__item:hover::after{ opacity:1; }

/* ---------- Showreel videos ---------- */
.showreel{ background:var(--bg-2); }
.showreel__grid{
  display:grid; gap:22px;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
}
.video-card{
  background:#000; border:1px solid var(--line);
  border-radius:var(--radius); overflow:hidden;
  aspect-ratio:16/9;
}
.video-card iframe{ width:100%; height:100%; border:0; }

/* ---------- CTA banner ---------- */
.cta-band{
  background:linear-gradient(135deg, #1a1423 0%, #2a1c0a 100%);
  border-block:1px solid var(--line);
  text-align:center;
}
.cta-band h2{ color:#fff; }
.cta-band h2 span{ color:var(--brand); font-style:italic; }
.cta-band .btn{ margin-top:18px; }

/* ---------- Map ---------- */
.map-section iframe{ width:100%; height:420px; border:0; display:block; filter:invert(.9) hue-rotate(180deg) saturate(.6); }

/* ---------- Footer ---------- */
.site-footer{ background:#07070b; border-top:1px solid var(--line); padding-top:60px; }
.site-footer__grid{
  display:grid; gap:40px;
  grid-template-columns:1fr;
}
@media(min-width:720px){ .site-footer__grid{ grid-template-columns:1fr 1fr; } }
@media(min-width:1024px){ .site-footer__grid{ grid-template-columns:1.4fr .8fr .8fr 1.1fr; } }
.footer-col h3{ color:#fff; margin:10px 0 8px; font-family:var(--font-head); }
.footer-col h4{ color:#fff; font-family:var(--font-body); font-size:.95rem; letter-spacing:2px; text-transform:uppercase; margin-bottom:18px; }
.footer-col p{ color:var(--muted); font-size:.92rem; }
.footer-logo img{ width:64px; height:64px; border-radius:50%; background:#fff; padding:6px; }
.footer-links li, .footer-contact li{ margin-bottom:12px; color:var(--muted); font-size:.92rem; display:flex; gap:10px; }
.footer-links a{ color:var(--muted); transition:color .25s ease, padding-left .25s ease; }
.footer-links a:hover{ color:var(--brand); padding-left:5px; }
.footer-contact i{ color:var(--brand); margin-top:3px; }
.footer-social{ display:flex; gap:10px; margin-top:18px; }
.footer-social a{
  width:40px; height:40px; border-radius:50%;
  display:inline-flex; align-items:center; justify-content:center;
  background:rgba(255,255,255,.05); border:1px solid var(--line);
  transition:all .25s ease;
}
.footer-social a:hover{ background:var(--brand); color:#111; border-color:var(--brand); transform:translateY(-3px); }
.footer-bar{ margin-top:48px; padding-block:20px; border-top:1px solid var(--line); font-size:.85rem; color:var(--muted); }
.footer-bar__inner{ display:flex; justify-content:space-between; flex-wrap:wrap; gap:10px; }
.footer-bar a{ color:var(--brand); }

/* ---------- Floating action buttons ---------- */
.float-actions{
  position:fixed; right:18px; bottom:18px; z-index:999;
  display:flex; flex-direction:column; gap:10px;
}
.float-btn{
  width:52px; height:52px; border-radius:50%;
  display:inline-flex; align-items:center; justify-content:center;
  color:#fff; font-size:1.1rem;
  box-shadow:0 12px 30px rgba(0,0,0,.35);
  transition:transform .3s ease, background .3s ease;
}
.float-btn:hover{ transform:scale(1.08); color:#fff; }
.float-btn--wa{ background:#25D366; }
.float-btn--call{ background:var(--brand); color:#111; }
.float-btn--call:hover{ color:#111; }
.float-btn--top{ background:#2a2a3a; display:none; }
.float-btn--top.visible{ display:inline-flex; }

/* ---------- Contact page ---------- */
.page-hero{
  padding:120px 0 80px;
  background:
    linear-gradient(120deg, rgba(11,11,15,.85), rgba(11,11,15,.65)),
    url('../../img/banner1.jpg') center/cover no-repeat;
  text-align:center;
}
.page-hero h1{ color:#fff; }
.page-hero p{ color:#ccccd8; max-width:620px; margin:0 auto; }

.contact-grid{
  display:grid; gap:clamp(24px,4vw,50px);
  grid-template-columns:1fr;
}
@media(min-width:900px){ .contact-grid{ grid-template-columns:1fr 1.4fr; } }

.contact-info{
  background:var(--surface); border:1px solid var(--line);
  border-radius:var(--radius-lg); padding:28px;
}
.contact-info h3{ color:#fff; margin-bottom:18px; }
.contact-info li{ display:flex; gap:14px; padding:12px 0; border-top:1px solid var(--line); align-items:flex-start; }
.contact-info li:first-of-type{ border-top:0; padding-top:0; }
.contact-info .icon{
  width:42px; height:42px; border-radius:12px;
  background:linear-gradient(135deg,var(--brand),var(--brand-2)); color:#141414;
  display:grid; place-items:center; flex-shrink:0;
}
.contact-info p{ margin:0; font-size:.92rem; color:var(--text); }
.contact-info small{ color:var(--muted); }

.form-card{
  background:var(--surface); border:1px solid var(--line);
  border-radius:var(--radius-lg); padding:clamp(22px,3vw,40px);
}
.form-card h3{ color:#fff; margin-bottom:6px; }
.form-card p.lead{ color:var(--muted); margin-bottom:26px; }
.form-grid{ display:grid; gap:14px; grid-template-columns:1fr; }
@media(min-width:640px){ .form-grid{ grid-template-columns:1fr 1fr; } }
.form-field{ display:flex; flex-direction:column; }
.form-field.full{ grid-column:1/-1; }
.form-field label{ font-size:.82rem; color:var(--muted); margin-bottom:6px; letter-spacing:1px; text-transform:uppercase; }
.form-field input,
.form-field select,
.form-field textarea{
  width:100%; padding:14px 16px;
  background:var(--surface-2); color:var(--text);
  border:1px solid var(--line); border-radius:12px;
  font:inherit; transition:border-color .25s ease, box-shadow .25s ease;
}
.form-field textarea{ min-height:140px; resize:vertical; }
.form-field input:focus,
.form-field select:focus,
.form-field textarea:focus{
  outline:0; border-color:var(--brand);
  box-shadow:0 0 0 3px rgba(232,184,75,.18);
}
.form-card .btn{ margin-top:20px; }

/* ---------- Utilities ---------- */
.text-center{ text-align:center; }
.mt-sm{ margin-top:20px; }
.mt-md{ margin-top:40px; }

/* ---------- Reveal on scroll ---------- */
.reveal{ opacity:0; transform:translateY(30px); transition:opacity .9s ease, transform .9s ease; }
.reveal.in{ opacity:1; transform:translateY(0); }

/* ---------- Respect reduced motion ---------- */
@media (prefers-reduced-motion: reduce){
  *{ animation:none !important; transition:none !important; }
  html{ scroll-behavior:auto; }
}
