:root{
  --bg1:#e9f6ff;
  --bg2:#fff4e6;
  --ink:#0b1220;
  --muted:#4b5563;
  --card:#ffffffcc;
  --border:#0b122020;
  --shadow: 0 18px 40px rgba(15, 23, 42, .12);
  --r: 18px;

  --g1:#22c55e;
  --g2:#06b6d4;
  --g3:#f97316;
  --g4:#a855f7;
  --g5:#f59e0b;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,Noto Sans,sans-serif;color:var(--ink)}
body{
  background:
    radial-gradient(900px 450px at 20% 10%, rgba(34,197,94,.20), transparent 60%),
    radial-gradient(900px 450px at 90% 15%, rgba(249,115,22,.20), transparent 60%),
    radial-gradient(900px 450px at 70% 85%, rgba(168,85,247,.18), transparent 60%),
    linear-gradient(180deg, var(--bg1), var(--bg2));
}

a{color:inherit;text-decoration:none}
.container{max-width:1100px;margin:0 auto;padding:0 16px}

.fab{
  position:fixed; right:14px; bottom:14px; z-index:30;
  background:linear-gradient(90deg,var(--g1),var(--g2));
  color:#042012;
  font-weight:900;
  padding:12px 14px;
  border-radius:999px;
  box-shadow:0 14px 28px rgba(2, 132, 199, .18);
  border:1px solid rgba(0,0,0,.08);
}

.hero{padding:28px 0 10px}
.hero__wrap{display:grid;gap:14px}
.pill{
  display:inline-flex;align-items:center;gap:8px;
  padding:8px 12px;border-radius:999px;
  background:rgba(255,255,255,.75);
  border:1px solid var(--border);
  box-shadow:0 10px 18px rgba(0,0,0,.06);
  font-weight:800;
  width:max-content;
}
h1{margin:8px 0 0;font-size:44px;line-height:1.03;letter-spacing:-.6px}
.accent{
  background:linear-gradient(90deg,var(--g3),var(--g4),var(--g1));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.subtitle{margin:10px 0 0;font-size:16px}
.muted{color:var(--muted)}
.small{font-size:13px}
.dot{opacity:.55; padding:0 6px}

.hero__grid{display:grid;grid-template-columns:1.15fr .85fr;gap:14px;align-items:start}
.infoCard,.recapCard{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--r);
  box-shadow:var(--shadow);
  padding:16px;
  backdrop-filter: blur(10px);
}
.infoRow{display:flex;gap:12px;align-items:flex-start;padding:10px 0;border-bottom:1px dashed rgba(15,23,42,.12)}
.infoRow:last-child{border-bottom:none}
.ico{width:38px;height:38px;border-radius:12px;display:grid;place-items:center;background:rgba(255,255,255,.9);border:1px solid var(--border)}
.label{font-size:12px;letter-spacing:.2px;color:var(--muted);font-weight:800;text-transform:uppercase}
.value{font-size:15px;font-weight:800}

.hero__cta{display:flex;gap:10px;flex-wrap:wrap;margin-top:14px}
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:12px 14px;border-radius:14px;font-weight:900;
  border:1px solid rgba(0,0,0,.08);
  background:linear-gradient(90deg,var(--g1),var(--g2));
  color:#062114;
  box-shadow:0 12px 22px rgba(34,197,94,.16);
  cursor:pointer;
}
.btn--ghost{
  background:rgba(255,255,255,.85);
  color:var(--ink);
  box-shadow:none;
}
.btn--wide{width:100%; margin-top:12px}

.banner{
  margin-top:12px;
  padding:10px 12px;
  border-radius:14px;
  background:linear-gradient(90deg, rgba(249,115,22,.18), rgba(245,158,11,.16));
  border:1px solid rgba(249,115,22,.22);
  font-weight:800;
}

.recapHead{display:flex;align-items:center;justify-content:space-between;gap:10px}
.recapHead h2{margin:0;font-size:20px}
.tag{
  padding:7px 10px;border-radius:999px;
  background:rgba(255,255,255,.85);
  border:1px solid var(--border);
  font-weight:900;font-size:12px;
}
.recapGrid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:12px}
.recapItem{
  background:rgba(255,255,255,.72);
  border:1px solid var(--border);
  border-radius:14px;
  padding:10px;
}
.k{font-size:12px;color:var(--muted);font-weight:900;text-transform:uppercase}
.v{font-size:15px;font-weight:900;margin-top:4px}

