
:root{
  --bg: #0f0f12;
  --surface: #15161a;
  --elev: #1e2026;
  --text: #e8e8ea;
  --muted:#b9bcc6;
  --gold:#d6b25e;
  --line:#353741;
  --card:#181a20;
  --accent:#ffe08a;

  --spine-left: 56px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;line-height:1.55}
img{max-width:100%;display:block;border-radius:18px}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}
.container{max-width:1240px;margin:0 auto;padding:0 20px}

nav.site{
  position:sticky;top:0;z-index:1000;
  backdrop-filter: blur(6px);
  background:rgba(15,15,18,.6);
  border-bottom:1px solid rgba(255,255,255,.06);
}
nav .bar{display:flex;align-items:center;gap:18px;padding:10px 16px}
.brand{display:flex;align-items:center;gap:12px;font-weight:700}
.brand img{width:28px;height:28px;border-radius:8px}
nav .links{display:flex;gap:14px;margin-left:auto;flex-wrap:wrap}
nav .links a{padding:8px 10px;border-radius:10px}
nav .links a:hover{background:rgba(255,255,255,.06);text-decoration:none}

.hero{position:relative;min-height:72vh;display:grid;place-items:center;
  overflow:hidden;border-bottom:1px solid #22252e;
}
.hero .bg{
  position:absolute;inset:0;background:url('assets/images/photo5.jpg') center/cover no-repeat;
  filter:contrast(1.05) saturate(1.05) brightness(.65);
}
.hero::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg, rgba(15,15,18,.2), rgba(15,15,18,.9));
}
.hero .content{
  position:relative;z-index:1;text-align:center;padding:0 20px;
}
.hero h1{
  font-size: clamp(36px, 6vw, 72px);
  line-height:1.0;margin:0 0 10px 0;letter-spacing:-.02em;
}
.hero .kicker{opacity:.9;margin-bottom:22px;font-size:clamp(14px,2.2vw,18px)}
.ctas{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.btn{background:var(--gold);color:#141414;padding:12px 16px;border-radius:12px;font-weight:700;border:none;cursor:pointer}
.btn.alt{background:transparent;color:var(--accent);border:1px solid rgba(255,255,255,.35)}

.story{
  position:relative;
  padding:40px 0 100px 0;
}
/* vertical spine */
.story::before{
  content:"";position:absolute;left: var(--spine-left);top:0;bottom:0;width:2px;background:linear-gradient(var(--gold), transparent 30px), linear-gradient(transparent, var(--line));
  background-repeat:no-repeat;
  background-size:2px 120px, 2px 100%;
}
/* section layout */
.section{position:relative;padding:60px 0;border-bottom:1px solid #20222b}
.section .wrap{display:grid;grid-template-columns:140px 1fr;gap:24px}
.node{position:sticky;top:120px;height:0}
.node .dot{position:absolute;left:var(--spine-left);transform:translateX(-50%);width:14px;height:14px;background:var(--gold);border-radius:50%;border:3px solid #2b2f39;box-shadow:0 0 0 4px rgba(214,178,94,.2)}
.section h2{font-size:clamp(32px,3.6vw,52px);margin:0 0 12px 0;letter-spacing:-.01em}
.lead{opacity:.9;font-size:18px;margin-bottom:18px}
.grid{display:grid;grid-template-columns:1.35fr 1fr;gap:20px;align-items:start}
.card{background:var(--card);border:1px solid #242835;border-radius:18px;padding:18px}
.kv{border-radius:18px;overflow:hidden}

.pillars{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.pillars .card h3{margin:0 0 6px 0;color:var(--accent)}
.pillars .card p{margin:0;color:var(--muted)}

ul.clean{list-style:none;padding:0;margin:0;display:grid;gap:8px}
ul.clean li{display:flex;gap:10px;align-items:flex-start}
.badge{background:#202431;color:#bfc4d3;padding:2px 8px;border-radius:999px;font-size:12px;border:1px solid #2a3040}
.klist{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px}

.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.form-grid .full{grid-column:1 / -1}
label{display:flex;flex-direction:column;gap:6px;font-size:15px}
input[type="text"],input[type="email"],input[type="tel"],select,textarea{
  background:#0f1116;border:1px solid #2a3040;border-radius:12px;padding:12px 12px;color:var(--text)
}
textarea{resize:vertical}
.checkgroup{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:8px}
.checkgroup label{display:flex;align-items:center;gap:8px}
.small{font-size:13px;color:var(--muted)}

.altbg{background:linear-gradient(180deg,#111318,#0f0f12)}

.footer{padding:40px 0;color:#9aa0ad;font-size:14px}
.footer a{color:#cfd3df}

@media (max-width: 980px){
  .story::before{left:40px}
  .section .wrap{grid-template-columns:80px 1fr}
  .node .dot{position:absolute;left:var(--spine-left);transform:translateX(-50%);width:14px;height:14px;background:var(--gold);border-radius:50%;border:3px solid #2b2f39;box-shadow:0 0 0 4px rgba(214,178,94,.2)}
  .grid{grid-template-columns:1fr}
  .pillars{grid-template-columns:1fr}
  .form-grid{grid-template-columns:1fr}
}

/* === v20.2 spine alignment === */
.story::before{ display:none !important; }
.section .wrap{ position: relative; }
.section .wrap::before{
  content:""; position:absolute; left: var(--spine-left); top: -40px; bottom: -40px; width:2px;
  background: linear-gradient(var(--gold), transparent 120px) no-repeat,
              linear-gradient(transparent, var(--line)) no-repeat;
  background-size: 2px 160px, 2px 100%;
  background-position: left top, left top;
}
.node{ position: relative; height:auto; }
.node .dot{
  position:absolute; left: var(--spine-left); top: 6px; transform: translateX(-50%);
  width:14px;height:14px;background:var(--gold);border-radius:50%;
  border:3px solid #2b2f39; box-shadow:0 0 0 4px rgba(214,178,94,.2);
}

/* === v20.3 global spine with scrolling dot === */
.section .wrap::before{ display:none !important; }

#spine{
  position: fixed; top: 60px; bottom: 0; width: 2px; z-index: 10;
  pointer-events: none;
}
#spine .track{
  position:absolute; top:0; bottom:0; left:0; right:0;
  background: linear-gradient(transparent, var(--line) 80px) no-repeat;
  background-size: 2px 100%;
  background-position: left top;
}
#spine .glow{
  position:absolute; width:2px; height:140px; left:0; background: linear-gradient(var(--gold), rgba(214,178,94,.0));
  filter: drop-shadow(0 0 6px rgba(214,178,94,.55));
  border-radius:2px;
}
#spine-dot{
  position:absolute; width:14px; height:14px; border-radius:50%;
  background: var(--gold); border:3px solid #2b2f39; box-shadow:0 0 0 4px rgba(214,178,94,.2);
  left: 50%; transform: translate(-50%, -50%);
}

/* v20.3.1 remove legacy per-section dots */
.node .dot{display:none !important}
.node{height:0 !important}

/* v20.4 Off-season tiles + footer socials */
.tiles{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-top:14px}
.tile{display:block;background:var(--card);border:1px solid #242835;border-radius:18px;overflow:hidden}
.tile img{width:100%;height:260px;object-fit:cover;border-radius:0}
.tile .tile-caption{padding:12px 14px;color:var(--muted)}
.footer .socials{display:flex;gap:14px;margin-top:8px;flex-wrap:wrap}
.footer .socials a{color:#cfd3df}
@media (max-width:980px){.tiles{grid-template-columns:1fr}.tile img{height:220px}}

/* allow JS to set #spine height so it stops at footer */
#spine{top:60px;height:calc(100vh - 60px);bottom:auto}
