/* ==========================================================================
   Rockport Golf Club — design system
   Mobile-first. One stylesheet shared by every page.
   Sections:  1) Tokens  2) Reset/base  3) Type  4) Buttons  5) Layout
              6) Header/nav  7) Hero  8) Components  9) Forms  10) Footer
              11) Utilities  12) Motion  13) Breakpoints
   ========================================================================== */

/* 1) ---------------------------------------------------------------- TOKENS */
:root{
  /* brand palette — coastal heritage */
  --ink:#10302c;          /* deep evergreen */
  --ink-700:#15403a;
  --ink-600:#1d514a;
  --paper:#f4eee1;        /* warm sand paper */
  --paper-2:#efe6d4;
  --sand:#e4d7bb;
  --brass:#b6894a;        /* decorative accent (lines, borders, dark-bg text) */
  --brass-btn:#8f6630;    /* darker brass for button fills — white text hits AA */
  --brass-2:#caa063;
  --sea:#3f726d;
  --sea-light:#86aca7;

  /* darkest brand shade for the footer + the evergreen hero base, and the radial
     accent glow on the evergreen hero. Defaults reproduce today's coastal hero/
     footer EXACTLY; each vibe overrides them so the hero treatment shifts too. */
  --band-deep:#0b231f;
  --band-deep-2:#12352f;
  --band-deep-mid:#0e2d28;
  --hero-glow:rgba(63,114,109,.55);   /* sea-toned radial on the evergreen hero */

  --line:rgba(16,48,44,.16);
  --line-light:rgba(244,238,225,.18);
  --shadow-sm:0 10px 30px -22px rgba(16,48,44,.5);
  --shadow:0 24px 60px -28px rgba(16,48,44,.45);

  --serif:'Fraunces',Georgia,serif;
  --sans:'Libre Franklin',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;

  --maxw:1240px;
  --gutter:24px;
  --radius:4px;
  --header-h:72px;
  --topbar-h:30px;
  --util-h:0px;           /* utility bar height (set per breakpoint) */
}

/* 1b) ------------------------------------------------------------- VIBES
   A "vibe" (core/scratch.py VIBES, stored as site.vibe) is a distinct visual
   identity — palette + typography + hero treatment. The whole design system is
   token-driven, so a vibe is just a re-definition of the colour/font custom
   properties under a body[data-vibe] hook. Components never change; they read the
   tokens. No data-vibe (or data-vibe absent) => the :root coastal defaults above,
   so the current look NEVER regresses.

   Each vibe redefines: the deep brand ink (+ its two tints used on bands/stats),
   the light paper backgrounds, the primary "brass-equivalent" accent (decorative
   + a darker AA-safe button fill + a lighter highlight), the secondary "sea"
   accent (eyebrows), and the lines/shadows derived from ink. Heading/body fonts
   shift too. Everything keeps AA contrast (dark ink text on light paper; white
   text on the darker *-btn fill).                                              */

/* Heritage — traditional deep forest green + antique gold; Playfair display.
   --ink/--paper/--brass/--brass-2 mirror the VIBES["heritage"] palette exactly
   (ink/bg/brand/accent); --brass-btn is a darker brand shade so white button text
   keeps AA contrast. The same alignment rule holds for parkland and links below. */
body[data-vibe="heritage"]{
  --ink:#16321f; --ink-700:#1d4128; --ink-600:#27543a;
  --paper:#f3efe6; --paper-2:#ece5d4; --sand:#ded2b4;
  --brass:#8a6d27; --brass-btn:#6d551c; --brass-2:#c4a049;
  --sea:#5d7b5c; --sea-light:#9bb198;
  --band-deep:#0c2113; --band-deep-2:#143420; --band-deep-mid:#0f2a19;
  --hero-glow:rgba(196,160,73,.42);
  --line:rgba(22,50,31,.16); --line-light:rgba(243,239,230,.18);
  --shadow-sm:0 10px 30px -22px rgba(22,50,31,.5);
  --shadow:0 24px 60px -28px rgba(22,50,31,.45);
  --serif:'Playfair Display',Georgia,serif;
  --sans:'Libre Franklin',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
}
/* Parkland — fresh sage greens, airy off-white; Fraunces + Inter. */
body[data-vibe="parkland"]{
  --ink:#33483a; --ink-700:#3d5645; --ink-600:#4f6a56;
  --paper:#f6f7f1; --paper-2:#eef0e6; --sand:#dfe4d3;
  --brass:#5c7a52; --brass-btn:#465f3d; --brass-2:#9bb07e;
  --sea:#6f8a63; --sea-light:#a6bb95;
  --band-deep:#1f2c23; --band-deep-2:#2f4234; --band-deep-mid:#26372b;
  --hero-glow:rgba(155,176,126,.50);
  --line:rgba(51,72,58,.15); --line-light:rgba(246,247,241,.20);
  --shadow-sm:0 10px 30px -22px rgba(51,72,58,.4);
  --shadow:0 24px 60px -28px rgba(51,72,58,.38);
  --serif:'Fraunces',Georgia,serif;
  --sans:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
}
/* Links — moody slate + stone, modern/understated; Fraunces + Inter. */
body[data-vibe="links"]{
  --ink:#23292e; --ink-700:#2e363c; --ink-600:#3f4a52;
  --paper:#eceef0; --paper-2:#e1e4e7; --sand:#cfd4d8;
  --brass:#4a5a63; --brass-btn:#384650; --brass-2:#8c9aa3;
  --sea:#5f7079; --sea-light:#9aa7af;
  --band-deep:#181d21; --band-deep-2:#23292e; --band-deep-mid:#1e2429;
  --hero-glow:rgba(140,154,163,.42);
  --line:rgba(35,41,46,.16); --line-light:rgba(236,238,240,.20);
  --shadow-sm:0 10px 30px -22px rgba(35,41,46,.45);
  --shadow:0 24px 60px -28px rgba(35,41,46,.42);
  --serif:'Fraunces',Georgia,serif;
  --sans:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
}

