/* ====================================================
   THE MESSAGE CHURCH — Combined Styles
   Palette: Aubergine + Gold + Cream
   Fonts: Cormorant Garamond + Inter Tight
   ==================================================== */

:root {
  --bg: #120b14;
  --paper: #1c1220;
  --ink: #f5efdf;
  --mute: #c8b8d4;
  --line: rgba(245,239,223,.13);
  --accent: #c9a84c;
  --serif: 'Cormorant Garamond', Georgia, serif;
  --sans: 'Inter Tight', system-ui, -apple-system, sans-serif;
  --ease: cubic-bezier(.22,.61,.36,1);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;overflow-x:hidden;max-width:100vw}
body{
  font-family:var(--sans);color:var(--ink);background:var(--bg);
  font-weight:400;line-height:1.55;font-size:15.5px;letter-spacing:.005em;
  -webkit-font-smoothing:antialiased;overflow-x:hidden;max-width:100vw;position:relative;
}
::selection{background:var(--accent);color:var(--bg)}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:0;background:0;color:inherit}
p{color:var(--ink);opacity:.85}

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

/* ---------- type ---------- */
.eyebrow{font-size:10.5px;letter-spacing:.32em;text-transform:uppercase;color:var(--mute);font-weight:500}
h1,h2,h3,h4{font-family:var(--serif);font-weight:300;letter-spacing:-.02em;line-height:.98}
em{font-style:italic;font-weight:400}
.wrap{max-width:1560px;margin:0 auto;padding:0 40px}
@media (max-width:760px){.wrap{padding:0 22px}}

/* ---------- nav ---------- */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:60;
  padding:22px 40px;
  display:flex;align-items:center;justify-content:space-between;
  transition:background .5s var(--ease),backdrop-filter .5s var(--ease),padding .35s;
}
.nav.scrolled{
  padding:12px 40px;
  background:rgba(18,11,20,.96);
  backdrop-filter:blur(28px) saturate(140%);-webkit-backdrop-filter:blur(28px) saturate(140%);
  border-bottom:1px solid var(--line);
  box-shadow:0 12px 40px rgba(0,0,0,.45);
}
@media (max-width:760px){.nav,.nav.scrolled{padding-left:22px;padding-right:22px}}
.brand{display:flex;align-items:center;gap:14px;font-family:var(--serif);font-size:22px;letter-spacing:.01em;font-weight:400}
.brand-mark{
  width:34px;height:34px;border:1px solid var(--ink);
  display:grid;place-items:center;position:relative;transform:rotate(45deg);
}
.brand-mark::after{content:"";width:10px;height:10px;background:var(--accent)}
.brand-name{display:flex;flex-direction:column;line-height:1}
.brand-name span:last-child{font-family:var(--sans);font-size:9px;letter-spacing:.32em;text-transform:uppercase;color:var(--mute);margin-top:5px}
.nav-links{display:flex;gap:36px;font-size:12px;letter-spacing:.18em;text-transform:uppercase}
.nav-links a{position:relative;padding:6px 0;opacity:.85;transition:opacity .3s}
.nav-links a:hover{opacity:1}
.nav-links a::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:1px;
  background:var(--accent);transform:scaleX(0);transform-origin:right;
  transition:transform .5s var(--ease);
}
.nav-links a:hover::after{transform:scaleX(1);transform-origin:left}
.nav-cta{
  background:var(--accent);border:1px solid var(--accent) !important;color:var(--bg) !important;
  padding:11px 22px;border-radius:99px;font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  font-weight:600;transition:background .35s,color .35s,border-color .35s;
}
.nav-cta:hover{background:var(--bg) !important;color:var(--accent) !important;border-color:var(--accent) !important}
@media (max-width:900px){.nav-links{display:none}}
@media (max-width:560px){
  .brand{gap:10px;font-size:18px}
  .brand-mark{width:28px;height:28px}
  .brand-mark::after{width:8px;height:8px}
  .brand-name span:last-child{font-size:8px;margin-top:3px}
  .nav-cta{padding:9px 16px;font-size:10px}
  .nav,.nav.scrolled{padding-left:16px;padding-right:16px;padding-top:14px;padding-bottom:14px}
}

