:root{
  --bg-canvas:#D5ECE6;
  --bg-panel:#F6F6F6;
  --bg-white:#FFFFFF;

  --text:#3E3E3E;
  --text2:#6E6E6E;
  --line:#E6E6E6;

  --green:#2D9E83;
  --pink:#CA4C8C;
  --yellow:#FBAE44;

  --shadow:0 10px 28px rgba(0,0,0,.06);
  --shadow2:0 16px 40px rgba(0,0,0,.08);

  --r-card:14px;
  --r-inner:12px;
  --r-btn:4px;

  --maxw:1040px;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  background:var(--bg-canvas);
  color:var(--text);
  font-family:"Work Sans", system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif;
}

h1,h2{
  font-family:"Open Sans", system-ui, sans-serif;
  font-weight:800;
  margin:0;
}

.canvas{min-height:100%; padding:34px 16px;}
.shell{max-width:var(--maxw); margin:0 auto;}

.hero{
  background:var(--bg-panel);
  border-radius:var(--r-card);
  box-shadow:var(--shadow);
  padding:26px 24px 18px;
  text-align:center;
}

.kicker{
  display:inline-block;
  font-size:12px;
  letter-spacing:1.6px;
  text-transform:uppercase;
  color:var(--text2);
  font-weight:800;
  margin-bottom:8px;
}

.hero h1{font-size:44px; line-height:1.05;}
.subhead{
  margin:12px auto 0;
  max-width:760px;
  color:var(--text2);
  line-height:1.6;
}

/* TTC site-like band */
.band{
  width:100%;
  border-radius:var(--r-card);
  overflow:hidden;
  box-shadow:var(--shadow);
  margin-top:18px;
  border:1px solid rgba(0,0,0,.03);
}
.band__top{
  padding:42px 24px;
  text-align:center;
}
.band__top h2{font-size:42px; line-height:1.05;}
.band__sub{
  margin:12px auto 0;
  max-width:760px;
  color:rgba(255,255,255,.9);
  line-height:1.6;
}
.accent-italic{
  font-family:"Karla", serif;
  font-style:italic;
  margin-top:6px;
  opacity:.95;
}

.band--gold .band__top{background:var(--yellow); color:#fff;}
.band__body{background:#fff; padding:26px;}

.card{
  border-radius:16px;
  box-shadow:var(--shadow2);
  padding:22px;
}

.cardTop{display:flex; gap:12px; align-items:flex-start; margin-bottom:16px;}
.pill{
  display:inline-flex;
  align-items:center;
  padding:6px 12px;
  border-radius:10px;
  background:rgba(62,62,62,.10);
  font-size:12px;
  font-weight:800;
  letter-spacing:1px;
  text-transform:uppercase;
}

.cardTitle{font-size:26px; font-weight:900; font-family:"Open Sans", system-ui, sans-serif;}
.cardDesc{margin-top:6px; color:var(--text2); line-height:1.55; font-size:14px;}

.grid2{display:grid; grid-template-columns:1fr 1fr; gap:16px;}
@media (max-width: 900px){
  .grid2{grid-template-columns:1fr;}
  .hero h1{font-size:36px;}
  .band__top h2{font-size:34px;}
}

.label{
  display:block;
  font-size:12px;
  letter-spacing:1.2px;
  text-transform:uppercase;
  color:var(--text2);
  font-weight:800;
  margin-bottom:8px;
}

.select,.textarea{
  width:100%;
  padding:12px 14px;
  border-radius:var(--r-inner);
  border:1px solid var(--line);
  background:#FAFAFA;
  font-size:14px;
}

.textarea{resize:vertical; line-height:1.6;}

.row{display:flex; gap:10px; flex-wrap:wrap; margin-top:12px;}

.btn{
  border-radius:var(--r-btn); /* squared */
  padding:12px 18px;
  font-weight:900;
  letter-spacing:.6px;
  text-transform:uppercase;
  border:1px solid transparent;
  cursor:pointer;
}
.btn:disabled{opacity:.5; cursor:not-allowed;}
.btn--primary{background:var(--green); color:#fff;}
.btn--primary:hover{opacity:.92;}
.btn--ghost{background:transparent; border-color:rgba(62,62,62,.22); color:var(--text);}
.btn--ghost:hover{background:rgba(255,255,255,.55);}

.output{
  border-radius:14px;
  border:1px solid var(--line);
  background:var(--bg-panel);
  padding:16px;
  min-height:280px;
  line-height:1.65;
  font-size:14px;
  overflow-wrap:anywhere;
}

.alert{
  background:#FFF8EC;
  border:1px solid rgba(251,174,68,.35);
  border-left:6px solid var(--yellow);
  border-radius:14px;
  box-shadow:var(--shadow);
  padding:12px 14px;
  margin-bottom:12px;
}
.alertTitle{
  font-weight:900;
  font-family:"Open Sans", system-ui, sans-serif;
  margin-bottom:6px;
}
.alertBody{color:var(--text2); line-height:1.6; font-size:13px;}

.muted{color:var(--text2);}
.is-hidden{display:none !important;}

.foot{
  margin-top:14px;
  display:flex;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
  color:var(--text2);
  font-size:12px;
  padding:0 4px;
}