/* 2) ------------------------------------------------------------ RESET/BASE */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--sans);
  background:var(--paper);
  color:var(--ink);
  font-weight:300;
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;background:none;border:0;color:inherit}
ul{list-style:none}
:focus-visible{outline:2px solid var(--brass);outline-offset:3px}
/* skip link — hidden until focused, then visible top-left */
.skip-link{position:absolute;left:-9999px;top:0;z-index:300;background:var(--ink);color:var(--paper);padding:10px 16px;font-size:.8rem;letter-spacing:.04em;border-radius:0 0 var(--radius) 0}
.skip-link:focus{left:0}

/* film grain overlay (subtle texture) */
.grain{
  position:fixed;inset:0;pointer-events:none;z-index:9999;opacity:.045;mix-blend-mode:multiply;
  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='0.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* 3) ------------------------------------------------------------------ TYPE */
h1,h2,h3,h4{font-family:var(--serif);font-weight:300;line-height:1.06;letter-spacing:-.01em}
.serif-it{font-style:italic;font-weight:300}
p{max-width:62ch}
.eyebrow{
  font-size:.72rem;letter-spacing:.32em;text-transform:uppercase;font-weight:500;
  color:var(--sea);display:inline-flex;align-items:center;gap:.7em;
}
.eyebrow::before{content:"";width:30px;height:1px;background:currentColor;display:inline-block}
.eyebrow.center{justify-content:center}
.eyebrow.center::after{content:"";width:30px;height:1px;background:currentColor;display:inline-block}
.eyebrow.light{color:var(--brass-2)}

/* 4) --------------------------------------------------------------- BUTTONS */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.6em;
  padding:1em 1.8em;font-family:var(--sans);font-size:.76rem;letter-spacing:.16em;
  text-transform:uppercase;font-weight:500;white-space:nowrap;
  border:1px solid var(--brass-btn);background:var(--brass-btn);color:#fff;border-radius:2px;
  transition:background .4s,color .4s,transform .4s,border-color .4s;
}
.btn:hover{background:transparent;color:var(--brass-btn);transform:translateY(-2px)}
.btn .ar{transition:transform .4s}
.btn:hover .ar{transform:translateX(4px)}
.btn--ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.55)}
.btn--ghost:hover{background:#fff;color:var(--ink);border-color:#fff}
.btn--ink{background:var(--ink);border-color:var(--ink);color:var(--paper)}
.btn--ink:hover{background:transparent;color:var(--ink)}
.btn--block{width:100%}

/* 5) ---------------------------------------------------------------- LAYOUT */
.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gutter)}
section{position:relative}
/* keep anchor targets clear of the pinned banner + nav */
:where(section,[id]){scroll-margin-top:calc(var(--topbar-h) + var(--util-h) + var(--header-h) + 12px)}
.section{padding-block:clamp(64px,10vw,130px)}
.section-head{max-width:640px}
.section-head.center{margin-inline:auto;text-align:center}
.section-head h2{font-size:clamp(2rem,5.4vw,3.4rem);margin:20px 0 16px}
.section-head p{color:rgba(16,48,44,.74)}
.lede{font-size:1.05rem;color:rgba(16,48,44,.8)}

/* the whole top chrome (banner + util + nav) pins together as one unit */
.topchrome{position:sticky;top:0;z-index:100}

/* demo / portfolio disclaimer bar */
.topbar{
  display:flex;justify-content:center;align-items:center;gap:.7em;flex-wrap:nowrap;overflow:hidden;text-align:center;
  height:var(--topbar-h);padding:0 16px;line-height:1;
  background:var(--band-deep);color:rgba(244,238,225,.8);
  font-size:.64rem;letter-spacing:.14em;text-transform:uppercase;font-weight:500;
  border-bottom:1px solid rgba(202,160,99,.35);
}
.topbar strong{color:var(--brass-2);font-weight:600;letter-spacing:.16em}
.topbar .sep{opacity:.4}
@media(max-width:520px){.topbar .hide-xs{display:none}}

/* 6) ------------------------------------------------------------ HEADER/NAV */
.util{display:none;background:var(--ink);color:rgba(244,238,225,.72);font-size:.7rem;letter-spacing:.1em}
/* collapse the slim util bar once scrolling starts, so only banner + nav stay pinned */
.topchrome.scrolled .util{display:none}
.util .wrap{display:flex;justify-content:space-between;align-items:center;min-height:38px;text-transform:uppercase;gap:12px}
.util a{transition:color .3s}.util a:hover{color:var(--brass-2)}
.util .right{display:flex;gap:18px;align-items:center}
.util .dot{opacity:.4}
.util .left{white-space:nowrap}

