/* ============================================================
   RYAN WEST MEMORIAL — site styles
   Design tokens + layout, distilled from the design system's
   colors_and_type.css and the website UI kit's index.html.
   "Long live the King." Sunny, vivid, generous — never somber.
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Bricolage+Grotesque:opsz,wght@12..96,400;12..96,500;12..96,600;12..96,700;12..96,800&family=Hanken+Grotesk:wght@400;500;600;700;800&family=Caveat:wght@500;600;700&display=swap');

:root {
  /* ---------- Brand palette ---------- */
  --pine:        #1C4D27;
  --grass:       #2E7D3A;
  --grass-bright:#46A04E;
  --gold:        #F5A623;
  --gold-soft:   #F8C75A;
  --sun:         #ED7A3A;
  --sky:         #2F9BD8;
  --sky-deep:    #1E6FA8;
  --sky-soft:    #BFE3F4;

  /* ---------- Neutrals (warm) ---------- */
  --cream:       #FBF6EA;
  --cream-2:     #F4ECD8;
  --star:        #FFF8E6;
  --paper:       #FFFFFF;
  --ink:         #1B2A20;
  --ink-soft:    #4A574E;
  --ink-faint:   #7A857D;
  --line:        #E4DBC6;
  --line-2:      #D6CBB0;

  /* ---------- Semantic ---------- */
  --bg: var(--cream); --bg-alt: var(--cream-2);
  --surface: var(--paper); --surface-tint:#FEFCF6;
  --fg1: var(--ink); --fg2: var(--ink-soft); --fg3: var(--ink-faint);
  --on-dark:#FBF6EA; --on-dark-2:#C9D8CB;
  --brand: var(--grass); --brand-deep: var(--pine);
  --accent: var(--gold); --accent-2: var(--sun); --link: var(--sky-deep);
  --border: var(--line); --border-strong: var(--line-2); --focus: var(--sky);

  /* ---------- Radii ---------- */
  --r-xs:6px; --r-sm:10px; --r-md:16px; --r-lg:24px; --r-xl:34px; --r-pill:999px;

  /* ---------- Spacing (4px base) ---------- */
  --s-1:4px; --s-2:8px; --s-3:12px; --s-4:16px; --s-5:24px; --s-6:32px;
  --s-7:48px; --s-8:64px; --s-9:96px; --s-10:128px;

  /* ---------- Shadows (warm, soft) ---------- */
  --sh-sm: 0 1px 2px rgba(28,77,39,.06), 0 1px 3px rgba(28,77,39,.08);
  --sh-md: 0 4px 12px rgba(28,77,39,.08), 0 2px 4px rgba(28,77,39,.06);
  --sh-lg: 0 14px 34px rgba(28,77,39,.12), 0 4px 10px rgba(28,77,39,.07);
  --sh-xl: 0 28px 60px rgba(28,77,39,.16), 0 8px 18px rgba(28,77,39,.08);
  --sh-gold: 0 10px 26px rgba(245,166,35,.32);

  /* ---------- Type ---------- */
  --font-display: 'Bricolage Grotesque', 'Hanken Grotesk', system-ui, sans-serif;
  --font-body:    'Hanken Grotesk', system-ui, -apple-system, sans-serif;
  --font-hand:    'Caveat', 'Bricolage Grotesque', cursive;

  --t-display: 700 clamp(48px, 7vw, 96px)/0.98 var(--font-display);
  --t-h1:      700 clamp(36px, 5vw, 64px)/1.02 var(--font-display);
  --t-h2:      700 clamp(28px, 3.4vw, 44px)/1.06 var(--font-display);
  --t-h3:      600 clamp(22px, 2.2vw, 30px)/1.14 var(--font-display);
  --t-h4:      600 19px/1.25 var(--font-display);
  --t-lead:    400 clamp(19px, 1.6vw, 23px)/1.55 var(--font-body);
  --t-body:    400 17px/1.62 var(--font-body);
  --t-small:   400 15px/1.55 var(--font-body);
  --t-meta:    600 13px/1.4 var(--font-body);
  --t-hand:    600 clamp(26px, 3vw, 40px)/1.05 var(--font-hand);
  --eyebrow:   700 13px/1 var(--font-body);
}

/* ---------- Base ---------- */
* { box-sizing: border-box; }
html, body { margin: 0; }
body { background: var(--cream); color: var(--ink); font-family: var(--font-body);
  -webkit-font-smoothing: antialiased; overflow-x: hidden; }
button { font-family: inherit; }
img { max-width: 100%; }
a { color: inherit; }
::selection { background: var(--gold-soft); color: var(--pine); }
:focus-visible { outline: 3px solid var(--focus); outline-offset: 2px; border-radius: 4px; }

