
/* ============ TOKENS ============ */
:root{
  /* Light theme. Names kept for compatibility:
     --asphalt* = surfaces (now light), --cream* = text (now dark),
     --amber* = primary accent (now red). */
  --asphalt: #FFFFFF;     /* page background + text-on-accent (white) */
  --asphalt-2: #F6F5F2;   /* card / panel background */
  --asphalt-3: #EDEBE6;   /* alternate rows / subtle fills */
  --cream: #16181C;       /* primary text (near-black) */
  --cream-dim: #565B63;   /* secondary text */
  --amber: #D62828;       /* primary accent — RED */
  --amber-dim: #9B1C1C;   /* darker red */
  --green: #16432F;
  --green-light: #1F6B47;
  --red: #D62828;
  --grey: #6B7079;        /* labels (darker for light bg) */
  --grey-dim: #9AA0A8;    /* subtle text / placeholders */
  --line: #E3E1DA;        /* borders */

  --font-display: 'Oswald', sans-serif;
  --font-body: 'Inter', sans-serif;
  --font-mono: 'JetBrains Mono', monospace;

  --container: 1180px;
}

*{ margin:0; padding:0; box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  background:var(--asphalt);
  color:var(--cream);
  font-family:var(--font-body);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
ul{ list-style:none; }
button{ font-family:inherit; cursor:pointer; border:none; background:none; color:inherit; }

.wrap{ max-width:var(--container); margin:0 auto; padding:0 24px; }

.eyebrow{
  font-family:var(--font-mono);
  font-size:11px;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:var(--amber);
  display:flex;
  align-items:center;
  gap:8px;
}
.eyebrow::before{
  content:"";
  width:6px; height:6px;
  background:var(--amber);
  display:inline-block;
  border-radius:1px;
}

h1,h2,h3{
  font-family:var(--font-display);
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:0.01em;
  line-height:1.05;
}

.section-title{
  font-size:clamp(28px,4vw,44px);
  margin-bottom:14px;
}
.section-kicker{
  font-family:var(--font-mono);
  font-size:12px;
  letter-spacing:0.16em;
  text-transform:uppercase;
  color:var(--grey);
  margin-bottom:10px;
}
.section-head{ margin-bottom:48px; max-width:640px; }
.section-head p{ color:var(--cream-dim); font-size:16px; }

section{ padding:88px 0; position:relative; }
.divider{
  height:1px;
  background:var(--line);
  width:100%;
}

/* focus visibility */
a:focus-visible, button:focus-visible, summary:focus-visible{
  outline:2px solid var(--amber);
  outline-offset:3px;
}

@media (prefers-reduced-motion: reduce){
  *{ animation-duration:0.001ms !important; animation-iteration-count:1 !important; transition-duration:0.001ms !important; }
}

/* ============ TRACK LINE MOTIF (decorative SVG used across sections) ============ */
.track-line-bg{
  position:absolute; inset:0;
  width:100%; height:100%;
  opacity:0.06;
  pointer-events:none;
  z-index:0;
}

/* ============ NAV ============ */
header.nav{
  position:sticky; top:0; z-index:50;
  background:rgba(255,255,255,0.92);
  backdrop-filter:blur(8px);
  border-bottom:1px solid var(--line);
}
.nav-inner{
  display:flex; align-items:center; justify-content:space-between;
  height:64px;
}
.brand{
  font-family:var(--font-display);
  font-weight:700;
  font-size:16px;
  letter-spacing:0.04em;
  text-transform:uppercase;
  display:flex; align-items:center; gap:10px;
}
.brand-chip{
  font-family:var(--font-mono);
  font-size:10px;
  background:var(--amber);
  color:var(--asphalt);
  padding:2px 6px;
  border-radius:2px;
  letter-spacing:0.05em;
}
.nav-links{
  display:flex; gap:28px; align-items:center;
  font-size:13px;
  letter-spacing:0.03em;
  text-transform:uppercase;
  font-weight:500;
}
.nav-links a{ color:var(--cream-dim); transition:color .15s; }
.nav-links a:hover{ color:var(--amber); }
.nav-cta{
  display:flex; gap:10px;
}
.btn{
  font-family:var(--font-mono);
  font-size:12.5px;
  font-weight:500;
  letter-spacing:0.06em;
  text-transform:uppercase;
  padding:11px 20px;
  border-radius:3px;
  display:inline-flex; align-items:center; gap:8px;
  transition:transform .15s, background .15s, color .15s, border-color .15s;
  border:1px solid transparent;
  white-space:nowrap;
}
.btn-amber{ background:var(--amber); color:#FFFFFF; }
.btn-amber:hover{ background:#B71F1F; transform:translateY(-1px); }
.btn-outline{ border-color:var(--cream-dim); color:var(--cream); }
.btn-outline:hover{ border-color:var(--amber); color:var(--amber); }
.btn-green{ background:var(--green-light); color:#FFFFFF; }
.btn-green:hover{ background:#268057; transform:translateY(-1px); }
.btn-sm{ padding:9px 16px; font-size:11.5px; }
.btn-block{ width:100%; justify-content:center; }

.menu-toggle{ display:none; }

@media (max-width: 860px){
  .nav-links{ display:none; }
  .nav-cta .btn-outline{ display:none; }
}

/* ============ HERO ============ */
.hero{
  position:relative;
  overflow:hidden;
  padding-top:14px;
  border-bottom:1px solid var(--line);
  background:
    radial-gradient(ellipse at 80% -10%, rgba(214,40,40,0.08), transparent 55%),
    radial-gradient(ellipse at 0% 100%, rgba(31,107,71,0.18), transparent 50%),
    var(--asphalt);
}
.hero-inner{
  padding:0px 0 64px;
  position:relative; z-index:2;
}
.hero-banner{
  width:100%;
  height:clamp(240px, 36vw, 460px);
  object-fit:cover;        /* fill the box by cropping — never stretch */
  object-position:center;
  display:block;
  border-radius:8px;
  border:1px solid var(--line);
  margin:24px 0 32px;
}
.race-strip{
  display:flex; flex-wrap:wrap; gap:24px 36px;
  font-family:var(--font-mono);
  font-size:11.5px;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:var(--grey);
  border:1px solid var(--line);
  background:rgba(0,0,0,0.02);
  padding:14px 20px;
  border-radius:4px;
  margin-bottom:40px;
}
.race-strip span b{ color:var(--cream); font-weight:500; }
.race-strip .live{ color:var(--red); display:flex; align-items:center; gap:6px;}
.live-dot{
  width:7px; height:7px; border-radius:50%;
  background:var(--red);
  animation:pulse 1.4s infinite;
}
@keyframes pulse{ 0%,100%{opacity:1;} 50%{opacity:0.25;} }

.hero h1{
  font-size:clamp(40px,7vw,80px);
  margin-bottom:18px;
}
.hero h1 span{ color:var(--amber); }
.hero .subhead{
  font-family:var(--font-display);
  font-weight:500;
  text-transform:none;
  font-size:clamp(18px,2.4vw,24px);
  color:var(--cream-dim);
  margin-bottom:20px;
  max-width:680px;
}
.hero .desc{
  max-width:560px;
  color:var(--cream-dim);
  font-size:16px;
  margin-bottom:36px;
}

/* lights out sequence */
.lights-block{
  display:flex; align-items:center; gap:20px;
  margin-bottom:36px;
  flex-wrap:wrap;
}
.lights{
  display:flex; gap:10px;
}
.light{
  width:22px; height:22px;
  border-radius:50%;
  background:#F0DADA;
  border:1px solid #E2BCBC;
  transition:background .25s, box-shadow .25s, border-color .25s;
}
.light.on{
  background:var(--red);
  border-color:var(--red);
  box-shadow:0 0 14px rgba(214,40,40,0.85);
}
.light.go{
  background:transparent;
  border-color:var(--green-light);
}
.lights-label{
  font-family:var(--font-mono);
  font-size:11px;
  letter-spacing:0.1em;
  text-transform:uppercase;
  color:var(--grey);
}
.lights-label b{ color:var(--cream); }

.hero-ctas{
  display:flex; gap:14px; flex-wrap:wrap;
  margin-bottom:48px;
}

.specs{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:1px;
  border:1px solid var(--line);
  border-radius:4px;
  overflow:hidden;
  background:var(--line);
}
.spec-cell{
  background:var(--asphalt-2);
  padding:16px 18px;
}
.spec-cell .k{
  font-family:var(--font-mono);
  font-size:10.5px;
  letter-spacing:0.12em;
  text-transform:uppercase;
  color:var(--grey);
  margin-bottom:6px;
}
.spec-cell .v{
  font-family:var(--font-mono);
  font-size:14px;
  color:var(--amber);
  font-weight:500;
}
@media (max-width:760px){
  .specs{ grid-template-columns:1fr 1fr; }
}

.countdown-wrap{
  margin-top:40px;
  display:flex; align-items:center; gap:24px; flex-wrap:wrap;
}
.countdown-label{
  font-family:var(--font-mono);
  font-size:11px;
  letter-spacing:0.12em;
  text-transform:uppercase;
  color:var(--grey);
}
.countdown{
  display:flex; gap:14px;
}
.cd-unit{ text-align:center; }
.cd-num{
  font-family:var(--font-mono);
  font-size:26px;
  font-weight:700;
  color:var(--cream);
  background:var(--asphalt-2);
  border:1px solid var(--line);
  border-radius:4px;
  padding:8px 12px;
  min-width:56px;
}
.cd-unit-label{
  font-family:var(--font-mono);
  font-size:9.5px;
  letter-spacing:0.1em;
  text-transform:uppercase;
  color:var(--grey-dim);
  margin-top:6px;
}

/* ============ PARTNERS ============ */
.partners{ padding:56px 0; border-bottom:1px solid var(--line); }
.partner-row{
  display:flex; flex-wrap:wrap; gap:18px;
  align-items:center;
}
.partner-group{
  display:flex; flex-direction:column; gap:12px;
  flex:1; min-width:220px;
}
.partner-group .label{
  font-family:var(--font-mono);
  font-size:10.5px;
  letter-spacing:0.12em;
  text-transform:uppercase;
  color:var(--grey);
}
.logo-slots{ display:flex; gap:12px; flex-wrap:wrap; }
.logo-slot{
  border:1px dashed var(--grey-dim);
  border-radius:4px;
  color:var(--grey);
  font-family:var(--font-mono);
  font-size:11px;
  text-align:center;
  padding:14px 18px;
  min-width:120px;
  background:rgba(0,0,0,0.015);
}
.logo-slot.hosted{
  border-style:solid;
  border-color:var(--amber);
  color:var(--cream);
  font-family:var(--font-display);
  font-weight:600;
  letter-spacing:0.04em;
  text-transform:uppercase;
  font-size:15px;
  padding:14px 22px;
}

/* ============ ABOUT ============ */
.about-grid{
  display:grid;
  grid-template-columns:1.1fr 1fr;
  gap:64px;
  align-items:start;
}
@media (max-width:840px){ .about-grid{ grid-template-columns:1fr; gap:36px; } }
.about-text p{ color:var(--cream-dim); font-size:16px; margin-bottom:16px; max-width:480px; }
.checklist{
  border:1px solid var(--line);
  border-radius:6px;
  background:var(--asphalt-2);
  padding:8px;
}
.checklist li{
  display:flex; align-items:flex-start; gap:14px;
  padding:14px 16px;
  font-size:15px;
  border-bottom:1px solid var(--line);
}
.checklist li:last-child{ border-bottom:none; }
.check-mark{
  flex-shrink:0;
  width:20px; height:20px;
  border-radius:3px;
  background:var(--amber);
  color:var(--asphalt);
  font-family:var(--font-mono);
  font-size:12px;
  font-weight:700;
  display:flex; align-items:center; justify-content:center;
  margin-top:1px;
}

/* ============ SCHEDULE ============ */
.timing-sheet{
  position:relative;
  border-left:2px solid var(--line);
  margin-left:6px;
}
.timing-row{
  display:grid;
  grid-template-columns:140px 1fr;
  gap:24px;
  padding:22px 0 22px 28px;
  position:relative;
  border-bottom:1px solid var(--line);
}
.timing-row:last-child{ border-bottom:none; }
.timing-row::before{
  content:"";
  position:absolute;
  left:-7px; top:26px;
  width:12px; height:12px;
  border-radius:50%;
  background:var(--asphalt);
  border:2px solid var(--grey-dim);
}
.timing-row.is-live::before{
  border-color:var(--amber);
  background:var(--amber);
  box-shadow:0 0 0 4px rgba(214,40,40,0.18);
}
.timing-time{
  font-family:var(--font-mono);
  font-size:18px;
  color:var(--cream);
  font-weight:500;
}
.timing-row.is-live .timing-time{ color:var(--amber); }
.timing-name{ font-size:16px; color:var(--cream-dim); display:flex; align-items:center; gap:10px; flex-wrap:wrap;}
.timing-row.is-live .timing-name{ color:var(--cream); font-weight:500; }
.tag-live{
  font-family:var(--font-mono);
  font-size:10px;
  letter-spacing:0.1em;
  background:var(--red);
  color:var(--cream);
  padding:3px 8px;
  border-radius:3px;
}
@media (max-width:600px){
  .timing-row{ grid-template-columns:90px 1fr; }
}

/* ============ GRID / COMPANIES ============ */
.grid-wall{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:14px;
}
@media (max-width:760px){ .grid-wall{ grid-template-columns:repeat(2,1fr); } }
.grid-tile{
  border:1px dashed var(--grey-dim);
  border-radius:5px;
  padding:22px 14px;
  text-align:center;
  font-family:var(--font-mono);
  font-size:12px;
  color:var(--grey);
  position:relative;
}
.grid-tile .pos{
  position:absolute; top:8px; left:10px;
  font-size:10px; color:var(--grey-dim);
}

/* ============ STANDINGS ============ */
.standings{
  border:1px solid var(--line);
  border-radius:6px;
  overflow:hidden;
}
.standing-row{
  display:grid;
  grid-template-columns:50px 1fr 70px;
  align-items:center;
  gap:18px;
  padding:18px 22px;
  border-bottom:1px solid var(--line);
  background:var(--asphalt-2);
}
.standing-row:last-child{ border-bottom:none; }
.standing-row:nth-child(odd){ background:var(--asphalt-3); }
.pos-num{
  font-family:var(--font-mono);
  font-weight:700;
  font-size:18px;
  color:var(--grey);
}
.standing-row:first-child .pos-num{ color:var(--amber); }
.team-name{ font-weight:600; font-size:15px; margin-bottom:8px; display:flex; align-items:center; gap:10px;}
.team-chip{ width:10px; height:10px; border-radius:2px; flex-shrink:0; }
.bar-track{
  height:8px;
  background:var(--asphalt);
  border-radius:4px;
  overflow:hidden;
}
.bar-fill{ height:100%; border-radius:4px; }
.standing-pct{
  font-family:var(--font-mono);
  font-size:16px;
  text-align:right;
  font-weight:600;
}
.standings-foot{
  font-family:var(--font-mono);
  font-size:11px;
  color:var(--grey-dim);
  margin-top:14px;
  letter-spacing:0.04em;
}

/* ============ PACKAGES ============ */
.packages{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
}
@media (max-width:900px){ .packages{ grid-template-columns:1fr; } }
.package{
  border:1px solid var(--line);
  border-radius:8px;
  padding:32px 28px;
  background:var(--asphalt-2);
  display:flex;
  flex-direction:column;
  position:relative;
}
.package.featured{
  border-color:var(--amber);
  background:linear-gradient(180deg, rgba(214,40,40,0.06), var(--asphalt-2) 40%);
}
.package-badge{
  position:absolute; top:-12px; left:28px;
  background:var(--amber);
  color:var(--asphalt);
  font-family:var(--font-mono);
  font-size:10.5px;
  letter-spacing:0.08em;
  text-transform:uppercase;
  padding:4px 10px;
  border-radius:3px;
  font-weight:700;
}
.package-pos{
  font-family:var(--font-mono);
  font-size:11px;
  color:var(--grey);
  letter-spacing:0.1em;
  margin-bottom:10px;
}
.package h3{
  font-size:22px;
  margin-bottom:6px;
}
.package .sub{
  font-family:var(--font-body);
  text-transform:none;
  font-size:13px;
  color:var(--grey);
  margin-bottom:18px;
}
.package .price{
  font-family:var(--font-mono);
  font-size:34px;
  font-weight:700;
  color:var(--cream);
  margin-bottom:4px;
}
.package .price span{ font-size:14px; color:var(--grey); font-weight:400; }
.package-divider{ height:1px; background:var(--line); margin:20px 0; }
.package ul{ flex-grow:1; margin-bottom:28px; }
.package li{
  display:flex; gap:10px; font-size:14.5px; color:var(--cream-dim);
  margin-bottom:10px;
}
.package li::before{
  content:"—";
  color:var(--amber);
  flex-shrink:0;
}

/* ============ GALLERY ============ */
.gallery-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:14px;
}
@media (max-width:760px){ .gallery-grid{ grid-template-columns:repeat(2,1fr); } }
.gallery-tile{
  aspect-ratio:4/3;
  border-radius:6px;
  background:linear-gradient(135deg, var(--asphalt-3), var(--asphalt-2));
  border:1px solid var(--line);
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  padding:16px;
}
.gallery-tile span{
  font-family:var(--font-mono);
  font-size:11px;
  color:var(--grey);
  letter-spacing:0.05em;
}

/* ============ FAQ ============ */
.faq-list{ border-top:1px solid var(--line); }
.faq-item{ border-bottom:1px solid var(--line); }
.faq-item summary{
  list-style:none;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:22px 4px;
  font-family:var(--font-display);
  font-weight:500;
  text-transform:uppercase;
  font-size:16px;
  letter-spacing:0.01em;
}
.faq-item summary::-webkit-details-marker{ display:none; }
.faq-icon{
  font-family:var(--font-mono);
  color:var(--amber);
  font-size:18px;
  transition:transform .2s;
  flex-shrink:0;
  margin-left:16px;
}
.faq-item[open] .faq-icon{ transform:rotate(45deg); }
.faq-answer{
  padding:0 4px 22px;
  color:var(--cream-dim);
  font-size:15px;
  max-width:680px;
}

/* ============ FOOTER ============ */
footer{
  background:var(--asphalt-2);
  border-top:1px solid var(--line);
  padding:64px 0 32px;
}
.footer-grid{
  display:grid;
  grid-template-columns:1.3fr 1fr 1fr;
  gap:40px;
  margin-bottom:48px;
}
@media (max-width:760px){ .footer-grid{ grid-template-columns:1fr; gap:32px; } }
.footer-brand{
  font-family:var(--font-display);
  font-weight:700;
  font-size:20px;
  text-transform:uppercase;
  margin-bottom:12px;
}
.footer-col .label{
  font-family:var(--font-mono);
  font-size:11px;
  letter-spacing:0.12em;
  text-transform:uppercase;
  color:var(--grey);
  margin-bottom:14px;
}
.footer-col p, .footer-col a{
  color:var(--cream-dim);
  font-size:14.5px;
  margin-bottom:8px;
  display:block;
}
.footer-col a:hover{ color:var(--amber); }
.footer-bottom{
  border-top:1px solid var(--line);
  padding-top:24px;
  display:flex;
  justify-content:space-between;
  flex-wrap:wrap;
  gap:12px;
  font-family:var(--font-mono);
  font-size:11.5px;
  color:var(--grey-dim);
  letter-spacing:0.04em;
}

/* ============ FORMS (RSVP + TABLE BOOKING) ============ */
.form-card{
  border:1px solid var(--line);
  border-radius:8px;
  background:var(--asphalt-2);
  padding:32px 30px;
}
@media (max-width:600px){ .form-card{ padding:24px 18px; } }

.form-block{ margin-bottom:32px; }
.form-block:last-of-type{ margin-bottom:24px; }
.form-block-title{
  font-family:var(--font-mono);
  font-size:11px;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:var(--amber);
  padding-bottom:12px;
  margin-bottom:20px;
  border-bottom:1px solid var(--line);
  display:flex; align-items:center; gap:8px;
}
.form-block-title .step-num{
  font-family:var(--font-mono);
  font-size:11px;
  background:var(--amber);
  color:var(--asphalt);
  width:20px; height:20px;
  border-radius:3px;
  display:inline-flex; align-items:center; justify-content:center;
  font-weight:700;
}

.form-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:18px;
}
@media (max-width:600px){ .form-grid{ grid-template-columns:1fr; } }
.field{ display:flex; flex-direction:column; gap:7px; }
.field.full{ grid-column:1 / -1; }
.field label{
  font-family:var(--font-mono);
  font-size:11px;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:var(--cream-dim);
}
.field label .req{ color:var(--amber); margin-left:2px; }

.field input,
.field select{
  font-family:var(--font-body);
  font-size:15px;
  color:var(--cream);
  background:var(--asphalt);
  border:1px solid var(--line);
  border-radius:4px;
  padding:12px 14px;
  width:100%;
  transition:border-color .15s, box-shadow .15s;
}
.field input::placeholder{ color:var(--grey-dim); }
.field input:focus,
.field select:focus{
  outline:none;
  border-color:var(--amber);
  box-shadow:0 0 0 3px rgba(214,40,40,0.14);
}
.field select{
  appearance:none;
  -webkit-appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%238A8F96' 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{ background:var(--asphalt-2); color:var(--cream); }

/* option cards (attendance type / package select) */
.option-grid{ display:grid; grid-template-columns:1fr 1fr; gap:12px; }
@media (max-width:600px){ .option-grid{ grid-template-columns:1fr; } }
.option-card{
  position:relative;
  border:1px solid var(--line);
  border-radius:6px;
  background:var(--asphalt);
  padding:16px 18px;
  cursor:pointer;
  transition:border-color .15s, background .15s;
  display:flex; flex-direction:column; gap:4px;
}
.option-card:hover{ border-color:var(--grey); }
.option-card input{ position:absolute; opacity:0; pointer-events:none; }
.option-card .opt-name{ font-weight:600; font-size:15px; color:var(--cream); }
.option-card .opt-meta{
  font-family:var(--font-mono);
  font-size:11px;
  letter-spacing:0.06em;
  text-transform:uppercase;
  color:var(--grey);
}
.option-card:has(input:checked){
  border-color:var(--amber);
  background:linear-gradient(180deg, rgba(214,40,40,0.07), var(--asphalt));
}
.option-card:has(input:checked) .opt-name{ color:var(--amber); }

/* interest checkboxes */
.checkbox-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:10px 18px;
}
@media (max-width:760px){ .checkbox-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:480px){ .checkbox-grid{ grid-template-columns:1fr; } }
.check-field{
  display:flex; align-items:center; gap:10px;
  font-size:14.5px;
  color:var(--cream-dim);
  cursor:pointer;
}
.check-field input{
  appearance:none;
  -webkit-appearance:none;
  width:18px; height:18px;
  border:1px solid var(--grey-dim);
  border-radius:3px;
  background:var(--asphalt);
  flex-shrink:0;
  display:inline-flex; align-items:center; justify-content:center;
  transition:background .15s, border-color .15s;
}
.check-field input:checked{
  background:var(--amber);
  border-color:var(--amber);
}
.check-field input:checked::after{
  content:"✓";
  color:var(--asphalt);
  font-family:var(--font-mono);
  font-size:12px;
  font-weight:700;
}
.check-field input:focus-visible{ outline:2px solid var(--amber); outline-offset:2px; }

.form-foot{
  display:flex; align-items:center; gap:16px; flex-wrap:wrap;
}
.form-note{
  font-family:var(--font-mono);
  font-size:11px;
  color:var(--grey-dim);
  letter-spacing:0.04em;
}

