/* ==========================================================================
   ROUNDLY — Design System
   "Keep the game going."
   Aesthetic: timeless, minimal, club/heritage. Old scorebooks, poker ledgers,
   golf scorecards, members' registers. No neon, no casino flash, no SaaS gloss.
   ========================================================================== */

/* ---- Tokens ------------------------------------------------------------- */
:root{
  /* Palette */
  --ink:        #14130F;   /* deep near-black, warm */
  --ink-soft:   #2A2823;   /* softened ink for body copy on cream */
  --cream:      #F4EEDF;   /* warm cream — primary paper */
  --cream-deep: #EBE3CF;   /* slightly deeper cream for panels */
  --forest:     #1E3A2B;   /* forest green */
  --forest-lo:  #16291E;   /* darker forest for button hover */
  --burgundy:   #5E2530;   /* burgundy */
  --brass:      #B08A47;   /* brass accent */
  --brass-lo:   #9A7637;   /* darker brass for text on cream */
  --line:       rgba(20,19,15,.16);  /* hairline rules */
  --line-soft:  rgba(20,19,15,.08);

  /* Type */
  --serif: "Cormorant Garamond", "Cormorant", Georgia, "Times New Roman", serif;
  --sans:  "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Helvetica, Arial, sans-serif;

  /* Scale */
  --step--1: clamp(.78rem, .76rem + .1vw, .85rem);
  --step-0:  clamp(1rem, .97rem + .15vw, 1.08rem);
  --step-1:  clamp(1.2rem, 1.1rem + .5vw, 1.5rem);
  --step-2:  clamp(1.6rem, 1.3rem + 1.5vw, 2.4rem);
  --step-3:  clamp(2.4rem, 1.8rem + 3vw, 4rem);
  --step-4:  clamp(3.4rem, 2.2rem + 6vw, 7rem);

  /* Space */
  --space-xs: .5rem;
  --space-s:  1rem;
  --space-m:  2rem;
  --space-l:  4rem;
  --space-xl: 7rem;

  --maxw: 1140px;
  --radius: 2px;
}