/* ---------- Type helpers ---------- */
.rw-eyebrow { font: var(--eyebrow); letter-spacing:.16em; text-transform:uppercase; color: var(--accent-2); }
.rw-prose { font: var(--t-body); color: var(--fg1); }
.rw-prose p { margin: 0 0 1em; max-width: 64ch; text-wrap: pretty; }
.rw-prose strong { font-weight: 700; }
.rw-prose em { font-style: italic; }
.rw-hand { font-family: var(--font-hand); }

/* ---------- Layout primitives ---------- */
.rw-section { padding: var(--s-9) var(--s-6); }
.rw-container { max-width: 1180px; margin: 0 auto; width: 100%; }
.rw-btnrow { display: flex; gap: 12px; flex-wrap: wrap; }

/* ---------- Header ---------- */
.rw-header { position: sticky; top: 0; z-index: 40; background: rgba(251,246,234,.82);
  backdrop-filter: blur(12px); border-bottom: 1px solid var(--line); }
.rw-header-inner { max-width: 1180px; margin: 0 auto; padding: 12px 24px; display: flex; align-items: center; gap: 20px; }
.rw-brand { display: flex; align-items: center; gap: 11px; background: none; border: 0; cursor: pointer; padding: 0; }
.rw-brand-text { display: flex; flex-direction: column; line-height: 1; text-align: left; }
.rw-brand-name { font-family: var(--font-display); font-weight: 700; font-size: 19px; color: var(--pine); letter-spacing: -.01em; }
.rw-brand-sub { font-size: 11.5px; font-weight: 600; color: var(--sun); letter-spacing: .04em; }
.rw-nav { display: flex; gap: 4px; margin-left: auto; }
.rw-navlink { background: none; border: 0; cursor: pointer; font-weight: 600; font-size: 14.5px; color: var(--fg2);
  padding: 8px 13px; border-radius: var(--r-pill); transition: background .15s, color .15s; }
.rw-navlink:hover { background: rgba(46,125,58,.09); color: var(--pine); }
.rw-navlink.is-active { color: var(--pine); background: rgba(46,125,58,.13); }
.rw-header-cta { margin-left: 6px; }

/* ---------- Buttons ---------- */
.rw-btn { font-family: var(--font-body); font-weight: 700; border: 0; cursor: pointer;
  border-radius: var(--r-pill); display: inline-flex; align-items: center; justify-content: center; gap: 9px;
  transition: transform .12s ease, box-shadow .18s ease, background .18s ease;
  font-size: 16px; padding: 13px 24px; white-space: nowrap; text-decoration: none; }