/* ---------- hero ---------- */
.hero{position:relative;height:100svh;min-height:720px;overflow:hidden}
.hero-img{
  position:absolute;inset:0;
  background:
    radial-gradient(ellipse at 30% 35%, rgba(100,35,100,.55) 0%, transparent 50%),
    radial-gradient(ellipse at 75% 65%, rgba(65,25,80,.35) 0%, transparent 48%),
    linear-gradient(160deg, #3d1a40 0%, #2a1232 25%, #1a0b20 55%, #0d0810 100%);
  transform:scale(1.04);animation:kb 18s var(--ease) forwards;
}
@keyframes kb{to{transform:scale(1)}}
.hero::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:
    linear-gradient(180deg,rgba(18,11,20,.6) 0%,rgba(18,11,20,.18) 28%,rgba(18,11,20,.5) 65%,rgba(13,8,16,.94) 100%),
    radial-gradient(ellipse at left bottom,rgba(0,0,0,.5) 0%,rgba(0,0,0,0) 65%);
}
.hero-content{
  position:relative;z-index:2;height:100%;padding-top:120px;
  max-width:1560px;margin:0 auto;padding:0 40px 70px;
  display:flex;flex-direction:column;justify-content:flex-end;
}
@media (max-width:760px){
  .hero-content{padding:100px 22px 60px}
  .hero-foot{margin-top:36px;gap:24px;padding-top:18px}
  .hero-foot p{font-size:14px}
  .hero-foot .scroll-cue{display:none}
  .hero-arrow{display:none}
}
.hero-tag{
  display:flex;gap:14px;align-items:center;flex-wrap:wrap;margin-bottom:36px;
  font-size:11px;letter-spacing:.32em;text-transform:uppercase;color:rgba(245,239,223,.85)
}
@media (max-width:760px){.hero-tag{font-size:9.5px;letter-spacing:.24em;margin-bottom:28px}}
.hero-tag .dot{width:6px;height:6px;background:var(--accent);border-radius:99px;display:inline-block;box-shadow:0 0 16px var(--accent)}
.hero h1{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(56px,11vw,200px);line-height:.9;letter-spacing:-.04em;max-width:18ch;
}
@media (max-width:760px){.hero h1{font-size:clamp(40px,11vw,72px) !important;line-height:.95}}
.hero h1 em{font-weight:400;color:var(--accent)}
.hero-foot{
  display:flex;justify-content:space-between;align-items:flex-end;
  gap:48px;flex-wrap:wrap;margin-top:56px;
  border-top:1px solid rgba(245,239,223,.18);padding-top:22px;
}
.hero-foot p{max-width:48ch;font-size:15.5px;color:rgba(245,239,223,.95);font-weight:300;line-height:1.65;text-shadow:0 1px 12px rgba(0,0,0,.6)}
.scroll-cue{display:flex;align-items:center;gap:12px;font-size:10.5px;letter-spacing:.3em;text-transform:uppercase;color:rgba(245,239,223,.65)}
.scroll-bar{display:inline-block;width:38px;height:1px;background:rgba(245,239,223,.35);position:relative;overflow:hidden}
.scroll-bar::after{content:"";position:absolute;inset:0;background:var(--accent);transform:translateX(-100%);animation:slide 2.6s infinite var(--ease)}
@keyframes slide{50%{transform:translateX(0)}100%{transform:translateX(100%)}}
.hero-arrow{
  position:absolute;left:50%;bottom:24px;transform:translateX(-50%);
  z-index:3;width:24px;height:40px;border:1px solid rgba(245,239,223,.5);border-radius:14px;
  display:grid;place-items:center;
}
.hero-arrow::after{
  content:"";width:3px;height:8px;background:var(--accent);border-radius:99px;
  animation:harrow 2s infinite var(--ease);
}
@keyframes harrow{0%{transform:translateY(-6px);opacity:0}50%{opacity:1}100%{transform:translateY(8px);opacity:0}}

/* ---------- ticker ---------- */
.ticker{
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  overflow:hidden;white-space:nowrap;padding:20px 0;
  font-family:var(--serif);font-style:italic;font-weight:300;
  font-size:clamp(20px,2.6vw,32px);color:var(--mute);letter-spacing:-.005em;
  background:var(--paper);
}
.ticker-track{display:inline-block;animation:tick 48s linear infinite}
.ticker-track span{margin:0 22px}
.ticker-track .sep{color:var(--accent);margin:0 8px}
@keyframes tick{to{transform:translateX(-50%)}}

