/* ════════════════════════════════════════════════════════════
   PROJECT RAHMAN: shared styles (index.html + bbq.html)
   navy + cream + ember · Fraunces / Hanken Grotesk
   ════════════════════════════════════════════════════════════ */

:root{
  --navy:#2d4356;
  --navy-deep:#21323f;
  --navy-ink:#1b2832;
  --cream:#f6efe2;
  --cream-soft:#fbf7ee;
  --ember:#c97b4a;
  --ember-deep:#b06337;
  --ink:#22313c;
  --muted:#6f6557;
  --line:rgba(45,67,86,.14);
  --card:#fffdf8;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:'Hanken Grotesk',sans-serif;
  background:var(--cream);
  color:var(--ink);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
a{color:inherit}
.wrap{max-width:720px;margin:0 auto;padding:0 24px}
.wrap-wide{max-width:880px;margin:0 auto;padding:0 24px}

/* editable placeholders */
.tbd{color:var(--ember-deep);border-bottom:2px dotted var(--ember);font-style:italic;font-weight:600}

/* ───── grain + glow helpers ───── */
.grain::after{
  content:'';position:absolute;inset:0;opacity:.04;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ───── top nav ───── */
.nav{position:sticky;top:0;z-index:50;background:rgba(246,239,226,.82);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav .wrap-wide{display:flex;align-items:center;justify-content:space-between;height:62px}
.nav .logo{display:flex;align-items:center;gap:9px;text-decoration:none}
.nav .logo svg{width:26px;height:26px;flex:none}
.nav .logo span{font-family:'Fraunces',serif;font-weight:600;font-size:.74rem;letter-spacing:.26em;text-transform:uppercase;color:var(--navy);padding-top:2px}
.nav .links{display:flex;gap:22px}
.nav .links a{text-decoration:none;font-size:.92rem;font-weight:600;color:var(--navy);opacity:.78;transition:opacity .15s}
.nav .links a:hover{opacity:1}
.nav .links a.pill{background:var(--ember);color:#fff;padding:7px 16px;border-radius:999px;opacity:1}
.nav .links a.pill:hover{background:var(--ember-deep)}
@media(max-width:560px){.nav .links a:not(.pill){display:none}}

/* ───── hero (shared) ───── */
.hero{background:var(--navy);color:var(--cream-soft);position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;top:-30%;left:50%;transform:translateX(-50%);width:120%;height:80%;background:radial-gradient(ellipse at center,rgba(201,123,74,.30),transparent 62%);pointer-events:none}
.hero .wrap,.hero .wrap-wide{position:relative;z-index:1}
.kicker{font-size:.74rem;letter-spacing:.28em;text-transform:uppercase;color:var(--ember);font-weight:600;margin-bottom:18px}
h1{font-family:'Fraunces',serif;font-weight:600;line-height:.99;letter-spacing:-.01em;color:#fff}
h1 em{font-style:italic;color:var(--ember)}
.lede{color:rgba(246,239,226,.84)}

/* ───── reveal ───── */
.rise{opacity:0;transform:translateY(18px);animation:rise .8s cubic-bezier(.2,.7,.3,1) forwards}
@keyframes rise{to{opacity:1;transform:none}}
.d1{animation-delay:.05s}.d2{animation-delay:.16s}.d3{animation-delay:.28s}.d4{animation-delay:.40s}.d5{animation-delay:.52s}
.obs{opacity:0;transform:translateY(22px);transition:opacity .7s ease,transform .7s ease}
.obs.seen{opacity:1;transform:none}

/* ───── buttons ───── */
.btn{display:inline-block;background:var(--ember);color:#fff;text-decoration:none;font-weight:700;font-size:1.02rem;padding:15px 36px;border-radius:999px;transition:transform .18s,background .18s,box-shadow .18s;box-shadow:0 14px 30px -12px rgba(201,123,74,.8);cursor:pointer;border:none}
.btn:hover{background:var(--ember-deep);transform:translateY(-2px);box-shadow:0 18px 36px -12px rgba(201,123,74,.9)}
.btn:active{transform:translateY(0)}
.btn-ghost{display:inline-block;text-decoration:none;font-weight:600;color:var(--navy);padding:13px 26px;border:1px solid var(--line);border-radius:999px;transition:background .18s}
.btn-ghost:hover{background:rgba(45,67,86,.05)}

/* ───── section headers ───── */
.eyebrow{font-size:.72rem;letter-spacing:.26em;text-transform:uppercase;color:var(--ember-deep);font-weight:700;margin-bottom:16px}
.sec-head{font-family:'Fraunces',serif;font-weight:600;font-size:clamp(1.6rem,5vw,2.1rem);color:var(--navy);line-height:1.1;margin-bottom:10px}
.sec-note{color:var(--muted);font-size:1rem}

/* ───── cards grid (past events) ───── */
.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:16px}
.ecard{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:24px;transition:transform .2s,box-shadow .2s}
.ecard:hover{transform:translateY(-3px);box-shadow:0 20px 40px -26px rgba(33,50,63,.4)}
.ecard .tagsm{font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;font-weight:700;color:var(--ember-deep);margin-bottom:10px}
.ecard h3{font-family:'Fraunces',serif;font-weight:600;font-size:1.18rem;color:var(--navy);margin-bottom:8px;line-height:1.2}
.ecard p{font-size:.94rem;color:var(--muted)}

/* ───── volunteer band ───── */
.vol{background:var(--navy);color:var(--cream-soft);border-radius:22px;padding:40px 34px;position:relative;overflow:hidden}
.vol::after{content:'';position:absolute;right:-50px;bottom:-50px;width:200px;height:200px;background:radial-gradient(circle,rgba(201,123,74,.26),transparent 70%)}
.vol .in{position:relative;z-index:1}
.vol .eyebrow{color:var(--ember)}
.vol h2{font-family:'Fraunces',serif;font-weight:600;font-size:1.7rem;color:#fff;margin-bottom:14px;line-height:1.15}
.vol p{color:rgba(246,239,226,.86);max-width:52ch;margin-bottom:10px}
.vol .pill-row{margin-top:22px;display:flex;flex-wrap:wrap;gap:9px}
.vol .vpill{background:rgba(246,239,226,.08);border:1px solid rgba(246,239,226,.18);border-radius:999px;padding:7px 14px;font-size:.85rem;font-weight:500}

/* ───── featured event teaser (on index) ───── */
.feature{background:var(--ember);color:#fff;border-radius:22px;padding:38px 34px;position:relative;overflow:hidden}
.feature::before{content:'';position:absolute;inset:0;opacity:.07;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
.feature .in{position:relative;z-index:1}
.feature .tagsm{font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;font-weight:700;opacity:.9;margin-bottom:12px}
.feature h2{font-family:'Fraunces',serif;font-weight:600;font-size:2rem;line-height:1.05;margin-bottom:12px}
.feature p{opacity:.92;max-width:40ch;margin-bottom:24px}
.feature .btn-w{display:inline-block;background:#fff;color:var(--ember-deep);text-decoration:none;font-weight:700;padding:14px 30px;border-radius:999px;transition:transform .18s}
.feature .btn-w:hover{transform:translateY(-2px)}

/* ───── plate / pricing (bbq) ───── */
.plate{background:var(--navy);color:var(--cream-soft);border-radius:22px;padding:40px 34px;position:relative;overflow:hidden;box-shadow:0 24px 60px -28px rgba(33,50,63,.6)}
.plate::after{content:'';position:absolute;right:-40px;top:-40px;width:180px;height:180px;background:radial-gradient(circle,rgba(201,123,74,.28),transparent 70%)}
.plate .pr{position:relative;z-index:1}
.price{display:flex;align-items:baseline;gap:6px;margin-bottom:2px}
.price .num{font-family:'Fraunces',serif;font-size:3.4rem;font-weight:600;color:#fff;line-height:1}
.price .per{color:var(--ember);font-weight:600;font-size:1rem}
.deal{margin:14px 0 4px;display:flex;align-items:center;gap:12px;background:rgba(201,123,74,.16);border:1px solid rgba(201,123,74,.4);border-radius:12px;padding:13px 16px}
.deal .big{font-family:'Fraunces',serif;font-weight:600;font-size:1.3rem;color:#fff;line-height:1}
.deal .small{font-size:.86rem;color:#f0c9ac;font-weight:500}
.plate h3{font-family:'Fraunces',serif;font-weight:500;font-size:1.12rem;color:#fff;margin:24px 0 14px}
.menu{list-style:none;display:grid;gap:12px}
.menu li{display:flex;gap:13px;align-items:flex-start;font-size:1rem;color:rgba(246,239,226,.9)}
.menu li svg{width:19px;height:19px;flex:none;margin-top:3px;color:var(--ember)}
.menu li b{color:#fff;font-weight:600}
.halal{margin-top:22px;display:inline-flex;align-items:center;gap:10px;background:rgba(246,239,226,.08);border:1px solid rgba(246,239,226,.2);color:#f0c9ac;border-radius:10px;padding:11px 17px;font-size:1.12rem;font-weight:600}
.halal span{text-decoration:underline;text-underline-offset:3px}

/* ───── order steps (bbq) ───── */
.steps{display:grid;gap:14px;counter-reset:s}
.step{display:grid;grid-template-columns:38px 1fr;gap:16px;align-items:start;background:var(--card);border:1px solid var(--line);border-radius:14px;padding:18px 20px}
.step .n{counter-increment:s;width:38px;height:38px;border-radius:50%;background:var(--navy);color:#fff;display:grid;place-items:center;font-family:'Fraunces',serif;font-weight:600;font-size:1.05rem}
.step .n::before{content:counter(s)}
.step .t{font-size:1rem;color:var(--ink)}
.step .t b{color:var(--navy);font-weight:700}
.step .t .venmo{font-weight:700;color:var(--ember-deep)}

/* ───── details rows (bbq) ───── */
.rows{display:grid;gap:2px}
.row{display:grid;grid-template-columns:34px 1fr;gap:16px;align-items:start;padding:18px 0;border-bottom:1px solid var(--line)}
.row:last-child{border-bottom:none}
.row .ic{width:34px;height:34px;border-radius:9px;background:rgba(45,67,86,.07);display:grid;place-items:center;color:var(--navy)}
.row .ic svg{width:18px;height:18px}
.row .lbl{font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);font-weight:700;margin-bottom:2px}
.row .val{font-size:1.06rem;color:var(--ink);font-weight:500}
.row .val small{display:block;font-size:.92rem;color:var(--muted);font-weight:400;margin-top:2px}

/* ───── trust strip ───── */
.trust{display:flex;justify-content:center;flex-wrap:wrap;gap:8px 22px}
.trust span{font-size:.84rem;color:var(--muted);font-weight:500}
.trust b{color:var(--navy);font-weight:700}

/* ───── footer ───── */
footer{padding:48px 0 60px;text-align:center;border-top:1px solid var(--line);margin-top:8px}
.ig{display:inline-flex;align-items:center;gap:9px;color:var(--navy);text-decoration:none;font-weight:600;font-size:1rem;padding:10px 18px;border:1px solid var(--line);border-radius:999px;transition:background .18s}
.ig:hover{background:rgba(45,67,86,.05)}
.ig svg{width:18px;height:18px}
.tag{font-family:'Fraunces',serif;font-style:italic;font-size:1.15rem;color:var(--navy);margin-top:26px}
.tag .heart{color:var(--ember)}
.credit{margin-top:14px;font-size:.78rem;color:var(--muted)}

/* ───── past-events photo gallery ───── */
.feed{padding:8px 0 56px;border-top:1px solid var(--line)}
.feed .wrap{padding-top:48px}
.shots{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;margin-top:22px}
.shot{position:relative;aspect-ratio:1/1;border-radius:14px;overflow:hidden;border:1px solid var(--line);margin:0}
.shot .ph{position:absolute;inset:0;display:grid;place-items:center;text-align:center;padding:16px;color:var(--cream-soft);font-family:'Fraunces',serif;font-weight:500;font-size:1rem;line-height:1.25;background:linear-gradient(155deg,var(--navy),var(--navy-deep))}
.shot .ph::after{content:'photo';position:absolute;bottom:12px;left:0;right:0;font-family:'Hanken Grotesk',sans-serif;font-weight:600;font-size:.62rem;letter-spacing:.22em;text-transform:uppercase;color:rgba(246,239,226,.4)}
.shot img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}

/* ───── hero rotating background ───── */
.hero-bg{position:absolute;inset:0;z-index:0;overflow:hidden}
.hero-slide{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;transition:opacity 1.6s ease;will-change:opacity}
.hero-slide.on{opacity:1}
.hero-bg::after{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 50% -10%,rgba(201,123,74,.26),transparent 60%),linear-gradient(180deg,rgba(33,50,63,.5),rgba(33,50,63,.86))}

/* ───── location map ───── */
.locmap{margin:30px 0 0;text-align:center}
.locmap img{width:100%;max-width:400px;border-radius:14px;border:1px solid var(--line);display:block;margin:0 auto;box-shadow:0 18px 40px -24px rgba(33,50,63,.45)}
.locmap figcaption{margin-top:12px;font-size:.9rem;color:var(--muted)}
.locmap figcaption b{color:var(--navy);font-weight:700}
