:root {
  --bg: #09090b;
  --bg-soft: #121216;
  --card: #15151b;
  --text: #f7f7f8;
  --muted: #b8b9c2;
  --line: #2b2d36;
  --accent: #ff3e4d;
  --accent-dark: #b91528;
}

* {
  box-sizing: border-box;
}

html,
body {
  margin: 0;
  padding: 0;
  background: radial-gradient(1200px 420px at 15% -8%, rgba(255, 62, 77, 0.2), transparent 60%), var(--bg);
  color: var(--text);
  font-family: "Manrope", system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
}

a {
  color: inherit;
}

.page-shell {
  width: min(1120px, calc(100% - 28px));
  margin: 0 auto;
  padding: 18px 0 36px;
}

.topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 10px 0 14px;
}

.brand {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
}

.brand img {
  width: min(280px, 56vw);
  height: auto;
  display: block;
}

.nav {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: flex-end;
}

.nav a {
  text-decoration: none;
  border: 1px solid #3f3f49;
  border-radius: 999px;
  padding: 8px 12px;
  font-size: 12px;
  color: #e2e2e7;
  background: rgba(18, 18, 22, 0.88);
}

.nav a.is-active {
  border-color: #ff5d6b;
  color: #fff;
  background: linear-gradient(180deg, #ff4f5f 0%, #cf1f33 100%);
}

.hero {
  border: 1px solid #3d3236;
  border-radius: 18px;
  padding: 26px 20px;
  background:
    radial-gradient(640px 220px at 100% -8%, rgba(255, 62, 77, 0.18), transparent 62%),
    linear-gradient(180deg, #151318 0%, #0f1014 100%);
}

.eyebrow {
  margin: 0;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: #ff9daa;
  font-weight: 800;
}

h1,
h2,
h3 {
  margin: 0;
  line-height: 1.2;
}

.hero h1 {
  margin-top: 8px;
  font-size: clamp(28px, 5.5vw, 44px);
}

.hero p {
  margin: 10px 0 0;
  color: var(--muted);
  max-width: 760px;
}

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

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  border-radius: 12px;
  padding: 10px 14px;
  font-weight: 800;
  border: 1px solid transparent;
}

.btn-solid {
  background: linear-gradient(180deg, #ff5968 0%, var(--accent-dark) 100%);
  color: #fff;
}

.btn-muted {
  background: #181922;
  border-color: #40424c;
  color: #e7e7eb;
}

.panel {
  margin-top: 14px;
  border: 1px solid var(--line);
  border-radius: 16px;
  padding: 16px;
  background: linear-gradient(180deg, #14141a 0%, #101116 100%);
}

.grid {
  margin-top: 12px;
  display: grid;
  gap: 10px;
  grid-template-columns: 1fr;
}

.card {
  border: 1px solid #32343e;
  border-radius: 12px;
  background: #161821;
  padding: 12px;
}

.card h3 {
  font-size: 18px;
}

.card p {
  margin: 8px 0 0;
  color: #cfd1d9;
  font-size: 14px;
  line-height: 1.5;
}

.kpis {
  margin-top: 12px;
  display: grid;
  gap: 10px;
  grid-template-columns: 1fr;
}

.kpi {
  border: 1px solid #3a3d47;
  border-radius: 12px;
  background: #14161d;
  padding: 12px;
}

.kpi strong {
  display: block;
  font-size: 24px;
  color: #fff;
}

.kpi span {
  display: block;
  margin-top: 6px;
  font-size: 13px;
  color: #c6c8d0;
}

.list {
  margin: 10px 0 0;
  padding-left: 18px;
  display: grid;
  gap: 6px;
  color: #d2d3da;
}

.pack-grid {
  margin-top: 12px;
  display: grid;
  gap: 10px;
  grid-template-columns: 1fr;
}

.pack {
  border: 1px solid #443238;
  border-radius: 12px;
  background: linear-gradient(180deg, #211419 0%, #151117 100%);
  padding: 12px;
}

.pack .price {
  margin-top: 8px;
  display: inline-flex;
  padding: 4px 10px;
  border-radius: 999px;
  border: 1px solid #8f3340;
  background: #31171d;
  color: #fff;
  font-weight: 800;
}

.store-grid {
  margin-top: 12px;
  display: grid;
  gap: 10px;
  grid-template-columns: 1fr;
}

.store-card {
  border: 1px solid #353843;
  border-radius: 12px;
  background: #151821;
  padding: 12px;
}

.store-card img {
  width: 100%;
  border-radius: 10px;
  display: block;
}

.store-card .price {
  margin-top: 10px;
  color: #ff7e8a;
  font-weight: 800;
  font-size: 22px;
}

.hidden {
  display: none !important;
}

.portal-hero {
  border-color: #2d3b4f;
  background:
    radial-gradient(640px 220px at 100% -8%, rgba(67, 126, 255, 0.22), transparent 62%),
    linear-gradient(180deg, #141824 0%, #0f121a 100%);
}

.portal-panel {
  border-color: #2f3a4e;
}

.portal-auth h2 {
  font-size: 26px;
}

.portal-auth p {
  margin: 10px 0 0;
  color: var(--muted);
}

.portal-auth-grid {
  margin-top: 16px;
  display: grid;
  gap: 10px;
  grid-template-columns: 1fr;
}

.portal-auth-card {
  border-color: #2f3a4e;
  background: linear-gradient(180deg, #141a26 0%, #101521 100%);
}

.portal-auth-card h3 {
  font-size: 18px;
}

.portal-login-form {
  margin-top: 12px;
  display: grid;
  gap: 12px;
}

.portal-login-form label {
  display: grid;
  gap: 8px;
}

.portal-login-form label span {
  font-weight: 700;
  font-size: 14px;
}

.portal-login-form input {
  width: 100%;
  border-radius: 12px;
  border: 1px solid #3a3f4f;
  background: #0f1219;
  color: #f2f4f8;
  padding: 12px 13px;
  font-size: 15px;
  font-family: inherit;
}

.portal-login-form input:focus {
  outline: none;
  border-color: #6b8fff;
  box-shadow: 0 0 0 2px rgba(107, 143, 255, 0.25);
}

.portal-message {
  min-height: 22px;
  margin: 10px 0 0;
  font-size: 14px;
}

.portal-support-note {
  margin: 10px 0 0;
  color: #aeb4c0;
  font-size: 13px;
}

.portal-message[data-state="error"] {
  color: #ff8e9a;
}

.portal-message[data-state="info"] {
  color: #b9d0ff;
}

.portal-dashboard-top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
}

.portal-meta {
  margin: 6px 0 0;
  color: #c8cfde;
}

.portal-status-row {
  margin-top: 14px;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}

.portal-status-badge {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  padding: 5px 10px;
  border: 1px solid #3f4f68;
  background: #182334;
  font-size: 12px;
  font-weight: 800;
}

.portal-status-badge.is-active {
  border-color: #2f8f5f;
  background: #123022;
  color: #9bf0bf;
}

.portal-status-badge.is-pending {
  border-color: #866216;
  background: #30260f;
  color: #ffd67c;
}

.portal-status-badge.is-completed {
  border-color: #4f5f8e;
  background: #1b2440;
  color: #c8d9ff;
}

.portal-next-session {
  color: #ccd2df;
  font-size: 14px;
}

.portal-kpis {
  margin-top: 12px;
}

.portal-progress-card {
  margin-top: 10px;
}

.portal-progress-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.portal-progress-track {
  margin-top: 10px;
  width: 100%;
  height: 10px;
  border-radius: 999px;
  background: #1b2130;
  border: 1px solid #313f5a;
  overflow: hidden;
}

.portal-progress-fill {
  display: block;
  width: 0;
  height: 100%;
  background: linear-gradient(90deg, #4b74ff 0%, #98b5ff 100%);
  transition: width 260ms ease;
}

.portal-grid {
  margin-top: 10px;
}

.portal-payment-list {
  display: grid;
  gap: 8px;
}

.portal-line-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  border: 1px solid #313641;
  border-radius: 10px;
  padding: 8px 10px;
  background: #151923;
}

.portal-line-item span {
  color: #c6c9d2;
  font-size: 13px;
}

.portal-line-item strong {
  color: #fff;
  font-size: 13px;
}

.portal-doc-list {
  display: grid;
  gap: 8px;
}

.portal-choice-list {
  display: grid;
  gap: 8px;
}

.portal-doc-btn {
  width: 100%;
}

.portal-note {
  margin: 8px 0 0;
  color: #d4d6dc;
  line-height: 1.55;
}

footer {
  margin-top: 16px;
  border-top: 1px solid #2b2d36;
  padding-top: 14px;
  color: #b9bbc4;
  font-size: 13px;
}

@media (min-width: 780px) {
  .grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .kpis {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .pack-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .store-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .portal-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .portal-auth-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