/* ---------- sections ---------- */
section{padding:110px 0;position:relative}
@media (max-width:760px){section{padding:72px 0}}
.sec-head{
  display:grid;grid-template-columns:1fr 2.2fr;gap:80px;
  align-items:end;margin-bottom:90px;position:relative;
}
@media (max-width:900px){
  .sec-head{grid-template-columns:1fr;gap:20px;margin-bottom:48px}
  .sec-head h2{font-size:clamp(32px,8vw,48px)}
}
.sec-head .label{display:flex;align-items:center;gap:18px}
.sec-head .label::before{content:"";width:36px;height:1px;background:var(--accent)}
.sec-head h2{font-size:clamp(40px,6.2vw,92px);font-weight:300;letter-spacing:-.03em}

/* ---------- manifesto / belief ---------- */
.manifesto{position:relative}
.manifesto-grid{display:grid;grid-template-columns:1fr 1fr;gap:120px;align-items:start}
@media (max-width:900px){.manifesto-grid{grid-template-columns:1fr;gap:60px}}
.manifesto-quote{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(26px,3.2vw,44px);line-height:1.18;letter-spacing:-.018em;color:var(--ink);
}
@media (max-width:760px){.manifesto-quote{font-size:22px;line-height:1.3}}
.manifesto-quote em{color:var(--accent)}
.manifesto-quote::before{
  content:"\201C";font-size:1.6em;line-height:0;vertical-align:-.18em;
  color:var(--accent);margin-right:.05em;
}
.manifesto-side p{font-size:16px !important;color:rgba(245,239,223,.78) !important;line-height:1.85;margin-bottom:18px;max-width:48ch}
@media (max-width:760px){.manifesto-side p{font-size:15px !important}}
.signature{margin-top:36px;display:flex;gap:28px;align-items:center}
.signature .sig-mark{font-family:var(--serif);font-style:italic;font-size:36px;color:var(--accent)}
.signature .sig-meta{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--mute)}
.signature .sig-meta strong{display:block;color:var(--ink);font-weight:400;margin-bottom:4px;font-family:var(--serif);font-size:14px;letter-spacing:.04em;text-transform:none}

/* ---------- trust bar (featured-in) ---------- */
.featured-in{
  background:var(--paper);padding:36px 0;
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
}
.fi-grid{display:grid;grid-template-columns:auto repeat(5,1fr);gap:48px;align-items:center}
.fi-lbl{font-size:10px;letter-spacing:.32em;text-transform:uppercase;color:var(--mute);white-space:nowrap}
.fi-logo{
  font-family:var(--serif);font-size:clamp(15px,1.4vw,21px);font-weight:400;
  color:rgba(245,239,223,.65);text-align:center;letter-spacing:.02em;
  transition:color .35s,transform .35s var(--ease);
}
.fi-logo em{font-style:italic;color:var(--accent);opacity:.85}
.fi-logo:hover{color:var(--ink);transform:translateY(-2px)}
@media (max-width:760px){.fi-grid{grid-template-columns:1fr 1fr;gap:14px}.fi-lbl{grid-column:1/-1;text-align:center}.fi-logo{font-size:14px}}

