/* ============================================
   COASTAL PERFORMANCE — shared styles
   Edit colors here; pages inherit everything.
   ============================================ */

:root{
  --ink:#0A0A0A;
  --ink-2:#111110;
  --bone:#F7F4EE;
  --sun:#F2B11B;
  --sun-deep:#C98A0E;
  --hairline:rgba(247,244,238,.18);
  --muted:rgba(247,244,238,.62);
  --faint:rgba(247,244,238,.4);
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}

body{
  background:var(--ink);
  color:var(--bone);
  font-family:'Jost',sans-serif;
  font-weight:300;
  min-height:100vh;
  display:flex;
  flex-direction:column;
  -webkit-font-smoothing:antialiased;
}

a{color:inherit}

/* ---- Header / Nav ---- */
header.site{
  width:100%;
  display:flex;align-items:center;justify-content:space-between;
  padding:22px 28px;
  border-bottom:1px solid var(--hairline);
  position:sticky;top:0;background:rgba(10,10,10,.92);
  backdrop-filter:blur(8px);z-index:10;
}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none}
.brand svg{width:44px;height:auto}
.brand .name{
  font-family:'Marcellus',serif;font-size:15px;
  letter-spacing:.2em;text-transform:uppercase;line-height:1.3;
}
.brand .name small{
  display:block;font-family:'Jost',sans-serif;font-size:9px;
  letter-spacing:.42em;color:var(--muted);font-weight:400;
}
nav{display:flex;gap:26px}
nav a{
  text-decoration:none;font-size:12px;letter-spacing:.22em;
  text-transform:uppercase;font-weight:400;color:var(--muted);
  padding:4px 0;border-bottom:1px solid transparent;
  transition:color .25s,border-color .25s;
}
nav a:hover{color:var(--bone)}
nav a.active{color:var(--sun);border-bottom-color:var(--sun)}

@media (max-width:640px){
  header.site{flex-direction:column;gap:16px;padding:18px 20px}
  nav{gap:18px}
}

/* ---- Layout ---- */
main.page{flex:1;width:100%;max-width:860px;margin:0 auto;padding:64px 24px 80px}

.kicker{
  font-size:11px;letter-spacing:.42em;text-transform:uppercase;
  color:var(--sun);font-weight:400;margin-bottom:16px;
}
h1.display{
  font-family:'Marcellus',serif;font-weight:400;
  font-size:clamp(34px,6vw,54px);
  letter-spacing:.08em;text-transform:uppercase;line-height:1.12;
}
.lede{
  margin-top:20px;font-size:17px;line-height:1.7;
  color:var(--muted);max-width:56ch;
}

section{margin-top:72px}
h2.section{
  font-family:'Marcellus',serif;font-weight:400;
  font-size:24px;letter-spacing:.12em;text-transform:uppercase;
  display:flex;align-items:center;gap:18px;
}
h2.section::after{content:"";height:1px;flex:1;background:var(--hairline)}

p{line-height:1.75;color:var(--muted);font-size:15.5px}
section p+p{margin-top:14px}
section h2+p,section h2+div{margin-top:24px}

/* ---- Buttons ---- */
.btn{
  display:inline-flex;align-items:center;gap:12px;
  padding:15px 28px;margin-top:34px;
  text-decoration:none;font-size:12px;letter-spacing:.26em;
  text-transform:uppercase;font-weight:500;
  border:1px solid var(--sun);color:var(--sun);
  transition:background .25s,color .25s;
}
.btn:hover{background:rgba(242,177,27,.08)}
.btn.solid{background:var(--sun);color:var(--ink)}
.btn.solid:hover{background:var(--sun-deep);border-color:var(--sun-deep)}
.btn .arrow{transition:transform .25s}
.btn:hover .arrow{transform:translateX(4px)}

/* ---- Cards (pillars / programs) ---- */
.grid{display:grid;gap:14px;grid-template-columns:repeat(auto-fit,minmax(230px,1fr))}
.card{
  border:1px solid var(--hairline);padding:26px 24px;
  background:var(--ink-2);
  transition:border-color .25s;
}
.card:hover{border-color:var(--sun)}
.card h3{
  font-size:13px;letter-spacing:.26em;text-transform:uppercase;
  font-weight:500;color:var(--bone);
}
.card .price{
  font-family:'Marcellus',serif;font-size:26px;margin-top:14px;color:var(--sun);
}
.card .price small{font-family:'Jost',sans-serif;font-size:11px;letter-spacing:.1em;color:var(--muted)}
.card p{margin-top:12px;font-size:14px}
.card ul{margin-top:14px;list-style:none}
.card li{
  font-size:13.5px;color:var(--muted);line-height:1.7;
  padding-left:16px;position:relative;
}
.card li::before{content:"●";position:absolute;left:0;top:1px;color:var(--sun);font-size:8px}

/* ---- Bullet lists in sections ---- */
.bullets{margin-top:18px;list-style:none}
.bullets li{
  font-size:15px;color:var(--muted);line-height:1.8;
  padding-left:18px;position:relative;
}
.bullets li::before{content:"●";position:absolute;left:0;top:2px;color:var(--sun);font-size:8px}

/* ---- Quote / testimonial ---- */
.quote{
  border-left:2px solid var(--sun);padding:6px 0 6px 24px;margin-top:24px;
}
.quote p{font-size:16px;color:var(--bone);font-style:italic}
.quote cite{
  display:block;margin-top:10px;font-style:normal;
  font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--muted);
}

/* ---- Link rows (contact) ---- */
.linklist{display:flex;flex-direction:column;gap:14px;margin-top:28px}
.link{
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 22px;border:1px solid var(--hairline);
  text-decoration:none;color:var(--bone);background:transparent;
  transition:border-color .25s,background .25s;
}
.link .label{font-size:13px;letter-spacing:.24em;text-transform:uppercase;font-weight:500}
.link .note{
  display:block;margin-top:5px;font-size:12px;letter-spacing:.04em;
  text-transform:none;color:rgba(247,244,238,.55);font-weight:300;
}
.link .arrow{color:var(--sun);font-size:15px;margin-left:16px;transition:transform .25s}
.link:hover{border-color:var(--sun);background:rgba(242,177,27,.05)}
.link:hover .arrow{transform:translateX(4px)}
.link.primary{background:var(--sun);border-color:var(--sun);color:var(--ink)}
.link.primary .note{color:rgba(10,10,10,.65)}
.link.primary .arrow{color:var(--ink)}
.link.primary:hover{background:var(--sun-deep);border-color:var(--sun-deep)}

/* ---- Hero mark animation ---- */
.mark .sun-disc{transform-origin:60px 34px;animation:rise 1.4s cubic-bezier(.22,1,.36,1) both}
@keyframes rise{from{transform:translateY(14px);opacity:0}to{transform:translateY(0);opacity:1}}
@media (prefers-reduced-motion:reduce){.mark .sun-disc{animation:none}}

/* ---- Footer ---- */
footer.site{
  border-top:1px solid var(--hairline);
  padding:34px 24px;text-align:center;
  font-size:10px;letter-spacing:.34em;text-transform:uppercase;
  color:var(--faint);
}
footer.site .dots i{font-style:normal;color:var(--sun);font-size:8px;margin:0 8px}
footer.site .row{margin-top:10px}