/* ---- Reset -------------------------------------------------------------- */
*,*::before,*::after{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; }
body{
  margin:0;
  background:var(--cream);
  color:var(--ink-soft);
  font-family:var(--sans);
  font-size:var(--step-0);
  line-height:1.6;
  font-feature-settings:"kern" 1, "liga" 1;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img,svg{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
h1,h2,h3{ margin:0; color:var(--ink); font-family:var(--serif); font-weight:500; line-height:1.04; letter-spacing:-.01em; }
p{ margin:0; }

/* ---- Texture ------------------------------------------------------------ */
/* Faint paper grain — kept extremely subtle so it reads as stock, not noise. */
body::before{
  content:"";
  position:fixed; inset:0; z-index:0; pointer-events:none;
  opacity:.5;
  background-image:
    radial-gradient(rgba(20,19,15,.020) 1px, transparent 1px),
    radial-gradient(rgba(20,19,15,.018) 1px, transparent 1px);
  background-position:0 0, 13px 17px;
  background-size:26px 26px, 26px 26px;
}
body > *{ position:relative; z-index:1; }

/* ---- Layout primitives -------------------------------------------------- */
.wrap{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:clamp(1.25rem, 4vw, 3rem); }
.section{ padding-block:var(--space-xl); }
.rule{ border:0; border-top:1px solid var(--line); margin:0; }
.rule--brass{ border-top:1px solid color-mix(in srgb, var(--brass) 55%, transparent); }

/* Small-caps register labels — the connective tissue of the whole system. */
.eyebrow{
  font-family:var(--sans);
  font-size:var(--step--1);
  font-weight:600;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--brass-lo);
}

/* ---- The mark ----------------------------------------------------------- */
.mark{ display:inline-flex; align-items:center; gap:.55rem; color:var(--ink); }
.mark__o{ width:1.15em; height:1.15em; flex:0 0 auto; }
.mark__o circle{ fill:none; stroke:currentColor; }
.wordmark{
  font-family:var(--serif);
  font-size:var(--step-1);
  font-weight:600;
  letter-spacing:.02em;
  line-height:1;
}

/* ---- Buttons ------------------------------------------------------------ */
.btn{
  --btn-fg:var(--cream); --btn-bg:var(--forest); --btn-bd:var(--forest);
  display:inline-flex; align-items:center; gap:.55rem;
  font-family:var(--sans); font-size:var(--step--1); font-weight:600;
  letter-spacing:.14em; text-transform:uppercase;
  color:var(--btn-fg); background:var(--btn-bg);
  border:1px solid var(--btn-bd); border-radius:var(--radius);
  padding:.95em 1.6em; cursor:pointer;
  transition:transform .18s ease, background .18s ease, color .18s ease, border-color .18s ease;
}
.btn:hover{ transform:translateY(-1px); background:var(--forest-lo); }
.btn--ghost{
  --btn-fg:var(--ink); --btn-bg:transparent; --btn-bd:var(--line);
}
.btn--ghost:hover{ background:transparent; border-color:var(--brass); color:var(--brass-lo); }
.btn--brass{ --btn-fg:var(--ink); --btn-bg:var(--brass); --btn-bd:var(--brass); }
.btn--brass:hover{ background:color-mix(in srgb, var(--brass) 88%, var(--ink)); }

.textlink{
  font-size:var(--step--1); font-weight:600; letter-spacing:.1em; text-transform:uppercase;
  color:var(--ink); border-bottom:1px solid var(--brass);
  padding-bottom:2px; transition:color .18s ease, border-color .18s ease;
}
.textlink:hover{ color:var(--brass-lo); border-color:var(--brass-lo); }

/* ---- Header ------------------------------------------------------------- */
.site-head{ border-top:3px double color-mix(in srgb, var(--brass) 60%, transparent); }
.site-head__bar{ display:flex; align-items:center; justify-content:space-between; gap:var(--space-m); padding-block:1.25rem; }
.nav{ display:flex; align-items:center; gap:clamp(1rem,2.5vw,2.2rem); }
.nav a{
  font-size:var(--step--1); font-weight:500; letter-spacing:.14em; text-transform:uppercase;
  color:var(--ink-soft); transition:color .18s ease;
}
.nav a:hover{ color:var(--brass-lo); }
.nav__cta{ margin-left:.5rem; }
@media (max-width:720px){ .nav a:not(.nav__cta){ display:none; } }

/* ---- Hero --------------------------------------------------------------- */
.hero{ padding-block:clamp(3.5rem, 8vw, 7rem); }
.hero__grid{ display:grid; grid-template-columns:1.15fr .85fr; gap:clamp(2rem,5vw,4.5rem); align-items:center; }
@media (max-width:880px){ .hero__grid{ grid-template-columns:1fr; } }
.hero__title{ font-size:var(--step-4); margin-top:1.2rem; }
.hero__title em{ font-style:italic; color:var(--forest); }
.hero__sub{ font-size:var(--step-1); font-weight:500; color:var(--ink); margin-top:.9rem; letter-spacing:-.005em; }
.hero__lede{ font-size:var(--step-1); line-height:1.45; color:var(--ink-soft); max-width:32ch; margin-top:1.1rem; }
.hero__actions{ display:flex; flex-wrap:wrap; align-items:center; gap:1.25rem; margin-top:2.25rem; }
.hero__meta{ margin-top:2.5rem; display:flex; gap:1.75rem; flex-wrap:wrap; }
.hero__meta div{ border-left:1px solid var(--line); padding-left:.9rem; }
.hero__meta dt{ font-family:var(--serif); font-size:var(--step-2); color:var(--ink); line-height:1; }
.hero__meta dd{ margin:.35rem 0 0; font-size:var(--step--1); letter-spacing:.12em; text-transform:uppercase; color:var(--brass-lo); }

/* ---- Ledger card (hero visual) ----------------------------------------- */
.ledger{
  background:var(--ink);
  color:var(--cream);
  border:1px solid color-mix(in srgb, var(--brass) 40%, transparent);
  border-radius:var(--radius);
  box-shadow:0 30px 60px -30px rgba(20,19,15,.6);
  overflow:hidden;
}
.ledger__head{
  display:flex; align-items:baseline; justify-content:space-between;
  padding:1.15rem 1.4rem; border-bottom:1px solid rgba(244,238,223,.14);
}
.ledger__head .eyebrow{ color:var(--brass); }
.ledger__head span{ font-family:var(--serif); font-size:var(--step-1); color:var(--cream); }
.ledger__rows{ width:100%; border-collapse:collapse; }
.ledger__rows td{ padding:.85rem 1.4rem; border-bottom:1px solid rgba(244,238,223,.10); vertical-align:middle; }
.ledger__rows tr:last-child td{ border-bottom:0; }
.ledger__rank{ font-family:var(--serif); font-size:var(--step-1); color:var(--brass); width:2.5rem; }
.ledger__name{ font-weight:500; letter-spacing:.01em; color:var(--cream); }
.ledger__name small{ display:block; font-weight:400; font-size:var(--step--1); letter-spacing:.1em; text-transform:uppercase; color:rgba(244,238,223,.5); margin-top:2px; }
.ledger__pts{ text-align:right; font-variant-numeric:tabular-nums; font-feature-settings:"tnum" 1; font-size:var(--step-1); color:var(--cream); }
.ledger__pts.up{ color:#8FB89B; }
.ledger__pts.down{ color:#C98A8A; }
.ledger__foot{ padding:.95rem 1.4rem; background:rgba(244,238,223,.04); font-size:var(--step--1); letter-spacing:.06em; color:rgba(244,238,223,.7); display:flex; justify-content:space-between; }
.ledger__foot em{ color:var(--brass); font-style:normal; }

/* ---- Lexicon ------------------------------------------------------------ */
.lexicon{ display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--line); border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; }
@media (max-width:880px){ .lexicon{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:460px){ .lexicon{ grid-template-columns:1fr; } }
.lex{ background:var(--cream); padding:1.5rem 1.4rem; }
.lex b{ display:block; font-family:var(--serif); font-size:var(--step-2); color:var(--ink); font-weight:500; }
.lex span{ display:block; margin-top:.35rem; font-size:var(--step--1); letter-spacing:.04em; color:var(--ink-soft); }
.lex span::before{ content:"was "; color:var(--brass-lo); font-style:italic; }

/* ---- Features ----------------------------------------------------------- */
.features{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(1.5rem,4vw,3rem); }
@media (max-width:880px){ .features{ grid-template-columns:1fr; } }
.feature{ border-top:1px solid var(--brass); padding-top:1.4rem; }
.feature__n{ font-family:var(--serif); font-size:var(--step-1); color:var(--brass-lo); }
.feature h3{ font-size:var(--step-2); margin-top:.5rem; }
.feature p{ margin-top:.8rem; color:var(--ink-soft); }

/* ---- Quiet band (forest) ----------------------------------------------- */
.band{ background:var(--forest); color:var(--cream); }
.band h2{ color:var(--cream); font-size:var(--step-3); max-width:18ch; }
.band .eyebrow{ color:var(--brass); }
.band p{ color:rgba(244,238,223,.8); max-width:46ch; margin-top:1.25rem; font-size:var(--step-1); line-height:1.5; }
.band__inner{ display:grid; grid-template-columns:1fr auto; gap:var(--space-m); align-items:end; }
@media (max-width:720px){ .band__inner{ grid-template-columns:1fr; } }

/* ---- Footer ------------------------------------------------------------- */
.site-foot{ background:var(--ink); color:rgba(244,238,223,.65); padding-block:var(--space-l); }
.site-foot a:hover{ color:var(--brass); }
.site-foot .mark{ color:var(--cream); }
.site-foot__grid{ display:flex; align-items:flex-start; justify-content:space-between; gap:var(--space-m); flex-wrap:wrap; }
.site-foot__cols{ display:flex; gap:clamp(2rem,6vw,5rem); flex-wrap:wrap; }
.foot-col h4{ margin:0 0 .9rem; font-size:var(--step--1); letter-spacing:.18em; text-transform:uppercase; color:var(--brass); font-weight:600; }
.foot-col a{ display:block; font-size:var(--step--1); letter-spacing:.04em; padding:.2rem 0; }
.site-foot__base{ margin-top:var(--space-m); padding-top:var(--space-s); border-top:1px solid rgba(244,238,223,.14); display:flex; justify-content:space-between; gap:1rem; flex-wrap:wrap; font-size:var(--step--1); letter-spacing:.06em; color:rgba(244,238,223,.45); }

/* ---- Utility ------------------------------------------------------------ */
.lead-in{ max-width:60ch; }
.lead-in h2{ font-size:var(--step-3); margin-top:1rem; }
.lead-in p{ margin-top:1.25rem; font-size:var(--step-1); color:var(--ink-soft); line-height:1.5; }
.center{ text-align:center; margin-inline:auto; }
.chips{ display:flex; flex-wrap:wrap; gap:.6rem; margin-top:1.75rem; }
.chip{
  font-family:var(--serif); font-style:italic; font-size:var(--step-0);
  color:var(--ink); background:var(--cream-deep);
  border:1px solid var(--line); border-radius:999px; padding:.4em 1em;
}

/* ==========================================================================
   CLUBHOUSE — server-rendered app surfaces (Rounds + Ledger)
   ========================================================================== */
.app{ padding-block:var(--space-l); min-height:60vh; }
.club-hero{ display:flex; align-items:flex-end; justify-content:space-between; gap:var(--space-m); flex-wrap:wrap; padding-bottom:var(--space-m); border-bottom:1px solid var(--line); }
.club-hero h1{ font-size:var(--step-3); margin-top:.4rem; }
.club-hero__next{ text-align:right; }
.club-hero__next .eyebrow{ display:block; margin-bottom:.3rem; }
.club-hero__next b{ font-family:var(--serif); font-size:var(--step-1); color:var(--ink); }

.cols{ display:grid; grid-template-columns:1.2fr .8fr; gap:clamp(1.5rem,4vw,3rem); margin-top:var(--space-m); align-items:start; }
@media (max-width:880px){ .cols{ grid-template-columns:1fr; } }

.panel{ border:1px solid var(--line); border-radius:var(--radius); background:var(--cream); }
.panel__head{ display:flex; align-items:baseline; justify-content:space-between; gap:1rem; padding:1.1rem 1.3rem; border-bottom:1px solid var(--line); }
.panel__head h2{ font-size:var(--step-1); }
.panel__body{ padding:1.1rem 1.3rem; }
.panel + .panel{ margin-top:var(--space-m); }

/* Standings — the Ledger, light "register" variant */
.register{ width:100%; border-collapse:collapse; }
.register td, .register th{ padding:.8rem 1.3rem; border-bottom:1px solid var(--line-soft); text-align:left; }
.register tr:last-child td{ border-bottom:0; }
.register .rk{ width:2.5rem; font-family:var(--serif); font-size:var(--step-1); color:var(--brass-lo); }
.register .nm{ font-weight:500; color:var(--ink); }
.register .nm small{ display:block; font-weight:400; font-size:var(--step--1); letter-spacing:.08em; text-transform:uppercase; color:var(--ink-soft); margin-top:2px; }
.register .pt{ text-align:right; font-variant-numeric:tabular-nums; font-feature-settings:"tnum" 1; font-size:var(--step-1); color:var(--ink); }
.register .pt.up{ color:var(--forest); }
.register .pt.down{ color:var(--burgundy); }
.register tr.lead td{ background:color-mix(in srgb, var(--brass) 10%, transparent); }

/* Rounds list */
.rounds-list{ list-style:none; margin:0; padding:0; }
.rounds-list li{ border-bottom:1px solid var(--line-soft); }
.rounds-list li:last-child{ border-bottom:0; }
.round-row{ display:flex; align-items:center; gap:1rem; padding:1rem 1.3rem; transition:background .15s ease; }
.round-row:hover{ background:var(--cream-deep); }
.round-row__date{ flex:0 0 4.5rem; font-variant-numeric:tabular-nums; font-size:var(--step--1); letter-spacing:.06em; text-transform:uppercase; color:var(--brass-lo); }
.round-row__main{ flex:1 1 auto; }
.round-row__main b{ font-family:var(--serif); font-size:var(--step-1); color:var(--ink); font-weight:500; }
.round-row__main span{ display:block; font-size:var(--step--1); color:var(--ink-soft); margin-top:1px; }

/* Status + RSVP tags */
.tag{ display:inline-block; font-size:var(--step--1); font-weight:600; letter-spacing:.12em; text-transform:uppercase; padding:.25em .7em; border-radius:999px; border:1px solid var(--line); }
.tag--settled{ color:var(--forest); border-color:color-mix(in srgb, var(--forest) 40%, transparent); background:color-mix(in srgb, var(--forest) 8%, transparent); }
.tag--called{ color:var(--brass-lo); border-color:color-mix(in srgb, var(--brass) 50%, transparent); background:color-mix(in srgb, var(--brass) 10%, transparent); }
.tag--in{ color:var(--forest); border-color:color-mix(in srgb,var(--forest) 40%,transparent); }
.tag--out{ color:var(--burgundy); border-color:color-mix(in srgb,var(--burgundy) 40%,transparent); }
.tag--maybe{ color:var(--brass-lo); border-color:color-mix(in srgb,var(--brass) 50%,transparent); }

.rsvp-tally{ display:flex; gap:.6rem; flex-wrap:wrap; margin-top:.2rem; }

/* Forms */
.form{ display:grid; gap:1.1rem; }
.field{ display:grid; gap:.4rem; }
.field label{ font-size:var(--step--1); font-weight:600; letter-spacing:.12em; text-transform:uppercase; color:var(--brass-lo); }
.field input, .field select{
  font-family:var(--sans); font-size:var(--step-0); color:var(--ink);
  background:var(--cream); border:1px solid var(--line); border-radius:var(--radius);
  padding:.7em .85em; width:100%;
}
.field input:focus, .field select:focus{ outline:2px solid color-mix(in srgb,var(--brass) 60%,transparent); outline-offset:1px; border-color:var(--brass); }
.form-row{ display:grid; grid-template-columns:1fr auto; gap:1rem; align-items:end; }
.result-grid{ display:grid; gap:.7rem; }
.result-grid .field{ grid-template-columns:1fr 7rem; align-items:center; gap:1rem; }
.result-grid .field label{ text-transform:none; letter-spacing:.01em; font-weight:500; font-family:var(--serif); font-size:var(--step-1); color:var(--ink); }
.result-grid input{ text-align:right; font-variant-numeric:tabular-nums; }

.crumbs{ font-size:var(--step--1); letter-spacing:.08em; text-transform:uppercase; color:var(--ink-soft); margin-bottom:.8rem; }
.crumbs a{ color:var(--brass-lo); }
.empty{ color:var(--ink-soft); font-style:italic; font-family:var(--serif); font-size:var(--step-1); }
.notice{ font-family:var(--serif); font-style:italic; color:var(--forest); margin-bottom:1.2rem; padding:.6rem 1rem; border-left:2px solid var(--brass); background:var(--cream-deep); }
