/* ============================================================
   Fairways — site design system
   "A country-club brochure, not a SaaS dashboard."
   Ivory paper, deep forest green, brass. Cormorant display serif,
   Optima wordmark, system sans body. Self-hosted, no third-party calls.
   ============================================================ */

@font-face{font-family:'Cormorant Garamond';font-style:normal;font-weight:500;font-display:swap;src:url(fonts/cormorant-500.woff2) format('woff2')}
@font-face{font-family:'Cormorant Garamond';font-style:normal;font-weight:600;font-display:swap;src:url(fonts/cormorant-600.woff2) format('woff2')}
@font-face{font-family:'Cormorant Garamond';font-style:italic;font-weight:500;font-display:swap;src:url(fonts/cormorant-500i.woff2) format('woff2')}

:root{
  --bg:#faf7f2;        /* ivory paper            */
  --paper:#fffdf9;     /* raised card            */
  --ink:#1a1d1a;       /* near-black text        */
  --green:#0d2818;     /* deep forest            */
  --green-mid:#2d5a2d; /* fairway green          */
  --brass:#b08654;     /* antique gold accent    */
  --brass-deep:#916a3e;
  --muted:#5a5f5a;
  --muted-2:#8e948e;
  --rule:#e6e2d8;
  --rule-soft:#efece4;
  --green-line:rgba(255,255,255,.14);
  --serif:'Cormorant Garamond',Georgia,'Times New Roman',serif;
  --sans:-apple-system,BlinkMacSystemFont,'SF Pro Text','Segoe UI',Roboto,Helvetica,Arial,sans-serif;
  --optima:'Optima','Optima Nova',Candara,'Gill Sans','Gill Sans Nova','Segoe UI',sans-serif;
  --maxw:1180px;
  --gutter:clamp(20px,5vw,64px);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;background:var(--bg);color:var(--ink);
  font-family:var(--sans);font-size:18px;line-height:1.65;font-weight:400;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:var(--green-mid);text-decoration:none}

/* ---- type ---- */
.wordmark{font-family:var(--optima);font-weight:700;letter-spacing:.5px;color:var(--green)}
.eyebrow{
  font-family:var(--sans);font-size:12px;font-weight:700;letter-spacing:2.4px;
  text-transform:uppercase;color:var(--brass);margin:0 0 18px;
}
.display{font-family:var(--serif);font-weight:600;color:var(--green);line-height:1.04;letter-spacing:-.01em;margin:0}
h1.display{font-size:clamp(42px,7vw,82px)}
h2.display{font-size:clamp(32px,4.6vw,54px)}
h3.display{font-size:clamp(24px,3vw,32px)}
.lead{font-size:clamp(18px,2.2vw,22px);color:var(--muted);max-width:42ch;margin:22px 0 0;line-height:1.6}
.caption{font-family:var(--serif);font-style:italic;font-weight:500;font-size:21px;color:var(--muted)}
.serif-num{font-family:var(--serif);font-weight:600;font-variant-numeric:lining-nums;letter-spacing:-.01em}

/* ---- layout ---- */
.wrap{max-width:var(--maxw);margin:0 auto;padding-left:var(--gutter);padding-right:var(--gutter)}
.sec{padding:clamp(72px,11vw,140px) 0;position:relative}
.sec--tight{padding:clamp(54px,8vw,96px) 0}
.sec-head{max-width:48ch}
.rule-sm{width:46px;height:2px;background:var(--brass);border:0;margin:0 0 26px}

/* ---- nav ---- */
.nav{
  position:sticky;top:0;z-index:50;
  background:rgba(250,247,242,.86);backdrop-filter:saturate(140%) blur(12px);
  -webkit-backdrop-filter:saturate(140%) blur(12px);
  border-bottom:1px solid transparent;transition:border-color .3s ease,background .3s ease;
}
.nav.is-stuck{border-bottom-color:var(--rule)}
.nav-in{display:flex;align-items:center;justify-content:space-between;height:68px}
.nav .wordmark{font-size:23px}
.nav-links{display:flex;align-items:center;gap:30px}
.nav-links a{
  font-size:12.5px;font-weight:600;letter-spacing:1.6px;text-transform:uppercase;
  color:var(--ink);opacity:.78;transition:opacity .15s,color .15s;
}
.nav-links a:hover{opacity:1;color:var(--brass-deep)}
.nav-cta{display:inline-flex}

/* ---- buttons ---- */
.btn{display:inline-flex;align-items:center;gap:10px;font-family:var(--sans);cursor:pointer;
  border-radius:999px;font-weight:600;letter-spacing:.2px;transition:transform .15s ease,box-shadow .15s ease,background .15s ease}