/* ---------- pastors / founder note ---------- */
.founder-note{background:var(--paper);position:relative;overflow:hidden}
.fn-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:90px;align-items:center}
@media (max-width:900px){.fn-grid{grid-template-columns:1fr;gap:36px}}
.fn-portrait{
  position:relative;aspect-ratio:4/5;overflow:hidden;
  background:
    radial-gradient(circle at 30% 20%,rgba(201,168,76,.08),transparent 60%),
    linear-gradient(135deg,#2d1535,#1a0c1f);
  box-shadow:0 30px 80px rgba(0,0,0,.5);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--serif);font-size:100px;font-weight:300;
  color:var(--accent);letter-spacing:-.05em;
  border:1px solid var(--line);
}
@media (max-width:900px){.fn-portrait{aspect-ratio:4/4;max-height:400px}}
.fn-portrait .badge{
  position:absolute;left:24px;bottom:24px;z-index:2;
  font-family:var(--serif);font-style:italic;font-weight:300;
  font-size:14px;color:rgba(245,239,223,.85);letter-spacing:.02em;
}
.fn-portrait .badge::before{content:"— ";color:var(--accent)}
.fn-text .eyebrow{margin-bottom:32px;display:block}
.fn-text h2{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(32px,4vw,58px);line-height:1.05;letter-spacing:-.025em;margin-bottom:36px;
}
@media (max-width:900px){.fn-text h2{font-size:clamp(28px,5vw,40px) !important;line-height:1.1}}
.fn-text h2 em{color:var(--accent)}
.fn-quote{
  font-family:var(--serif);font-style:italic;font-weight:300;
  font-size:clamp(20px,2.2vw,28px);line-height:1.4;letter-spacing:-.012em;
  color:var(--ink);margin-bottom:36px;padding-left:24px;
  border-left:2px solid var(--accent);
}
@media (max-width:900px){.fn-quote{font-size:18px;line-height:1.5;padding-left:18px}}
.fn-bio{font-size:14.5px;color:var(--mute) !important;opacity:1 !important;line-height:1.8;margin-bottom:28px;max-width:52ch}
.fn-vents{display:flex;flex-wrap:wrap;gap:8px;margin-top:36px;padding-top:36px;border-top:1px solid var(--line)}
.fn-vent{
  font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  padding:9px 16px;border:1px solid var(--line);border-radius:99px;
  color:var(--ink);transition:border-color .3s,background .3s,color .3s;
}
.fn-vent:hover{border-color:var(--accent);background:var(--accent);color:var(--bg)}
.fn-sign{margin-top:40px;display:flex;align-items:center;gap:24px}
.fn-sign .glyph{font-family:var(--serif);font-style:italic;font-size:48px;font-weight:300;color:var(--accent);line-height:1}
.fn-sign .who{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--mute)}
.fn-sign .who strong{display:block;font-family:var(--serif);font-style:italic;font-size:17px;color:var(--ink);font-weight:400;letter-spacing:.02em;text-transform:none;margin-bottom:4px}

/* ---------- pillars strip ---------- */
.index-strip{
  background:var(--paper);border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:0;
}
.index-grid{display:grid;grid-template-columns:repeat(4,1fr)}
@media (max-width:900px){.index-grid{grid-template-columns:repeat(2,1fr)}}
.ix{padding:60px 36px;border-right:1px solid var(--line);position:relative;overflow:hidden}
.ix:last-child{border-right:0}
.ix .num{font-family:var(--serif);font-size:13px;letter-spacing:.04em;color:var(--accent);margin-bottom:24px}
.ix .v{font-family:var(--serif);font-weight:300;line-height:1.1;letter-spacing:-.015em}
.ix .l{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--mute);margin-top:12px;line-height:1.6}
@media (max-width:760px){.ix{padding:36px 20px}.ix .l{font-size:10px}}

/* ---------- ministry cards (discipline cards) ---------- */
.disc-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:48px}
@media (max-width:900px){.disc-cards{grid-template-columns:1fr;gap:18px}}
.dc{
  position:relative;overflow:hidden;aspect-ratio:5/6;min-height:520px;
  background:#1a1220;cursor:pointer;border:1px solid var(--line);
}
@media (max-width:900px){.dc{aspect-ratio:auto;min-height:440px !important;width:100%}}
.dc .dc-bg{
  position:absolute;inset:0;background-size:cover;background-position:center;
  transition:transform 1.6s var(--ease),filter .8s;
}
.dc:hover .dc-bg{transform:scale(1.06)}
.dc::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(18,11,20,.1) 0%,rgba(18,11,20,.2) 50%,rgba(18,11,20,.95) 100%);
  pointer-events:none;
}
.dc-content{
  position:absolute;inset:0;z-index:2;
  padding:36px;display:flex;flex-direction:column;justify-content:flex-end;color:var(--ink);
}
.dc-num{position:absolute;top:24px;left:24px;font-family:var(--serif);font-size:13px;letter-spacing:.06em;color:var(--accent)}
.dc-content h3{font-family:var(--serif);font-weight:300;font-size:clamp(28px,3vw,42px);line-height:1;letter-spacing:-.02em;margin-bottom:16px}
.dc-content h3 em{color:var(--accent)}
.dc-content p{font-size:14px;line-height:1.65;color:rgba(245,239,223,.85);margin-bottom:24px;max-width:32ch;opacity:1 !important}
.dc-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:24px}
.dc-tags span{font-size:10px;letter-spacing:.16em;text-transform:uppercase;padding:6px 12px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.14);border-radius:99px;color:rgba(245,239,223,.85);backdrop-filter:blur(8px)}
.dc-cta{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--accent);padding-top:18px;border-top:1px solid rgba(201,168,76,.4);display:flex;justify-content:space-between;align-items:center}
.dc-cta .arr{transition:transform .4s var(--ease)}
.dc:hover .dc-cta .arr{transform:translateX(8px)}

