.ht-page{
  display:grid;
  gap:22px;
}
.ht-hero{
  padding:28px;
  background:
    radial-gradient(circle at top left, rgba(239,68,68,.10), transparent 26%),
    radial-gradient(circle at right top, rgba(59,130,246,.10), transparent 26%),
    linear-gradient(135deg, #fff, #fff8fb 48%, #f6fbff 100%);
}
.ht-hero-grid{
  display:grid;
  grid-template-columns:minmax(0,1.4fr) minmax(260px,.8fr);
  gap:18px;
  align-items:stretch;
}
.ht-kicker{
  display:inline-flex;
  align-items:center;
  min-height:34px;
  padding:0 12px;
  border-radius:999px;
  background:#fff;
  border:1px solid rgba(239,68,68,.16);
  color:#dc2626;
  font-size:.78rem;
  font-weight:800;
  letter-spacing:.04em;
  text-transform:uppercase;
}
.ht-hero h1{
  margin:14px 0 10px;
  font-size:clamp(1.75rem,3vw,2.5rem);
  line-height:1.05;
  letter-spacing:-.05em;
}
.ht-hero p{
  margin:0;
  color:var(--muted);
  line-height:1.7;
  max-width:62ch;
}
.ht-chip-row{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:18px;
}
.ht-chip{
  display:inline-flex;
  align-items:center;
  min-height:38px;
  padding:0 14px;
  border-radius:999px;
  background:#fff;
  border:1px solid var(--line);
  font-weight:700;
  color:#334155;
}
.ht-hero-side{
  display:grid;
  gap:12px;
  align-content:start;
}
.ht-meta-card{
  padding:16px 18px;
  border-radius:20px;
  background:rgba(255,255,255,.88);
  border:1px solid var(--line);
  box-shadow:var(--shadow-soft);
}
.ht-meta-card strong,
.ht-meta-card span{
  display:block;
}
.ht-meta-card strong{
  margin-bottom:6px;
  font-size:1rem;
}
.ht-meta-card span{
  color:var(--muted);
  line-height:1.55;
}
.ht-layout{
  display:grid;
  grid-template-columns:minmax(0,1.05fr) minmax(300px,.95fr);
  gap:20px;
  align-items:start;
}
.ht-panel{
  padding:22px;
}
.ht-card-head{
  margin-bottom:16px;
}
.ht-card-head h2,
.ht-panel h2{
  margin:0 0 8px;
  font-size:1.18rem;
  letter-spacing:-.03em;
}
.ht-card-head p,
.ht-panel > p,
.ht-panel li,
.ht-result-copy,
.ht-note,
.ht-disclaimer{
  color:var(--muted);
  line-height:1.7;
}
.ht-form{
  display:grid;
  gap:16px;
}
.ht-grid-2,
.ht-grid-3{
  display:grid;
  gap:14px;
}
.ht-grid-2{grid-template-columns:repeat(2,minmax(0,1fr));}
.ht-grid-3{grid-template-columns:repeat(3,minmax(0,1fr));}
.ht-field{
  display:grid;
  gap:8px;
}
.ht-field small,
.ht-helper{
  color:#7b8799;
  font-size:.86rem;
  line-height:1.55;
}
.ht-segment{
  display:grid;
  gap:14px;
  padding:16px;
  border-radius:18px;
  background:#f9fbff;
  border:1px solid var(--line);
}
.ht-button-row{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin-top:4px;
}
.ht-button,
.ht-button-secondary{
  appearance:none;
  border:0;
  min-height:50px;
  padding:0 18px;
  border-radius:14px;
  cursor:pointer;
  font-weight:800;
  letter-spacing:-.01em;
}
.ht-button{
  background:linear-gradient(135deg, #ef4444, #8b5cf6);
  color:#fff;
  box-shadow:0 14px 30px rgba(139,92,246,.18);
}
.ht-button-secondary{
  background:#fff;
  color:#334155;
  border:1px solid var(--line-strong);
}
.ht-result-panel{
  display:grid;
  gap:16px;
}
.ht-result-focus{
  padding:18px;
  border-radius:20px;
  background:linear-gradient(135deg, #fff7f7, #f7f5ff);
  border:1px solid rgba(239,68,68,.12);
}
.ht-result-label{
  display:block;
  margin-bottom:8px;
  color:#64748b;
  font-size:.84rem;
  font-weight:800;
  letter-spacing:.04em;
  text-transform:uppercase;
}
.ht-result-number{
  font-size:clamp(2rem,4vw,3rem);
  font-weight:800;
  line-height:1;
  letter-spacing:-.06em;
  color:#0f172a;
}
.ht-result-text{
  margin-top:8px;
  font-size:1rem;
  font-weight:700;
  color:#334155;
}
.ht-stat-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px;
}
.ht-stat{
  padding:15px 16px;
  border-radius:18px;
  background:#fff;
  border:1px solid var(--line);
}
.ht-stat strong,
.ht-stat span{
  display:block;
}
.ht-stat strong{
  margin-bottom:6px;
  font-size:1.1rem;
  letter-spacing:-.03em;
}
.ht-stat span{
  color:#64748b;
  font-size:.92rem;
  line-height:1.5;
}
.ht-list{
  margin:0;
  padding-left:18px;
}
.ht-list li + li{margin-top:8px;}
.ht-note,
.ht-disclaimer{
  margin:0;
  padding:14px 16px;
  border-radius:16px;
  background:#f8fafc;
  border:1px solid var(--line);
}
.ht-disclaimer{
  background:#fff8f8;
  border-color:rgba(239,68,68,.14);
}
.ht-inline-links{
  display:grid;
  gap:12px;
}
.ht-inline-links .home-card{
  display:grid;
  gap:8px;
  align-content:start;
}
.ht-inline-links .home-card p{
  margin:0;
  color:var(--muted);
  line-height:1.6;
  font-size:.92rem;
}
.ht-empty{
  color:#94a3b8;
}
@media (max-width: 980px){
  .ht-hero-grid,
  .ht-layout{grid-template-columns:1fr;}
}
@media (max-width: 680px){
  .ht-hero,
  .ht-panel{padding:18px;}
  .ht-grid-2,
  .ht-grid-3,
  .ht-stat-grid{grid-template-columns:1fr;}
  .ht-button-row > *{flex:1 1 100%;}
  .ht-chip-row{gap:8px;}
  .ht-chip{min-height:34px;padding:0 12px;font-size:.86rem;}
}
