/* ============================================================
   The Eli's Charity Golf Tournament — shared styles
   Forest green country club × Eli's copper × CT Children's blue
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=DM+Serif+Display:ital@0;1&family=Hanken+Grotesk:wght@400;500;600;700;800&display=swap');

:root{
  /* brand */
  /* Structural brand color — Eli's navy blue (var names kept as --green* for compatibility) */
  --green:        #16365A;   /* Eli's deep navy */
  --green-800:    #0F2742;
  --green-700:    #244F7C;
  --green-soft:   #3C6FA0;
  --copper:       #905838;   /* Eli's logo brown — warm CTA */
  --copper-dark:  #774526;
  --copper-soft:  #B07A54;
  --blue:         #0061A8;   /* Connecticut Children's */
  --blue-soft:    #2E86C9;

  /* neutrals */
  --paper:        #FBF8F1;
  --cream:        #F4EDDF;
  --cream-deep:   #EAE0CC;
  --ink:          #2A2118;
  --muted:        #6E6052;
  --line:         #DED2BC;

  --shadow-sm: 0 1px 3px rgba(42,33,24,.06), 0 1px 2px rgba(42,33,24,.04);
  --shadow:    0 18px 40px -24px rgba(22,54,90,.45), 0 4px 14px -8px rgba(42,33,24,.12);
  --shadow-lg: 0 40px 80px -40px rgba(15,39,66,.5);

  --container: 1160px;
  --radius: 14px;
}

*{ box-sizing:border-box; }
[hidden]{ display:none !important; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  margin:0;
  font-family:'Hanken Grotesk',system-ui,sans-serif;
  color:var(--ink);
  background:var(--paper);
  font-size:17px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
}
img{ display:block; max-width:100%; }
a{ color:inherit; }

/* ---------- type ---------- */
h1,h2,h3,h4{ font-family:'DM Serif Display',Georgia,serif; font-weight:400; line-height:1.08; margin:0; letter-spacing:-.01em; }
.display{ font-size:clamp(2.6rem,6vw,5rem); }
h2{ font-size:clamp(2rem,4vw,3.1rem); }
h3{ font-size:clamp(1.4rem,2.4vw,1.85rem); }
p{ margin:0 0 1rem; }
.lead{ font-size:clamp(1.1rem,1.6vw,1.32rem); line-height:1.6; color:var(--muted); }

.eyebrow{
  font-family:'Hanken Grotesk',sans-serif;
  font-weight:700; font-size:.78rem; letter-spacing:.22em; text-transform:uppercase;
  color:var(--copper); margin:0 0 1rem; display:inline-flex; align-items:center; gap:.7rem;
}
.eyebrow::before{ content:""; width:26px; height:2px; background:var(--copper); display:inline-block; }
.eyebrow.center{ justify-content:center; }
.eyebrow.on-green{ color:var(--copper-soft); }
.eyebrow.on-green::before{ background:var(--copper-soft); }

/* ---------- layout ---------- */
.container{ width:100%; max-width:var(--container); margin:0 auto; padding:0 28px; }
.section{ padding:clamp(56px,8vw,108px) 0; }
.section.tight{ padding:clamp(40px,5vw,64px) 0; }
.center{ text-align:center; }
.muted{ color:var(--muted); }
.maxw{ max-width:62ch; }
.maxw.center{ margin-left:auto; margin-right:auto; }

