/* ===========================================================
   House of Solution — Warm & Heritage
   Design system (static gift site)
   =========================================================== */

:root{
  --navy:#171B33; --navy-2:#1F2546; --navy-3:#10132A;
  --gold:#E0A82E; --gold-2:#C8902B; --gold-soft:#F2D89A;
  --wine:#6E1B30; --wine-2:#8A2440;
  --orange:#EF8A1E; --orange-2:#D9760F;
  --cream:#F7F3EA; --cream-2:#EFE7D6;
  --ink:#15182C; --muted:#5C6178;
  --line:rgba(21,24,44,.12);
  --line-d:rgba(247,243,234,.14);
  --container:1240px;
  --r:16px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:"Hanken Grotesk",system-ui,sans-serif;
  background:var(--navy);color:var(--cream);
  line-height:1.6;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.display{font-family:"Fraunces",Georgia,serif;font-optical-sizing:auto;font-weight:600}
.wrap{max-width:var(--container);margin:0 auto;padding:0 clamp(22px,5vw,48px)}

/* ---- type helpers ---- */
.eyebrow{display:inline-flex;align-items:center;gap:12px;font-size:12.5px;letter-spacing:.3em;
  text-transform:uppercase;font-weight:700;color:var(--gold)}
.eyebrow::before{content:"";width:30px;height:2px;background:var(--wine-2)}
.eyebrow.on-light{color:var(--wine)}
.eyebrow.on-light::before{background:var(--gold-2)}
h2.sec{font-weight:600;font-size:clamp(30px,4.2vw,52px);line-height:1.04;letter-spacing:-.02em}
.lede{font-size:clamp(16px,1.35vw,19px);color:#D7D2E0;max-width:54ch}
.lede.on-light{color:#41465f}

/* ---- buttons ---- */
.btn{display:inline-flex;align-items:center;gap:10px;font-weight:700;font-size:16px;
  border-radius:100px;padding:15px 28px;border:1px solid transparent;cursor:pointer;
  transition:transform .25s var(--ease),box-shadow .25s var(--ease),background .25s var(--ease)}
.btn:hover{transform:translateY(-2px)}
.btn-primary{background:linear-gradient(180deg,var(--orange),var(--orange-2));color:#231202;
  box-shadow:0 14px 30px -12px rgba(239,138,30,.7)}
.btn-primary:hover{box-shadow:0 18px 38px -12px rgba(239,138,30,.85)}
.btn-ghost{color:var(--cream);border-color:rgba(247,243,234,.3)}
.btn-ghost:hover{border-color:var(--gold);color:var(--gold)}
.btn-dark{background:var(--navy);color:var(--cream)}
.btn-dark:hover{background:var(--navy-2)}

/* ---- header / nav ---- */
.site-head{position:absolute;top:0;left:0;right:0;z-index:30}
.nav{display:flex;align-items:center;justify-content:space-between;gap:24px;padding:26px 0}
.brand{display:flex;align-items:center;gap:13px}
.mark{width:40px;height:40px;border-radius:50%;flex:none;position:relative;
  background:radial-gradient(circle at 38% 34%,#FBE6A6,var(--gold) 40%,var(--gold-2) 72%);
  box-shadow:0 0 0 1px rgba(224,168,46,.35),0 0 24px 3px rgba(224,168,46,.45)}
.mark::after{content:"";position:absolute;inset:0;border-radius:50%;
  background:conic-gradient(from 210deg,transparent 0 18%,rgba(255,255,255,.85) 22%,transparent 30%)}
.brand .name{display:block;font-family:"Fraunces";font-weight:600;letter-spacing:.05em;font-size:18px;line-height:1;text-transform:uppercase}
.brand .sub{display:block;font-size:10px;letter-spacing:.34em;text-transform:uppercase;color:var(--gold);font-weight:700;margin-top:5px}
.nav-right{display:flex;align-items:center;gap:30px}
.nav-links{display:flex;align-items:center;gap:28px;font-size:14.5px;font-weight:500;color:#D9D3E4}
.nav-links a{opacity:.85;transition:opacity .2s,color .2s}
.nav-links a:hover{opacity:1;color:var(--gold)}
.pill{border:1px solid rgba(224,168,46,.55);color:var(--gold);padding:10px 20px;border-radius:100px;font-weight:600;font-size:14px;transition:background .25s,color .25s}
.pill:hover{background:var(--gold);color:var(--navy)}

/* language switch */
.lang{display:inline-flex;align-items:center;gap:2px;border:1px solid var(--line-d);border-radius:100px;padding:4px}
.lang button{background:none;border:0;color:#B9B4C6;font:inherit;font-size:12.5px;font-weight:700;
  letter-spacing:.04em;padding:5px 11px;border-radius:100px;cursor:pointer;transition:.2s}
.lang button:hover{color:var(--cream)}
.lang button[aria-current="true"]{background:var(--gold);color:var(--navy)}

/* mobile nav */
.burger{display:none;background:none;border:1px solid var(--line-d);border-radius:10px;width:42px;height:42px;cursor:pointer;color:var(--cream)}
.burger span{display:block;width:18px;height:2px;background:currentColor;margin:3px auto;transition:.25s}

/* ---- HERO ---- */
.hero{position:relative;overflow:hidden;min-height:100svh;display:flex;flex-direction:column;
  background:
    radial-gradient(900px 620px at 82% 6%,rgba(224,168,46,.30),transparent 60%),
    radial-gradient(720px 540px at 10% 108%,rgba(110,27,48,.55),transparent 62%),
    linear-gradient(180deg,#191D38,#13162B 72%);}
.hero::after{content:"";position:absolute;inset:0;pointer-events:none;opacity:.55;
  background:radial-gradient(rgba(255,255,255,.02) 1px,transparent 1.4px);background-size:3px 3px}
.hero-inner{position:relative;z-index:5;flex:1;display:flex;align-items:center;padding:120px 0 90px}
.hero h1{font-weight:600;font-size:clamp(42px,6.6vw,94px);line-height:1.0;letter-spacing:-.022em;margin:24px 0 0;max-width:16ch}
.hero h1 em{font-style:italic;color:var(--gold)}
.hero .lede{margin-top:24px}
.hero-cta{display:flex;align-items:center;gap:16px;margin-top:38px;flex-wrap:wrap}
.chip{position:absolute;right:clamp(22px,5vw,48px);bottom:86px;z-index:5;display:flex;align-items:center;gap:10px;
  background:rgba(20,24,46,.85);border:1px solid rgba(224,168,46,.3);padding:12px 18px;border-radius:13px;font-size:13.5px;font-weight:600}
.dot{width:9px;height:9px;border-radius:50%;background:#33D17A;box-shadow:0 0 12px 2px rgba(51,209,122,.8)}
.sidelabel{position:absolute;left:-4px;bottom:160px;z-index:5;transform:rotate(-90deg);transform-origin:left bottom;
  font-size:11px;letter-spacing:.4em;text-transform:uppercase;color:rgba(247,243,234,.4);font-weight:600}
.hero-rule{position:absolute;left:clamp(22px,5vw,48px);right:clamp(22px,5vw,48px);bottom:56px;height:1px;z-index:5;
  background:linear-gradient(90deg,transparent,rgba(224,168,46,.5),transparent)}

/* ---- generic section ---- */
section{position:relative}
.band-dark{background:var(--navy);color:var(--cream)}
.band-cream{background:var(--cream);color:var(--ink)}
.band-cream .lede{color:#41465f}
.pad{padding:clamp(70px,9vw,120px) 0}
.sec-head{max-width:62ch}
.sec-head h2{margin-top:18px}
.sec-head p{margin-top:18px}

/* welcome / new here */
.welcome-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(36px,6vw,80px);align-items:center;margin-top:14px}
.welcome-points{display:flex;flex-direction:column;gap:22px;margin-top:30px}
.wp{display:flex;gap:18px;align-items:flex-start}
.wp .n{font-family:"Fraunces";font-weight:600;font-size:26px;color:var(--gold-2);line-height:1;flex:none;width:40px}
.wp h4{font-size:18px;font-weight:700;color:var(--ink)}
.wp p{font-size:15px;color:var(--muted);margin-top:4px;max-width:42ch}
.welcome-card{background:linear-gradient(160deg,var(--navy-2),var(--navy-3));border:1px solid var(--line-d);
  border-radius:24px;padding:40px;color:var(--cream);position:relative;overflow:hidden}
.welcome-card::before{content:"";position:absolute;width:280px;height:280px;right:-90px;top:-90px;border-radius:50%;
  background:radial-gradient(circle,rgba(224,168,46,.3),transparent 70%)}
.welcome-card .big{font-family:"Fraunces";font-weight:600;font-size:30px;line-height:1.15;position:relative}
.welcome-card .small{margin-top:18px;color:#cdd0db;font-size:15px;position:relative}

/* pastor */
.pastor{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(36px,6vw,72px);align-items:center}
.portrait{aspect-ratio:4/5;border-radius:22px;position:relative;overflow:hidden;
  background:radial-gradient(420px 320px at 50% 28%,rgba(224,168,46,.16),transparent 62%),linear-gradient(160deg,#222a4e,#141832);border:1px solid var(--line-d);
  display:flex;align-items:center;justify-content:center}
.portrait img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:1}
.portrait img ~ .mono,.portrait img ~ .pin{display:none}
.portrait .mono{font-family:"Fraunces";font-weight:600;font-size:96px;color:rgba(224,168,46,.92);letter-spacing:.02em;
  text-shadow:0 8px 40px rgba(224,168,46,.3)}
.portrait .pin{position:absolute;left:18px;bottom:16px;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:rgba(247,243,234,.5);font-weight:600}
.quote{font-family:"Fraunces";font-weight:500;font-size:clamp(24px,3vw,38px);line-height:1.22;letter-spacing:-.01em}
.quote em{color:var(--gold)}
.byline{margin-top:26px;font-weight:700;color:var(--cream)}
.byline span{display:block;color:var(--gold);font-size:14px;letter-spacing:.04em;margin-top:3px}
.pastor .bio{margin-top:22px;color:#cdd0db;font-size:15.5px;max-width:52ch}

/* sermons / watch */
.watch{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,60px);align-items:center}
.video{aspect-ratio:16/9;border-radius:20px;position:relative;overflow:hidden;border:1px solid var(--line-d);display:block;text-decoration:none;
  background:linear-gradient(160deg,#1d2348,#121530);transition:transform .3s var(--ease),box-shadow .3s var(--ease)}
.video:hover{transform:translateY(-3px);box-shadow:0 26px 56px -28px rgba(0,0,0,.55)}
.video-thumb{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.video::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(8,10,22,.10) 45%,rgba(8,10,22,.66));pointer-events:none}
.yt-play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:80px;height:56px;border-radius:16px;background:#FF0000;
  display:flex;align-items:center;justify-content:center;box-shadow:0 12px 32px rgba(0,0,0,.5);z-index:2;transition:transform .25s var(--ease)}
.yt-play::after{content:"";border-style:solid;border-width:12px 0 12px 20px;border-color:transparent transparent transparent #fff;margin-left:4px}
.video:hover .yt-play{transform:translate(-50%,-50%) scale(1.09)}
.video-foot{position:absolute;left:18px;bottom:16px;z-index:2;display:flex;align-items:center;gap:10px;color:#fff;font-weight:700;font-size:14px;text-shadow:0 1px 8px rgba(0,0,0,.6)}
.video-foot .yt-badge{display:inline-flex;align-items:center;gap:6px;background:#FF0000;color:#fff;font-size:12px;font-weight:800;padding:4px 9px;border-radius:6px}
.video-foot .yt-badge::before{content:"";border-style:solid;border-width:5px 0 5px 8px;border-color:transparent transparent transparent #fff}
.watch-list{display:flex;flex-direction:column;gap:14px;margin-top:26px}
.watch-row{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px 0;border-bottom:1px solid var(--line-d)}
.watch-row b{font-weight:600;font-family:"Fraunces";font-size:18px}
.watch-row small{color:#a9adbd;font-size:13px;display:block;margin-top:2px;font-family:"Hanken Grotesk"}
.watch-row .arw{color:var(--gold);font-size:20px}

/* ministries */
.min-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:14px}
.min{background:var(--cream);border:1px solid var(--line);border-radius:18px;padding:30px 26px;transition:transform .3s var(--ease),box-shadow .3s var(--ease)}
.min:hover{transform:translateY(-5px);box-shadow:0 24px 50px -28px rgba(21,24,44,.45)}
.min .ix{font-family:"Fraunces";font-weight:600;color:var(--gold-2);font-size:15px}
.min h4{font-family:"Fraunces";font-weight:600;font-size:23px;margin:14px 0 8px;letter-spacing:-.01em}
.min p{color:var(--muted);font-size:14.5px}
.min.feature{background:linear-gradient(160deg,var(--wine),#561226);color:var(--cream);border-color:transparent;grid-row:span 2}
.min.feature h4,.min.feature .ix{color:var(--gold-soft)}
.min.feature p{color:#ecd9de}

/* conference band */
.conf{background:linear-gradient(120deg,var(--navy-3),#241a39 60%,#3a1326);overflow:hidden;position:relative}
.conf::after{content:"";position:absolute;right:-100px;top:-80px;width:420px;height:420px;border-radius:50%;
  background:radial-gradient(circle,rgba(224,168,46,.28),transparent 70%)}
.conf .wrap{position:relative;z-index:2;display:grid;grid-template-columns:1fr 1.1fr;gap:48px;align-items:center}
.conf-poster img{width:100%;border-radius:18px;border:1px solid rgba(224,168,46,.28);box-shadow:0 34px 70px -34px rgba(0,0,0,.7);display:block}
.conf h2{color:var(--cream)}
.conf .kicker{font-family:"Fraunces";font-style:italic;color:var(--gold);font-size:clamp(20px,2.4vw,30px)}

/* visit */
.visit{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,60px);align-items:stretch}
.map{display:flex;align-items:center;justify-content:center;text-decoration:none;border-radius:20px;overflow:hidden;
  border:1px solid var(--line-d);min-height:340px;
  background:radial-gradient(560px 300px at 50% 28%,rgba(224,168,46,.18),transparent 65%),linear-gradient(160deg,#1d2348,#11142c);
  transition:transform .3s var(--ease),box-shadow .3s var(--ease),border-color .3s}
.map:hover{transform:translateY(-3px);border-color:rgba(224,168,46,.45);box-shadow:0 26px 56px -30px rgba(0,0,0,.6)}
.map-inner{display:flex;flex-direction:column;align-items:center;gap:10px;text-align:center;color:var(--cream);padding:28px}
.map-pin{color:var(--gold);filter:drop-shadow(0 8px 16px rgba(224,168,46,.4))}
.map-addr{font-weight:600;font-size:15px;color:#e9e6ef}
.map-hint{color:var(--gold);font-weight:700;font-size:14px;letter-spacing:.02em}
.map:hover .map-hint{text-decoration:underline}
.visit-info{display:flex;flex-direction:column;justify-content:center}
.times{display:flex;flex-direction:column;gap:12px;margin:24px 0}
.time-row{display:flex;align-items:baseline;justify-content:space-between;gap:16px;padding:14px 0;border-bottom:1px solid var(--line)}
.time-row b{font-family:"Fraunces";font-weight:600;font-size:18px}
.time-row span{color:var(--gold);font-weight:600}
.addr{color:var(--muted);font-size:15.5px;margin-bottom:8px}

/* give */
.give{background:var(--cream);color:var(--ink)}
.give-card{background:linear-gradient(155deg,#1b1f3c,#11142a);border-radius:26px;padding:clamp(36px,5vw,64px);
  color:var(--cream);text-align:center;position:relative;overflow:hidden}
.give-card::before{content:"";position:absolute;width:340px;height:340px;left:50%;top:-120px;transform:translateX(-50%);
  background:radial-gradient(circle,rgba(224,168,46,.28),transparent 70%)}
.give-card h2,.give-card p,.give-card .btn{position:relative}
.give-card h2{color:var(--cream)}
.give-card .lede{margin:18px auto 30px;color:#cdd0db}

/* footer */
.foot{background:var(--navy-3);color:#c7cad8;padding:72px 0 36px;border-top:1px solid var(--line-d)}
.foot-top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px}
.foot h5{font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);font-weight:700;margin-bottom:16px}
.foot a{display:block;padding:5px 0;color:#c7cad8;transition:color .2s}
.foot a:hover{color:var(--gold)}
.foot .chan{display:flex;gap:12px;margin-top:18px}
.foot .chan a{width:40px;height:40px;border:1px solid var(--line-d);border-radius:11px;display:flex;align-items:center;justify-content:center;color:#c7cad8;font-size:13px;font-weight:700;padding:0}
.foot .chan a:hover{border-color:var(--gold);color:var(--gold)}
.foot-bottom{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-top:48px;padding-top:24px;border-top:1px solid var(--line-d);font-size:13px;color:#8a8ea0}
.foot-bottom a{display:inline;color:#8a8ea0}
.foot-bottom a:hover{color:var(--gold)}

/* reveal animation */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}html{scroll-behavior:auto}}

/* ---- responsive ---- */
@media (max-width:900px){
  .nav-links{display:none}
  .burger{display:block}
  .nav{padding:18px 0}
  .nav-right{gap:12px}
  .brand .sub{display:none}
  .brand .name{font-size:15px}
  .mark{width:34px;height:34px}
  .pill{display:none}
  .lang button{padding:5px 9px;font-size:12px}
  .welcome-grid,.pastor,.watch,.visit,.conf .wrap,.min-grid,.foot-top{grid-template-columns:1fr}
  .min.feature{grid-row:auto}
  .min-grid{gap:14px}
  .pastor .portrait{max-width:380px}
  .chip{position:static;display:inline-flex;margin-top:28px}
  .hero-rule,.sidelabel{display:none}
  .hero-inner{padding:108px 0 70px}
}
@media (max-width:560px){
  .foot-bottom{flex-direction:column}
  .btn{width:100%;justify-content:center}
  .hero-cta{flex-direction:column;align-items:stretch}
}

/* mobile menu open state */
body.menu-open .nav-links{display:flex;position:absolute;top:78px;left:clamp(22px,5vw,48px);right:clamp(22px,5vw,48px);
  flex-direction:column;gap:0;background:var(--navy-2);border:1px solid var(--line-d);border-radius:16px;padding:8px 18px}
body.menu-open .nav-links a{padding:14px 0;border-bottom:1px solid var(--line-d)}