header{position:relative;z-index:100}
.nav{background:rgba(244,238,225,.86);backdrop-filter:blur(14px);border-bottom:1px solid transparent;transition:background .5s,border-color .5s,box-shadow .5s}
.topchrome.scrolled .nav{background:rgba(244,238,225,.97);border-bottom-color:var(--line);box-shadow:var(--shadow-sm)}
.nav .wrap{display:flex;align-items:center;justify-content:space-between;height:var(--header-h)}

.brand{display:flex;align-items:center;gap:12px}
.brand img{height:42px;width:auto}
/* inline crest used when there's no logo asset — sized like the <img> it replaces,
   tinted with the brand brass so it reads as a real mark, never a broken image. */
.brandmark{display:block;width:auto;flex:none}
.brand .brandmark{height:40px;color:var(--brass)}
.brand .wm{line-height:1}
.brand .wm .t{font-family:var(--serif);font-size:1.1rem;letter-spacing:.01em;display:block;color:var(--ink)}
.brand .wm .s{font-size:.56rem;letter-spacing:.36em;text-transform:uppercase;color:var(--sea);font-weight:500;margin-top:3px}

.menu{display:none;align-items:center;gap:30px}
.menu a{font-size:.76rem;letter-spacing:.12em;text-transform:uppercase;font-weight:400;position:relative;padding:6px 0;color:var(--ink)}
.menu a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:1px;background:var(--brass);transition:width .4s}
.menu a:hover::after,.menu a[aria-current="page"]::after{width:100%}
.menu a[aria-current="page"]{color:var(--brass)}

.nav-cta{display:flex;align-items:center;gap:14px}
.nav-cta .btn{display:none}
.burger{display:inline-flex;flex-direction:column;gap:5px;padding:8px}
.burger span{width:24px;height:1.6px;background:var(--ink);transition:transform .3s,opacity .3s}
.burger.open span:nth-child(1){transform:translateY(6.6px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-6.6px) rotate(-45deg)}

/* mobile drawer */
.drawer{
  position:fixed;inset:0 0 0 auto;width:min(86vw,360px);background:var(--paper);
  transform:translateX(100%);transition:transform .45s cubic-bezier(.2,.7,.3,1);
  z-index:200;box-shadow:var(--shadow);display:flex;flex-direction:column;
  padding:26px 26px 36px;overflow-y:auto;
}
.drawer.open{transform:none}
.drawer .x{align-self:flex-end;font-size:1.6rem;line-height:1;padding:4px 8px;color:var(--ink)}
.drawer nav{display:flex;flex-direction:column;margin-top:10px}
.drawer nav a{font-family:var(--serif);font-size:1.45rem;padding:13px 0;border-bottom:1px solid var(--line);color:var(--ink)}
.drawer .btn{margin-top:24px}
.drawer .meta{margin-top:auto;padding-top:24px;font-size:.8rem;color:var(--ink-600);letter-spacing:.04em}
.scrim-nav{position:fixed;inset:0;background:rgba(16,48,44,.5);opacity:0;visibility:hidden;transition:.4s;z-index:150}
.scrim-nav.open{opacity:1;visibility:visible}

/* 7) ------------------------------------------------------------------ HERO */
.hero{
  position:relative;min-height:78vh;display:flex;align-items:center;color:#fff;
  /* the per-page photo is set inline via background-image (resolves against the
     document, unlike a url() inside a custom property which resolves against the
     stylesheet's folder). color + sizing live here. */
  background-color:var(--ink);
  background-position:center;
  background-size:cover;
  background-repeat:no-repeat;
  padding-block:clamp(90px,16vh,150px);
}
.hero::after{content:"";position:absolute;inset:0;background:
  linear-gradient(95deg,rgba(8,28,25,.86) 0%,rgba(8,28,25,.55) 42%,rgba(8,28,25,.12) 72%,rgba(8,28,25,.05) 100%),
  linear-gradient(0deg,rgba(8,28,25,.6),transparent 40%);}