/* ---------- gallery ---------- */
.gallery{padding:0;display:grid;grid-template-columns:2fr 1fr;gap:4px;height:60vh;min-height:480px;background:var(--bg)}
.gallery > div{background-size:cover;background-position:center;position:relative;overflow:hidden}
.gallery > div::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 60%,rgba(18,11,20,.6))}
.gallery .gcap{position:absolute;left:24px;bottom:24px;z-index:2;font-family:var(--serif);font-style:italic;font-size:18px;color:#fff}
@media (max-width:760px){.gallery{grid-template-columns:1fr;gap:4px;height:auto}.gallery > div{height:50vh}}

/* ---------- testimonials ---------- */
.testimonials{background:var(--paper);position:relative;overflow:hidden}
.t-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;margin-top:64px}
@media (max-width:900px){.t-grid{grid-template-columns:1fr;gap:32px}}
.t-card{
  padding:48px;border:1px solid var(--line);background:var(--bg);
  position:relative;transition:transform .5s var(--ease),border-color .5s;
}
@media (max-width:760px){.t-card{padding:32px 24px}}
.t-card:hover{transform:translateY(-6px);border-color:var(--accent)}
.t-card::before{
  content:"\201C";position:absolute;top:18px;left:24px;
  font-family:var(--serif);font-size:96px;line-height:1;color:var(--accent);opacity:.4;font-weight:300;
}
@media (max-width:760px){.t-card::before{font-size:64px}}
.t-quote{
  font-family:var(--serif);font-weight:300;font-style:italic;
  font-size:clamp(18px,2vw,24px);line-height:1.45;letter-spacing:-.012em;
  color:var(--ink);margin-bottom:32px;padding-top:28px;
}
@media (max-width:760px){.t-quote{font-size:18px}}
.t-meta{display:flex;align-items:center;gap:16px;padding-top:28px;border-top:1px solid var(--line)}
.t-avatar{
  width:54px;height:54px;border-radius:99px;background:var(--paper);
  border:1px solid var(--accent);display:grid;place-items:center;
  font-family:var(--serif);font-size:20px;color:var(--accent);flex-shrink:0;
}
.t-name strong{display:block;font-family:var(--serif);font-size:17px;font-weight:400;color:var(--ink);margin-bottom:2px}
.t-name span{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--mute)}

/* ---------- journey / timeline ---------- */
.timeline{padding:120px 0;background:var(--paper)}
.tl-rows{margin-top:64px}
.tl-row{
  display:grid;grid-template-columns:auto 1fr 2fr auto;gap:48px;
  padding:36px 0;border-bottom:1px solid var(--line);align-items:center;
  transition:padding .5s var(--ease),background .5s;
}
.tl-row:hover{padding-left:18px;background:linear-gradient(90deg,rgba(201,168,76,.04),transparent 50%)}
@media (max-width:900px){.tl-row{grid-template-columns:auto 1fr;gap:24px;padding:24px 0}.tl-desc,.tl-time{display:none}}
.tl-step{
  width:64px;height:64px;border-radius:99px;
  border:1px solid var(--accent);display:grid;place-items:center;
  font-family:var(--serif);font-size:24px;color:var(--accent);font-weight:300;
}
@media (max-width:900px){.tl-step{width:48px;height:48px;font-size:16px}}
.tl-name{font-family:var(--serif);font-weight:300;font-size:clamp(26px,3vw,42px);letter-spacing:-.02em;line-height:1}
@media (max-width:900px){.tl-name{font-size:24px}}
.tl-name em{color:var(--accent)}
.tl-desc{font-size:14.5px;color:var(--mute) !important;opacity:1 !important;line-height:1.7;max-width:60ch}
.tl-time{font-family:var(--serif);font-size:14px;color:var(--mute);white-space:nowrap;font-style:italic}