/* ---------- buttons ---------- */
.btn{
  font-family:'Hanken Grotesk',sans-serif; font-weight:700; font-size:1rem;
  display:inline-flex; align-items:center; justify-content:center; gap:.6rem;
  padding:.95rem 1.7rem; border-radius:999px; border:1.5px solid transparent;
  cursor:pointer; text-decoration:none; transition:transform .15s ease, box-shadow .2s ease, background .2s ease, color .2s ease;
  white-space:nowrap; line-height:1;
}
.btn:hover{ transform:translateY(-2px); }
.btn-primary{ background:var(--copper); color:#fff; box-shadow:0 10px 24px -10px rgba(144,88,56,.7); }
.btn-primary:hover{ background:var(--copper-dark); box-shadow:0 14px 30px -10px rgba(144,88,56,.8); }
.btn-green{ background:var(--green); color:var(--paper); }
.btn-green:hover{ background:var(--green-800); }
.btn-ghost{ background:transparent; color:var(--green); border-color:var(--line); }
.btn-ghost:hover{ border-color:var(--green); background:rgba(22,54,90,.04); }
.btn-ghost.on-green{ color:var(--paper); border-color:rgba(255,255,255,.4); }
.btn-ghost.on-green:hover{ border-color:#fff; background:rgba(255,255,255,.08); }
.btn-lg{ padding:1.15rem 2.3rem; font-size:1.08rem; }
.btn-block{ width:100%; }

/* ---------- top nav ---------- */
.nav{
  position:sticky; top:0; z-index:50;
  background:rgba(22,54,90,.97); backdrop-filter:blur(10px);
  border-bottom:1px solid rgba(255,255,255,.08);
}
.nav-inner{ display:flex; align-items:center; justify-content:space-between; height:74px; gap:24px; }
.nav-brand{ display:flex; align-items:center; gap:.7rem; text-decoration:none; }
.nav-brand img{ height:34px; width:auto; }
.nav-brand .tag{
  font-family:'Hanken Grotesk',sans-serif; font-weight:700; font-size:.66rem; letter-spacing:.18em;
  text-transform:uppercase; color:var(--copper-soft); border-left:1px solid rgba(255,255,255,.25);
  padding-left:.7rem; line-height:1.25;
}
.nav-links{ display:flex; align-items:center; gap:6px; list-style:none; margin:0; padding:0; }
.nav-links a{
  position:relative;
  text-decoration:none; color:rgba(255,255,255,.82); font-weight:600; font-size:.95rem;
  padding:.5rem .85rem; border-radius:8px; transition:color .15s, background .15s;
}
.nav-links a:hover{ color:#fff; background:rgba(255,255,255,.08); }
.nav-links a.active{ color:#fff; }
.nav-links a.active::after{ content:""; position:absolute; left:.85rem; right:.85rem; bottom:.18rem;
  height:2px; background:var(--copper-soft); border-radius:2px; }
.nav-cta{ margin-left:8px; }
.nav-toggle{ display:none; }

@media (max-width:860px){
  .nav-inner{ height:64px; }
  .nav-links{
    position:absolute; top:64px; left:0; right:0; flex-direction:column; align-items:stretch;
    background:var(--green); padding:14px; gap:4px; border-bottom:1px solid rgba(255,255,255,.12);
    max-height:0; overflow:hidden; transition:max-height .3s ease, padding .3s ease; padding-top:0; padding-bottom:0;
  }
  .nav-toggle:checked ~ .nav-links{ max-height:380px; padding:14px; }
  .nav-links a{ padding:.8rem 1rem; font-size:1.05rem; }
  .nav-links .active::after{ display:none; }
  .nav-cta{ margin:6px 0 0; }
  .nav-burger{ display:flex; flex-direction:column; gap:5px; cursor:pointer; padding:8px; }
  .nav-burger span{ width:24px; height:2px; background:#fff; border-radius:2px; transition:.2s; }
  .nav-toggle:checked ~ .nav-burger span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
  .nav-toggle:checked ~ .nav-burger span:nth-child(2){ opacity:0; }
  .nav-toggle:checked ~ .nav-burger span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }
}
@media (min-width:861px){ .nav-burger{ display:none; } }

/* ---------- image placeholders ---------- */
.ph{
  position:relative; border-radius:var(--radius); overflow:hidden;
  background:
    repeating-linear-gradient(135deg, var(--cream-deep) 0 14px, var(--cream) 14px 28px);
  border:1px solid var(--line);
  display:flex; align-items:center; justify-content:center; color:var(--muted);
}
.ph.dark{
  background:repeating-linear-gradient(135deg, var(--green-800) 0 16px, var(--green-700) 16px 32px);
  border-color:rgba(255,255,255,.1); color:rgba(255,255,255,.7);
}
.ph .ph-label{
  font-family:'Hanken Grotesk',monospace; font-family:ui-monospace,'SFMono-Regular',Menlo,monospace;
  font-size:.74rem; letter-spacing:.06em; text-transform:uppercase;
  background:rgba(251,248,241,.85); padding:.45rem .7rem; border-radius:6px; border:1px solid var(--line);
  text-align:center; max-width:80%;
}
.ph.dark .ph-label{ background:rgba(15,39,66,.7); border-color:rgba(255,255,255,.18); color:rgba(255,255,255,.85); }

/* ---------- cards ---------- */
.card{
  background:#fff; border:1px solid var(--line); border-radius:var(--radius);
  padding:30px; box-shadow:var(--shadow-sm);
}

/* small divider mark */
.tee{ display:flex; align-items:center; gap:14px; color:var(--copper); }
.tee::before,.tee::after{ content:""; height:1px; background:var(--line); flex:1; }
.tee .dot{ width:9px; height:9px; transform:rotate(45deg); background:var(--copper); }
.tee.center{ max-width:240px; margin:0 auto; }

/* ---------- footer ---------- */
.footer{ background:var(--green-800); color:rgba(255,255,255,.78); }
.footer-top{ padding-top:64px; padding-bottom:48px; display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:40px; }
.footer-brand img{ height:38px; margin-bottom:18px; }
.footer-brand p{ max-width:34ch; font-size:.95rem; }
.footer h4{ font-family:'Hanken Grotesk',sans-serif; font-weight:700; font-size:.78rem; letter-spacing:.18em;
  text-transform:uppercase; color:var(--copper-soft); margin-bottom:1.1rem; }
.footer-links{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:.6rem; }
.footer-links a{ text-decoration:none; color:rgba(255,255,255,.78); font-size:.97rem; transition:color .15s; }
.footer-links a:hover{ color:#fff; }
.footer .charity-logo{ color:#fff; max-width:200px; margin-top:6px; opacity:.92; }
.footer-bottom{ border-top:1px solid rgba(255,255,255,.12); padding-top:22px; padding-bottom:22px; display:flex;
  justify-content:space-between; align-items:center; gap:16px; flex-wrap:wrap; font-size:.85rem; color:rgba(255,255,255,.55); }
.footer-bottom a{ color:rgba(255,255,255,.7); text-decoration:none; }

@media (max-width:760px){
  .footer-top{ grid-template-columns:1fr 1fr; }
  .footer-brand{ grid-column:1/-1; }
}
@media (max-width:480px){
  .footer-top{ grid-template-columns:1fr; }
}

/* utility grids */
.grid{ display:grid; gap:24px; }
.grid-2{ grid-template-columns:repeat(2,1fr); }
.grid-3{ grid-template-columns:repeat(3,1fr); }
.grid-4{ grid-template-columns:repeat(4,1fr); }
@media (max-width:900px){ .grid-3,.grid-4{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:620px){ .grid-2,.grid-3,.grid-4{ grid-template-columns:1fr; } }

.tag-pill{
  display:inline-block; font-weight:700; font-size:.72rem; letter-spacing:.12em; text-transform:uppercase;
  color:var(--green); background:var(--cream); border:1px solid var(--line); padding:.35rem .75rem; border-radius:999px;
}
.inline-link{ color:var(--copper); text-decoration:underline; text-underline-offset:3px; font-weight:600; }
.inline-link:hover{ color:var(--copper-dark); }

/* ============================================================
   HOME
   ============================================================ */
.hero{ position:relative; color:#fff; overflow:hidden; }
.hero-bg{ position:absolute; inset:0; border-radius:0; border:0; }
.hero-bg .ph-label{ position:absolute; bottom:18px; right:18px; max-width:none; }
.hero-overlay{ position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(15,39,66,.78) 0%, rgba(15,39,66,.72) 45%, rgba(15,39,66,.9) 100%); }
.hero-content{ position:relative; z-index:2; text-align:center;
  padding:clamp(56px,9vw,104px) 28px clamp(64px,9vw,108px); }
.hero-logo{ height:clamp(58px,9vw,92px); width:auto; margin:0 auto clamp(20px,3vw,30px);
  filter:drop-shadow(0 6px 18px rgba(0,0,0,.3)); }
.hero-title{ margin:.4rem auto .2rem; max-width:14ch; }
.hero-sub{ font-size:clamp(1.05rem,1.8vw,1.32rem); color:rgba(255,255,255,.9); max-width:46ch;
  margin:1.1rem auto 0; line-height:1.55; text-wrap:balance; }
.hero-sub strong{ color:#fff; }
.hero-meta{ display:flex; align-items:center; justify-content:center; flex-wrap:wrap; gap:8px 26px;
  margin:clamp(26px,4vw,38px) auto 0; padding:18px 26px; max-width:760px;
  background:rgba(255,255,255,.07); border:1px solid rgba(255,255,255,.16); border-radius:14px; backdrop-filter:blur(4px); }
.hero-meta-item{ display:flex; flex-direction:column; gap:.15rem; }
.hero-meta-item .k{ font-size:.7rem; letter-spacing:.2em; text-transform:uppercase; color:var(--copper-soft); font-weight:700; }
.hero-meta-item .v{ font-family:'DM Serif Display',serif; font-size:1.32rem; line-height:1.1; }
.hero-meta-sep{ width:1px; height:34px; background:rgba(255,255,255,.2); }
.hero-actions{ display:flex; gap:14px; justify-content:center; flex-wrap:wrap; margin-top:clamp(28px,4vw,40px); }
@media (max-width:560px){ .hero-meta-sep{ display:none; } .hero-meta{ gap:16px 26px; } }

.details-grid{ margin-top:clamp(34px,5vw,54px); }
.detail-card{ text-align:left; }
.detail-icon{ color:var(--copper); font-size:.9rem; }
.detail-k{ font-family:'Hanken Grotesk',sans-serif; font-weight:700; font-size:.76rem; letter-spacing:.16em;
  text-transform:uppercase; color:var(--muted); margin:.7rem 0 .4rem; }
.detail-v{ font-family:'DM Serif Display',serif; font-size:1.5rem; line-height:1.15; margin:0 0 .5rem; color:var(--green); }
.detail-note{ font-size:.92rem; color:var(--muted); margin:0; }

.included-section{ background:var(--green); color:#fff; }
.on-green-h{ color:#fff; }
.included-head{ display:grid; grid-template-columns:1fr 1fr; gap:30px 60px; align-items:end; margin-bottom:clamp(34px,5vw,52px); }
.included-lead{ color:rgba(255,255,255,.8); margin:0; }
.included-grid{ }
.included-item{ display:flex; gap:16px; align-items:flex-start; padding:22px 0; border-top:1px solid rgba(255,255,255,.14); }
.included-item > div{ display:flex; flex-direction:column; gap:.25rem; }
.included-item .im{ color:var(--copper-soft); font-size:.85rem; margin-top:.4rem; }
.included-item strong{ font-size:1.12rem; font-weight:700; line-height:1.25; }
.included-item span{ color:rgba(255,255,255,.7); font-size:.95rem; line-height:1.4; }
@media (max-width:760px){ .included-head{ grid-template-columns:1fr; align-items:start; } }

.pricing-grid{ margin-top:clamp(34px,5vw,52px); max-width:920px; margin-left:auto; margin-right:auto; align-items:stretch; }
.price-card{ display:flex; flex-direction:column; }
.price-card.featured{ border:1.5px solid var(--copper); box-shadow:var(--shadow); position:relative; }
.featured-pill{ color:#fff; background:var(--copper); border-color:var(--copper); }
.price-name{ margin:.9rem 0 .5rem; color:var(--green); }
.price-name-note{ display:block; font-family:'Hanken Grotesk',sans-serif; font-size:.92rem; font-weight:600;
  color:var(--muted); margin-top:.25rem; letter-spacing:0; }
.price-desc{ color:var(--muted); font-size:.97rem; }
.price-amount{ font-family:'DM Serif Display',serif; font-size:2.8rem; color:var(--ink); margin:.6rem 0 1.2rem; line-height:1; }
.price-amount span{ font-family:'Hanken Grotesk',sans-serif; font-size:.95rem; color:var(--muted); font-weight:600; margin-left:.4rem; }
.price-list{ list-style:none; margin:0 0 1.6rem; padding:0; display:flex; flex-direction:column; gap:.7rem; flex:1; }
.price-list li{ position:relative; padding-left:1.6rem; font-size:.98rem; }
.price-list li::before{ content:"◆"; position:absolute; left:0; top:1px; color:var(--copper); font-size:.62rem; }
.price-note{ margin-top:28px; font-size:.95rem; }

.cause-section{ background:var(--cream); }
.cause-inner{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(32px,5vw,64px); align-items:center; }
.cause-media{ aspect-ratio:4/3.4; min-height:340px; }
.cause-copy h2{ color:var(--green); margin:.2rem 0 1rem; }
.cause-charity{ margin-top:28px; padding-top:24px; border-top:1px solid var(--line); }
.cause-charity-label{ display:block; font-size:.72rem; letter-spacing:.18em; text-transform:uppercase; color:var(--muted); font-weight:700; margin-bottom:12px; }
.cause-charity-logo{ color:var(--blue); max-width:230px; }
@media (max-width:760px){ .cause-inner{ grid-template-columns:1fr; } .cause-media{ min-height:260px; } }

.cta-band{ background:var(--green-800); color:#fff; padding:clamp(56px,8vw,96px) 0; text-align:center; }
.cta-lead{ color:rgba(255,255,255,.82); max-width:54ch; margin:1rem auto 0; }
.center-actions{ justify-content:center; }

/* ============================================================
   PAGE HERO (sponsors / register)
   ============================================================ */
.page-hero{ position:relative; background:var(--green); color:#fff; overflow:hidden;
  padding:clamp(56px,8vw,92px) 0 clamp(52px,7vw,80px); }
.page-hero .ph{ position:absolute; inset:0; border-radius:0; border:0; opacity:.5; }
.page-hero-overlay{ position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(22,54,90,.86), rgba(15,39,66,.95)); }
.page-hero-inner{ position:relative; z-index:2; text-align:center; max-width:760px; margin:0 auto; }
.page-hero h1{ font-size:clamp(2.4rem,5vw,4rem); margin:.4rem 0 0; }
.page-hero .lead{ color:rgba(255,255,255,.85); margin:1.1rem auto 0; }

/* ============================================================
   SPONSORS
   ============================================================ */
.why-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:clamp(34px,5vw,52px); }
.why-card{ text-align:left; }
.why-num{ font-family:'DM Serif Display',serif; font-size:2.2rem; color:var(--copper); line-height:1; }
.why-card h3{ font-size:1.3rem; color:var(--green); margin:.7rem 0 .5rem; }
.why-card p{ color:var(--muted); font-size:.97rem; margin:0; }
@media (max-width:760px){ .why-grid{ grid-template-columns:1fr; } }

.tiers-section{ background:var(--cream); }
.tier-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:20px; margin-top:clamp(34px,5vw,52px); align-items:stretch; }
@media (max-width:1000px){ .tier-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:560px){ .tier-grid{ grid-template-columns:1fr; } }
.tier-card{ background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:28px 26px;
  display:flex; flex-direction:column; box-shadow:var(--shadow-sm); }
.tier-card.featured{ border:1.5px solid var(--copper); box-shadow:var(--shadow); }
.tier-ribbon{ font-weight:700; font-size:.68rem; letter-spacing:.16em; text-transform:uppercase; color:var(--copper);
  display:flex; align-items:center; gap:.5rem; margin-bottom:.9rem; }
.tier-ribbon::before{ content:"◆"; font-size:.55rem; }
.tier-name{ font-size:1.5rem; color:var(--green); margin:0 0 .3rem; line-height:1.1; }
.tier-price{ font-family:'DM Serif Display',serif; font-size:2rem; color:var(--ink); margin:.4rem 0 1rem; }
.tier-price span{ font-family:'Hanken Grotesk',sans-serif; font-size:.85rem; color:var(--muted); font-weight:600; }
.tier-list{ list-style:none; margin:0 0 1.4rem; padding:0; display:flex; flex-direction:column; gap:.6rem; flex:1;
  border-top:1px solid var(--line); padding-top:1.2rem; }
.tier-list li{ position:relative; padding-left:1.4rem; font-size:.93rem; color:var(--ink); }
.tier-list li::before{ content:"◆"; position:absolute; left:0; top:2px; color:var(--copper); font-size:.55rem; }
.tier-card .btn{ margin-top:auto; }

.sponsor-logos{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; margin-top:clamp(30px,4vw,44px); }
@media (max-width:760px){ .sponsor-logos{ grid-template-columns:repeat(2,1fr); } }
.sponsor-logo{ aspect-ratio:3/2; border:1px solid var(--line); border-radius:12px; background:#fff;
  display:flex; align-items:center; justify-content:center; }
.sponsor-logo span{ font-family:ui-monospace,Menlo,monospace; font-size:.72rem; letter-spacing:.05em;
  text-transform:uppercase; color:var(--muted); text-align:center; padding:0 10px; }
.sponsor-logo img{ max-width:72%; max-height:68%; object-fit:contain; display:block; }
.sponsor-logo.dark{ background:#0c0c0c; border-color:#0c0c0c; }
.sponsor-logo.dark img{ max-width:85%; max-height:80%; }
.cause-media img{ width:100%; height:100%; object-fit:cover; border-radius:var(--radius); display:block; }

.contact-band{ background:var(--green); color:#fff; text-align:center; padding:clamp(52px,7vw,88px) 0; }
.contact-email{ font-family:'DM Serif Display',serif; font-size:clamp(1.6rem,3.4vw,2.6rem); color:#fff;
  text-decoration:none; display:inline-block; margin:.6rem 0 1.4rem; border-bottom:2px solid var(--copper-soft); padding-bottom:.2rem; transition:color .2s; }
.contact-email:hover{ color:var(--copper-soft); }

/* ============================================================
   REGISTER
   ============================================================ */
.reg-layout{ display:grid; grid-template-columns:1.25fr .85fr; gap:clamp(28px,4vw,48px); align-items:start; }
@media (max-width:880px){ .reg-layout{ grid-template-columns:1fr; } }

.form-card{ background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:clamp(26px,4vw,40px); box-shadow:var(--shadow); }
.form-section + .form-section{ margin-top:34px; padding-top:30px; border-top:1px solid var(--line); }
.form-legend{ font-family:'Hanken Grotesk',sans-serif; font-weight:700; font-size:.78rem; letter-spacing:.16em;
  text-transform:uppercase; color:var(--copper); margin:0 0 .35rem; padding:0; }
.form-section h3{ color:var(--green); margin:0 0 1.3rem; font-size:1.4rem; }
.field{ margin-bottom:18px; }
.field:last-child{ margin-bottom:0; }
.field label{ display:block; font-weight:600; font-size:.92rem; margin-bottom:.4rem; color:var(--ink); }
.field .req{ color:var(--copper); margin-left:.15rem; }
.field .opt{ color:var(--muted); font-weight:500; font-size:.82rem; margin-left:.3rem; }
.input{
  width:100%; font:inherit; font-size:1rem; color:var(--ink); background:var(--paper);
  border:1.5px solid var(--line); border-radius:10px; padding:.8rem .95rem; transition:border-color .15s, box-shadow .15s;
}
.input::placeholder{ color:#A99B89; }
.input:focus{ outline:none; border-color:var(--copper); box-shadow:0 0 0 3px rgba(144,88,56,.14); background:#fff; }
.field-row{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
@media (max-width:520px){ .field-row{ grid-template-columns:1fr; } }

/* entry type choice */
.choice-grid{ display:grid; grid-template-columns:1fr 1fr; gap:14px; }
@media (max-width:520px){ .choice-grid{ grid-template-columns:1fr; } }
.choice{ position:relative; }
.choice input{ position:absolute; opacity:0; inset:0; cursor:pointer; }
.choice-box{
  display:block; border:1.5px solid var(--line); border-radius:12px; padding:18px; cursor:pointer;
  background:var(--paper); transition:border-color .15s, background .15s, box-shadow .15s; height:100%;
}
.choice-box .ct{ display:flex; align-items:center; gap:.55rem; font-weight:700; color:var(--green); font-size:1.05rem; }
.choice-box .ct::before{ content:""; width:18px; height:18px; border-radius:50%; border:2px solid var(--line); flex:none; transition:.15s; }
.choice-box .cp{ display:block; color:var(--muted); font-size:.9rem; margin-top:.4rem; }
.choice-box .camt{ display:block; font-family:'DM Serif Display',serif; color:var(--ink); font-size:1.5rem; margin-top:.5rem; }
.choice input:checked + .choice-box{ border-color:var(--copper); background:#fff; box-shadow:0 0 0 3px rgba(144,88,56,.12); }
.choice input:checked + .choice-box .ct::before{ border-color:var(--copper); background:radial-gradient(circle at center, var(--copper) 0 5px, transparent 6px); }
.choice input:focus-visible + .choice-box{ box-shadow:0 0 0 3px rgba(144,88,56,.25); }

/* payment rail */
.pay-rail{ position:sticky; top:96px; }
.pay-card{ background:var(--green); color:#fff; border-radius:var(--radius); padding:clamp(24px,3vw,32px); box-shadow:var(--shadow); }
.pay-card h3{ color:#fff; font-size:1.5rem; margin:0 0 .4rem; }
.pay-card .pay-sub{ color:rgba(255,255,255,.78); font-size:.95rem; margin:0 0 1.4rem; }
.pay-btn{
  display:flex; align-items:center; justify-content:space-between; gap:14px; width:100%;
  font-family:'Hanken Grotesk',sans-serif; font-weight:700; font-size:1.02rem; text-decoration:none;
  padding:1.05rem 1.3rem; border-radius:12px; border:1.5px solid transparent; cursor:pointer; line-height:1.2;
  transition:transform .15s ease, box-shadow .2s, background .2s; margin-bottom:12px;
}
.pay-btn:hover{ transform:translateY(-2px); }
.pay-btn .amt{ font-family:'DM Serif Display',serif; font-size:1.35rem; }
.pay-btn-primary{ background:var(--copper); color:#fff; box-shadow:0 12px 26px -12px rgba(0,0,0,.5); }
.pay-btn-primary:hover{ background:var(--copper-dark); }
.pay-btn-alt{ background:rgba(255,255,255,.08); color:#fff; border-color:rgba(255,255,255,.28); }
.pay-btn-alt:hover{ background:rgba(255,255,255,.14); }
.pay-note{ display:flex; gap:.6rem; align-items:flex-start; margin-top:18px; padding-top:16px;
  border-top:1px solid rgba(255,255,255,.16); color:rgba(255,255,255,.78); font-size:.86rem; line-height:1.5; }
.pay-note::before{ content:"◆"; color:var(--copper-soft); font-size:.6rem; margin-top:.35rem; flex:none; }
.pay-secure{ display:flex; align-items:center; gap:.5rem; justify-content:center; margin-top:18px;
  color:var(--muted); font-size:.82rem; }
.confirm-banner{ display:flex; gap:.7rem; align-items:flex-start; background:var(--cream); border:1px solid var(--line);
  border-left:3px solid var(--copper); border-radius:10px; padding:14px 16px; font-size:.92rem; color:var(--ink); margin-top:22px; }
.confirm-banner strong{ color:var(--green); }

/* multi-step: how-it-works rail */
.how-card{ background:var(--green); color:#fff; border-radius:var(--radius); padding:clamp(24px,3vw,30px); box-shadow:var(--shadow); }
.how-card h3{ color:#fff; font-size:1.4rem; margin:0 0 1.2rem; }
.how-list{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:1.15rem; counter-reset:how; }
.how-list li{ display:flex; gap:14px; align-items:flex-start; }
.how-n{ flex:none; width:30px; height:30px; border-radius:50%; background:rgba(255,255,255,.12);
  color:#fff; display:flex; align-items:center; justify-content:center; font-weight:700; font-size:.92rem; }
.how-list div strong{ display:block; font-size:1.02rem; font-weight:700; }
.how-list div span{ display:block; color:rgba(255,255,255,.72); font-size:.92rem; margin-top:.15rem; line-height:1.45; }

/* payment screen (revealed after submit) */
.pay-screen{ max-width:860px; margin:0 auto; }
.back-link{ background:none; border:0; cursor:pointer; color:var(--copper); font:inherit; font-weight:700;
  padding:.4rem 0; margin-bottom:18px; display:inline-flex; align-items:center; gap:.45rem; }
.back-link:hover{ color:var(--copper-dark); }
.pay-screen-head{ margin-bottom:clamp(26px,4vw,38px); }
.payopt-grid{ align-items:stretch; }
.payopt{ background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:32px;
  display:flex; flex-direction:column; box-shadow:var(--shadow-sm); }
.payopt.featured{ border:1.5px solid var(--copper); box-shadow:var(--shadow); }
.payopt-name{ color:var(--green); margin:.85rem 0 .45rem; }
.payopt-desc{ color:var(--muted); font-size:.97rem; min-height:2.8em; }
.payopt-amt{ font-family:'DM Serif Display',serif; font-size:2.4rem; color:var(--ink); margin:.5rem 0 1.4rem; line-height:1; }
.payopt-amt span{ font-family:'Hanken Grotesk',sans-serif; font-size:.9rem; color:var(--muted); font-weight:600; margin-left:.4rem; }
.payopt .btn{ margin-top:auto; }
.pay-secure.center{ margin-top:26px; }