.rw-btn.sm { font-size: 14px; padding: 9px 17px; }
.rw-btn.lg { font-size: 18px; padding: 16px 30px; }
.rw-btn svg { width: 1.05em; height: 1.05em; }
.rw-btn-primary { background: var(--gold); color: var(--pine); box-shadow: var(--sh-gold); }
.rw-btn-secondary { background: var(--grass); color: var(--star); }
.rw-btn-ghost { background: transparent; color: var(--grass); border: 2px solid var(--grass); }
.rw-btn-ghost-light { background: rgba(255,255,255,.12); color: var(--star); border: 2px solid rgba(255,255,255,.5); }
.rw-btn:hover { transform: translateY(-2px); }
.rw-btn:active { transform: scale(.97); }
.rw-btn-primary:hover { box-shadow: 0 14px 32px rgba(245,166,35,.42); background: #f8b53f; }
.rw-btn-secondary:hover { background: var(--grass-bright); }
.rw-btn-ghost:hover { background: rgba(46,125,58,.08); }

/* ---------- Chip ---------- */
.rw-chip { display: inline-flex; align-items: center; gap: 6px; font-weight: 600; font-size: 13.5px;
  padding: 6px 13px; border-radius: var(--r-pill); background: var(--gold-soft); color: var(--pine); }

/* ---------- Cards ---------- */
.rw-card { background: var(--surface); color: var(--ink); border-radius: var(--r-lg);
  box-shadow: var(--sh-md); overflow: hidden; }
.rw-card.dark { background: var(--pine); color: var(--star); }
.rw-card-accent { height: 6px; }
.rw-card.hoverable { transition: transform .18s ease, box-shadow .18s ease; }
.rw-card.hoverable:hover { transform: translateY(-3px); box-shadow: var(--sh-lg); }

/* ---------- Photo ---------- */
.rw-photo { position: relative; border-radius: var(--r-lg); overflow: hidden; box-shadow: var(--sh-md);
  background: linear-gradient(160deg,#9ED2F0,#C7E6F6 55%,#E7F1E1); }
.rw-photo.tint-grass { background: linear-gradient(160deg,#7FC07F,#A9D6A0 60%,#E7F1E1); }
.rw-photo.tint-gold  { background: linear-gradient(160deg,#F8C75A,#FBE0A0 60%,#FBF6EA); }
.rw-photo.tint-pine  { background: linear-gradient(160deg,#2E7D3A,#1C4D27); }
.rw-photo-img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.rw-photo-watermark { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center;
  flex-direction: column; gap: 10px; opacity: .82; }
.rw-photo-watermark img { height: 40px; opacity: .55; }
.rw-photo-watermark span { font-weight: 600; font-size: 13px; color: var(--pine); letter-spacing: .02em; }
.rw-photo.tint-pine .rw-photo-watermark span { color: var(--on-dark-2); }
.rw-photo-scrim { position: absolute; inset: 0; background: linear-gradient(to top, rgba(28,77,39,.55), transparent 45%); }
.rw-photo-caption { position: absolute; left: 14px; bottom: 12px; font-weight: 600; font-size: 13px; color: var(--star);
  text-shadow: 0 1px 6px rgba(20,33,25,.5); }
.rw-photo-tag { position: absolute; left: 14px; top: 14px; font: var(--eyebrow); letter-spacing: .14em;
  text-transform: uppercase; background: var(--pine); color: var(--star); padding: 5px 11px; border-radius: var(--r-pill); }

/* ---------- Disc mark ---------- */
.rw-disc { display: block; height: auto; }
.rw-float { animation: rw-float 5s ease-in-out infinite; }
@keyframes rw-float { 0%,100% { transform: translateY(0) rotate(-3deg); } 50% { transform: translateY(-12px) rotate(3deg); } }

/* ---------- Forms ---------- */
.rw-field { width: 100%; font-family: var(--font-body); font-size: 15.5px; color: var(--ink);
  background: var(--paper); border: 1.5px solid var(--line-2); border-radius: var(--r-sm); padding: 12px 14px; }
.rw-field::placeholder { color: var(--ink-faint); }
.rw-field:focus { outline: none; border-color: var(--sky); box-shadow: 0 0 0 3px rgba(47,155,216,.25); }
.rw-flabel { display: block; font-weight: 600; font-size: 13px; color: var(--fg2); margin-bottom: 6px; }

/* ---------- Hero ---------- */
.rw-hero-split { display: grid; grid-template-columns: 1.05fr .95fr; gap: 54px; align-items: center; }

/* hero switcher */
.rw-hero-switch { position: fixed; left: 50%; transform: translateX(-50%); bottom: 18px; z-index: 50;
  display: flex; align-items: center; gap: 6px; background: var(--pine); color: var(--star);
  padding: 6px 8px 6px 14px; border-radius: var(--r-pill); box-shadow: var(--sh-lg); }
.rw-hero-switch-lbl { font-size: 11px; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; color: var(--gold-soft); }
.rw-hero-switch-btn { width: 30px; height: 30px; border-radius: 50%; border: 0; cursor: pointer; font-weight: 700;
  background: rgba(255,255,255,.12); color: var(--star); transition: background .15s; }
.rw-hero-switch-btn:hover { background: rgba(255,255,255,.24); }
.rw-hero-switch-btn.is-on { background: var(--gold); color: var(--pine); }

/* ---------- Grids ---------- */
.rw-stats { display: grid; grid-template-columns: repeat(4,1fr); gap: 24px; }
.rw-story { display: grid; grid-template-columns: .9fr 1.1fr; gap: 50px; align-items: center; }
.rw-cta { display: flex; justify-content: space-between; align-items: center; gap: 30px; flex-wrap: wrap;
  background: var(--cream-2); border-radius: var(--r-xl); padding: 36px 40px; border: 1px solid var(--line); }
.rw-donate-grid { display: grid; grid-template-columns: 1.1fr .9fr; gap: 24px; align-items: start; }
.rw-tiers { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-top: 14px; }
.rw-tier { text-align: left; background: var(--surface-tint); border: 2px solid var(--line-2); border-radius: var(--r-md);
  padding: 14px 16px; cursor: pointer; transition: border-color .15s, box-shadow .15s, transform .12s; font: inherit; }
.rw-tier:hover { transform: translateY(-2px); border-color: var(--gold-soft); }
.rw-tier.is-on { border-color: var(--gold); box-shadow: var(--sh-gold); background: #fffdf6; }
.rw-custom { display: flex; align-items: center; gap: 4px; border: 1.5px solid var(--line-2); border-radius: var(--r-sm);
  padding-left: 14px; margin-bottom: 18px; font-weight: 700; color: var(--fg2); }
.rw-checklist { list-style: none; padding: 0; margin: 14px 0 0; display: flex; flex-direction: column; gap: 11px; }
.rw-checklist li { display: flex; align-items: center; gap: 10px; font-size: 15px; }
.rw-checklist:not(.rw-checklist-light) li { color: var(--on-dark-2); }
.rw-checklist-light li { color: var(--fg2); }
.rw-mem-grid { display: grid; grid-template-columns: .8fr 1.2fr; gap: 24px; align-items: start; }
.rw-info-row { display: grid; grid-template-columns: repeat(4,1fr); gap: 14px; }
.rw-info-tile { display: flex; align-items: center; gap: 12px; background: var(--paper); border: 1px solid var(--line);
  border-radius: var(--r-md); padding: 16px 18px; box-shadow: var(--sh-sm); }
.rw-tourney-grid { display: grid; grid-template-columns: 1.15fr .85fr; gap: 44px; align-items: start; }
.rw-sponsor { display: flex; gap: 10px; margin-top: 10px; }
.rw-sponsor-tier { flex: 1; display: flex; flex-direction: column; gap: 2px; align-items: center; background: var(--paper);
  border: 2px solid var(--line-2); border-radius: var(--r-md); padding: 14px 8px; }
.rw-schol-intro { display: grid; grid-template-columns: .85fr 1.15fr; gap: 48px; align-items: center; }
.rw-recipients { display: grid; grid-template-columns: repeat(3,1fr); gap: 20px; }

/* gallery */
.rw-gallery { display: grid; grid-template-columns: repeat(4,1fr); gap: 16px; grid-auto-flow: dense; }
.rw-gallery-cell { padding: 0; border: 0; background: none; cursor: pointer; transition: transform .15s; }
.rw-gallery-cell:hover { transform: translateY(-3px); }
.rw-gallery-cell.is-big { grid-column: span 2; }
.rw-lightbox { position: fixed; inset: 0; z-index: 60; background: rgba(20,33,25,.74); backdrop-filter: blur(6px);
  display: flex; align-items: center; justify-content: center; padding: 30px; }
.rw-lightbox-inner { max-width: 720px; width: 100%; }
.rw-lightbox-close { background: rgba(255,255,255,.14); border: 0; border-radius: 50%; width: 40px; height: 40px;
  cursor: pointer; display: inline-flex; align-items: center; justify-content: center; }

/* footer */
.rw-footer { background: var(--pine); color: var(--on-dark); padding: var(--s-8) var(--s-6) var(--s-6); }
.rw-foot-cols { display: flex; flex-wrap: wrap; gap: 40px; justify-content: space-between; align-items: flex-start; }
.rw-foot-h { font-weight: 700; font-size: 13px; letter-spacing: .14em; text-transform: uppercase; color: var(--gold-soft); margin-bottom: 12px; }
.rw-foot-link { display: block; background: none; border: 0; cursor: pointer; color: var(--on-dark); font-size: 15px; padding: 5px 0; opacity: .9; text-align: left; }
.rw-foot-link:hover { opacity: 1; color: var(--gold-soft); }
.rw-foot-line { display: flex; align-items: center; gap: 9px; color: var(--on-dark-2); font-size: 14.5px; margin-bottom: 9px; }
.rw-foot-bottom { border-top: 1px solid rgba(255,255,255,.16); margin-top: 36px; padding-top: 18px;
  display: flex; justify-content: space-between; flex-wrap: wrap; gap: 10px; font: var(--t-small); color: var(--on-dark-2); }

/* reveal */
.rw-reveal { opacity: 1; transform: translateY(16px); transition: opacity .6s ease, transform .6s ease; }
.rw-reveal:not(.rw-in) { opacity: 0; }
.rw-in { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) { .rw-reveal { opacity: 1; transform: none; } .rw-float { animation: none; } }

/* responsive */
@media (max-width: 920px) {
  .rw-hero-split, .rw-story, .rw-donate-grid, .rw-mem-grid, .rw-tourney-grid, .rw-schol-intro { grid-template-columns: 1fr; gap: 32px; }
  .rw-stats, .rw-info-row { grid-template-columns: 1fr 1fr; }
  .rw-recipients, .rw-gallery { grid-template-columns: 1fr 1fr; }
  .rw-gallery-cell.is-big { grid-column: span 2; }
  .rw-nav { display: none; }
  .rw-section { padding: var(--s-8) var(--s-5); }
}
@media (max-width: 560px) {
  .rw-stats { grid-template-columns: 1fr 1fr; }
  .rw-cta { padding: 26px 22px; }
}