.section{padding:22px 0}
.sectionHead h2{margin:0;font-size:28px}
.sectionHead p{margin:6px 0 0}

.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:14px}
.stageCard{
  border-radius:20px;
  padding:14px;
  border:1px solid var(--border);
  box-shadow:var(--shadow);
  background:rgba(255,255,255,.82);
  position:relative;
  overflow:hidden;
}
.stageCard:before{
  content:"";
  position:absolute; inset:-2px -2px auto -2px;
  height:84px;
  background:linear-gradient(90deg, rgba(34,197,94,.35), rgba(6,182,212,.25));
  transform:skewY(-2deg);
}
.stageCard > *{position:relative}
.stageCard h3{margin:10px 0 4px;font-size:18px}
.age{
  display:inline-flex;
  padding:6px 10px;border-radius:999px;
  background:rgba(255,255,255,.9);
  border:1px solid rgba(0,0,0,.08);
  font-weight:900;font-size:12px;
}
.price{font-weight:900;margin:8px 0 8px}
.cardBtn{
  display:inline-flex;align-items:center;gap:8px;
  margin-top:8px;
  font-weight:900;
  padding:10px 12px;
  border-radius:14px;
  border:1px solid rgba(0,0,0,.08);
  background:rgba(255,255,255,.92);
}

.stageCard.c1:before{background:linear-gradient(90deg, rgba(34,197,94,.35), rgba(245,158,11,.22))}
.stageCard.c2:before{background:linear-gradient(90deg, rgba(6,182,212,.30), rgba(34,197,94,.22))}
.stageCard.c3:before{background:linear-gradient(90deg, rgba(249,115,22,.32), rgba(245,158,11,.22))}
.stageCard.c4:before{background:linear-gradient(90deg, rgba(168,85,247,.32), rgba(6,182,212,.22))}
.stageCard.c5:before{background:linear-gradient(90deg, rgba(245,158,11,.30), rgba(249,115,22,.22))}

.alt{padding-top:10px}
.infoGrid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.box{
  background:rgba(255,255,255,.82);
  border:1px solid var(--border);
  border-radius:18px;
  box-shadow:var(--shadow);
  padding:14px;
}
.box h3{margin:0 0 8px}
.box ul{margin:0;padding-left:18px;color:var(--muted)}
.box li{margin:6px 0}

.form{
  background:rgba(255,255,255,.90);
  border:1px solid var(--border);
  border-radius:18px;
  box-shadow:var(--shadow);
  padding:16px;
}
.form label{display:block;font-weight:900;margin:0 0 8px}
.form input,.form select{
  width:100%;
  padding:12px 12px;
  border-radius:14px;
  border:1px solid rgba(0,0,0,.12);
  background:#fff;
  outline:none;
}
.form input:focus,.form select:focus{border-color:rgba(6,182,212,.6)}
.formGrid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.sep{border:none;border-top:1px solid rgba(0,0,0,.10);margin:16px 0}
.row{display:flex;gap:12px;align-items:end;justify-content:space-between;flex-wrap:wrap}
.rowLeft{min-width:260px}
.children{display:grid;gap:12px;margin-top:12px}
.child{
  border:1px solid rgba(0,0,0,.10);
  border-radius:16px;
  padding:12px;
  background:#ffffff;
}
.childHead{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}
.childTitle{font-weight:1000}
.childGrid{display:grid;grid-template-columns:1.1fr .5fr 1.2fr;gap:10px}
.checks{display:flex;flex-wrap:wrap;gap:12px;margin-top:10px}
.check{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--muted);font-weight:800}
.check input{width:auto}
.totalRow{
  display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;
  margin-top:14px;
  padding-top:12px;
  border-top:1px dashed rgba(0,0,0,.16);
}
.total{font-size:28px;font-weight:1000}
.hidden{display:none}

.footer{padding:22px 0 40px}
.footer__inner{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}

@media (max-width: 980px){
  .hero__grid{grid-template-columns:1fr}
  .cards{grid-template-columns:repeat(2,1fr)}
  .infoGrid{grid-template-columns:1fr}
}
@media (max-width: 620px){
  h1{font-size:38px}
  .cards{grid-template-columns:1fr}
  .formGrid{grid-template-columns:1fr}
  .childGrid{grid-template-columns:1fr}
}
