:root{
  --forest:#124734;
  --forest-2:#0b3327;
  --mint:#e8f4ee;
  --mint-2:#f4fbf7;
  --gold:#e0b14f;
  --ink:#10221b;
  --muted:#51625b;
  --line:#d7e5dd;
  --danger:#8b2f2f;
  --white:#ffffff;
  --shadow:0 18px 45px rgba(16,34,27,.12);
  --radius:22px;
  --max:1180px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color:var(--ink);
  background:linear-gradient(180deg,#f7fbf8 0%,#fff 42%,#f3faf6 100%);
  line-height:1.45;
}
a{color:inherit}
.topline{
  background:var(--forest-2);
  color:white;
  font-weight:800;
  letter-spacing:.02em;
  font-size:.92rem;
}
.topline .wrap{
  max-width:var(--max);
  margin:auto;
  padding:.65rem 1rem;
  display:flex;
  gap:1rem;
  justify-content:space-between;
  align-items:center;
  flex-wrap:wrap;
}
.topline span:last-child{color:#f6d88f}
header{
  position:sticky;
  top:0;
  z-index:5;
  backdrop-filter:saturate(130%) blur(14px);
  background:rgba(255,255,255,.90);
  border-bottom:1px solid var(--line);
}
.nav{
  max-width:var(--max);
  margin:auto;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:.9rem 1rem;
  gap:1rem;
}
.brand{
  display:flex;
  align-items:center;
  gap:.7rem;
  font-weight:950;
  font-size:1.05rem;
  letter-spacing:-.02em;
  text-decoration:none;
}
.mark{
  width:38px;
  height:38px;
  border-radius:12px;
  background:linear-gradient(135deg,var(--forest),#2d7a5a);
  box-shadow:inset 0 0 0 3px rgba(255,255,255,.22);
  display:grid;
  place-items:center;
  color:#fff4c7;
  font-weight:950;
}
nav ul{
  display:flex;
  list-style:none;
  gap:.25rem;
  padding:0;
  margin:0;
  align-items:center;
  flex-wrap:wrap;
  justify-content:flex-end;
}
nav a{
  text-decoration:none;
  padding:.55rem .75rem;
  border-radius:999px;
  font-weight:750;
  color:#24463a;
  font-size:.93rem;
}
nav a:hover,.active-nav{background:var(--mint)}
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.45rem;
  padding:.8rem 1rem;
  border-radius:999px;
  border:1px solid transparent;
  background:var(--forest);
  color:white;
  text-decoration:none;
  font-weight:900;
  box-shadow:0 10px 24px rgba(18,71,52,.18);
  cursor:pointer;
}
button.btn{font-family:inherit;font-size:1rem}
.btn.secondary{
  background:white;
  color:var(--forest);
  border-color:#bad8c9;
  box-shadow:none;
}
.btn.gold{
  background:var(--gold);
  color:#1e2118;
  box-shadow:0 10px 24px rgba(224,177,79,.22);
}
.btn.danger{
  background:var(--danger);
  color:white;
}
.hero{
  max-width:var(--max);
  margin:auto;
  padding:4.7rem 1rem 2rem;
  display:grid;
  grid-template-columns:1.18fr .82fr;
  gap:2rem;
  align-items:center;
}
.hero.slim{
  grid-template-columns:1fr;
  padding-bottom:1rem;
}
.eyebrow{
  display:inline-flex;
  width:max-content;
  max-width:100%;
  padding:.35rem .7rem;
  border-radius:999px;
  background:#fff6db;
  color:#614500;
  border:1px solid #f0d586;
  font-weight:950;
  text-transform:uppercase;
  font-size:.78rem;
  letter-spacing:.08em;
}
h1{
  font-size:clamp(2.45rem,7vw,5.6rem);
  line-height:.93;
  letter-spacing:-.075em;
  margin:.85rem 0 .85rem;
}
h1.compact{font-size:clamp(2.4rem,5.5vw,4.5rem)}
.lead{
  font-size:clamp(1.05rem,1.8vw,1.35rem);
  color:#355247;
  max-width:850px;
  margin:0 0 1.35rem;
  font-weight:560;
}
.hero-actions{
  display:flex;
  gap:.7rem;
  flex-wrap:wrap;
  margin:1.25rem 0 1.4rem;
}
.hero-card{
  background:white;
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  overflow:hidden;
}
.hero-card .cap{
  background:linear-gradient(135deg,var(--forest),#1d6a4f);
  color:white;
  padding:1.15rem;
}
.hero-card h2{margin:0;font-size:1.45rem;letter-spacing:-.03em}
.hero-card .body{padding:1rem}
.mini-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:.75rem;
}
.stat{
  border:1px solid var(--line);
  border-radius:18px;
  padding:1rem;
  background:var(--mint-2);
  min-height:112px;
}
.stat b{
  display:block;
  font-size:2.25rem;
  line-height:1;
  letter-spacing:-.06em;
  color:var(--forest);
  margin-bottom:.3rem;
}
.stat span{
  color:#40584e;
  font-weight:760;
  font-size:.91rem;
}
.source-note,.help{
  font-size:.9rem;
  color:var(--muted);
  margin:.95rem 0 0;
}
section{
  max-width:var(--max);
  margin:0 auto;
  padding:2.4rem 1rem;
}
.section-title{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:1rem;
  margin-bottom:1rem;
}
h2{
  margin:0;
  font-size:clamp(1.75rem,3vw,2.65rem);
  letter-spacing:-.055em;
  line-height:1;
}
.section-title p{
  max-width:640px;
  margin:0;
  color:var(--muted);
  font-weight:600;
}
.banner{
  border-radius:var(--radius);
  background:linear-gradient(135deg,var(--forest),#1d6f52);
  color:white;
  padding:1.4rem;
  display:grid;
  grid-template-columns:1fr auto;
  gap:1rem;
  align-items:center;
  box-shadow:var(--shadow);
}
.banner strong{
  display:block;
  font-size:1.45rem;
  letter-spacing:-.035em;
}
.banner p{margin:.35rem 0 0;color:#e4f5ed;font-weight:600}
.grid-3{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1rem;
}
.grid-2{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:1rem;
}
.card{
  background:white;
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:1.25rem;
  box-shadow:0 10px 30px rgba(16,34,27,.06);
}
.card h3{
  margin:.1rem 0 .55rem;
  font-size:1.2rem;
  letter-spacing:-.025em;
}
.card p{margin:0;color:var(--muted);font-weight:560}
.tag{
  display:inline-block;
  border-radius:999px;
  padding:.28rem .55rem;
  background:var(--mint);
  color:var(--forest);
  font-size:.78rem;
  font-weight:950;
  margin-bottom:.55rem;
}
.seat-table{
  width:100%;
  border-collapse:separate;
  border-spacing:0;
  overflow:hidden;
  border-radius:18px;
  border:1px solid var(--line);
  background:white;
  box-shadow:0 10px 30px rgba(16,34,27,.05);
}
.seat-table th,.seat-table td{
  padding:.85rem .9rem;
  text-align:left;
  border-bottom:1px solid var(--line);
  vertical-align:top;
  font-size:.96rem;
}
.seat-table th{
  background:var(--forest);
  color:white;
  font-size:.82rem;
  text-transform:uppercase;
  letter-spacing:.08em;
}
.seat-table tr:last-child td{border-bottom:0}
.seat-table td:first-child{font-weight:900;color:var(--forest)}
.issue-list{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:.75rem;
}
.issue{
  display:flex;
  gap:.75rem;
  padding:.9rem;
  border:1px solid var(--line);
  border-radius:18px;
  background:linear-gradient(180deg,#fff,#f8fcfa);
}
.issue .num{
  flex:0 0 34px;
  width:34px;height:34px;
  border-radius:12px;
  background:var(--forest);
  color:white;
  display:grid;place-items:center;
  font-weight:950;
}
.issue b{display:block;margin-bottom:.15rem}
.issue span{color:var(--muted);font-weight:560;font-size:.93rem}
.timeline{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:.75rem;
}
.step{
  background:white;
  border:1px solid var(--line);
  border-radius:20px;
  padding:1rem;
  position:relative;
}
.step b{
  display:block;
  color:var(--forest);
  font-size:.88rem;
  text-transform:uppercase;
  letter-spacing:.08em;
  margin-bottom:.35rem;
}
.step strong{
  display:block;
  font-size:1.08rem;
  line-height:1.15;
  margin-bottom:.4rem;
}
.step span{color:var(--muted);font-size:.92rem;font-weight:560}
.quote{
  background:#fffaf0;
  border:1px solid #eed59a;
  border-left:8px solid var(--gold);
  border-radius:var(--radius);
  padding:1.2rem;
  font-size:1.08rem;
  font-weight:720;
  color:#3f3214;
}
.form-shell{
  display:grid;
  grid-template-columns:minmax(0,1.15fr) minmax(320px,.85fr);
  gap:1rem;
  align-items:start;
}
.form-card{
  background:white;
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  padding:1.25rem;
}
.field-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:.8rem;
}
label{
  display:block;
  font-weight:900;
  margin:0 0 .28rem;
  color:#183b2f;
}
input,select,textarea{
  width:100%;
  border:1px solid #bcd6ca;
  border-radius:14px;
  padding:.8rem .85rem;
  font:inherit;
  background:#fbfefc;
  color:var(--ink);
}
textarea{min-height:115px;resize:vertical}
fieldset{
  border:1px solid var(--line);
  border-radius:18px;
  padding:1rem;
  margin:1rem 0;
  background:#fbfefc;
}
legend{
  font-weight:950;
  color:var(--forest);
  padding:0 .35rem;
}
.check{
  display:grid;
  grid-template-columns:24px 1fr;
  gap:.65rem;
  align-items:start;
  padding:.55rem 0;
  border-bottom:1px solid #e3eee8;
}
.check:last-child{border-bottom:0}
.check input{
  width:20px;
  height:20px;
  margin:.12rem 0 0;
  accent-color:var(--forest);
}
.check label{
  margin:0;
  font-weight:780;
  line-height:1.3;
}
.check small{
  display:block;
  color:var(--muted);
  font-weight:560;
  margin-top:.18rem;
}
.form-actions{
  display:flex;
  gap:.65rem;
  flex-wrap:wrap;
  margin-top:1rem;
}
.output-box{
  min-height:290px;
  white-space:pre-wrap;
  font-family:ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  font-size:.85rem;
  line-height:1.42;
}
.notice{
  border-radius:18px;
  border:1px solid #efd188;
  background:#fff8e7;
  color:#4e3a0d;
  padding:.9rem;
  font-weight:650;
}
.notice.green{
  border-color:#b9dccb;
  background:#effaf4;
  color:#183b2f;
}
footer{
  background:#0b271f;
  color:#dceddf;
  margin-top:2rem;
}
footer .wrap{
  max-width:var(--max);
  margin:auto;
  padding:2rem 1rem;
  display:grid;
  grid-template-columns:1.2fr .8fr;
  gap:1rem;
}
footer h2{font-size:1.7rem;color:white}
footer p{color:#b8d0c4;margin:.5rem 0 0}
.fineprint{
  font-size:.84rem;
  color:#adc7ba;
  border-top:1px solid rgba(255,255,255,.12);
  padding-top:1rem;
  margin-top:1rem;
}
@media (max-width:980px){
  .hero,.form-shell{grid-template-columns:1fr;padding-top:2.6rem}
  .grid-3,.grid-2,.timeline{grid-template-columns:1fr}
  .section-title{display:block}
  .section-title p{margin-top:.55rem}
  .banner{grid-template-columns:1fr}
  footer .wrap{grid-template-columns:1fr}
}
@media (max-width:680px){
  nav ul{display:none}
  .mini-grid,.issue-list,.field-grid{grid-template-columns:1fr}
  h1{font-size:3rem}
  .hero-actions .btn,.form-actions .btn{width:100%}
  .seat-table{font-size:.88rem}
  .seat-table th,.seat-table td{padding:.7rem}
}