/* ---------- plan visit / lead CTA ---------- */
.lead-cta{position:relative;overflow:hidden;background:var(--ink);color:var(--bg);padding:0}
.lead-cta-grid{display:grid;grid-template-columns:1fr 1fr;min-height:560px;align-items:stretch}
@media (max-width:900px){.lead-cta-grid{grid-template-columns:1fr}}
.lc-img{position:relative;overflow:hidden;min-height:380px}
.lc-img > div{position:absolute;inset:0;background-size:cover;background-position:center;transform:scale(1.04);transition:transform 1.4s var(--ease)}
.lead-cta:hover .lc-img > div{transform:scale(1.08)}
.lc-text{padding:80px;display:flex;flex-direction:column;justify-content:center}
@media (max-width:900px){.lc-text{padding:48px 22px 64px}}
.lc-text .eyebrow{color:var(--bg);margin-bottom:24px}
.lc-text h2{font-family:var(--serif);font-weight:300;font-size:clamp(36px,4.5vw,64px);line-height:1;letter-spacing:-.025em;margin-bottom:28px;color:var(--bg)}
@media (max-width:900px){.lc-text h2{font-size:36px !important}}
.lc-text h2 em{color:#7a3a80}
.lc-text p{font-size:15.5px;line-height:1.7;color:rgba(18,11,20,.7) !important;opacity:1 !important;margin-bottom:36px;max-width:46ch}
@media (max-width:900px){.lc-text p{font-size:14.5px}}
.lc-actions{display:flex;gap:16px;flex-wrap:wrap;align-items:center}
@media (max-width:900px){.lc-actions{flex-direction:column;align-items:stretch}}

/* ---------- buttons ---------- */
.btn-primary{
  display:inline-flex;align-items:center;gap:10px;
  padding:18px 32px;background:var(--accent);color:var(--bg);
  font-family:var(--sans);font-size:11.5px;letter-spacing:.22em;text-transform:uppercase;font-weight:600;
  border-radius:99px;cursor:pointer;border:1px solid var(--accent);
  transition:transform .35s var(--ease),background .35s,color .35s;
}
.btn-primary:hover{transform:translateX(6px);background:var(--bg);color:var(--accent);border-color:var(--accent)}
.btn-secondary{
  display:inline-flex;align-items:center;gap:10px;
  padding:18px 28px;background:transparent;color:rgba(245,239,223,.95);
  font-family:var(--sans);font-size:11.5px;letter-spacing:.22em;text-transform:uppercase;font-weight:500;
  border-radius:99px;cursor:pointer;border:1px solid rgba(245,239,223,.3);
  transition:border-color .35s,color .35s;
}
.btn-secondary:hover{border-color:var(--accent);color:var(--accent)}
@media (max-width:900px){.btn-primary,.btn-secondary{justify-content:center;padding:16px 24px;font-size:11px}}

/* ---------- FAQ ---------- */
.faq{padding:120px 0}
@media (max-width:900px){.faq{padding:80px 0}}
.faq-grid{display:grid;grid-template-columns:1fr 1.6fr;gap:80px;align-items:start}
@media (max-width:900px){.faq-grid{grid-template-columns:1fr;gap:32px}}
.faq-list{border-top:1px solid var(--line)}
.faq-item{border-bottom:1px solid var(--line);cursor:pointer}
.faq-q{
  display:flex;justify-content:space-between;align-items:center;gap:24px;
  padding:28px 0;font-family:var(--serif);font-weight:300;
  font-size:clamp(18px,2vw,26px);letter-spacing:-.012em;
  transition:padding .4s var(--ease),color .4s;
}
@media (max-width:900px){.faq-q{font-size:18px;padding:22px 0;gap:16px}}
.faq-item:hover .faq-q{padding-left:14px;color:var(--accent)}
.faq-q .ic{
  width:32px;height:32px;border:1px solid var(--line);border-radius:99px;
  display:grid;place-items:center;font-family:var(--sans);font-size:14px;
  flex-shrink:0;transition:transform .4s var(--ease),background .4s,color .4s,border-color .4s;
}
@media (max-width:900px){.faq-q .ic{width:28px;height:28px}}
.faq-item.open .faq-q .ic{transform:rotate(45deg);background:var(--accent);color:var(--bg);border-color:var(--accent)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .6s var(--ease),padding .6s var(--ease)}
.faq-item.open .faq-a{max-height:400px;padding:0 0 32px}
.faq-a p{font-size:15px;color:var(--mute) !important;opacity:1 !important;line-height:1.75;max-width:62ch}
@media (max-width:900px){.faq-a p{font-size:14px}}

/* ---------- contact ---------- */
.contact{background:var(--bg);padding:110px 0 60px}
@media (max-width:900px){.contact{padding:72px 0 40px}}
.contact h2{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(48px,10vw,180px);line-height:.9;letter-spacing:-.04em;margin-bottom:80px;
}
@media (max-width:900px){.contact h2{font-size:48px !important;line-height:1;margin-bottom:48px}}
.contact h2 em{color:var(--accent);font-weight:400}
.contact h2 a{position:relative;display:inline-block;transition:transform .6s var(--ease)}
.contact h2 a:hover{transform:translateX(14px)}
.contact h2 a::after{content:" →";color:var(--accent)}
.contact-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:48px;padding-top:48px;border-top:1px solid var(--line)}
@media (max-width:900px){.contact-grid{grid-template-columns:1fr 1fr;gap:28px}}
@media (max-width:560px){.contact-grid{grid-template-columns:1fr}}
.ci strong{display:block;font-size:10px;letter-spacing:.28em;text-transform:uppercase;color:var(--mute);margin-bottom:14px;font-weight:500}
.ci{font-family:var(--serif);font-size:18px;line-height:1.6;color:var(--ink);font-weight:400}
@media (max-width:900px){.ci{font-size:14px !important}}
.ci a:hover{color:var(--accent)}

