/*
  Mahoney Road — Shared Stylesheet
  Version: 1.0 — May 2026
  Applies to: all pages on mahoneyroad.com
  Page-specific styles live in each HTML file's own <style> block
*/

/* ── TOKENS ──────────────────────────────────────────────────── */
:root{
  --olive:#766621;--olive-dark:#5a4f1b;
  --rust:#9c4f20;--rust-dark:#7a3c17;
  --sand:#daa46d;--cream:#fbe1b6;--cream-light:#fdf3e3;
  --slate:#7388a0;
  --ink:#2d2a26;--muted:#6e655c;
  --bg:#f7f1e8;--white:#ffffff;
  --line:rgba(45,42,38,0.10);
  --shadow:0 20px 50px rgba(45,42,38,0.09);
  --max:1160px;--nav-h:76px;--pad:104px;
}

/* ── RESET ───────────────────────────────────────────────────── */
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--ink);font-family:"Lora",serif;font-size:17px;line-height:1.76;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

/* ── LAYOUT ──────────────────────────────────────────────────── */
.wrap{width:min(var(--max),calc(100% - 48px));margin:0 auto}
.section{padding:var(--pad) 0}
.section-white{background:var(--white)}
.section-warm{background:var(--bg)}
.two-col{display:grid;grid-template-columns:1.08fr 0.92fr;gap:68px;align-items:start}
.rule-warm{border:0;height:1px;background:linear-gradient(90deg,transparent,rgba(156,79,32,0.2),transparent);margin:0}

/* ── NAVIGATION ──────────────────────────────────────────────── */
nav{position:sticky;top:0;z-index:100;height:var(--nav-h);background:var(--white);backdrop-filter:blur(16px);border-bottom:3px solid var(--slate)}
.nav-inner{height:100%;display:flex;align-items:center;justify-content:space-between;gap:24px}
.nav-logo{display:flex;align-items:center;gap:11px;text-decoration:none}
.nav-logo img{width:44px;height:44px;border-radius:50%;object-fit:cover;flex-shrink:0}
.nav-wordmark{display:flex;flex-direction:column;gap:3px}
.nav-wordmark strong{font-family:"Playfair Display",serif;font-size:20px;font-weight:600;letter-spacing:0.08em;color:var(--ink);line-height:1}
.nav-wordmark span{font-family:"Montserrat",sans-serif;font-size:7.5px;font-weight:600;letter-spacing:0.20em;text-transform:uppercase;color:var(--muted)}
.nav-links{display:flex;align-items:center;gap:18px;list-style:none;font-family:"Montserrat",sans-serif;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:0.08em}
.nav-links a{color:var(--muted);transition:color .15s}
.nav-links a:hover{color:var(--rust)}
.nav-cta{padding:10px 18px;background:var(--rust);color:var(--white)!important;border-radius:3px;transition:background .15s!important}
.nav-cta:hover{background:var(--rust-dark)!important}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:4px;border:none;background:transparent}
.hamburger span{display:block;width:22px;height:2px;background:var(--ink);border-radius:2px;transition:all .2s}

/* ── TYPOGRAPHY ──────────────────────────────────────────────── */
h1,h2,h3,h4{font-family:"Montserrat",sans-serif;color:var(--ink);margin:0}
h1{font-size:clamp(38px,5vw,66px);line-height:1.0;letter-spacing:-0.03em;font-weight:700}
h2{font-size:clamp(28px,3.5vw,44px);line-height:1.06;letter-spacing:-0.025em;font-weight:700}
h3{font-size:18px;line-height:1.26;font-weight:700}
.eyebrow{display:inline-flex;align-items:center;gap:9px;font-family:"Montserrat",sans-serif;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:0.16em;margin-bottom:14px}
.eyebrow::before{content:"";width:22px;height:1px;background:currentColor;flex-shrink:0}
.eyebrow-rust{color:var(--rust)}
.eyebrow-light{color:rgba(255,255,255,0.78)}
.eyebrow-cream{color:var(--cream)}
.lead{color:var(--muted);font-size:17px;line-height:1.78;margin-top:18px;max-width:700px}

