/* ==========================================================================
   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;

  --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) */
}

/* 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:#0b231f;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}
.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}

/* 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:#0b231f;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 .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)}
.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}

/* 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}
.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)}

/* 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)}

/* 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}
}