.btn:active{transform:translateY(1px)}
.btn-app{background:var(--green);color:#fff;padding:13px 22px 13px 18px;font-size:15.5px;
  box-shadow:0 6px 22px rgba(13,40,24,.18)}
.btn-app:hover{background:#10301d;box-shadow:0 10px 30px rgba(13,40,24,.26)}
.btn-app svg{width:19px;height:19px;fill:#fff;flex:none}
.btn-app .ba-sub{display:block;font-size:9.5px;letter-spacing:1px;text-transform:uppercase;opacity:.72;line-height:1}
.btn-app .ba-main{display:block;font-size:15px;line-height:1.15;margin-top:1px}
.btn-pill{background:var(--brass);color:#fff;padding:10px 20px;font-size:13px;letter-spacing:1.3px;text-transform:uppercase;font-weight:700}
.btn-pill:hover{background:var(--brass-deep)}
.btn-ghost{color:var(--green);border:1px solid var(--rule);background:var(--paper);padding:12px 22px;font-size:14px;font-weight:600}
.btn-ghost:hover{border-color:var(--brass)}
.btn-ghost-light{color:#fff;border:1px solid var(--green-line);padding:12px 22px;font-size:14px}
.btn-ghost-light:hover{border-color:var(--brass)}

/* ---- hero ---- */
.hero{position:relative;min-height:88vh;display:flex;align-items:flex-end;overflow:hidden;background:var(--green)}
.hero-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 38%;
  transform:scale(1.06);animation:slowzoom 18s ease-out forwards}
@keyframes slowzoom{to{transform:scale(1)}}
.hero-scrim{position:absolute;inset:0;background:
  linear-gradient(to top,rgba(7,22,13,.95) 0%,rgba(7,22,13,.74) 30%,rgba(7,22,13,.4) 52%,rgba(7,22,13,.12) 74%,rgba(7,22,13,.34) 100%)}
.hero-grain{position:absolute;inset:0;opacity:.5;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
.hero-in{position:relative;width:100%;padding-bottom:clamp(56px,9vw,104px);padding-top:120px}
.hero .eyebrow{color:#f0d49a;font-size:14px;letter-spacing:2.9px;text-shadow:0 1px 2px rgba(0,0,0,.98),0 1px 4px rgba(0,0,0,.85),0 0 12px rgba(0,0,0,.6)}
.hero h1{color:#fbf8f2;max-width:16ch}
.hero .hero-sub{font-family:var(--serif);font-style:italic;font-size:clamp(20px,2.4vw,26px);color:#e8e2d4;margin:24px 0 34px;max-width:34ch;line-height:1.45}
.hero-cta{display:flex;align-items:center;gap:18px;flex-wrap:wrap}
.hero-meta{color:#bcae93;font-size:13px;letter-spacing:.3px}

/* staggered entrance */
.up{opacity:0;transform:translateY(22px);animation:up .9s cubic-bezier(.2,.7,.2,1) forwards}
@keyframes up{to{opacity:1;transform:none}}
.d1{animation-delay:.15s}.d2{animation-delay:.3s}.d3{animation-delay:.45s}.d4{animation-delay:.6s}

/* ---- split / editorial ---- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,6vw,88px);align-items:center}
.split--rev .split-media{order:2}
.split-copy{max-width:46ch}

/* phone frame */
.phone{position:relative;width:min(300px,76%);margin:0 auto;border-radius:42px;background:#0d0f0d;
  padding:11px;box-shadow:0 30px 70px rgba(13,40,24,.28),0 6px 18px rgba(0,0,0,.16)}
.phone img{border-radius:32px;width:100%}
.phone--tilt{transform:rotate(-2.2deg)}
.phone-stack{position:relative;min-height:520px}
.phone-stack .phone{position:absolute}
.phone-a{left:0;top:0;z-index:2;width:min(264px,62%)}
.phone-b{right:0;top:46px;z-index:1;width:min(238px,56%);opacity:.96}

/* ---- steps ---- */
.steps{display:grid;gap:30px;margin-top:8px}
.step{display:grid;grid-template-columns:auto 1fr;gap:20px;align-items:start}
.step-n{font-family:var(--serif);font-size:34px;font-weight:600;color:var(--brass);line-height:1;
  width:54px;height:54px;border:1px solid var(--rule);border-radius:50%;display:grid;place-items:center;background:var(--paper);flex:none}
.step h3{font-family:var(--serif);font-size:25px;font-weight:600;color:var(--green);margin:0 0 4px}
.step p{margin:0;color:var(--muted);font-size:16.5px}

/* ---- stats ledger ---- */
.ledger{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--rule);
  border:1px solid var(--rule);border-radius:14px;overflow:hidden;margin-top:40px}
.ledger div{background:var(--paper);padding:26px 18px;text-align:center}
.ledger b{display:block;font-family:var(--serif);font-size:40px;font-weight:600;color:var(--green);line-height:1}
.ledger span{display:block;font-size:11px;letter-spacing:1.6px;text-transform:uppercase;color:var(--muted-2);margin-top:9px}

/* ---- green section ---- */
.sec-green{background:var(--green);color:#ece7da;position:relative;overflow:hidden}
.sec-green .eyebrow{color:#cB9e6e;color:#cb9e6e}
.sec-green .display{color:#fbf8f0}
.sec-green .lead{color:#c8c2b2}
.sec-green .caption{color:#b7b0a0}
.sec-green .rule-sm{background:var(--brass)}
.sec-green-grain{position:absolute;inset:0;opacity:.35;mix-blend-mode:overlay;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%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")}

/* cards (clubhouse) */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:48px}
.card{background:rgba(255,255,255,.05);border:1px solid var(--green-line);border-radius:16px;padding:30px 26px}
.card .ic{width:26px;height:26px;stroke:var(--brass);stroke-width:1.5;fill:none;margin-bottom:18px}
.card h3{font-family:var(--serif);font-size:24px;font-weight:600;color:#fbf8f0;margin:0 0 8px}
.card p{margin:0;color:#bdb6a6;font-size:15.5px;line-height:1.55}

/* feature image bleed */
.bleed{border-radius:18px;overflow:hidden;box-shadow:0 26px 60px rgba(13,40,24,.22)}
.bleed img{width:100%}

/* ---- founding CTA ---- */
.founding{text-align:center;max-width:56ch;margin:0 auto}
.seal{width:96px;height:96px;border-radius:50%;border:2px solid var(--brass);display:grid;place-items:center;margin:0 auto 26px;background:var(--paper)}
.seal svg{width:30px;height:30px;stroke:var(--brass);stroke-width:1.4;fill:none}
.seal .n{font-family:var(--serif);font-size:15px;color:var(--brass);font-weight:600}

/* ---- footer ---- */
.foot{background:var(--green);color:#b9b2a3;padding:64px 0 40px;border-top:3px solid var(--brass)}
.foot-top{display:flex;justify-content:space-between;gap:40px;flex-wrap:wrap;align-items:flex-start}
.foot .wordmark{color:#fbf8f0;font-size:26px}
.foot-tag{font-family:var(--serif);font-style:italic;color:#a59e8f;margin-top:8px;font-size:18px}
.foot-cols{display:flex;gap:64px;flex-wrap:wrap}
.foot-col h4{font-size:11px;letter-spacing:1.8px;text-transform:uppercase;color:var(--brass);margin:0 0 14px;font-weight:700}
.foot-col a{display:block;color:#cfc8b9;font-size:14.5px;margin-bottom:10px}
.foot-col a:hover{color:#fff}
.foot-bot{display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap;margin-top:54px;padding-top:24px;
  border-top:1px solid var(--green-line);font-size:13px;color:#8f897b}

/* ---- pure-CSS scroll reveal (modern browsers; degrades to visible) ---- */
@supports (animation-timeline: view()){
  @media (prefers-reduced-motion:no-preference){
    .reveal{animation:up linear both;animation-timeline:view();animation-range:entry 2% cover 22%}
  }
}

/* ---- responsive ---- */
@media (max-width:860px){
  .nav-links a:not(.nav-cta){display:none}
  .split{grid-template-columns:1fr;gap:40px}
  .split--rev .split-media{order:0}
  .ledger{grid-template-columns:repeat(2,1fr)}
  .cards{grid-template-columns:1fr}
  .phone-stack{min-height:440px}
  .hero{min-height:82vh}
}
@media (max-width:520px){
  body{font-size:17px}
  .ledger{grid-template-columns:repeat(2,1fr)}
  .hero-cta{gap:14px}
}

/* === build-site-data: course pages + gallery (generated) === */
/* forest "FAIRWAYS" brochure panel (no-photo fallback, mirrors in-app empty state) */
.cp-panel{position:relative;width:100%;height:100%;min-height:100%;
  background:linear-gradient(160deg,#123420 0%,var(--green) 55%,#0a2013 100%);
  display:grid;place-items:center;overflow:hidden}
.cp-panel::after{content:"";position:absolute;inset:0;opacity:.3;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%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")}
.cp-panel-mark{position:relative;font-family:var(--optima);font-weight:700;letter-spacing:1px;
  color:#caa572;font-size:clamp(20px,3vw,28px);opacity:.92}

/* ---- gallery header ---- */
.g-head{max-width:62ch}
.g-head .lead{max-width:64ch}

/* ---- course gallery grid ---- */
.course-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,2.6vw,34px) clamp(18px,2.2vw,28px)}
.cc{display:block;color:inherit;text-decoration:none;group:card}
.cc-media{position:relative;aspect-ratio:4/3;border-radius:14px;overflow:hidden;background:var(--green);
  box-shadow:0 14px 34px rgba(13,40,24,.16);transition:transform .35s cubic-bezier(.2,.7,.2,1),box-shadow .35s ease}
.cc-media img{width:100%;height:100%;object-fit:cover;display:block;
  transition:transform .55s cubic-bezier(.2,.7,.2,1)}
.cc:hover .cc-media{transform:translateY(-4px);box-shadow:0 22px 48px rgba(13,40,24,.26)}
.cc:hover .cc-media img{transform:scale(1.05)}
.cc-body{padding:16px 2px 0}
.cc-eyebrow{font-family:var(--sans);font-size:10.5px;font-weight:700;letter-spacing:1.8px;
  text-transform:uppercase;color:var(--brass);margin:0 0 7px}
.cc-name{font-family:var(--serif);font-weight:600;color:var(--green);font-size:23px;line-height:1.12;
  letter-spacing:-.01em;margin:0}
.cc-loc{font-family:var(--serif);font-style:italic;color:var(--muted);font-size:16px;margin:5px 0 0}

/* ---- course page hero ---- */
.ch{position:relative;min-height:62vh;display:flex;align-items:flex-end;overflow:hidden;background:var(--green)}
.ch--green{background:linear-gradient(160deg,#123420 0%,var(--green) 55%,#0a2013 100%)}
.ch-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 42%;
  transform:scale(1.05);animation:slowzoom 16s ease-out forwards}
.ch-scrim{position:absolute;inset:0;background:
  linear-gradient(to top,rgba(8,26,16,.92) 0%,rgba(8,26,16,.5) 40%,rgba(8,26,16,.14) 72%,rgba(8,26,16,.32) 100%)}
.ch .sec-green-grain{opacity:.3}
.ch-in{position:relative;width:100%;padding-top:120px;padding-bottom:clamp(44px,7vw,76px)}
.ch h1{color:#fbf8f2;max-width:18ch}
.ch-by{font-family:var(--serif);font-style:italic;color:#e2dcce;font-size:clamp(18px,2.2vw,24px);margin:18px 0 0}

/* ---- course page body ---- */
.c-split{display:grid;grid-template-columns:1.55fr 1fr;gap:clamp(34px,5vw,68px);align-items:start}
.c-main{min-width:0}
.c-about-body{font-size:clamp(18px,1.5vw,20px);line-height:1.72;color:#33372f;margin:0;max-width:60ch}
.c-actions{display:flex;align-items:center;gap:24px;flex-wrap:wrap;margin-top:38px}
.c-back{font-size:13px;font-weight:600;letter-spacing:1.4px;text-transform:uppercase;color:var(--brass-deep)}
.c-back:hover{color:var(--green)}
.c-soon{font-family:var(--serif);font-style:italic;color:var(--muted-2);font-size:16px;margin:20px 0 0}
.btn-ghost[aria-disabled="true"]{opacity:.55;cursor:default;pointer-events:none}

/* aside */
.c-aside{position:sticky;top:96px}
.c-ledger{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--rule);
  border:1px solid var(--rule);border-radius:14px;overflow:hidden}
.c-ledger div{background:var(--paper);padding:22px 18px;text-align:center}
.c-ledger b{display:block;font-family:var(--serif);font-size:30px;font-weight:600;color:var(--green);line-height:1.05}
.c-ledger .c-led-serif{font-size:21px;line-height:1.2}
.c-ledger span{display:block;font-size:10px;letter-spacing:1.6px;text-transform:uppercase;color:var(--muted-2);margin-top:9px}
.c-cta{margin-top:26px;background:var(--paper);border:1px solid var(--rule);border-radius:16px;padding:26px 24px}
.c-cta .eyebrow{margin-bottom:12px}
.c-cta-copy{font-family:var(--serif);font-size:19px;line-height:1.45;color:var(--green);margin:0 0 20px}
.c-cta .btn-app{width:100%;justify-content:center}

@media (max-width:860px){
  .course-grid{grid-template-columns:repeat(2,1fr)}
  .c-split{grid-template-columns:1fr;gap:40px}
  .c-aside{position:static}
  .ch{min-height:54vh}
}
@media (max-width:520px){
  .course-grid{grid-template-columns:1fr 1fr;gap:18px 14px}
  .cc-name{font-size:20px}
}
/* === end build-site-data === */
/* no-photograph gallery card: forest panel with the wordmark, mirrors the course-page green hero */
.cc-media--green{background:linear-gradient(160deg,#123420 0%,#0e2a1a 55%,#0a2013 100%);display:grid;place-items:center}
.cc-gm{font-family:var(--serif);font-style:italic;font-size:23px;letter-spacing:.5px;color:#b08654;opacity:.62}