.hero .wrap{position:relative;z-index:2;width:100%}
.hero-content{max-width:620px}
.hero h1{font-size:clamp(2.1rem,8vw,5.4rem);color:#fdfaf2;margin:22px 0 20px;letter-spacing:-.02em;text-wrap:balance}
.hero h1 em{color:var(--brass-2)}
.hero .lead{font-size:clamp(1rem,2.4vw,1.15rem);color:rgba(253,250,242,.88);max-width:520px}
.hero .actions{display:flex;gap:14px;margin-top:32px;flex-wrap:wrap}
.hero--short{min-height:56vh}

/* evergreen photographic-gradient hero — used when there's no real course photo
   (a logo must NEVER be stretched across the hero). Rich, on-brand, premium.
   Token-driven so each vibe (body[data-vibe]) gets its own deep hero treatment;
   the coastal defaults reproduce the original look (the corner radial is now the
   opaque --band-deep rather than the old rgba(...,.95) — visually identical over
   the matching --ink base). */
.hero--evergreen{
  background-color:var(--ink);
  background-image:
    radial-gradient(120% 90% at 18% 0%,var(--hero-glow) 0%,transparent 55%),
    radial-gradient(140% 120% at 100% 100%,var(--band-deep) 0%,transparent 60%),
    linear-gradient(160deg,var(--band-deep-2) 0%,var(--band-deep-mid) 45%,var(--band-deep) 100%);
}
.hero--evergreen::after{background:
  linear-gradient(95deg,rgba(8,28,25,.55) 0%,rgba(8,28,25,.22) 50%,transparent 100%),
  linear-gradient(0deg,rgba(8,28,25,.5),transparent 45%);}
/* faint contour lines drawn behind the evergreen hero content for texture */
.hero-topo{position:absolute;inset:0;width:100%;height:100%;opacity:.10;z-index:1;color:var(--brass-2);pointer-events:none}
.hero--evergreen .hero-topo{opacity:.12}

/* stat ribbon */
.stats{background:var(--ink-700);color:var(--paper);border-top:1px solid var(--line-light)}
.stats .wrap{display:grid;grid-template-columns:repeat(2,1fr)}
.stat{padding:26px 14px;text-align:center;border-right:1px solid var(--line-light);border-bottom:1px solid var(--line-light)}
.stat .n{font-family:var(--serif);font-size:1.9rem;color:var(--brass-2);line-height:1}
.stat .l{font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;color:rgba(244,238,225,.62);margin-top:8px}

/* 8) ------------------------------------------------------------ COMPONENTS */
/* media figure (real photos) */
.media{position:relative;border-radius:var(--radius);overflow:hidden;background:var(--sand)}
.media img{width:100%;height:100%;object-fit:cover}
.media--portrait{aspect-ratio:4/5}
.media--landscape{aspect-ratio:4/3}
.media--wide{aspect-ratio:16/10}
.media--square{aspect-ratio:1/1}
.media__cap{
  position:absolute;left:0;right:0;bottom:0;z-index:2;padding:16px 18px;color:#fff;
  font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;
  background:linear-gradient(0deg,rgba(8,28,25,.7),transparent);
}
.media__credit{font-style:italic;font-family:var(--serif);font-size:.8rem;color:var(--sea);margin-top:10px}
/* decorative inner border + corners */
.media--framed::after{content:"";position:absolute;inset:10px;border:1px solid rgba(255,255,255,.4);pointer-events:none;border-radius:2px}
.corner{position:absolute;width:18px;height:18px;border:1.5px solid var(--brass-2);z-index:3}
.corner.tl{top:14px;left:14px;border-right:0;border-bottom:0}
.corner.br{bottom:14px;right:14px;border-left:0;border-top:0}

/* split: text + image */
.split{display:grid;gap:40px;align-items:center}
.split h2{font-size:clamp(2rem,5vw,3.2rem);margin:18px 0 18px}
.split p{color:rgba(16,48,44,.78);margin-bottom:16px}
.split .imgwrap{position:relative}
.badge{
  position:absolute;bottom:-22px;left:-12px;width:112px;height:112px;border-radius:50%;
  background:var(--ink);color:var(--paper);display:flex;flex-direction:column;align-items:center;
  justify-content:center;text-align:center;box-shadow:var(--shadow);z-index:4;
}
.badge .y{font-family:var(--serif);font-size:1.6rem;color:var(--brass-2);line-height:1}
.badge .x{font-size:.52rem;letter-spacing:.2em;text-transform:uppercase;margin-top:5px;opacity:.85;padding:0 8px}

/* dark band */
.band-ink{background:var(--ink);color:var(--paper)}
.band-ink h2{color:#fdfaf2}
.band-ink p{color:rgba(244,238,225,.72)}
.band-paper2{background:var(--paper-2)}

/* feature cards grid */
.cards{display:grid;gap:1px;background:var(--line-light);border:1px solid var(--line-light)}
.card{background:var(--ink);padding:30px 26px;transition:background .5s}
.card:hover{background:var(--ink-700)}
.card .ic{color:var(--brass-2);margin-bottom:16px}
.card .ic svg{width:28px;height:28px}
.card h3{font-size:1.12rem;color:#fdfaf2;margin-bottom:8px}
.card p{font-size:.86rem;color:rgba(244,238,225,.64);line-height:1.6}

/* scorecard */
.scorecard{border:1px solid var(--line-light);border-radius:var(--radius);overflow:hidden}
.scorecard .sc-head{background:var(--ink-700);padding:14px 22px;display:flex;justify-content:space-between;align-items:center;gap:10px;flex-wrap:wrap;font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(244,238,225,.72)}
.holes{display:grid;grid-template-columns:repeat(5,1fr)}
.hole{padding:16px 4px;text-align:center;border-right:1px solid var(--line-light);border-top:1px solid var(--line-light)}
.hole .h{font-size:.56rem;letter-spacing:.12em;color:rgba(244,238,225,.5);text-transform:uppercase}
.hole .p{font-family:var(--serif);font-size:1.2rem;color:#fdfaf2;margin-top:4px}
.hole--total{background:var(--ink-700)}

/* chips */
.chips{display:flex;flex-wrap:wrap;gap:9px}
.chip{font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;padding:.55em 1em;border:1px solid var(--line);border-radius:40px;color:var(--ink-600);background:rgba(255,255,255,.45)}
.band-ink .chip{border-color:var(--line-light);color:rgba(244,238,225,.85);background:rgba(255,255,255,.04)}

/* gallery masonry-ish grid */
.gallery-grid{display:grid;grid-template-columns:repeat(2,1fr);grid-auto-rows:42vw;gap:12px}
.gallery-grid .media{cursor:zoom-in}
.gallery-grid .media img{transition:transform .6s}
.gallery-grid .media:hover img{transform:scale(1.04)}
.g-tall{grid-row:span 2}
.g-wide{grid-column:span 2}

/* tiers */
.tiers{display:grid;gap:22px}
.tier{border:1px solid var(--line);border-radius:var(--radius);padding:34px 30px;background:#fff;transition:transform .5s,box-shadow .5s,border-color .5s;position:relative}
.tier:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:var(--brass)}
.tier.feat{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.tier .tag{font-size:.64rem;letter-spacing:.2em;text-transform:uppercase;color:var(--sea)}
.tier.feat .tag{color:var(--brass-2)}
.tier h3{font-family:var(--serif);font-size:1.6rem;margin:12px 0 6px}
.tier .price{font-size:.88rem;color:rgba(16,48,44,.6);margin-bottom:20px}
.tier.feat .price{color:rgba(244,238,225,.7)}
.tier ul{margin-bottom:26px}
.tier li{font-size:.88rem;padding:9px 0;border-top:1px solid var(--line);display:flex;gap:10px;align-items:flex-start;color:rgba(16,48,44,.82)}
.tier.feat li{border-top-color:var(--line-light);color:rgba(244,238,225,.85)}
.tier li svg{width:15px;height:15px;color:var(--brass);flex:none;margin-top:4px}
.tier.feat li svg{color:var(--brass-2)}

/* info blocks (visit/contact) */
.info{display:flex;flex-direction:column;gap:22px}
.info .blk{display:flex;gap:16px;align-items:flex-start}
.info .ic{width:42px;height:42px;border:1px solid var(--brass);border-radius:50%;display:flex;align-items:center;justify-content:center;flex:none;color:var(--brass)}
.info .ic svg{width:18px;height:18px}
.info .k{font-size:.64rem;letter-spacing:.18em;text-transform:uppercase;color:var(--sea);margin-bottom:4px}
.info .v{font-size:1rem;color:var(--ink)}
.info .v a:hover{color:var(--brass)}

/* hours list */
.hours{display:grid;gap:14px;margin:20px 0 30px}
.hours .row{display:flex;justify-content:space-between;gap:16px;padding-bottom:12px;border-bottom:1px solid var(--line-light)}
.hours .k{font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:var(--brass-2)}
.hours .v{font-family:var(--serif);font-size:1.02rem;color:#fdfaf2;text-align:right}

/* prose */
.prose p{margin-bottom:18px;color:rgba(16,48,44,.82)}
.prose h3{font-size:1.4rem;margin:30px 0 12px}

/* 9) ------------------------------------------------------------------ FORM */
.inquiry{background:var(--ink);color:var(--paper);border-radius:var(--radius);overflow:hidden;display:grid;box-shadow:var(--shadow)}
.inquiry .left{padding:42px 32px}
.inquiry .left :is(h2,h3){font-size:1.8rem;color:#fdfaf2;margin:16px 0 14px}
.inquiry .left p{color:rgba(244,238,225,.72);font-size:.95rem;margin-bottom:24px}
.inquiry .meta{font-size:.86rem;color:rgba(244,238,225,.85);display:flex;flex-direction:column;gap:12px}
.inquiry .meta div{display:flex;align-items:center;gap:12px}
.inquiry .meta svg{width:17px;height:17px;color:var(--brass-2);flex:none}
.inquiry .meta a:hover{color:var(--brass-2)}
.form{padding:32px}
.form .row{display:grid;gap:16px}
.field{margin-bottom:16px}
.field label{display:block;font-size:.62rem;letter-spacing:.16em;text-transform:uppercase;color:rgba(244,238,225,.62);margin-bottom:7px}
.field input,.field select,.field textarea{
  width:100%;border:1px solid var(--line-light);border-radius:2px;background:rgba(255,255,255,.04);
  padding:12px 14px;font:inherit;font-size:.9rem;color:#fdfaf2;transition:border-color .3s,background .3s;
}
.field textarea{min-height:96px;resize:vertical}
.field input::placeholder,.field textarea::placeholder{color:rgba(244,238,225,.4)}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--brass-2);background:rgba(255,255,255,.07)}
.field select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' fill='none' stroke='%23caa063' stroke-width='1.6'%3E%3Cpath d='M1 1l5 5 5-5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:36px}
.field select option{color:#10302c}
.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.form-status{font-size:.85rem;margin-top:12px;min-height:1.2em}
.form-status.ok{color:var(--brass-2)}
.form-status.err{color:#e7a17a}

/* 10) ---------------------------------------------------------------- FOOTER */
footer{background:var(--band-deep);color:rgba(244,238,225,.62);padding:64px 0 32px}
.f-top{display:grid;gap:36px;padding-bottom:44px;border-bottom:1px solid var(--line-light)}
.f-brand img{height:48px;width:auto;margin-bottom:14px}
.f-brand .f-mark{height:46px;color:var(--brass-2);margin-bottom:14px}
.f-brand .nm{font-family:var(--serif);font-size:1.25rem;color:var(--paper);margin-bottom:12px}
.f-brand p{font-style:italic;font-family:var(--serif);font-size:.95rem;line-height:1.7;max-width:320px;color:rgba(244,238,225,.55)}
/* address + phone + email surfaced in the footer (where do I find them?) */
.f-contact{font-style:normal;display:flex;flex-direction:column;gap:10px;margin-top:18px;max-width:320px}
.f-contact__line{display:flex;align-items:flex-start;gap:11px;font-size:.86rem;color:rgba(244,238,225,.7);line-height:1.5;transition:color .3s}
.f-contact__line:hover{color:var(--brass-2)}
.f-contact__line svg{width:16px;height:16px;color:var(--brass-2);flex:none;margin-top:3px}
.f-col h4{font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;color:var(--brass-2);margin-bottom:16px;font-family:var(--sans);font-weight:500}
.f-col a{display:block;font-size:.9rem;padding:6px 0;transition:color .3s}
.f-col a:hover{color:var(--brass-2)}
.f-bot{display:flex;justify-content:space-between;align-items:center;padding-top:26px;font-size:.74rem;letter-spacing:.04em;flex-wrap:wrap;gap:14px}
.f-social{display:flex;gap:12px}
.f-social a{width:34px;height:34px;border:1px solid var(--line-light);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:.4s}
.f-social a:hover{background:var(--brass);border-color:var(--brass);color:#fff}
.f-social svg{width:15px;height:15px}
.teegem-badge{color:var(--brass-2);text-decoration:none;font-weight:500}
.teegem-badge:hover{color:#fff;text-decoration:underline}

/* 11) ------------------------------------------------------------- UTILITIES */
.note{background:var(--brass);color:#fff;text-align:center;font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;padding:9px;font-weight:500}
.mt-sm{margin-top:14px}.mt{margin-top:24px}.mt-lg{margin-top:40px}
.center{text-align:center}
.stack{display:flex;flex-wrap:wrap;gap:14px}
.stack.center-x{justify-content:center}
.divider{height:1px;background:var(--line);border:0;margin-block:clamp(48px,8vw,90px)}
.topo{position:absolute;inset:0;opacity:.06;pointer-events:none}

/* 12) ----------------------------------------------------------------- MOTION */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .9s cubic-bezier(.2,.7,.3,1),transform .9s cubic-bezier(.2,.7,.3,1)}
.reveal.in{opacity:1;transform:none}
.d1{transition-delay:.08s}.d2{transition-delay:.16s}.d3{transition-delay:.24s}.d4{transition-delay:.32s}

/* lightbox */
.lightbox{position:fixed;inset:0;z-index:300;background:rgba(8,20,18,.94);display:none;align-items:center;justify-content:center;padding:24px}
.lightbox.open{display:flex}
.lightbox img{max-width:92vw;max-height:88vh;border-radius:2px;box-shadow:var(--shadow)}
.lightbox .x{position:absolute;top:18px;right:24px;color:#fff;font-size:2rem;line-height:1}

/* rates table */
.rates{width:100%;border-collapse:collapse;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:#fff}
.rates caption{caption-side:top;text-align:left;font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:var(--sea);padding:0 0 12px}
.rates th,.rates td{padding:14px 18px;text-align:left;border-bottom:1px solid var(--line);font-size:.95rem}
.rates thead th{background:var(--ink);color:var(--paper);font-weight:500;font-size:.66rem;letter-spacing:.14em;text-transform:uppercase}
.rates tbody tr:last-child td{border-bottom:0}
.rates td:not(:first-child),.rates th:not(:first-child){text-align:right;font-family:var(--serif);color:var(--ink)}
.rates tbody th{font-weight:400;color:var(--ink-600);font-family:var(--sans)}

/* staff grid */
.staff{display:grid;gap:32px}
.staff .person .media{aspect-ratio:4/5;margin-bottom:18px}
.staff .person h3{font-family:var(--serif);font-size:1.5rem;margin-bottom:2px}
.staff .person .role{font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;color:var(--brass);margin-bottom:12px}
.staff .person p{font-size:.92rem;color:rgba(16,48,44,.78)}
.band-ink .staff .person p{color:rgba(244,238,225,.74)}

/* invitation band — a warm closing call-to-action (scaffolding for sparse sites) */
.invite{text-align:center}
.invite-inner{max-width:680px;margin-inline:auto}
.invite-inner h2{font-size:clamp(2rem,5.4vw,3.4rem);margin:20px 0 16px}
.invite-inner p{margin-inline:auto}
.invite .topo{opacity:.07}

/* visit / location — prominent address, hours, and an embedded map */
.visit-split{align-items:stretch}
.visit-hours{display:grid;gap:12px;max-width:420px}
.visit-hours .row{display:flex;justify-content:space-between;gap:16px;padding-bottom:11px;border-bottom:1px solid var(--line)}
.visit-hours .k{font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:var(--sea)}
.visit-hours .v{font-family:var(--serif);font-size:1.02rem;color:var(--ink);text-align:right}
/* embedded keyless Google Maps panel — framed like a real photo, never a blank box */
.map-frame{position:relative;border-radius:var(--radius);overflow:hidden;background:var(--sand);min-height:320px;box-shadow:var(--shadow-sm);border:1px solid var(--line)}
.map-frame iframe{width:100%;height:100%;min-height:320px;border:0;display:block;filter:grayscale(.18) contrast(1.02)}
@media(min-width:768px){.map-frame,.map-frame iframe{min-height:100%}}

/* callout */
.callout{background:var(--paper-2);border-left:3px solid var(--brass);border-radius:0 var(--radius) var(--radius) 0;padding:22px 26px}
.callout p{margin:0;color:var(--ink-600)}
.band-ink .callout{background:rgba(255,255,255,.04);border-left-color:var(--brass-2)}
.band-ink .callout p{color:rgba(244,238,225,.8)}

/* 14) -------------------------------------------- "TODAY AT THE COURSE" BOARD
   A slim status strip rendered from site.conditions, just under the pinned header.
   Token-driven so every vibe inherits the look. Tucks away when nothing's set
   (the template only emits it when conditions exist). */
.conditions{
  background:var(--ink-700);color:rgba(244,238,225,.9);
  border-bottom:1px solid rgba(202,160,99,.28);
  font-size:.74rem;
}
.cond__inner{
  display:flex;align-items:center;gap:10px 22px;flex-wrap:wrap;
  padding-block:11px;line-height:1.3;
}
.cond__title{
  font-family:var(--serif);font-size:.92rem;color:var(--brass-2);
  letter-spacing:.01em;white-space:nowrap;flex:none;
}
.cond__items{display:flex;align-items:center;gap:8px 18px;flex-wrap:wrap}
.cond__item{display:inline-flex;align-items:baseline;gap:.5em;white-space:nowrap}
.cond__k{
  font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;
  color:rgba(244,238,225,.55);font-weight:500;
}
.cond__v{color:#fdfaf2;font-weight:400}
.cond__item--status .cond__v{color:var(--brass-2)}
.cond__dot{
  width:7px;height:7px;border-radius:50%;display:inline-block;align-self:center;
  margin-right:.15em;background:var(--sea-light);box-shadow:0 0 0 3px rgba(255,255,255,.06);
}
.cond__dot.is-open{background:#6fbf73;box-shadow:0 0 0 3px rgba(111,191,115,.18)}
.cond__dot.is-closed{background:#e07a5f;box-shadow:0 0 0 3px rgba(224,122,95,.18)}
.cond__note{
  font-style:italic;font-family:var(--serif);font-size:.84rem;
  color:rgba(244,238,225,.66);margin-left:auto;
}
@media(max-width:680px){
  .cond__note{margin-left:0;flex-basis:100%}
  .cond__title{flex-basis:100%}
}

/* footer echo of the day's status — quieter than the top band */
.f-conditions{
  display:flex;align-items:baseline;gap:10px 18px;flex-wrap:wrap;
  padding:22px 0 4px;font-size:.74rem;color:rgba(244,238,225,.62);
}
.f-conditions__lead{
  font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;color:var(--brass-2);
  font-weight:500;flex:none;
}
.f-conditions__items{display:flex;align-items:baseline;gap:6px 16px;flex-wrap:wrap}
.f-conditions .cond__k{color:rgba(244,238,225,.45)}
.f-conditions .cond__v{color:rgba(244,238,225,.8)}
.f-conditions .cond__dot{box-shadow:none}
.f-conditions .cond__note{display:none}

/* 15) ---------------------------------------------------- AI CONCIERGE WIDGET
   A tasteful chat bubble (bottom-right) + an on-brand panel. Never blocks the page
   (fixed, isolated). Vanilla JS toggles .is-open. Token-driven; respects every vibe
   and prefers-reduced-motion. */
.concierge{
  position:fixed;right:clamp(14px,3vw,28px);bottom:clamp(14px,3vw,28px);
  z-index:250;font-family:var(--sans);
}
/* launcher bubble */
.concierge__launch{
  display:inline-flex;align-items:center;gap:.6em;
  padding:.85em 1.25em .85em 1.05em;border-radius:40px;
  background:var(--ink);color:#fdfaf2;border:1px solid rgba(202,160,99,.5);
  box-shadow:var(--shadow);font-size:.78rem;letter-spacing:.04em;font-weight:500;
  transition:transform .35s cubic-bezier(.2,.7,.3,1),box-shadow .35s,background .35s;
}
.concierge__launch:hover{transform:translateY(-2px);background:var(--ink-700)}
.concierge__launch-ic{width:20px;height:20px;color:var(--brass-2);flex:none}
.concierge__launch-label{white-space:nowrap}
.concierge.is-open .concierge__launch{transform:scale(.9);opacity:0;pointer-events:none}
@media(max-width:480px){.concierge__launch-label{display:none}.concierge__launch{padding:.9em}}

/* panel */
.concierge__panel{
  position:absolute;right:0;bottom:0;
  width:min(92vw,376px);max-height:min(78vh,620px);
  display:flex;flex-direction:column;overflow:hidden;
  background:var(--paper);border:1px solid var(--line);
  border-radius:var(--radius);box-shadow:var(--shadow);
  opacity:0;transform:translateY(14px) scale(.98);transform-origin:bottom right;
  pointer-events:none;transition:opacity .3s,transform .3s cubic-bezier(.2,.7,.3,1);
}
.concierge__panel[hidden]{display:none}
.concierge.is-open .concierge__panel{opacity:1;transform:none;pointer-events:auto}
.concierge__head{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:14px 16px;background:var(--ink);color:#fdfaf2;flex:none;
}
.concierge__id{display:flex;align-items:center;gap:11px;min-width:0}
.concierge__avatar{
  width:36px;height:36px;border-radius:50%;flex:none;display:flex;align-items:center;
  justify-content:center;background:rgba(202,160,99,.14);border:1px solid rgba(202,160,99,.4);
}
.concierge__mark{height:20px;width:auto;color:var(--brass-2)}
.concierge__title-wrap{display:flex;flex-direction:column;min-width:0}
.concierge__title{font-family:var(--serif);font-size:1.02rem;line-height:1.1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.concierge__byline{font-size:.58rem;letter-spacing:.14em;text-transform:uppercase;color:var(--brass-2);margin-top:3px}
.concierge__close{font-size:1.5rem;line-height:1;color:rgba(253,250,242,.85);padding:0 4px;flex:none}
.concierge__close:hover{color:#fff}
/* message log */
.concierge__log{
  flex:1 1 auto;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:12px;
  background:var(--paper);scroll-behavior:smooth;
}
.concierge__msg{max-width:84%;font-size:.88rem;line-height:1.55}
.concierge__msg p{margin:0;max-width:none}
.concierge__msg p + p{margin-top:.5em}
.concierge__msg--bot{align-self:flex-start;background:#fff;border:1px solid var(--line);color:var(--ink);padding:11px 14px;border-radius:4px 14px 14px 14px;box-shadow:var(--shadow-sm)}
.concierge__msg--user{align-self:flex-end;background:var(--ink);color:#fdfaf2;padding:11px 14px;border-radius:14px 4px 14px 14px}
.concierge__msg a{color:var(--brass-btn);text-decoration:underline;text-underline-offset:2px}
.concierge__msg--user a{color:var(--brass-2)}
.concierge__msg--typing{display:inline-flex;gap:5px;align-items:center;padding:13px 16px}
.concierge__msg--typing span{width:6px;height:6px;border-radius:50%;background:var(--sea);opacity:.5;animation:cdot 1.1s infinite}
.concierge__msg--typing span:nth-child(2){animation-delay:.18s}
.concierge__msg--typing span:nth-child(3){animation-delay:.36s}
@keyframes cdot{0%,60%,100%{transform:translateY(0);opacity:.4}30%{transform:translateY(-4px);opacity:.9}}
/* suggestion chips */
.concierge__chips{display:flex;gap:8px;flex-wrap:wrap;padding:0 16px 12px;flex:none}
.concierge__chip{
  font-size:.74rem;letter-spacing:.01em;padding:.5em .9em;border-radius:40px;
  border:1px solid var(--line);background:rgba(255,255,255,.6);color:var(--ink-600);
  transition:background .3s,border-color .3s,color .3s;
}
.concierge__chip:hover{background:var(--ink);border-color:var(--ink);color:#fdfaf2}
/* composer */
.concierge__form{display:flex;gap:8px;padding:12px 14px;border-top:1px solid var(--line);background:var(--paper-2);flex:none}
.concierge__field{flex:1 1 auto;min-width:0}
.concierge__input{
  width:100%;border:1px solid var(--line);border-radius:40px;background:#fff;
  padding:11px 16px;font:inherit;font-size:.88rem;color:var(--ink);transition:border-color .3s;
}
.concierge__input:focus{outline:none;border-color:var(--brass)}
.concierge__input::placeholder{color:rgba(16,48,44,.42)}
.concierge__send{
  width:42px;height:42px;flex:none;border-radius:50%;background:var(--brass-btn);color:#fff;
  display:flex;align-items:center;justify-content:center;transition:background .3s,transform .3s;
}
.concierge__send:hover{background:var(--ink);transform:translateY(-1px)}
.concierge__send svg{width:18px;height:18px}
.concierge__foot{font-size:.62rem;letter-spacing:.06em;text-align:center;color:rgba(16,48,44,.5);padding:0 14px 12px;background:var(--paper-2);margin:0}
.concierge__foot a{color:var(--brass-btn);font-weight:500}
.concierge__foot a:hover{text-decoration:underline}
/* visually-hidden label */
.vh{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}
@media(prefers-reduced-motion:reduce){
  .concierge__launch,.concierge__panel,.concierge__send{transition:none}
  .concierge__msg--typing span{animation:none;opacity:.6}
  .concierge.is-open .concierge__launch{opacity:0}
}

/* 13) ------------------------------------------------------------ BREAKPOINTS */
@media(min-width:600px){
  :root{--util-h:38px}
  .util{display:block}
  .stats .wrap{grid-template-columns:repeat(4,1fr)}
  .stat{border-bottom:0}
  .form .row{grid-template-columns:1fr 1fr}
  .tiers{grid-template-columns:repeat(2,1fr)}
  .gallery-grid{grid-template-columns:repeat(3,1fr);grid-auto-rows:22vw}
  .holes{grid-template-columns:repeat(10,1fr)}
  .hole--total{border-right:0}
}
@media(min-width:768px){
  :root{--gutter:40px}
  .cards{grid-template-columns:repeat(2,1fr)}
  .staff{grid-template-columns:repeat(3,1fr)}
  .split{grid-template-columns:1fr 1fr;gap:56px}
  .split.wide-text{grid-template-columns:1.05fr .95fr}
  .inquiry{grid-template-columns:.9fr 1.1fr}
  .inquiry .left{border-right:1px solid var(--line-light)}
  .inquiry .left,.form{padding:48px}
  .f-top{grid-template-columns:1.6fr 1fr 1fr 1fr}
}
@media(min-width:960px){
  :root{--header-h:78px}
  .menu{display:flex}
  .burger{display:none}
  .nav-cta .btn{display:inline-flex}
  .brand img{height:46px}
  .cards{grid-template-columns:repeat(4,1fr)}
  .tiers{grid-template-columns:repeat(3,1fr)}
  .gallery-grid{grid-template-columns:repeat(4,1fr);grid-auto-rows:200px}
}
@media(prefers-reduced-motion:reduce){
  *{scroll-behavior:auto!important}
  .reveal{transition:none;opacity:1;transform:none}
}