/* ---------- footer ---------- */
footer{
  margin-top:120px;padding-top:32px;border-top:1px solid var(--line);
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:18px;
  font-size:11px;color:var(--mute);letter-spacing:.16em;text-transform:uppercase;
}
footer .socials{display:flex;gap:28px}
footer a{transition:color .3s}
footer a:hover{color:var(--accent)}
.built-by{
  font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--mute);opacity:.75;display:inline-flex;gap:6px;align-items:center;
}
.built-by a{color:var(--accent);border-bottom:1px solid transparent;padding-bottom:1px;transition:border-color .3s,color .3s}
.built-by a:hover{border-bottom-color:var(--accent);color:var(--ink)}
.built-by .heart{color:var(--accent)}

/* ---------- floating call button ---------- */
.fab{
  position:fixed;right:24px;bottom:24px;z-index:70;
  width:60px;height:60px;border-radius:99px;
  background:var(--accent);color:var(--bg);
  display:grid;place-items:center;cursor:pointer;
  box-shadow:0 12px 32px rgba(201,168,76,.35),0 4px 12px rgba(0,0,0,.3);
  transition:transform .35s var(--ease),box-shadow .35s;
  text-decoration:none;
}
.fab:hover{transform:translateY(-4px) scale(1.08);box-shadow:0 18px 42px rgba(201,168,76,.5),0 6px 16px rgba(0,0,0,.4)}
.fab svg{width:28px;height:28px;fill:currentColor}
.fab .pulse{position:absolute;inset:-4px;border-radius:99px;border:2px solid var(--accent);animation:pulse 2.4s infinite}
@keyframes pulse{0%{transform:scale(.95);opacity:.7}70%{transform:scale(1.4);opacity:0}100%{opacity:0}}
.fab .lbl{
  position:absolute;right:74px;top:50%;
  background:var(--ink);color:var(--bg);
  padding:10px 18px;border-radius:99px;
  font-family:var(--sans);font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  white-space:nowrap;pointer-events:none;opacity:0;transform:translate(8px,-50%);
  transition:opacity .3s,transform .3s var(--ease);
}
.fab:hover .lbl{opacity:1;transform:translate(0,-50%)}
@media (max-width:560px){.fab .lbl{display:none}.fab{width:54px;height:54px;right:16px;bottom:16px}.fab svg{width:24px;height:24px}}