/* ── BUTTONS ─────────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;justify-content:center;font-family:"Montserrat",sans-serif;font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:0.09em;border-radius:3px;transition:all .18s;white-space:normal}
.btn-rust{padding:15px 26px;background:var(--rust);color:var(--white);box-shadow:0 8px 20px rgba(156,79,32,0.22)}
.btn-rust:hover{background:var(--rust-dark);transform:translateY(-1px)}
.btn-outline{padding:13px 22px;border:1.5px solid rgba(45,42,38,0.24);color:var(--ink);background:transparent}
.btn-outline:hover{border-color:var(--rust);color:var(--rust)}
.btn-white{padding:15px 26px;background:var(--white);color:var(--rust)}
.btn-white:hover{background:var(--cream-light)}
.btn-outline-light{padding:13px 22px;border:1.5px solid rgba(255,255,255,0.45);color:var(--white);background:transparent}
.btn-outline-light:hover{border-color:rgba(255,255,255,0.85)}

/* ── BRIDGE BAND ─────────────────────────────────────────────── */
.bridge{background:var(--slate);padding:36px 0;text-align:center}
.bridge-inner{max-width:1060px;margin:0 auto}
.bridge p{font-family:"Montserrat",sans-serif;font-size:clamp(15px,1.8vw,20px);font-weight:500;line-height:1.62;color:var(--white);letter-spacing:-0.005em;max-width:880px;margin:0 auto}
.bridge p span{color:var(--cream)}

/* ── ICON CARDS ──────────────────────────────────────────────── */
.icon-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;align-self:center}
.icon-card{background:var(--bg);border:1px solid var(--line);border-radius:8px;padding:22px 20px}
.section-white .icon-card{background:var(--white)}
.icon-dot{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:14px}
.icon-card h3{font-size:15px;line-height:1.25}
.icon-card p{color:var(--muted);font-size:13px;margin-top:7px;line-height:1.6}

/* ── OUTCOME PANEL ───────────────────────────────────────────── */
.outcome{display:grid;grid-template-columns:1fr 1fr;border-radius:10px;overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow)}
.outcome-photo{position:relative;min-height:480px;overflow:hidden}
.outcome-photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center center}
.outcome-copy{background:rgba(251,225,182,0.48);padding:52px 46px;display:flex;flex-direction:column;justify-content:center}
.outcome-copy h2{font-size:clamp(24px,2.8vw,36px)}
.outcome-copy .sub{color:#5a5047;margin-top:14px;font-size:16px;font-family:"Lora",serif}
.check-list{list-style:none;margin-top:20px;display:grid;gap:10px}
.check-list li{display:flex;gap:10px;align-items:flex-start;font-size:15px;color:#5a5047;font-family:"Lora",serif}
.check-list li::before{content:"✓";color:var(--rust);font-weight:700;flex-shrink:0;margin-top:1px}
.outcome-cta{margin-top:28px}

/* ── PROCESS / HOW IT WORKS ──────────────────────────────────── */
.process-intro{max-width:760px;margin-bottom:44px}
.process-intro h2{margin-bottom:14px}
.process-intro p{color:var(--muted);font-size:17px;line-height:1.76}
.process-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.process-tile{background:var(--bg);border:1px solid var(--line);border-radius:8px;padding:26px 22px;display:flex;flex-direction:column}
.section-white .process-tile{background:var(--white)}
.step-badge{width:44px;height:44px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-family:"Montserrat",sans-serif;font-size:11px;font-weight:700;color:var(--white);margin-bottom:16px;flex-shrink:0}
.s1{background:var(--olive)}.s2{background:var(--rust)}.s3{background:var(--sand)}.s4{background:var(--slate)}
.process-tile h3{font-size:16px;margin-bottom:10px}
.process-tile p{color:var(--muted);font-size:13px;line-height:1.65;flex:1}
.process-footer{margin-top:24px;padding:16px 22px;background:rgba(45,42,38,0.05);border-radius:6px;border:1px solid var(--line);text-align:center;font-family:"Montserrat",sans-serif;font-size:11px;color:var(--muted);letter-spacing:0.03em}

/* ── CTA BAND ────────────────────────────────────────────────── */
.cta-band{background:var(--rust);padding:64px 0;text-align:center}
.cta-inner{max-width:600px;margin:0 auto}
.cta-band h2{color:var(--white);font-size:clamp(24px,3vw,38px)}
.cta-band p{color:rgba(255,255,255,0.84);margin-top:14px;font-size:17px}
.cta-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-top:26px}
.cta-note{margin-top:14px;font-family:"Montserrat",sans-serif;font-size:10px;color:rgba(255,255,255,0.48);letter-spacing:0.04em}

/* ── FOOTER ──────────────────────────────────────────────────── */
footer{background:var(--white);border-top:3px solid var(--slate);padding:40px 0 22px}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr;gap:48px;margin-bottom:24px;align-items:start}
.footer-left{display:flex;gap:13px;align-items:flex-start}
.footer-logo-img{width:42px;height:42px;border-radius:50%;object-fit:cover;flex-shrink:0;margin-top:2px}
.footer-wordmark strong{font-family:"Playfair Display",serif;font-size:18px;font-weight:600;letter-spacing:0.06em;color:var(--ink);display:block;line-height:1;margin-bottom:4px}
.footer-wordmark span{font-family:"Montserrat",sans-serif;font-size:7.5px;font-weight:600;letter-spacing:0.18em;text-transform:uppercase;color:var(--muted);display:block;margin-bottom:12px}
.footer-desc{font-size:13px;line-height:1.7;color:var(--muted);max-width:460px}
.footer-right{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.footer-nav h4{font-family:"Montserrat",sans-serif;font-size:9px;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;color:var(--muted);margin-bottom:12px}
.footer-links{list-style:none;display:grid;gap:8px}
.footer-links a{font-family:"Montserrat",sans-serif;font-size:12px;color:var(--muted);transition:color .15s}
.footer-links a:hover{color:var(--rust)}
.footer-hr{border:0;border-top:1px solid var(--line);margin:0 0 16px}
.footer-bottom{display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap;font-family:"Montserrat",sans-serif;font-size:10px;color:var(--muted)}

/* ── REVEAL ANIMATIONS ───────────────────────────────────────── */
.reveal{opacity:0;transform:translateY(14px);transition:opacity .58s ease,transform .58s ease}
.reveal.in{opacity:1;transform:none}
.d1{transition-delay:.07s}.d2{transition-delay:.14s}.d3{transition-delay:.21s}.d4{transition-delay:.28s}

/* ── RESPONSIVE ──────────────────────────────────────────────── */
@media(max-width:900px){
  .two-col,.outcome,.footer-grid,.hero-grid{grid-template-columns:1fr}
  .hero-grid{min-height:unset}
  .process-grid{grid-template-columns:1fr 1fr}
  .outcome-photo{min-height:320px}
  .footer-left{flex-direction:column}
  .icon-grid{grid-template-columns:1fr 1fr}
  .hero-photo-col{min-height:380px}
  .hero-copy-col{padding:48px 0}
}
@media(max-width:580px){
  :root{--pad:72px;--nav-h:66px}
  .hero-copy-col{padding:40px 0}
  .hero-photo-col{min-height:300px}
  .process-grid,.icon-grid{grid-template-columns:1fr}
  .hero-actions,.cta-actions{flex-direction:column;align-items:flex-start}
  .cta-actions{align-items:center}
  .footer-right{grid-template-columns:1fr}
  .hamburger{display:flex}
  .nav-links{display:none;position:absolute;top:var(--nav-h);left:0;right:0;flex-direction:column;align-items:flex-start;gap:16px;padding:20px 24px;background:rgba(247,241,232,0.98);border-bottom:1px solid var(--line);z-index:99}
  .nav-links.open{display:flex}
}