/* ---------- sticky CTA bar ---------- */
.sticky-bar{
  position:fixed;left:50%;bottom:24px;transform:translateX(-50%) translateY(160%);
  z-index:65;background:#1c1220;border:1px solid var(--accent);
  padding:14px 14px 14px 28px;border-radius:99px;
  display:flex;align-items:center;gap:18px;
  box-shadow:0 18px 48px rgba(0,0,0,.65),0 0 0 4px rgba(201,168,76,.07);
  transition:transform .6s var(--ease);max-width:calc(100vw - 32px);backdrop-filter:blur(8px);
}
.sticky-bar.show{transform:translateX(-50%) translateY(0)}
.sticky-bar .sb-text{font-family:var(--serif);font-style:italic;font-size:15px;color:var(--ink);white-space:nowrap}
.sticky-bar .sb-text em{color:var(--accent);font-weight:400;font-style:italic}
.sticky-bar .sb-cta{
  background:var(--accent);color:var(--bg);padding:11px 22px;border-radius:99px;
  font-family:var(--sans);font-size:10.5px;letter-spacing:.2em;text-transform:uppercase;font-weight:600;
  transition:background .3s,color .3s;
}
.sticky-bar .sb-cta:hover{background:var(--bg);color:var(--accent)}
@media (max-width:560px){.sticky-bar{display:none}}

/* ---------- section dots ---------- */
.section-dots{
  position:fixed;right:32px;top:50%;transform:translateY(-50%);z-index:55;
  display:flex;flex-direction:column;gap:14px;
}
.section-dots a{
  width:8px;height:8px;border-radius:99px;background:rgba(245,239,223,.2);
  transition:all .3s;position:relative;
}
.section-dots a:hover,.section-dots a.active{background:var(--accent);transform:scale(1.4)}
.section-dots a .lab{
  position:absolute;right:18px;top:50%;transform:translate(8px,-50%);
  font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--mute);
  white-space:nowrap;opacity:0;transition:opacity .3s,transform .3s var(--ease);
  pointer-events:none;
}
.section-dots a:hover .lab{opacity:1;transform:translate(0,-50%);color:var(--accent)}
@media (max-width:1280px){.section-dots{display:none}}

/* ---------- cursor ---------- */
.cursor{position:fixed;top:0;left:0;width:8px;height:8px;border-radius:99px;background:var(--accent);pointer-events:none;z-index:200;mix-blend-mode:difference;transform:translate(-50%,-50%);transition:width .3s var(--ease),height .3s var(--ease)}
@media (hover:none){.cursor{display:none}}

/* ---------- progress bar ---------- */
.progress{position:fixed;top:0;left:0;height:2px;background:var(--accent);z-index:80;width:0;transition:width .15s linear}

/* ---------- reveal animations ---------- */
.reveal{opacity:0;transform:translateY(48px);transition:opacity 1.2s var(--ease),transform 1.2s var(--ease);will-change:transform,opacity}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.1s}.reveal.d2{transition-delay:.2s}.reveal.d3{transition-delay:.3s}
.r-up{opacity:0;transform:translateY(60px);transition:opacity 1.1s var(--ease),transform 1.1s var(--ease)}
.r-up.in{opacity:1;transform:none}
.r-zoom{opacity:0;transform:scale(.94);transition:opacity 1.2s var(--ease),transform 1.4s var(--ease)}
.r-zoom.in{opacity:1;transform:scale(1)}
.r-fade{opacity:0;transition:opacity 1.4s var(--ease)}
.r-fade.in{opacity:1}
.parallax{will-change:transform}
@media (max-width:900px){.parallax,.dc-bg.parallax{transform:none !important;transition:none !important}.dc-bg{position:absolute !important;inset:0 !important;width:100% !important;height:100% !important;transform:none !important}}

/* ---------- accessibility ---------- */
a:focus-visible,button:focus-visible,input:focus-visible,textarea:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:2px}
@media (hover:none){.cursor{display:none !important}}
@media (prefers-reduced-motion:reduce){.reveal,.r-up,.r-zoom,.r-fade{opacity:1;transform:none;transition:none}body::after{display:none}}
