:root {
  --primary-500: #3182f6;
  --primary-600: #186ee8;
  --navy-900: #191f28;
  --text-default: #4e5968;
  --text-muted: #8b95a1;
  --bg-default: #f9fafb;
  --bg-card: #ffffff;
  --border-default: #e5e8eb;
  --success: #00c773;
  --warning: #ffb020;
  --radius-lg: 20px;
  --shadow-card: 0 18px 40px rgba(15, 23, 42, 0.05);
  --shadow-focus: 0 0 0 4px rgba(49, 130, 246, 0.12);
  --max-width: 1180px;
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

html {
  font-size: 16px;
}

body {
  margin: 0;
  min-height: 100vh;
  font-family: "Pretendard", "Noto Sans KR", "Segoe UI", sans-serif;
  color: var(--navy-900);
  background:
    radial-gradient(circle at top left, rgba(49, 130, 246, 0.08), transparent 24%),
    linear-gradient(180deg, #fcfdff 0%, var(--bg-default) 32%, #f4f7fb 100%);
}

a {
  color: inherit;
  text-decoration: none;
}

button,
input,
select,
textarea {
  font: inherit;
}

button {
  cursor: pointer;
  border: 0;
}

input,
select,
textarea {
  width: 100%;
  border: 1px solid var(--border-default);
  border-radius: 14px;
  padding: 0.95rem 1rem;
  background: #fff;
  color: var(--navy-900);
}

textarea {
  resize: vertical;
  min-height: 120px;
}

input:focus,
select:focus,
textarea:focus {
  outline: none;
  border-color: var(--primary-500);
  box-shadow: var(--shadow-focus);
}

h1,
h2,
h3,
p,
ul {
  margin: 0;
}

ul {
  padding: 0;
  list-style: none;
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
}

.site-shell {
  padding: 0 1.25rem 2.5rem;
}

.marketing-header,
.site-footer,
.hero-section,
.section {
  width: min(100%, var(--max-width));
  margin: 0 auto;
}

.marketing-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 1.25rem 0;
  position: sticky;
  top: 0;
  z-index: 30;
  backdrop-filter: blur(12px);
  background: rgba(249, 250, 251, 0.78);
}

.brand {
  display: inline-flex;
  align-items: center;
  gap: 0.75rem;
  font-weight: 700;
  font-size: 1.05rem;
}

.brand-mark {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.25rem;
  height: 2.25rem;
  border-radius: 0.9rem;
  background: linear-gradient(135deg, var(--primary-500), #74aefd);
  color: #fff;
  font-size: 0.95rem;
  box-shadow: var(--shadow-card);
}

.brand-mark-admin {
  width: auto;
  min-width: 3.2rem;
  padding: 0 0.75rem;
  font-size: 0.8rem;
}

.nav-links {
  display: flex;
  align-items: center;
  gap: 0.65rem;
}

.nav-link {
  padding: 0.75rem 0.95rem;
  color: var(--text-default);
  border-radius: 999px;
  transition: background 0.2s ease, color 0.2s ease;
}

.nav-link:hover,
.nav-link.is-active {
  background: rgba(49, 130, 246, 0.08);
  color: var(--primary-600);
}

.nav-toggle,
.mobile-only {
  display: none;
}

.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  min-height: 2.8rem;
  padding: 0.8rem 1.1rem;
  border-radius: 14px;
  font-weight: 600;
  transition: transform 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
}

.button-small {
  min-height: 2.4rem;
  padding: 0.6rem 0.9rem;
  font-size: 0.92rem;
}

.button:hover {
  transform: translateY(-1px);
}

.button-primary {
  background: var(--primary-500);
  color: #fff;
  box-shadow: 0 10px 24px rgba(49, 130, 246, 0.22);
}

.button-secondary {
  background: #fff;
  color: var(--navy-900);
  border: 1px solid var(--border-default);
}

.button-ghost {
  background: transparent;
  color: var(--text-default);
}

.button-block {
  width: 100%;
}

.hero-section {
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: 2rem;
  align-items: center;
  padding: 4rem 0 2rem;
}

.hero-copy,
.auth-card,
.auth-aside,
.pricing-note {
  display: grid;
  gap: 1.15rem;
}

.hero-copy h1,
.auth-card h1,
.pricing-hero h1 {
  font-size: clamp(2.4rem, 5vw, 4.25rem);
  line-height: 1.08;
  letter-spacing: -0.04em;
}

.hero-copy p,
.auth-card p,
.pricing-note p,
.card p,
.site-footer p {
  color: var(--text-default);
  line-height: 1.7;
}

.button-row,
.chip-row,
.header-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
}

.hero-proof {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
}

.card {
  background: var(--bg-card);
  border: 1px solid rgba(229, 232, 235, 0.92);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-card);
}

.hero-preview {
  padding: 1.2rem;
  display: grid;
  gap: 1rem;
}

.hero-window {
  border-radius: 1.4rem;
  background: linear-gradient(180deg, #fefefe 0%, #f4f8fd 100%);
  border: 1px solid rgba(229, 232, 235, 0.8);
  overflow: hidden;
}

.window-bar,
.preview-bar {
  height: 2.4rem;
  background: linear-gradient(90deg, rgba(49, 130, 246, 0.12), rgba(49, 130, 246, 0));
  border-bottom: 1px solid rgba(229, 232, 235, 0.8);
}

.window-body {
  display: grid;
  grid-template-columns: 88px 1fr;
  min-height: 22rem;
}

.window-sidebar {
  border-right: 1px solid rgba(229, 232, 235, 0.8);
  background: linear-gradient(180deg, #f8fbff 0%, #eef4fb 100%);
}

.window-content {
  display: grid;
  gap: 1rem;
  padding: 1rem;
}

.window-grid,
.preview-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.85rem;
}

.window-panel,
.preview-grid div {
  min-height: 6rem;
  border-radius: 1rem;
  background: linear-gradient(180deg, rgba(49, 130, 246, 0.12), rgba(49, 130, 246, 0.02));
}

.window-panel.large,
.preview-tall {
  min-height: 8.5rem;
}

.section {
  padding: 1.2rem 0 1rem;
}

.section-surface {
  padding: 1.8rem;
  border-radius: 2rem;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.72), rgba(241, 245, 249, 0.72));
  border: 1px solid rgba(229, 232, 235, 0.8);
}

.section-heading {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1.25rem;
}

.section-heading h2 {
  font-size: clamp(1.5rem, 2vw, 1.95rem);
  line-height: 1.2;
  letter-spacing: -0.03em;
}

.eyebrow {
  display: inline-flex;
  align-items: center;
  color: var(--primary-600);
  font-size: 0.8rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  text-transform: uppercase;
}

.muted {
  color: var(--text-muted);
}

.card-grid {
  display: grid;
  gap: 1rem;
}

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

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

.feature-card,
.stat-card,
.plan-card,
.list-card,
.preview-panel,
.faq-item,
.pricing-note,
.tone-card {
  padding: 1.35rem;
  display: grid;
  gap: 0.9rem;
}

.feature-icon {
  width: 2.65rem;
  height: 2.65rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 1rem;
  background: rgba(49, 130, 246, 0.1);
}

.icon-mark {
  font-weight: 800;
  color: var(--primary-600);
}

.feature-card h3,
.plan-card h3,
.card h3,
.list-card h3 {
  font-size: 1.15rem;
  line-height: 1.3;
}

.feature-meta {
  color: var(--text-muted);
  font-size: 0.9rem;
}

.stat-value {
  font-size: 1.9rem;
  line-height: 1.1;
  letter-spacing: -0.04em;
}

.card-topline {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 0.75rem;
}

.badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 1.95rem;
  padding: 0.2rem 0.75rem;
  border-radius: 999px;
  font-size: 0.82rem;
  font-weight: 700;
}

.badge-neutral {
  background: rgba(78, 89, 104, 0.08);
  color: var(--text-default);
}

.badge-info {
  background: rgba(49, 130, 246, 0.12);
  color: var(--primary-600);
}

.badge-success {
  background: rgba(0, 199, 115, 0.12);
  color: #008b53;
}

.badge-warning {
  background: rgba(255, 176, 32, 0.16);
  color: #a76300;
}

.chip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2rem;
  padding: 0.15rem 0.75rem;
  border-radius: 999px;
  background: #f5f7fa;
  color: var(--text-default);
  border: 1px solid rgba(229, 232, 235, 0.9);
  font-size: 0.88rem;
}

.chip-button {
  border: 0;
  cursor: pointer;
}

.chip-active {
  background: rgba(49, 130, 246, 0.12);
  color: var(--primary-600);
}

.chip-highlight {
  background: rgba(49, 130, 246, 0.1);
  color: var(--primary-600);
}

.two-column,
.dashboard-grid,
.auth-page {
  display: grid;
  gap: 1rem;
}

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

.dashboard-grid {
  grid-template-columns: 1.3fr 0.9fr;
}

.stack,
.detail-list,
.auth-actions,
.page-content,
.compact-stack,
.product-copy,
.product-actions,
.info-grid {
  display: grid;
  gap: 1rem;
}

.compact-stack {
  gap: 0.75rem;
}

.preview-screen {
  padding: 0.9rem;
  border-radius: 1.15rem;
  background: linear-gradient(180deg, #f8fbff 0%, #eef5fb 100%);
  border: 1px solid rgba(229, 232, 235, 0.84);
}

.preview-topbar,
.preview-summary,
.preview-metric,
.mini-list,
.mini-row,
.overview-card,
.analysis-card,
.comparison-card,
.saved-card,
.saved-controls,
.compare-save-form,
.notice,
.workflow-card,
.meter,
.auth-form,
.info-inline {
  display: grid;
  gap: 0.9rem;
}

.preview-topbar,
.preview-summary,
.mini-row,
.saved-controls {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  align-items: start;
}

.preview-metric {
  gap: 0.35rem;
  padding: 0.9rem 1rem;
  background: #f6f9fd;
  border-radius: 1rem;
}

.preview-metric span {
  color: var(--text-muted);
  font-size: 0.88rem;
}

.preview-metric strong {
  font-size: 1.4rem;
}

.mini-list {
  padding-top: 0.4rem;
}

.mini-row {
  gap: 1rem;
  padding: 0.95rem 0;
  border-top: 1px solid rgba(229, 232, 235, 0.7);
}

.mini-row:first-child {
  border-top: 0;
  padding-top: 0;
}

.mini-row-card {
  padding: 1rem;
  border: 1px solid rgba(229, 232, 235, 0.88);
  border-radius: 1rem;
  background: #fbfcfe;
}

.workflow-card {
  padding: 1.35rem;
}

.step-index {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.4rem;
  height: 2.4rem;
  border-radius: 999px;
  background: rgba(49, 130, 246, 0.12);
  color: var(--primary-600);
  font-weight: 700;
}

.notice {
  width: min(100%, var(--max-width));
  margin: 0 auto 1rem;
  grid-template-columns: 1fr auto;
  padding: 0.9rem 1rem;
  border-radius: 1rem;
  border: 1px solid rgba(49, 130, 246, 0.1);
  background: #fff;
  box-shadow: var(--shadow-card);
}

.notice-info {
  border-color: rgba(49, 130, 246, 0.15);
}

.notice-warning {
  border-color: rgba(255, 176, 32, 0.18);
}

.notice-success {
  border-color: rgba(0, 199, 115, 0.16);
}

.overview-card {
  padding: 1.35rem;
  grid-template-columns: 1.1fr 0.9fr;
  align-items: center;
}

.auth-form label,
.saved-controls label {
  display: grid;
  gap: 0.45rem;
  color: var(--text-default);
}

.analysis-card,
.comparison-card,
.saved-card {
  padding: 1.2rem;
}

.analysis-card-compact {
  gap: 0.8rem;
}

.info-inline {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  color: var(--text-muted);
  font-size: 0.9rem;
}

.compare-save-form {
  grid-template-columns: 1fr auto;
  gap: 0.75rem;
}

.meter {
  gap: 0.5rem;
}

.meter-topline {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  color: var(--text-default);
  font-size: 0.92rem;
}

.meter-track {
  height: 0.7rem;
  background: #eef2f7;
  border-radius: 999px;
  overflow: hidden;
}

.meter-fill {
  display: block;
  height: 100%;
  border-radius: inherit;
}

.meter-fill-success {
  background: linear-gradient(90deg, #00c773, #4ed9a2);
}

.meter-fill-info {
  background: linear-gradient(90deg, #3182f6, #7aaefb);
}

.meter-fill-warning {
  background: linear-gradient(90deg, #ffb020, #ffd36d);
}

.meter-fill-neutral {
  background: linear-gradient(90deg, #8b95a1, #b9c1ca);
}

.empty-state {
  padding: 2rem;
  text-align: center;
}

.preview-grid div:nth-child(2) {
  background: linear-gradient(180deg, rgba(0, 199, 115, 0.14), rgba(0, 199, 115, 0.05));
}

.preview-grid div:nth-child(3) {
  background: linear-gradient(180deg, rgba(255, 176, 32, 0.18), rgba(255, 176, 32, 0.04));
}

.site-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 2rem 0 0.5rem;
  color: var(--text-default);
}

.footer-links {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  justify-content: flex-end;
}

.footer-links a {
  font-weight: 600;
}

.cta-banner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 1.5rem;
  border-radius: 2rem;
  background: linear-gradient(135deg, rgba(49, 130, 246, 0.09), rgba(255, 255, 255, 0.92));
  border: 1px solid rgba(49, 130, 246, 0.12);
}

.auth-page {
  width: min(100%, 1040px);
  margin: 0 auto;
  padding: 3rem 0;
  grid-template-columns: 1fr 0.9fr;
}

.auth-card,
.auth-aside,
.action-panel,
.analysis-start-card,
.product-hero,
.compare-topbar,
.filter-card {
  padding: 1.35rem;
  display: grid;
  gap: 1rem;
}

.hero-mini-note {
  padding: 0.2rem 0.25rem 0.5rem;
}

.bullet-row {
  display: flex;
  gap: 0.75rem;
  align-items: start;
}

.bullet-dot {
  width: 0.75rem;
  height: 0.75rem;
  margin-top: 0.45rem;
  border-radius: 999px;
  background: var(--primary-500);
  flex: 0 0 auto;
}

.app-shell {
  display: grid;
  grid-template-columns: 272px 1fr;
  min-height: 100vh;
}

.sidebar {
  position: sticky;
  top: 0;
  height: 100vh;
  padding: 1.2rem;
  background: rgba(248, 251, 255, 0.92);
  border-right: 1px solid rgba(229, 232, 235, 0.86);
  display: grid;
  align-content: start;
  gap: 1.4rem;
}

.brand-sidebar {
  padding: 0.35rem 0;
}

.sidebar-block {
  display: grid;
  gap: 0.45rem;
}

.sidebar-card {
  padding: 1rem;
  background: #fff;
  border-radius: 1.2rem;
  border: 1px solid rgba(229, 232, 235, 0.92);
  box-shadow: var(--shadow-card);
  display: grid;
  gap: 0.8rem;
}

.app-main {
  padding: 1.2rem 1.2rem 2.5rem;
}

.app-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 0.2rem 0 1rem;
}

.app-header h1 {
  font-size: clamp(1.9rem, 2vw, 2.4rem);
  line-height: 1.15;
  letter-spacing: -0.03em;
}

.page-content {
  width: min(100%, 1560px);
}

/* Service polish overrides */
.app-main {
  padding: 1.4rem 1.4rem 3.2rem;
  display: block;
}

.page-content {
  width: min(100%, 1540px);
  margin-inline: auto;
  gap: 1.2rem;
  grid-template-columns: minmax(0, 1fr);
  justify-items: stretch;
  align-items: start;
}

.section {
  margin-top: 0;
  gap: 1.2rem;
  grid-template-columns: minmax(0, 1fr);
  justify-items: stretch;
  align-items: start;
}

.section-surface,
.analysis-status-card,
.analysis-page-result-block,
.analysis-comparison-block,
.compare-topbar,
.overview-card,
.analysis-start-card,
.analysis-card,
.comparison-card,
.saved-card {
  border-radius: 1.15rem;
  border-color: rgba(226, 232, 240, 0.92);
  box-shadow: 0 16px 40px rgba(15, 23, 42, 0.06);
  width: 100%;
  min-width: 0;
}

.page-content > *,
.section > * {
  width: 100%;
  max-width: none;
  min-width: 0;
  justify-self: stretch;
}

.page-content,
.section {
  display: block !important;
}

.page-content > .section + .section {
  margin-top: 1.2rem;
}

.section > * + * {
  margin-top: 1rem;
}

.section-heading,
.analysis-page-result-head,
.compare-topbar,
.dashboard-overview-card,
.analysis-status-card {
  align-items: start;
}

.section-heading h2,
.analysis-page-result-head strong,
.compare-topbar h2,
.overview-card h2,
.analysis-start-card h2 {
  letter-spacing: -0.04em;
}

.dashboard-grid,
.dashboard-overview-card,
.dashboard-overview-card-compact,
.overview-card,
.compare-topbar {
  gap: 1.1rem;
}

.analysis-comparison-block,
.analysis-page-result-block {
  padding: 0.95rem;
  background: linear-gradient(180deg, rgba(248, 250, 252, 0.96), rgba(255, 255, 255, 0.98));
}

.analysis-page-result-head {
  gap: 0.35rem;
  padding-bottom: 0.15rem;
  border-bottom: 1px solid rgba(226, 232, 240, 0.78);
}

.analysis-comparison-table .table-shell,
.analysis-page-result-table .table-shell {
  padding: 0.15rem;
  border-radius: 0.95rem;
  background: rgba(255, 255, 255, 0.94);
  border: 1px solid rgba(226, 232, 240, 0.9);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.9);
}

.analysis-comparison-table .data-table,
.analysis-page-result-table .data-table {
  border-collapse: separate;
  border-spacing: 0;
}

.analysis-comparison-table .data-table th,
.analysis-page-result-table .data-table th {
  padding: 0.68rem 0.6rem;
  background: #f8fbff;
  color: #3159d6;
  font-size: 0.73rem;
  font-weight: 800;
  letter-spacing: 0.01em;
  border-bottom: 1px solid rgba(226, 232, 240, 0.95);
}

.analysis-comparison-table .data-table td,
.analysis-page-result-table .data-table td {
  padding: 0.56rem 0.52rem;
  background: rgba(255, 255, 255, 0.98);
  border-bottom: 1px solid rgba(241, 245, 249, 1);
  vertical-align: middle;
}

.analysis-comparison-table .data-table tbody tr:hover td,
.analysis-page-result-table .data-table tbody tr:hover td {
  background: #fbfdff;
}

.analysis-product-cell {
  grid-template-columns: 54px minmax(0, 1fr);
  gap: 0.55rem;
  align-items: center;
}

.analysis-candidate-thumb,
.analysis-product-thumb {
  width: 54px;
  height: 54px;
  border-radius: 0.8rem;
  box-shadow: 0 8px 20px rgba(15, 23, 42, 0.08);
}

.analysis-comparison-table .analysis-product-cell,
.analysis-page-result-table .analysis-product-cell {
  grid-template-columns: 54px minmax(0, 1fr);
  gap: 0.6rem;
}

.analysis-comparison-table .analysis-product-copy,
.analysis-page-result-table .analysis-product-copy {
  gap: 0.16rem;
}

.analysis-comparison-table .analysis-product-title,
.analysis-page-result-table .analysis-product-title {
  font-size: 0.68rem;
  line-height: 1.18;
  letter-spacing: -0.01em;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-wrap: balance;
}

.analysis-comparison-table .analysis-field-main,
.analysis-page-result-table .analysis-field-main {
  font-size: 0.74rem;
  line-height: 1.12;
  font-weight: 700;
}

.analysis-comparison-table .analysis-field-note,
.analysis-page-result-table .analysis-field-note,
.analysis-comparison-table .analysis-candidate-url,
.analysis-page-result-table .analysis-candidate-url {
  display: none;
}

.analysis-comparison-table .analysis-action-row .button,
.analysis-page-result-table .analysis-action-row .button {
  min-height: 1.7rem;
  padding: 0.24rem 0.48rem;
  border-radius: 999px;
  font-size: 0.68rem;
}

.analysis-shipping-badge {
  max-width: 76px;
  max-height: 26px;
}

.analysis-comparison-table .data-table td:nth-child(2),
.analysis-page-result-table .data-table td:nth-child(2) {
  width: 32%;
}

.analysis-comparison-table .data-table td:nth-child(3) {
  width: 10%;
}

.analysis-comparison-table .data-table td:nth-child(4),
.analysis-comparison-table .data-table td:nth-child(5),
.analysis-comparison-table .data-table td:nth-child(6),
.analysis-comparison-table .data-table td:nth-child(7),
.analysis-comparison-table .data-table td:nth-child(8),
.analysis-comparison-table .data-table td:nth-child(9),
.analysis-page-result-table .data-table td:nth-child(n+3) {
  width: 9.5%;
}

.card-grid.grid-4,
.card-grid.grid-3 {
  gap: 0.95rem;
}

.overview-card,
.compare-topbar,
.analysis-status-card {
  padding: 1rem 1.05rem;
}

/* Release clean layout */
.app-shell {
  grid-template-columns: 236px minmax(0, 1fr);
  background: linear-gradient(180deg, #f6f8fc 0%, #f3f6fb 100%);
}

.sidebar {
  padding: 1rem 0.85rem;
  background: rgba(255, 255, 255, 0.9);
  border-right: 1px solid rgba(226, 232, 240, 0.92);
  box-shadow: 8px 0 28px rgba(15, 23, 42, 0.03);
  gap: 1rem;
}

.brand-sidebar {
  padding: 0.35rem 0.35rem 0.6rem;
}

.sidebar-block {
  gap: 0.3rem;
}

.sidebar .nav-link {
  width: 100%;
  padding: 0.78rem 0.9rem;
  border-radius: 0.95rem;
  font-weight: 700;
}

.sidebar .nav-link.is-active {
  background: linear-gradient(135deg, rgba(37, 99, 235, 0.12), rgba(96, 165, 250, 0.16));
  color: #1749c7;
  box-shadow: inset 0 0 0 1px rgba(147, 197, 253, 0.55);
}

.sidebar-card {
  padding: 0.9rem;
  border-radius: 1rem;
  background: linear-gradient(180deg, #ffffff, #f8fbff);
}

.sidebar-card p {
  font-size: 0.82rem;
  line-height: 1.45;
}

.app-main {
  padding: 1.15rem 1.15rem 2.4rem;
}

.app-header {
  padding: 0.25rem 0 0.85rem;
  margin-bottom: 0.2rem;
}

.app-header h1 {
  font-size: clamp(1.7rem, 1vw + 1.45rem, 2.25rem);
}

.app-header .muted {
  font-size: 0.9rem;
}

.page-content {
  width: min(100%, 1260px);
}

.analysis-start-hero {
  max-width: 1080px;
  margin-inline: auto;
  padding: 1.2rem;
  border-radius: 1.3rem;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(247, 250, 255, 0.98));
  border: 1px solid rgba(226, 232, 240, 0.95);
  box-shadow: 0 24px 50px rgba(15, 23, 42, 0.07);
}

.analysis-start-hero-grid {
  grid-template-columns: minmax(0, 0.95fr) minmax(0, 1.05fr);
  gap: 1rem;
}

.analysis-start-copy {
  align-content: start;
  gap: 0.75rem;
}

.analysis-start-copy h2 {
  font-size: clamp(1.9rem, 1vw + 1.55rem, 2.55rem);
  line-height: 1.04;
  letter-spacing: -0.045em;
}

.analysis-start-copy p {
  max-width: 44ch;
  color: #5b6675;
}

.analysis-start-keyword-pills {
  gap: 0.45rem;
}

.analysis-search-shell {
  padding: 0.9rem;
  border-radius: 1.05rem;
  background: linear-gradient(180deg, #fbfdff, #f6f9ff);
  border: 1px solid rgba(226, 232, 240, 0.95);
}

.analysis-form.analysis-form-hero {
  padding: 0.38rem;
  border-radius: 1rem;
  background: #eef4ff;
  border: 1px solid rgba(191, 219, 254, 0.85);
}

.analysis-form.analysis-form-hero input {
  border: 0;
  background: rgba(255, 255, 255, 0.96);
}

.analysis-start-quick-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.7rem;
}

.analysis-start-mini-card,
.analysis-mode-card {
  padding: 0.85rem 0.9rem;
  border-radius: 1rem;
  background: #fff;
  border: 1px solid rgba(226, 232, 240, 0.95);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.92);
}

.analysis-start-mini-card strong,
.analysis-mode-card strong {
  font-size: 0.96rem;
  line-height: 1.3;
}

.analysis-start-mini-card p,
.analysis-mode-card p {
  font-size: 0.82rem;
  line-height: 1.45;
  color: #667281;
}

.analysis-mode-grid.analysis-mode-grid-wide {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.75rem;
}

.analysis-status-card,
.analysis-page-result-block,
.analysis-comparison-block {
  max-width: 1080px;
  margin-inline: auto;
}

@media (max-width: 1199px) {
  .app-shell {
    grid-template-columns: 1fr;
  }

  .page-content {
    width: 100%;
  }

  .analysis-start-hero,
  .analysis-status-card,
  .analysis-page-result-block,
  .analysis-comparison-block {
    max-width: none;
  }
}

.dense-section {
  padding-top: 0.3rem;
}

.analysis-form {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 0.75rem;
}

.analysis-mode-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.85rem;
}

.analysis-mode-card {
  padding: 1rem 1.05rem;
  border-radius: 1rem;
  border: 1px solid rgba(229, 232, 235, 0.92);
  background: linear-gradient(180deg, rgba(247, 249, 252, 0.95), rgba(255, 255, 255, 0.98));
  display: grid;
  gap: 0.4rem;
}

.analysis-mode-card strong {
  font-size: 1rem;
  color: var(--navy-900);
}

.analysis-mode-card p {
  color: var(--text-muted);
  font-size: 0.92rem;
}

.analysis-mode-card.is-disabled {
  background: linear-gradient(180deg, rgba(249, 250, 251, 0.96), rgba(255, 255, 255, 0.98));
  border-color: rgba(226, 232, 240, 0.95);
}

.analysis-mode-card.is-disabled strong,
.analysis-mode-card.is-disabled .eyebrow {
  color: var(--text-muted);
}

.analysis-status-card {
  border-style: solid;
  border-width: 1px;
  padding: 0.95rem 1rem;
  display: grid;
  gap: 0.7rem;
}

.analysis-status-info {
  border-color: rgba(49, 130, 246, 0.24);
  background: rgba(49, 130, 246, 0.05);
}

.analysis-status-success {
  border-color: rgba(18, 184, 134, 0.28);
  background: rgba(18, 184, 134, 0.06);
}

.analysis-status-warning {
  border-color: rgba(245, 158, 11, 0.28);
  background: rgba(245, 158, 11, 0.08);
}

.analysis-status-input {
  font-size: 0.9rem;
  line-height: 1.35;
  word-break: break-word;
}

.analysis-status-message {
  font-size: 0.92rem;
  line-height: 1.5;
}

.analysis-status-list,
.analysis-warning-list ul {
  margin: 0;
  padding-left: 1rem;
  color: var(--text-muted);
  display: grid;
  gap: 0.25rem;
  font-size: 0.88rem;
}

.analysis-status-actions {
  margin-top: 0.05rem;
}

.analysis-diagnostics .mini-row {
  align-items: start;
}

.analysis-diagnostics a {
  word-break: break-all;
}

.analysis-candidate-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(196px, 1fr));
  gap: 0.65rem;
}

.analysis-candidate-grid-secondary {
  opacity: 0.92;
}

.analysis-candidate-card {
  display: grid;
  gap: 0.35rem;
  align-content: start;
  text-align: left;
  padding: 0.8rem;
  border-radius: 0.9rem;
  border: 1px solid rgba(49, 130, 246, 0.16);
  background: #fff;
  color: var(--navy-900);
  transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
}

.analysis-candidate-card:hover {
  transform: translateY(-2px);
  border-color: rgba(49, 130, 246, 0.3);
  box-shadow: 0 18px 32px rgba(15, 23, 42, 0.08);
}

.analysis-candidate-card strong {
  font-size: 0.92rem;
  line-height: 1.35;
}

.analysis-candidate-header {
  display: grid;
  grid-template-columns: 52px 1fr;
  gap: 0.6rem;
  align-items: start;
}

.analysis-candidate-copy {
  display: grid;
  gap: 0.25rem;
  min-width: 0;
}

.analysis-candidate-thumb {
  width: 52px;
  height: 52px;
  border-radius: 0.8rem;
  overflow: hidden;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, rgba(49, 130, 246, 0.18), rgba(49, 130, 246, 0.05));
  color: var(--primary-600);
  font-weight: 800;
  font-size: 1rem;
}

.analysis-candidate-thumb-image {
  padding: 0;
  background: #fff;
  border: 1px solid rgba(229, 232, 235, 0.92);
}

.analysis-candidate-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.analysis-candidate-title {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.analysis-candidate-url {
  color: var(--text-muted);
  font-size: 0.74rem;
  line-height: 1.35;
  word-break: break-all;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.analysis-page-result-block {
  display: grid;
  gap: 0.6rem;
}

.analysis-keyword-pipeline {
  display: grid;
  gap: 0.65rem;
  padding: 0.8rem 0.85rem;
  border-radius: 0.95rem;
  border: 1px solid rgba(13, 90, 229, 0.12);
  background: linear-gradient(180deg, rgba(13, 90, 229, 0.06), rgba(255, 255, 255, 0.9));
}

.analysis-keyword-pipeline-copy {
  display: grid;
  gap: 0.25rem;
}

.analysis-keyword-pipeline-copy strong {
  font-size: 0.96rem;
  color: var(--navy-900);
}

.analysis-keyword-pipeline-steps {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
  gap: 0.6rem;
}

.analysis-keyword-pipeline-step {
  display: grid;
  gap: 0.25rem;
  padding: 0.72rem 0.78rem;
  border-radius: 0.88rem;
  border: 1px solid rgba(148, 163, 184, 0.22);
  background: rgba(255, 255, 255, 0.82);
}

.analysis-keyword-pipeline-step-label {
  font-size: 0.74rem;
  color: var(--text-muted);
}

.analysis-keyword-pipeline-step strong {
  font-size: 0.92rem;
  color: var(--navy-900);
}

.analysis-keyword-pipeline-step-done {
  border-color: rgba(18, 184, 134, 0.24);
  background: rgba(18, 184, 134, 0.08);
}

.analysis-keyword-pipeline-step-active {
  border-color: rgba(49, 130, 246, 0.26);
  background: rgba(49, 130, 246, 0.08);
}

.analysis-keyword-pipeline-step-todo {
  border-style: dashed;
}

.analysis-keyword-pipeline-actions {
  margin-top: 0.1rem;
}

.analysis-keyword-signals {
  display: grid;
  gap: 0.65rem;
  padding: 0.8rem 0.85rem;
  border-radius: 0.95rem;
  border: 1px solid rgba(15, 118, 110, 0.14);
  background: linear-gradient(180deg, rgba(15, 118, 110, 0.07), rgba(255, 255, 255, 0.94));
}

.analysis-keyword-signals-head {
  display: grid;
  gap: 0.24rem;
}

.analysis-keyword-signals-head strong {
  font-size: 0.96rem;
  color: var(--navy-900);
}

.analysis-keyword-signal-meters {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
  gap: 0.6rem;
}

.analysis-page-result-head {
  display: grid;
  gap: 0.3rem;
}

.analysis-page-result-head strong {
  font-size: 1.08rem;
  color: var(--navy-900);
}

.analysis-page-result-legend {
  display: flex;
  flex-wrap: wrap;
  gap: 0.42rem;
  align-items: center;
}

.analysis-page-result-note {
  margin: 0;
  color: var(--text-muted);
  font-size: 0.82rem;
  line-height: 1.45;
}

.analysis-field-cell {
  display: grid;
  gap: 0.28rem;
  min-width: 0;
}

.analysis-field-cell-placeholder {
  min-height: 100%;
  align-content: start;
}

.analysis-field-cell-core {
  padding: 0.58rem 0.62rem;
  border-radius: 0.85rem;
  background: linear-gradient(180deg, rgba(13, 90, 229, 0.08), rgba(13, 90, 229, 0.02));
  border: 1px solid rgba(13, 90, 229, 0.12);
}

.analysis-field-main {
  font-size: 0.88rem;
  line-height: 1.4;
  word-break: break-word;
}

.analysis-field-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.32rem;
  align-items: center;
}

.analysis-field-note {
  color: var(--text-muted);
  font-size: 0.73rem;
  line-height: 1.35;
  word-break: break-word;
}

.analysis-progress {
  display: grid;
  gap: 0.38rem;
  padding: 0.55rem 0.7rem;
  border-radius: 12px;
  background: rgba(13, 90, 229, 0.06);
  border: 1px solid rgba(13, 90, 229, 0.12);
}

.analysis-progress-copy {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  font-size: 0.78rem;
  color: var(--text-muted);
}

.analysis-progress-copy strong {
  color: var(--text-main);
  font-size: 0.8rem;
}

.analysis-progress-bar {
  position: relative;
  width: 100%;
  height: 8px;
  border-radius: 999px;
  background: rgba(148, 163, 184, 0.22);
  overflow: hidden;
}

.analysis-progress-bar-fill {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, rgba(37, 99, 235, 0.92), rgba(59, 130, 246, 0.72));
}

.analysis-meta-list {
  display: grid;
  gap: 0.38rem;
}

.analysis-product-cell {
  display: grid;
  grid-template-columns: 52px minmax(0, 1fr);
  gap: 0.7rem;
  align-items: start;
  min-width: 220px;
}

.analysis-product-thumb {
  flex: 0 0 auto;
}

.analysis-product-copy {
  display: grid;
  gap: 0.3rem;
  min-width: 0;
}

.analysis-product-title {
  font-size: 0.96rem;
  line-height: 1.45;
  word-break: break-word;
}

.analysis-product-chip-row {
  gap: 0.35rem;
}

.analysis-meta-item {
  display: grid;
  gap: 0.2rem;
}

.analysis-meta-item strong {
  font-size: 0.84rem;
  line-height: 1.35;
}

.analysis-comparison-block {
  display: grid;
  gap: 1rem;
  padding: 1.1rem;
  border-radius: 1.5rem;
  border: 1px solid rgba(148, 163, 184, 0.18);
  background:
    radial-gradient(circle at top right, rgba(14, 165, 233, 0.12), transparent 34%),
    linear-gradient(180deg, rgba(248, 251, 255, 0.94), rgba(255, 255, 255, 0.98));
}

.analysis-wing-batch-bar {
  display: grid;
  grid-template-columns: minmax(0, 1.45fr) auto;
  gap: 1rem;
  align-items: center;
  padding: 1rem 1.05rem;
  border-radius: 1.35rem;
  border: 1px solid #e7e1d8;
  background:
    radial-gradient(circle at top right, rgba(220, 233, 240, 0.5), transparent 36%),
    linear-gradient(135deg, #fffdf9, #f7f4ef);
  color: #121212;
  box-shadow: none;
}

.analysis-wing-batch-bar .eyebrow,
.analysis-wing-batch-bar p,
.analysis-wing-batch-bar .analysis-field-note {
  color: #6f6b64;
}

.analysis-wing-batch-bar-active {
  border-color: #d9d3ca;
  box-shadow: none;
}

.analysis-wing-batch-copy {
  display: grid;
  gap: 0.42rem;
  min-width: 0;
}

.analysis-wing-batch-copy strong {
  font-size: 1.08rem;
  line-height: 1.35;
  color: #121212;
}

.analysis-wing-batch-copy p {
  margin: 0;
  font-size: 0.84rem;
  line-height: 1.55;
}

.analysis-wing-batch-meta {
  gap: 0.42rem;
}

.analysis-wing-batch-meta .chip {
  background: #faf8f4;
  border-color: #e7e1d8;
  color: #6f6b64;
}

.analysis-wing-batch-meta .chip-highlight {
  background: #fff1ef;
  border-color: #f6c2bc;
  color: #b43328;
}

.analysis-wing-batch-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
}

.analysis-wing-batch-actions .button {
  white-space: nowrap;
}

.analysis-wing-batch-progress {
  grid-column: 1 / -1;
  display: grid;
  gap: 0.42rem;
  padding-top: 0.15rem;
}

.analysis-wing-batch-progress-copy {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 0.7rem;
  font-size: 0.8rem;
}

.analysis-wing-batch-progress-copy strong {
  color: #121212;
}

.analysis-wing-batch-progress-track {
  position: relative;
  width: 100%;
  height: 10px;
  border-radius: 999px;
  overflow: hidden;
  background: #ece7df;
  border: 1px solid #e7e1d8;
}

.analysis-wing-batch-progress-fill {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, #111111, #484848);
}

.analysis-comparison-table .table-shell {
  margin: 0;
  padding: 0.55rem;
  border-radius: 1.35rem;
  overflow: auto;
  background: rgba(255, 255, 255, 0.96);
  border: 1px solid rgba(191, 219, 254, 0.5);
  box-shadow: 0 18px 40px rgba(148, 163, 184, 0.16);
}

.analysis-comparison-table .data-table {
  min-width: 1120px;
  border-collapse: separate;
  border-spacing: 0;
}

.analysis-comparison-table .data-table thead th {
  position: sticky;
  top: 0;
  z-index: 1;
  background: linear-gradient(180deg, rgba(241, 247, 255, 0.98), rgba(231, 240, 255, 0.96));
}

.analysis-comparison-table .data-table thead th:first-child {
  border-top-left-radius: 1rem;
}

.analysis-comparison-table .data-table thead th:last-child {
  border-top-right-radius: 1rem;
}

.analysis-comparison-table .data-table tbody tr:nth-child(odd) {
  background: rgba(248, 251, 255, 0.82);
}

.analysis-comparison-table .data-table tbody tr:hover {
  background: rgba(219, 234, 254, 0.22);
}

.analysis-comparison-table .data-table th:nth-child(2),
.analysis-comparison-table .data-table th:nth-child(3),
.analysis-comparison-table .data-table th:nth-child(4) {
  color: var(--primary-600);
  background: rgba(13, 90, 229, 0.08);
}

.analysis-comparison-table .data-table td:nth-child(2) {
  min-width: 300px;
}

.analysis-comparison-table .data-table td:nth-child(3),
.analysis-comparison-table .data-table td:nth-child(4) {
  background: linear-gradient(180deg, rgba(13, 90, 229, 0.05), rgba(13, 90, 229, 0.02));
  min-width: 196px;
}

.analysis-comparison-table .data-table td:nth-child(8) {
  min-width: 170px;
}

.analysis-secondary-block {
  display: grid;
  gap: 0.7rem;
  padding-top: 0.15rem;
}

.analysis-secondary-head {
  display: grid;
  gap: 0.18rem;
}

.analysis-page-result-table .table-shell {
  margin: 0;
}

.analysis-page-result-table .data-table th:nth-child(3),
.analysis-page-result-table .data-table th:nth-child(4) {
  color: var(--primary-600);
  background: rgba(13, 90, 229, 0.08);
}

.analysis-page-result-table .data-table td:nth-child(3),
.analysis-page-result-table .data-table td:nth-child(4) {
  background: rgba(13, 90, 229, 0.035);
  min-width: 168px;
}

.product-hero {
  display: grid;
  grid-template-columns: 104px 1fr 220px;
  align-items: start;
  gap: 1rem;
}

.product-thumb {
  width: 104px;
  height: 104px;
  border-radius: 1.6rem;
  overflow: hidden;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, rgba(49, 130, 246, 0.18), rgba(49, 130, 246, 0.05));
  color: var(--primary-600);
  font-weight: 800;
  font-size: 1.6rem;
}

.product-thumb-image {
  padding: 0;
  background: #fff;
  border: 1px solid rgba(229, 232, 235, 0.92);
}

.product-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.info-grid {
  grid-template-columns: repeat(auto-fit, minmax(0, 1fr));
}

.info-pair {
  padding: 0.95rem 1rem;
  border-radius: 1rem;
  background: #f7f9fc;
  display: grid;
  gap: 0.35rem;
}

.info-pair span {
  color: var(--text-muted);
  font-size: 0.86rem;
}

.product-meta-line {
  margin-top: -0.35rem;
}

.detail-row {
  display: grid;
  gap: 0.5rem;
}

.table-shell {
  overflow: auto;
  padding: 0.4rem;
}

.data-table {
  width: 100%;
  border-collapse: collapse;
  min-width: 720px;
}

.data-table th,
.data-table td {
  padding: 1rem;
  text-align: left;
  border-bottom: 1px solid rgba(229, 232, 235, 0.92);
  color: var(--text-default);
}

.data-table th {
  color: var(--navy-900);
  font-size: 0.92rem;
}

@media (max-width: 960px) {
  .analysis-comparison-block {
    padding: 0.9rem;
  }

  .analysis-wing-batch-bar {
    grid-template-columns: 1fr;
  }

  .analysis-wing-batch-actions {
    justify-content: flex-start;
  }
}

.plan-card-featured {
  border-color: rgba(49, 130, 246, 0.28);
  background: linear-gradient(180deg, rgba(49, 130, 246, 0.05), #ffffff);
}

.feature-list {
  display: grid;
  gap: 0.65rem;
  color: var(--text-default);
}

.feature-list li {
  position: relative;
  padding-left: 1rem;
}

.feature-list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.65rem;
  width: 0.38rem;
  height: 0.38rem;
  border-radius: 999px;
  background: var(--primary-500);
}

@media (max-width: 1199px) {
  .hero-section,
  .dashboard-grid,
  .auth-page,
  .product-hero,
  .grid-4,
  .overview-card {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .app-shell {
    grid-template-columns: 1fr;
  }

  .sidebar {
    position: fixed;
    left: 0;
    top: 0;
    width: min(320px, 88vw);
    transform: translateX(-105%);
    transition: transform 0.2s ease;
    z-index: 40;
  }

  .sidebar.is-open {
    transform: translateX(0);
  }

  .mobile-only {
    display: inline-flex;
  }
}

@media (max-width: 767px) {
  .site-shell {
    padding-left: 1rem;
    padding-right: 1rem;
  }

  .marketing-header {
    padding: 1rem 0;
  }

  .nav-links {
    position: absolute;
    left: 1rem;
    right: 1rem;
    top: calc(100% + 0.35rem);
    padding: 1rem;
    border-radius: 1.2rem;
    background: rgba(255, 255, 255, 0.98);
    border: 1px solid rgba(229, 232, 235, 0.96);
    box-shadow: var(--shadow-card);
    display: none;
    flex-direction: column;
    align-items: stretch;
  }

  .nav-links.is-open {
    display: flex;
  }

  .nav-toggle {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 2.8rem;
    padding: 0 1rem;
    border-radius: 14px;
    background: #fff;
    border: 1px solid var(--border-default);
  }

  .hero-section,
  .hero-proof,
  .grid-3,
  .grid-4,
  .two-column,
  .dashboard-grid,
  .auth-page,
  .product-hero,
  .info-grid,
  .analysis-form,
  .analysis-mode-grid,
  .cta-banner,
  .overview-card,
  .preview-summary,
  .preview-topbar,
  .mini-row,
  .saved-controls,
  .compare-save-form,
  .notice,
  .info-inline {
    grid-template-columns: 1fr;
  }

  .section-surface {
    padding: 1.2rem;
  }

  .site-footer,
  .app-header,
  .section-heading {
    flex-direction: column;
    align-items: stretch;
  }

  .app-main {
    padding: 1rem 1rem 2rem;
  }

  .product-thumb {
    width: 88px;
    height: 88px;
  }
}

:root {
  --primary-500: #0d5ae5;
  --primary-600: #0948b6;
  --navy-900: #0f172a;
  --text-default: #445066;
  --text-muted: #7f8aa3;
  --bg-default: #eef3fb;
  --bg-card: rgba(255, 255, 255, 0.94);
  --border-default: rgba(143, 164, 204, 0.24);
  --success: #159f6a;
  --warning: #d98b16;
  --shadow-card: 0 28px 80px rgba(15, 23, 42, 0.10);
  --shadow-focus: 0 0 0 4px rgba(13, 90, 229, 0.14);
}

body {
  background:
    radial-gradient(circle at top left, rgba(13, 90, 229, 0.20), transparent 22%),
    radial-gradient(circle at top right, rgba(15, 23, 42, 0.12), transparent 28%),
    linear-gradient(180deg, #f7faff 0%, #ecf1fb 32%, #e8eef8 100%);
}

.marketing-header,
.sidebar,
.app-header {
  background: rgba(248, 251, 255, 0.84);
  border: 1px solid rgba(255, 255, 255, 0.4);
  box-shadow: 0 14px 48px rgba(15, 23, 42, 0.08);
}

.card,
.sidebar-card,
.action-panel,
.overview-card,
.analysis-status-card,
.product-hero,
.table-shell {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(246, 249, 255, 0.92));
  border: 1px solid rgba(148, 163, 184, 0.18);
  box-shadow: var(--shadow-card);
}

.button {
  border-radius: 16px;
}

.button-primary {
  background: linear-gradient(135deg, #0d5ae5 0%, #2679ff 100%);
  box-shadow: 0 18px 36px rgba(13, 90, 229, 0.24);
}

.button-secondary {
  background: rgba(255, 255, 255, 0.88);
  border-color: rgba(138, 156, 190, 0.24);
}

.hero-section {
  padding-top: 5rem;
  gap: 2.4rem;
}

.hero-copy h1 {
  max-width: 11ch;
}

.hero-trust-row {
  margin-top: 0.2rem;
}

.hero-preview {
  padding: 1.4rem;
  gap: 1.15rem;
  position: relative;
  overflow: hidden;
}

.hero-preview::before {
  content: "";
  position: absolute;
  inset: auto -20% 72% auto;
  width: 260px;
  height: 260px;
  border-radius: 999px;
  background: radial-gradient(circle, rgba(13, 90, 229, 0.18), transparent 70%);
  pointer-events: none;
}

.hero-analysis-board {
  display: grid;
  grid-template-columns: 1.2fr 0.8fr;
  gap: 0.85rem;
}

.hero-analysis-card {
  padding: 1rem;
  border-radius: 1.2rem;
  border: 1px solid rgba(148, 163, 184, 0.18);
  background: rgba(244, 248, 255, 0.88);
}

.diagnostic-field-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(92px, 1fr));
  gap: 0.7rem;
  margin-top: 0.8rem;
}

.diagnostic-field {
  padding: 0.8rem 0.85rem;
  border-radius: 1rem;
  background: rgba(255, 255, 255, 0.88);
  border: 1px solid rgba(148, 163, 184, 0.16);
  display: grid;
  gap: 0.18rem;
}

.diagnostic-field span,
.diagnostic-field small {
  color: var(--text-muted);
}

.diagnostic-field strong {
  font-size: 0.95rem;
}

.diagnostic-field.is-ok {
  border-color: rgba(21, 159, 106, 0.24);
  background: rgba(236, 252, 245, 0.9);
}

.diagnostic-field.is-missing {
  border-color: rgba(217, 139, 22, 0.24);
  background: rgba(255, 248, 236, 0.94);
}

.overview-card,
.compare-topbar,
.filter-card,
.analysis-start-card {
  position: relative;
  overflow: hidden;
}

.overview-card::before,
.compare-topbar::before,
.filter-card::before,
.analysis-start-card::before {
  content: "";
  position: absolute;
  inset: 0 auto auto 0;
  width: 100%;
  height: 4px;
  background: linear-gradient(90deg, #0d5ae5, #61a4ff);
}

.analysis-card,
.comparison-card,
.saved-card,
.list-card,
.feature-card,
.preview-panel,
.workflow-card,
.plan-card {
  border-radius: 1.35rem;
}

.analysis-card h3,
.comparison-card h3,
.saved-card h3,
.feature-card h3,
.preview-panel h3 {
  letter-spacing: -0.02em;
}

.chip {
  background: rgba(15, 23, 42, 0.05);
  border: 1px solid rgba(148, 163, 184, 0.18);
}

.chip-highlight {
  background: rgba(13, 90, 229, 0.10);
  border-color: rgba(13, 90, 229, 0.18);
  color: var(--primary-600);
}

.analysis-status-card,
.notice {
  border-radius: 1.2rem;
}

.analysis-candidate-card {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.97), rgba(242, 247, 255, 0.92));
}

.product-hero {
  gap: 1.25rem;
  grid-template-columns: 120px 1fr 240px;
}

.product-copy h2 {
  font-size: clamp(1.7rem, 3vw, 2.3rem);
  letter-spacing: -0.03em;
}

.product-actions {
  display: grid;
  gap: 0.7rem;
}

.analysis-diagnostics .mini-row-card,
.saved-card,
.action-panel,
.comparison-card {
  backdrop-filter: blur(10px);
}

.cta-banner {
  border-radius: 1.6rem;
  background:
    linear-gradient(135deg, rgba(13, 90, 229, 0.92), rgba(15, 23, 42, 0.92)),
    linear-gradient(180deg, #0d5ae5, #0f172a);
  color: #fff;
  box-shadow: 0 30px 70px rgba(15, 23, 42, 0.18);
}

.cta-banner p,
.cta-banner h2,
.cta-banner .eyebrow {
  color: #fff;
}

.plan-card-featured {
  border-color: rgba(13, 90, 229, 0.26);
  background:
    linear-gradient(180deg, rgba(13, 90, 229, 0.08), rgba(255, 255, 255, 0.96));
}

.sidebar-card p,
.muted,
.analysis-candidate-url,
.info-pair span,
.hero-copy p,
.card p {
  color: var(--text-default);
}

@media (max-width: 1199px) {
  .hero-analysis-board {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 767px) {
  .hero-section {
    padding-top: 2rem;
  }

  .hero-copy h1 {
    max-width: none;
  }

  .hero-analysis-board,
  .diagnostic-field-grid {
    grid-template-columns: 1fr;
  }
}

:root {
  --font-sans: "SUIT Variable", "Pretendard Variable", "Pretendard", "Noto Sans KR", "Apple SD Gothic Neo", "Malgun Gothic", sans-serif;
  --text-xs: clamp(0.76rem, 0.14vw + 0.72rem, 0.84rem);
  --text-sm: clamp(0.88rem, 0.18vw + 0.82rem, 0.96rem);
  --text-base: clamp(0.98rem, 0.18vw + 0.92rem, 1.06rem);
  --text-lg: clamp(1.08rem, 0.24vw + 1rem, 1.22rem);
  --text-xl: clamp(1.28rem, 0.42vw + 1.14rem, 1.58rem);
  --text-2xl: clamp(1.6rem, 0.95vw + 1.25rem, 2.25rem);
  --text-3xl: clamp(2.1rem, 1.8vw + 1.5rem, 3.55rem);
}

html {
  font-size: clamp(15px, 0.12vw + 14.6px, 17px);
  -webkit-text-size-adjust: 100%;
}

body {
  font-family: var(--font-sans);
  font-size: var(--text-base);
  line-height: 1.58;
  text-rendering: optimizeLegibility;
  word-break: keep-all;
}

button,
input,
select,
textarea {
  font-family: var(--font-sans);
}

input,
select,
textarea {
  min-height: 3.2rem;
  padding: 1rem 1.05rem;
  font-size: var(--text-base);
  line-height: 1.45;
}

textarea {
  min-height: 132px;
}

h1,
h2,
h3,
.brand,
.nav-link,
.button,
.badge,
.chip,
.stat-value,
.preview-metric strong,
.analysis-card h3,
.comparison-card h3,
.saved-card h3,
.feature-card h3,
.preview-panel h3,
.product-copy h2,
.app-header h1 {
  font-family: var(--font-sans);
}

.brand,
.nav-link,
.button,
.badge,
.chip,
.eyebrow,
.analysis-candidate-url,
.preview-metric span,
.info-pair span,
.muted {
  letter-spacing: -0.01em;
}

.button,
.nav-link,
.chip,
.badge,
.feature-meta,
.analysis-mode-card p,
.meter-topline,
.analysis-status-input,
.product-meta-line,
.data-table th,
.data-table td {
  font-size: var(--text-sm);
}

.button {
  min-height: 3rem;
  padding: 0.9rem 1.18rem;
  font-size: var(--text-sm);
  line-height: 1.2;
}

.button-small {
  min-height: 2.55rem;
  padding: 0.65rem 0.95rem;
  font-size: var(--text-xs);
}

.brand {
  font-size: var(--text-lg);
  letter-spacing: -0.02em;
}

.nav-link {
  font-weight: 600;
}

.eyebrow {
  font-size: var(--text-xs);
}

.badge {
  min-height: 2rem;
  font-size: var(--text-xs);
}

.chip {
  min-height: 2.1rem;
  font-size: var(--text-xs);
}

.hero-copy h1,
.auth-card h1,
.pricing-hero h1 {
  font-size: var(--text-3xl);
  line-height: 1.02;
  letter-spacing: -0.05em;
}

.hero-copy p,
.auth-card p,
.pricing-note p,
.card p,
.site-footer p,
.empty-state p,
.faq-item p,
.analysis-card p,
.comparison-card p,
.saved-card p {
  font-size: var(--text-base);
  line-height: 1.68;
}

.section-heading h2 {
  font-size: var(--text-2xl);
  line-height: 1.08;
}

.feature-card h3,
.plan-card h3,
.card h3,
.list-card h3 {
  font-size: var(--text-lg);
  line-height: 1.24;
}

.preview-metric strong {
  font-size: var(--text-xl);
  line-height: 1.08;
}

.stat-value {
  font-size: clamp(1.7rem, 0.72vw + 1.42rem, 2.35rem);
}

.app-header h1 {
  font-size: clamp(1.7rem, 0.92vw + 1.35rem, 2.45rem);
  line-height: 1.05;
}

.product-copy h2 {
  font-size: clamp(1.62rem, 1vw + 1.25rem, 2.55rem);
  line-height: 1.08;
}

.analysis-card,
.comparison-card,
.saved-card,
.feature-card,
.preview-panel,
.workflow-card,
.plan-card,
.action-panel,
.filter-card,
.analysis-start-card,
.auth-card,
.auth-aside {
  gap: 1rem;
}

.data-table th,
.data-table td {
  padding: 1rem 1.05rem;
  white-space: normal;
  vertical-align: top;
}

.analysis-form {
  align-items: stretch;
}

.analysis-form input,
.analysis-form button {
  min-height: 3.4rem;
}

.product-thumb {
  width: clamp(92px, 8vw, 120px);
  height: clamp(92px, 8vw, 120px);
}

.hero-preview,
.overview-card,
.analysis-start-card,
.product-hero,
.compare-topbar,
.filter-card {
  padding: clamp(1.15rem, 0.4vw + 1rem, 1.5rem);
}

@media (max-width: 1023px) {
  .site-shell {
    padding: 0 1rem 2rem;
  }

  .hero-section,
  .auth-page,
  .dashboard-grid,
  .overview-card {
    grid-template-columns: 1fr;
  }

  .hero-section {
    padding-top: 3rem;
    gap: 1.5rem;
  }

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

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

  .product-hero {
    grid-template-columns: 96px 1fr;
  }

  .product-actions {
    grid-column: 1 / -1;
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .page-content {
    width: 100%;
  }
}

@media (max-width: 767px) {
  body {
    line-height: 1.58;
  }

  input,
  select,
  textarea {
    min-height: 3rem;
    padding: 0.92rem 0.98rem;
  }

  .marketing-header {
    gap: 0.8rem;
  }

  .hero-copy h1,
  .auth-card h1,
  .pricing-hero h1 {
    font-size: clamp(1.9rem, 5.6vw, 2.65rem);
    line-height: 1.04;
  }

  .section-heading h2,
  .app-header h1,
  .product-copy h2 {
    font-size: clamp(1.38rem, 4vw, 1.9rem);
  }

  .hero-proof,
  .grid-3,
  .grid-4,
  .product-actions,
  .diagnostic-field-grid {
    grid-template-columns: 1fr;
  }

  .app-main {
    padding: 0.95rem 0.9rem 1.8rem;
  }

  .section {
    padding: 0.8rem 0;
  }

  .card,
  .sidebar-card,
  .action-panel,
  .analysis-status-card,
  .hero-preview,
  .overview-card,
  .analysis-start-card,
  .product-hero,
  .compare-topbar,
  .filter-card {
    border-radius: 1.15rem;
  }

  .preview-metric strong,
  .stat-value {
    font-size: clamp(1.35rem, 5vw, 1.85rem);
  }

  .mini-row,
  .card-topline,
  .preview-topbar,
  .preview-summary,
  .header-actions {
    gap: 0.7rem;
  }

  .compare-save-form,
  .analysis-form,
  .notice {
    gap: 0.7rem;
  }

  .data-table {
    min-width: 620px;
  }
}

@media (max-width: 479px) {
  html {
    font-size: 15px;
  }

  .site-shell {
    padding-left: 0.75rem;
    padding-right: 0.75rem;
  }

  .app-main {
    padding-left: 0.72rem;
    padding-right: 0.72rem;
  }

  .button-row,
  .chip-row,
  .header-actions {
    gap: 0.55rem;
  }

  .button,
  .button-small {
    width: 100%;
  }

  .analysis-candidate-grid {
    grid-template-columns: 1fr;
  }

  .hero-preview,
  .overview-card,
  .analysis-start-card,
  .product-hero,
  .compare-topbar,
  .filter-card,
  .saved-card,
  .analysis-card,
  .comparison-card {
    padding: 1rem;
  }

  .product-thumb {
    width: 84px;
    height: 84px;
  }
}

:root {
  --max-width: 1280px;
  --navy-900: #111827;
  --text-default: #334155;
  --text-muted: #64748b;
  --bg-default: #f5f7fb;
  --bg-card: rgba(255, 255, 255, 0.98);
  --border-default: rgba(148, 163, 184, 0.22);
  --shadow-card: 0 18px 44px rgba(15, 23, 42, 0.07);
}

body {
  background:
    radial-gradient(circle at top left, rgba(13, 90, 229, 0.08), transparent 20%),
    radial-gradient(circle at top right, rgba(15, 23, 42, 0.05), transparent 24%),
    linear-gradient(180deg, #fbfcfe 0%, #f4f7fb 38%, #eef3f9 100%);
  color: var(--navy-900);
}

.site-shell {
  padding-top: 0.4rem;
}

.marketing-header {
  background: rgba(255, 255, 255, 0.9);
  border: 1px solid rgba(226, 232, 240, 0.9);
  border-radius: 1.25rem;
}

.hero-section,
.section,
.site-footer,
.marketing-header {
  width: min(100%, 1280px);
}

.hero-section {
  grid-template-columns: minmax(0, 1.08fr) minmax(380px, 0.92fr);
  align-items: start;
  gap: 1.5rem;
  padding-top: 2.8rem;
}

.hero-copy,
.auth-card,
.auth-aside,
.pricing-note {
  gap: 0.95rem;
}

.hero-copy h1,
.auth-card h1,
.pricing-hero h1 {
  max-width: 13ch;
  font-size: clamp(2.2rem, 2vw + 1.6rem, 3.7rem);
  line-height: 1.08;
  letter-spacing: -0.045em;
}

.hero-copy p,
.auth-card p,
.pricing-note p,
.card p,
.site-footer p,
.empty-state p,
.faq-item p,
.analysis-card p,
.comparison-card p,
.saved-card p {
  max-width: 62ch;
  font-size: clamp(1rem, 0.22vw + 0.94rem, 1.08rem);
  line-height: 1.72;
  color: var(--text-default);
}

.hero-trust-row {
  margin-top: 0.35rem;
}

.button-row,
.chip-row,
.header-actions {
  gap: 0.65rem;
}

.button {
  font-weight: 700;
}

.badge,
.chip,
.eyebrow {
  letter-spacing: 0;
}

.badge {
  background-clip: padding-box;
}

.chip {
  background: #f8fafc;
  color: #475569;
  border-color: rgba(203, 213, 225, 0.9);
}

.chip-highlight {
  background: rgba(13, 90, 229, 0.12);
  color: #0b57db;
  border-color: rgba(13, 90, 229, 0.16);
}

.card,
.sidebar-card,
.action-panel,
.overview-card,
.analysis-status-card,
.product-hero,
.table-shell,
.hero-preview,
.analysis-candidate-card,
.hero-analysis-card {
  background: rgba(255, 255, 255, 0.98);
  border-color: rgba(226, 232, 240, 0.95);
  box-shadow: var(--shadow-card);
}

.hero-preview {
  max-width: 520px;
  justify-self: end;
}

.hero-preview::before {
  opacity: 0.45;
}

.hero-analysis-board {
  grid-template-columns: 1fr;
}

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

.diagnostic-field {
  padding: 0.9rem;
  gap: 0.25rem;
}

.diagnostic-field strong {
  font-size: 1rem;
  color: var(--navy-900);
}

.preview-metric {
  background: #f8fafc;
  border: 1px solid rgba(226, 232, 240, 0.95);
}

.preview-metric strong,
.stat-value {
  color: var(--navy-900);
}

.analysis-card,
.comparison-card,
.saved-card,
.feature-card,
.preview-panel,
.workflow-card,
.plan-card,
.action-panel,
.filter-card,
.analysis-start-card,
.auth-card,
.auth-aside,
.compare-topbar,
.product-hero {
  padding: 1.25rem;
}

.analysis-card h3,
.comparison-card h3,
.saved-card h3,
.feature-card h3,
.preview-panel h3,
.card h3 {
  font-size: clamp(1.12rem, 0.18vw + 1.06rem, 1.24rem);
  line-height: 1.35;
}

.section-heading {
  align-items: center;
  margin-bottom: 1rem;
}

.section-heading h2 {
  font-size: clamp(1.45rem, 0.45vw + 1.28rem, 1.95rem);
  line-height: 1.18;
}

.overview-card {
  grid-template-columns: minmax(0, 1.2fr) minmax(300px, 0.8fr);
  gap: 1rem;
}

.app-header {
  padding-bottom: 0.7rem;
}

.app-header h1 {
  font-size: clamp(1.72rem, 0.55vw + 1.5rem, 2.2rem);
  line-height: 1.12;
}

.product-hero {
  grid-template-columns: 112px minmax(0, 1fr) 220px;
  gap: 1rem;
}

.product-copy h2 {
  font-size: clamp(1.55rem, 0.7vw + 1.35rem, 2.2rem);
  line-height: 1.16;
}

.product-copy,
.product-actions,
.page-content,
.stack,
.detail-list,
.compact-stack,
.info-grid {
  gap: 0.9rem;
}

.info-inline {
  font-size: 0.94rem;
}

.info-pair {
  background: #f8fafc;
  border: 1px solid rgba(226, 232, 240, 0.95);
}

.analysis-candidate-card strong,
.analysis-status-input,
.meter-topline,
.data-table th,
.data-table td,
.analysis-mode-card strong,
.analysis-mode-card p {
  color: var(--navy-900);
}

.muted,
.analysis-candidate-url,
.info-pair span,
.analysis-status-list,
.analysis-warning-list ul,
.meter-topline span,
.preview-metric span,
.feature-meta {
  color: var(--text-muted);
}

.cta-banner {
  background:
    linear-gradient(135deg, #0d5ae5, #17336d);
}

@media (max-width: 1199px) {
  .hero-section {
    grid-template-columns: 1fr;
  }

  .hero-preview {
    max-width: none;
    justify-self: stretch;
  }

  .overview-card {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 767px) {
  .hero-copy h1,
  .auth-card h1,
  .pricing-hero h1 {
    max-width: none;
    font-size: clamp(1.95rem, 4.8vw, 2.8rem);
    line-height: 1.1;
  }

  .hero-copy p,
  .auth-card p,
  .pricing-note p,
  .card p,
  .site-footer p {
    max-width: none;
    font-size: 1rem;
  }

  .diagnostic-field-grid,
  .product-hero,
  .overview-card,
  .hero-proof,
  .grid-3,
  .grid-4,
  .product-actions {
    grid-template-columns: 1fr;
  }

  .marketing-header {
    border-radius: 1rem;
  }
}

:root {
  --primary-500: #2563eb;
  --primary-600: #1d4ed8;
  --navy-900: #0f172a;
  --text-default: #334155;
  --text-muted: #64748b;
  --bg-default: #f8fafc;
  --bg-card: #ffffff;
  --border-default: #e2e8f0;
  --shadow-card: 0 6px 18px rgba(15, 23, 42, 0.05);
  --shadow-focus: 0 0 0 4px rgba(37, 99, 235, 0.12);
  --max-width: 1200px;
}

body {
  background: var(--bg-default);
}

.site-shell {
  padding: 0 1.25rem 2rem;
}

.marketing-header,
.sidebar,
.app-header {
  background: rgba(255, 255, 255, 0.94);
  border: 1px solid var(--border-default);
  box-shadow: none;
  backdrop-filter: blur(10px);
}

.marketing-header {
  border-radius: 1rem;
}

.card,
.sidebar-card,
.action-panel,
.overview-card,
.analysis-status-card,
.product-hero,
.table-shell,
.hero-preview,
.analysis-candidate-card,
.hero-analysis-card,
.section-surface,
.cta-banner {
  background: var(--bg-card);
  border: 1px solid var(--border-default);
  box-shadow: var(--shadow-card);
}

.hero-section {
  grid-template-columns: minmax(0, 1fr) minmax(360px, 0.92fr);
  gap: 1.25rem;
  padding: 2rem 0 1rem;
}

.hero-copy h1,
.auth-card h1,
.pricing-hero h1 {
  max-width: 14ch;
  font-size: clamp(2rem, 1.55vw + 1.55rem, 3.2rem);
  line-height: 1.12;
  letter-spacing: -0.04em;
}

.hero-copy p,
.auth-card p,
.pricing-note p,
.card p,
.site-footer p,
.empty-state p,
.faq-item p,
.analysis-card p,
.comparison-card p,
.saved-card p {
  color: var(--text-default);
  max-width: 58ch;
}

.button-primary {
  background: var(--primary-500);
  color: #fff;
  box-shadow: none;
}

.button-secondary {
  background: #fff;
  color: var(--navy-900);
  border: 1px solid var(--border-default);
}

.button-ghost {
  color: var(--text-default);
}

.nav-link:hover,
.nav-link.is-active,
.chip-highlight,
.chip-active,
.badge-info {
  background: #eff6ff;
  color: var(--primary-600);
}

.badge-success {
  background: #ecfdf3;
  color: #15803d;
}

.badge-warning {
  background: #fff7ed;
  color: #c2410c;
}

.chip {
  background: #fff;
  border: 1px solid var(--border-default);
  color: var(--text-default);
}

.hero-preview {
  max-width: none;
  justify-self: stretch;
}

.hero-preview::before,
.overview-card::before,
.compare-topbar::before,
.filter-card::before,
.analysis-start-card::before {
  display: none;
}

.preview-metric,
.info-pair,
.hero-analysis-card,
.mini-row-card,
.analysis-mode-card,
.product-thumb-image {
  background: #f8fafc;
  border: 1px solid var(--border-default);
}

.hero-analysis-board {
  grid-template-columns: 1fr;
}

.diagnostic-field {
  background: #fff;
  border: 1px solid var(--border-default);
}

.diagnostic-field.is-ok {
  background: #f8fafc;
  border-color: #cbd5e1;
}

.diagnostic-field.is-missing {
  background: #fff;
  border-color: #f1f5f9;
}

.section-surface {
  padding: 1.35rem;
}

.preview-screen,
.window-sidebar,
.window-panel,
.preview-grid div,
.preview-grid div:nth-child(2),
.preview-grid div:nth-child(3) {
  background: #f8fafc;
}

.cta-banner {
  display: grid;
  grid-template-columns: 1fr auto;
  color: var(--navy-900);
  border-radius: 1.25rem;
}

.cta-banner p,
.cta-banner h2,
.cta-banner .eyebrow {
  color: inherit;
}

.site-footer {
  color: var(--text-default);
  padding-top: 1.4rem;
}

.product-hero {
  grid-template-columns: 108px minmax(0, 1fr) 220px;
}

.product-thumb {
  background: #eff6ff;
  color: var(--primary-600);
}

.analysis-card,
.comparison-card,
.saved-card,
.feature-card,
.preview-panel,
.workflow-card,
.plan-card,
.action-panel,
.filter-card,
.analysis-start-card,
.auth-card,
.auth-aside,
.compare-topbar,
.product-hero {
  border-radius: 1.1rem;
}

.section-heading {
  margin-bottom: 0.9rem;
}

@media (max-width: 1023px) {
  .hero-section,
  .overview-card,
  .dashboard-grid,
  .auth-page {
    grid-template-columns: 1fr;
  }

  .hero-copy h1,
  .auth-card h1,
  .pricing-hero h1 {
    max-width: none;
  }

  .product-hero {
    grid-template-columns: 96px 1fr;
  }

  .product-actions {
    grid-column: 1 / -1;
    grid-template-columns: 1fr;
  }
}

@media (max-width: 767px) {
  .site-shell {
    padding-left: 1rem;
    padding-right: 1rem;
  }

  .hero-section {
    padding-top: 1.2rem;
    gap: 1rem;
  }

  .hero-copy h1,
  .auth-card h1,
  .pricing-hero h1 {
    font-size: clamp(1.85rem, 4.9vw, 2.5rem);
  }

  .cta-banner,
  .hero-proof,
  .grid-3,
  .grid-4,
  .diagnostic-field-grid,
  .product-hero {
    grid-template-columns: 1fr;
  }

  .extension-status-head {
    display: grid;
    grid-template-columns: 1fr;
  }
}

.extension-status-panel {
  display: grid;
  gap: 1rem;
  padding: 1.25rem;
}

.extension-status-panel-compact {
  padding: 1rem;
}

.extension-status-head {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  align-items: start;
}

.extension-status-badge-wrap {
  flex: 0 0 auto;
}

.extension-guide-card {
  display: grid;
  gap: 0.75rem;
  padding: 1rem;
  border-radius: 1rem;
  background: #f8fafc;
  border: 1px solid var(--border-default);
}

.extension-download-note {
  display: grid;
  gap: 0.35rem;
  padding: 0.85rem 0.95rem;
  border-radius: 0.85rem;
  background: #eff6ff;
  border: 1px solid #bfdbfe;
}

.extension-download-note p {
  margin: 0;
}

.extension-guide-card-success {
  background: #f0fdf4;
  border-color: #bbf7d0;
}

.extension-guide-list {
  margin: 0;
  padding-left: 1.2rem;
  color: var(--text-default);
  display: grid;
  gap: 0.45rem;
}

.extension-guide-list li {
  list-style: decimal;
}

@media (max-width: 720px) {
  .analysis-product-cell {
    grid-template-columns: 44px minmax(0, 1fr);
    min-width: 180px;
  }
}


.wing-guide-card {
  background: #f8fafc;
}

.wing-guide-card strong {
  color: var(--navy-900);
}

/* === Design pass v1: refined SaaS surface system === */
:root {
  --page-gutter: clamp(1rem, 1.8vw, 1.5rem);
  --surface-soft: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(248, 250, 252, 0.96));
  --surface-accent: linear-gradient(135deg, rgba(255, 255, 255, 0.98), rgba(239, 246, 255, 0.92));
  --card-radius-xl: 1.5rem;
  --card-radius-lg: 1.2rem;
  --shadow-soft: 0 18px 50px rgba(15, 23, 42, 0.07);
  --shadow-float: 0 24px 70px rgba(37, 99, 235, 0.12);
}

html {
  scroll-behavior: smooth;
}

body {
  color: var(--navy-900);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  background:
    radial-gradient(circle at top left, rgba(59, 130, 246, 0.1), transparent 28%),
    radial-gradient(circle at top right, rgba(14, 165, 233, 0.09), transparent 22%),
    linear-gradient(180deg, #f8fbff 0%, #f8fafc 36%, #f1f5f9 100%);
}

.site-shell {
  padding: 0 var(--page-gutter) 3rem;
}

.marketing-header,
.app-header,
.sidebar {
  border-radius: 1.25rem;
  border-color: rgba(226, 232, 240, 0.9);
  box-shadow: 0 12px 36px rgba(15, 23, 42, 0.06);
}

.marketing-header {
  margin-top: 1rem;
  padding: 1rem 1.2rem;
}

.brand {
  letter-spacing: -0.02em;
}

.brand-mark {
  box-shadow: 0 14px 28px rgba(49, 130, 246, 0.26);
}

.nav-link {
  font-weight: 600;
}

.nav-link:hover,
.nav-link.is-active {
  background: rgba(255, 255, 255, 0.88);
  box-shadow: inset 0 0 0 1px rgba(191, 219, 254, 0.9);
}

.page-content,
.section {
  display: grid;
  gap: 1rem;
}

.section {
  margin-top: 1.15rem;
}

.section-heading {
  align-items: end;
  gap: 1rem;
  margin-bottom: 1.15rem;
}

.section-heading h2,
.overview-card h2,
.analysis-start-card h2,
.product-copy h2,
.compare-topbar h2,
.cta-banner h2,
.hero-copy h1 {
  letter-spacing: -0.04em;
}

.section-heading h2 {
  font-size: clamp(1.45rem, 1.1vw + 1.1rem, 2rem);
}

.eyebrow {
  letter-spacing: 0.08em;
  font-weight: 700;
}

.card,
.sidebar-card,
.action-panel,
.overview-card,
.analysis-status-card,
.product-hero,
.table-shell,
.hero-preview,
.analysis-candidate-card,
.hero-analysis-card,
.section-surface,
.cta-banner,
.auth-card,
.auth-aside,
.compare-topbar,
.filter-card,
.analysis-start-card,
.analysis-card,
.comparison-card,
.saved-card,
.feature-card,
.preview-panel,
.workflow-card,
.stat-card {
  background: var(--surface-soft);
  border: 1px solid rgba(226, 232, 240, 0.9);
  border-radius: var(--card-radius-lg);
  box-shadow: var(--shadow-soft);
}

.hero-section,
.dashboard-grid,
.product-hero,
.overview-card,
.analysis-start-card,
.compare-topbar {
  gap: 1.4rem;
}

.hero-section {
  grid-template-columns: minmax(0, 1.08fr) minmax(340px, 0.92fr);
  padding: 2.6rem 0 1.4rem;
}

.hero-copy,
.hero-preview,
.dashboard-overview-main,
.dashboard-overview-side,
.analysis-start-copy,
.analysis-search-shell,
.product-copy,
.product-actions,
.action-panel,
.analysis-start-mini-card,
.overview-mini-card {
  display: grid;
  gap: 0.95rem;
}

.hero-copy {
  align-content: start;
}

.hero-copy p,
.product-copy > p,
.analysis-start-copy p,
.overview-card p,
.action-panel p,
.compare-topbar p,
.analysis-card p,
.comparison-card p,
.saved-card p {
  font-size: 0.98rem;
  line-height: 1.72;
}

.hero-proof,
.analysis-start-quick-grid,
.analysis-mode-grid,
.diagnostic-field-grid,
.info-grid {
  gap: 0.9rem;
}

.preview-summary,
.info-grid,
.card-grid.grid-4,
.card-grid.grid-3,
.analysis-start-quick-grid,
.analysis-mode-grid-wide {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

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

.preview-summary,
.hero-proof {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.preview-metric,
.info-pair,
.hero-analysis-card,
.mini-row-card,
.analysis-mode-card,
.product-thumb-image,
.analysis-start-mini-card,
.overview-mini-card,
.extension-guide-card,
.extension-download-note,
.analysis-status-card,
.table-shell,
.empty-state {
  border-radius: 1rem;
}

.preview-metric,
.info-pair,
.analysis-mode-card,
.analysis-start-mini-card,
.overview-mini-card,
.extension-guide-card,
.analysis-status-card,
.empty-state {
  background: rgba(255, 255, 255, 0.82);
  border: 1px solid rgba(226, 232, 240, 0.95);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.9);
}

.button {
  min-height: 2.95rem;
  padding: 0.84rem 1.1rem;
  border-radius: 0.95rem;
  font-weight: 700;
}

.button:hover {
  transform: translateY(-2px);
}

.button-primary {
  background: linear-gradient(135deg, #2563eb, #3b82f6 56%, #60a5fa);
  box-shadow: 0 16px 34px rgba(37, 99, 235, 0.24);
}

.button-secondary {
  background: rgba(255, 255, 255, 0.88);
  border-color: rgba(203, 213, 225, 0.95);
}

.button-ghost {
  background: rgba(248, 250, 252, 0.72);
}

.button-block {
  justify-content: center;
}

.analysis-card,
.comparison-card,
.saved-card,
.feature-card,
.preview-panel,
.workflow-card,
.stat-card,
.action-panel,
.filter-card {
  transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
}

.analysis-card:hover,
.comparison-card:hover,
.saved-card:hover,
.feature-card:hover,
.preview-panel:hover,
.workflow-card:hover,
.stat-card:hover,
.action-panel:hover,
.filter-card:hover {
  transform: translateY(-3px);
  border-color: rgba(147, 197, 253, 0.95);
  box-shadow: 0 22px 48px rgba(15, 23, 42, 0.1);
}

.dashboard-overview-card,
.analysis-start-card,
.product-hero-refined,
.compare-topbar,
.hero-preview,
.cta-banner {
  background: var(--surface-accent);
  box-shadow: var(--shadow-float);
}

.dashboard-overview-card {
  grid-template-columns: minmax(0, 1.5fr) minmax(280px, 0.82fr);
  align-items: start;
}

.dashboard-quick-form {
  margin-top: 0.35rem;
}

.dashboard-overview-side {
  align-content: start;
}

.dashboard-overview-card-compact {
  grid-template-columns: 1fr;
}

.dashboard-overview-card-compact .dashboard-quick-form {
  grid-template-columns: minmax(0, 1fr);
}

.dashboard-overview-card-compact .dashboard-quick-form .button {
  width: 100%;
  justify-content: center;
}

.dashboard-overview-card-compact .dashboard-overview-side {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.overview-mini-card strong,
.analysis-start-mini-card strong,
.analysis-mode-card strong,
.stat-value {
  font-size: 1.1rem;
  line-height: 1.35;
}

.analysis-start-hero-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(0, 1fr);
  gap: 1.2rem;
  align-items: start;
}

.analysis-form,
.compare-save-form {
  padding: 0.45rem;
  border-radius: 1rem;
  background: rgba(255, 255, 255, 0.74);
  border: 1px solid rgba(226, 232, 240, 0.95);
}

.analysis-form input,
.compare-save-form input {
  background: #fff;
  border-color: rgba(203, 213, 225, 0.95);
}

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

.analysis-card,
.comparison-card,
.saved-card {
  padding: 1.15rem;
}

.card-topline {
  align-items: start;
  gap: 0.85rem;
}

.chip-row {
  gap: 0.6rem;
}

.chip,
.badge {
  border-radius: 999px;
  font-weight: 600;
}

.chip {
  background: rgba(255, 255, 255, 0.85);
}

.info-inline {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
}

.info-inline span {
  padding: 0.42rem 0.7rem;
  border-radius: 999px;
  background: rgba(248, 250, 252, 0.96);
  border: 1px solid rgba(226, 232, 240, 0.9);
  color: var(--text-default);
}

.extension-status-panel,
.table-shell {
  background: rgba(255, 255, 255, 0.86);
}

.data-table th {
  font-size: 0.8rem;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--text-muted);
}

.data-table td,
.data-table th {
  padding-top: 0.95rem;
  padding-bottom: 0.95rem;
}

.product-hero-refined {
  grid-template-columns: 112px minmax(0, 1fr) minmax(220px, 0.72fr);
  align-items: start;
}

.product-thumb {
  width: 112px;
  height: 112px;
  border-radius: 1.4rem;
  box-shadow: inset 0 0 0 1px rgba(191, 219, 254, 0.9);
}

.product-copy h2 {
  font-size: clamp(1.55rem, 1vw + 1.2rem, 2.2rem);
  line-height: 1.18;
}

.product-meta-line {
  font-size: 0.94rem;
}

.product-actions-sticky {
  position: sticky;
  top: 6.5rem;
  padding: 1rem;
  border-radius: 1.1rem;
  background: rgba(255, 255, 255, 0.72);
  border: 1px solid rgba(226, 232, 240, 0.95);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.9);
}

.detail-row,
.mini-row,
.mini-row-card {
  gap: 0.85rem;
}

.empty-state {
  padding: 1.5rem;
}

@media (max-width: 1023px) {
  .dashboard-overview-card,
  .analysis-start-hero-grid,
  .hero-section,
  .dashboard-grid,
  .auth-page,
  .product-hero-refined {
    grid-template-columns: 1fr;
  }

  .product-actions-sticky {
    position: static;
    top: auto;
  }

  .card-grid.grid-4,
  .preview-summary,
  .hero-proof,
  .analysis-start-quick-grid,
  .diagnostic-field-grid,
  .info-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 767px) {
  .site-shell {
    padding-left: 1rem;
    padding-right: 1rem;
  }

  .marketing-header,
  .app-header,
  .sidebar {
    border-radius: 1rem;
  }

  .hero-section {
    padding-top: 1.35rem;
  }

  .card-grid.grid-4,
  .card-grid.grid-3,
  .preview-summary,
  .hero-proof,
  .analysis-start-quick-grid,
  .analysis-mode-grid-wide,
  .diagnostic-field-grid,
  .info-grid,
  .product-hero-refined {
    grid-template-columns: 1fr;
  }

  .product-thumb {
    width: 88px;
    height: 88px;
  }

  .button-row,
  .header-actions {
    gap: 0.6rem;
  }

  .button,
  .button-small {
    width: 100%;
  }
}

/* === Design pass v2: compact SaaS density === */
:root {
  --shadow-card: 0 2px 10px rgba(15, 23, 42, 0.04);
}

body {
  background: #f6f8fb;
}

.site-shell {
  padding-bottom: 2rem;
}

.section,
.page-content,
.stack,
.detail-list,
.product-copy,
.product-actions,
.info-grid,
.analysis-card,
.comparison-card,
.saved-card,
.action-panel,
.filter-card,
.analysis-start-card,
.compare-topbar,
.overview-card,
.hero-preview,
.hero-copy,
.analysis-start-copy,
.analysis-search-shell,
.dashboard-overview-main,
.dashboard-overview-side {
  gap: 0.7rem;
}

.section {
  margin-top: 0.8rem;
}

.marketing-header,
.app-header,
.sidebar {
  box-shadow: none;
}

.card,
.sidebar-card,
.action-panel,
.overview-card,
.analysis-status-card,
.product-hero,
.table-shell,
.hero-preview,
.analysis-candidate-card,
.hero-analysis-card,
.section-surface,
.cta-banner,
.auth-card,
.auth-aside,
.compare-topbar,
.filter-card,
.analysis-start-card,
.analysis-card,
.comparison-card,
.saved-card,
.feature-card,
.preview-panel,
.workflow-card,
.stat-card {
  background: #fff;
  border-color: #e2e8f0;
  border-radius: 0.9rem;
  box-shadow: var(--shadow-card);
}

.marketing-header {
  margin-top: 0.75rem;
  padding: 0.8rem 1rem;
}

.hero-section {
  grid-template-columns: minmax(0, 1fr) minmax(320px, 0.88fr);
  gap: 1rem;
  padding: 1.35rem 0 0.7rem;
}

.hero-copy h1,
.auth-card h1,
.pricing-hero h1 {
  font-size: clamp(1.85rem, 1.1vw + 1.5rem, 2.8rem);
  line-height: 1.08;
  max-width: 13ch;
}

.hero-copy p,
.auth-card p,
.pricing-note p,
.card p,
.site-footer p,
.empty-state p,
.faq-item p,
.analysis-card p,
.comparison-card p,
.saved-card p {
  font-size: 0.94rem;
  line-height: 1.55;
  max-width: none;
}

.preview-metric,
.info-pair,
.analysis-mode-card,
.analysis-start-mini-card,
.overview-mini-card,
.extension-guide-card,
.analysis-status-card,
.empty-state,
.hero-analysis-card,
.mini-row-card,
.saved-controls,
.extension-download-note,
.analysis-field-cell-core {
  border-radius: 0.75rem;
}

.hero-preview,
.analysis-card,
.comparison-card,
.saved-card,
.feature-card,
.preview-panel,
.workflow-card,
.plan-card,
.action-panel,
.filter-card,
.analysis-start-card,
.auth-card,
.auth-aside,
.compare-topbar,
.product-hero,
.overview-card,
.section-surface,
.extension-status-panel,
.table-shell {
  padding: 1rem;
}

.button {
  min-height: 2.55rem;
  padding: 0.66rem 0.9rem;
  border-radius: 0.72rem;
}

.button-small {
  min-height: 2.15rem;
  padding: 0.48rem 0.72rem;
}

.button:hover,
.analysis-card:hover,
.comparison-card:hover,
.saved-card:hover,
.feature-card:hover,
.preview-panel:hover,
.workflow-card:hover,
.stat-card:hover,
.action-panel:hover,
.filter-card:hover,
.analysis-candidate-card:hover {
  transform: none;
  box-shadow: var(--shadow-card);
}

.hero-proof,
.preview-summary,
.card-grid.grid-3,
.card-grid.grid-4,
.analysis-start-quick-grid,
.diagnostic-field-grid,
.info-grid {
  gap: 0.65rem;
}

.hero-proof .stat-card,
.card-grid.grid-4 .feature-card,
.card-grid.grid-4 .workflow-card {
  padding: 0.95rem;
}

.hero-analysis-board-compact {
  gap: 0.6rem;
}

.hero-analysis-list-card {
  padding: 0.9rem;
}

.hero-inline-list {
  display: grid;
  gap: 0.45rem;
}

.hero-inline-item {
  display: grid;
  grid-template-columns: 32px 1fr;
  gap: 0.55rem;
  align-items: center;
  padding: 0.45rem 0;
  border-top: 1px solid #edf2f7;
  font-size: 0.88rem;
}

.hero-inline-item:first-child {
  border-top: 0;
  padding-top: 0;
}

.hero-inline-item strong {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 1.7rem;
  border-radius: 999px;
  background: #eff6ff;
  color: var(--primary-600);
  font-size: 0.78rem;
}

.hero-inline-list-muted .hero-inline-item strong {
  background: #f8fafc;
}

.compact-panel-head {
  display: grid;
  gap: 0.35rem;
}

.compact-panel-head p {
  color: var(--text-muted);
}

.dashboard-overview-card,
.analysis-start-card,
.compare-topbar,
.hero-preview,
.cta-banner,
.product-hero-refined {
  background: #fff;
}

.dashboard-overview-card {
  grid-template-columns: minmax(0, 1.35fr) minmax(240px, 0.65fr);
  align-items: start;
}

.dashboard-overview-card-compact .overview-mini-card,
.analysis-start-mini-card,
.analysis-mode-card,
.info-pair,
.preview-metric {
  padding: 0.8rem 0.85rem;
}

.analysis-form,
.compare-save-form {
  padding: 0.35rem;
  border-radius: 0.8rem;
  background: #f8fafc;
}

.analysis-form input,
.compare-save-form input,
input,
select,
textarea {
  min-height: 2.7rem;
  padding: 0.72rem 0.82rem;
  border-radius: 0.7rem;
}

textarea {
  min-height: 108px;
}

.info-inline {
  gap: 0.45rem;
}

.info-inline span,
.chip,
.badge {
  font-size: 0.76rem;
}

.info-inline span {
  padding: 0.28rem 0.55rem;
}

.chip {
  min-height: 1.75rem;
  padding: 0.12rem 0.58rem;
}

.badge {
  min-height: 1.7rem;
  padding: 0.08rem 0.58rem;
}

.analysis-card h3,
.comparison-card h3,
.saved-card h3,
.feature-card h3,
.preview-panel h3,
.card h3 {
  font-size: 1rem;
  line-height: 1.35;
}

.app-header h1,
.product-copy h2,
.section-heading h2 {
  line-height: 1.12;
}

.section-heading {
  margin-bottom: 0.65rem;
}

.table-shell,
.table-shell-dense {
  padding: 0.2rem;
  overflow: auto;
}

.data-table,
.data-table-dense {
  min-width: 780px;
}

.data-table th,
.data-table td,
.data-table-dense th,
.data-table-dense td {
  padding: 0.62rem 0.72rem;
  font-size: 0.82rem;
  line-height: 1.45;
  vertical-align: top;
}

.data-table th,
.data-table-dense th {
  position: sticky;
  top: 0;
  z-index: 1;
  background: #f8fafc;
  color: #64748b;
  font-size: 0.72rem;
  letter-spacing: 0.04em;
}

.data-table tbody tr:hover,
.data-table-dense tbody tr:hover {
  background: #f8fafc;
}

.analysis-comparison-block {
  gap: 0.7rem;
  padding: 0.8rem;
  border-radius: 0.95rem;
  background: #f8fafc;
  border: 1px solid var(--border-default);
}

.analysis-comparison-table .table-shell {
  padding: 0.2rem;
  border-radius: 0.85rem;
  box-shadow: none;
  width: 100%;
  max-width: 100%;
  overflow-x: visible;
  overflow-y: visible;
  display: block;
}

.analysis-comparison-table .data-table {
  width: 100%;
  min-width: 0;
  table-layout: fixed;
}

.analysis-comparison-table .data-table th:nth-child(1),
.analysis-comparison-table .data-table td:nth-child(1),
.analysis-comparison-table .data-table th:nth-child(3),
.analysis-comparison-table .data-table td:nth-child(3),
.analysis-comparison-table .data-table th:nth-child(4),
.analysis-comparison-table .data-table td:nth-child(4),
.analysis-comparison-table .data-table th:nth-child(5),
.analysis-comparison-table .data-table td:nth-child(5),
.analysis-comparison-table .data-table th:nth-child(6),
.analysis-comparison-table .data-table td:nth-child(6),
.analysis-comparison-table .data-table th:nth-child(7),
.analysis-comparison-table .data-table td:nth-child(7),
.analysis-comparison-table .data-table th:nth-child(8),
.analysis-comparison-table .data-table td:nth-child(8),
.analysis-comparison-table .data-table th:nth-child(9),
.analysis-comparison-table .data-table td:nth-child(9) {
  text-align: center;
  vertical-align: middle;
}

.analysis-comparison-table .data-table td:nth-child(2) {
  width: 34%;
}

.analysis-comparison-table .data-table td:nth-child(3) {
  width: 11%;
}

.analysis-comparison-table .data-table td:nth-child(4),
.analysis-comparison-table .data-table td:nth-child(5),
.analysis-comparison-table .data-table td:nth-child(6),
.analysis-comparison-table .data-table td:nth-child(7),
.analysis-comparison-table .data-table td:nth-child(8),
.analysis-comparison-table .data-table td:nth-child(9) {
  width: 9%;
}

.analysis-page-result-table .data-table td:nth-child(2) {
  width: 34%;
}

.analysis-page-result-table .table-shell {
  width: 100%;
  max-width: 100%;
  overflow-x: visible;
  overflow-y: visible;
  display: block;
}

.analysis-page-result-table .data-table {
  width: 100%;
  min-width: 0;
  table-layout: fixed;
}

.analysis-page-result-table .data-table td:nth-child(n+3) {
  width: 9%;
  text-align: center;
  vertical-align: middle;
}

.analysis-field-cell {
  gap: 0.18rem;
}

.analysis-shipping-cell {
  display: grid;
  justify-items: center;
  align-items: center;
  gap: 0.28rem;
}

.analysis-shipping-badge {
  display: block;
  max-width: 72px;
  max-height: 24px;
  object-fit: contain;
}

.analysis-metric-cluster {
  display: grid;
  gap: 0.34rem;
}

.analysis-status-cell {
  display: grid;
  gap: 0.24rem;
  min-width: 132px;
}

.analysis-status-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: fit-content;
  padding: 0.2rem 0.5rem;
  border-radius: 999px;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.01em;
}

.analysis-status-badge-success {
  background: rgba(22, 163, 74, 0.12);
  color: #166534;
}

.analysis-status-badge-progress {
  background: rgba(37, 99, 235, 0.12);
  color: #1d4ed8;
}

.analysis-status-badge-warning {
  background: rgba(245, 158, 11, 0.14);
  color: #b45309;
}

.analysis-status-badge-neutral {
  background: rgba(148, 163, 184, 0.16);
  color: #475569;
}

.analysis-status-note {
  font-size: 0.78rem;
  line-height: 1.35;
}

.analysis-action-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.32rem;
}

.analysis-action-row .button {
  width: auto;
  justify-content: center;
  min-height: 1.9rem;
  padding: 0.35rem 0.55rem;
  font-size: 0.72rem;
  border-radius: 0.7rem;
}

.analysis-field-cell-core {
  padding: 0.44rem 0.52rem;
  background: #eff6ff;
  border-color: #bfdbfe;
}

.analysis-field-main {
  font-size: 0.8rem;
  line-height: 1.35;
}

.analysis-field-note,
.analysis-candidate-url,
.analysis-page-result-note,
.feature-meta,
.meter-topline,
.preview-metric span,
.info-pair span,
.muted,
.analysis-status-list,
.analysis-warning-list ul {
  font-size: 0.74rem;
  line-height: 1.4;
}

.analysis-product-cell {
  grid-template-columns: 40px minmax(0, 1fr);
  gap: 0.5rem;
  min-width: 0;
}

.analysis-candidate-thumb,
.analysis-product-thumb {
  width: 40px;
  height: 40px;
  border-radius: 0.6rem;
}

.analysis-comparison-table .analysis-product-cell,
.analysis-page-result-table .analysis-product-cell {
  grid-template-columns: 40px minmax(0, 1fr);
  min-width: 0;
}

.analysis-comparison-table .analysis-product-chip-row,
.analysis-page-result-table .analysis-product-chip-row {
  display: none;
}

.analysis-comparison-table .analysis-product-copy,
.analysis-page-result-table .analysis-product-copy {
  gap: 0.28rem;
}

.analysis-comparison-table .analysis-product-title,
.analysis-page-result-table .analysis-product-title {
  font-size: 0.76rem;
  line-height: 1.28;
}

.analysis-comparison-table .analysis-field-cell,
.analysis-page-result-table .analysis-field-cell {
  align-items: center;
  justify-items: center;
  text-align: center;
  gap: 0.14rem;
}

.analysis-comparison-table .analysis-field-main,
.analysis-page-result-table .analysis-field-main {
  font-size: 0.78rem;
}

.analysis-comparison-table .analysis-field-meta,
.analysis-page-result-table .analysis-field-meta {
  justify-content: center;
  display: none;
}

.analysis-comparison-table .analysis-field-note,
.analysis-page-result-table .analysis-field-note {
  font-size: 0.68rem;
  line-height: 1.25;
}

.analysis-status-card,
.analysis-page-result-block,
.analysis-comparison-block,
.analysis-page-result-table {
  overflow: visible;
}

.analysis-product-copy,
.analysis-meta-list,
.analysis-meta-item,
.meter,
.mini-row,
.detail-row,
.saved-controls,
.compare-save-form,
.preview-topbar,
.preview-summary,
.analysis-status-card,
.analysis-secondary-block,
.analysis-page-result-block,
.analysis-page-result-head {
  gap: 0.45rem;
}

.analysis-product-title {
  font-size: 0.84rem;
  line-height: 1.35;
}

.mini-row {
  padding: 0.62rem 0;
  gap: 0.7rem;
}

.mini-row-card {
  padding: 0.7rem 0.8rem;
}

.saved-controls,
.preview-summary,
.preview-topbar {
  grid-template-columns: minmax(0, 1fr) auto;
}

.product-hero-refined {
  grid-template-columns: 92px minmax(0, 1fr) minmax(190px, 0.58fr);
  gap: 0.85rem;
}

.product-thumb {
  width: 92px;
  height: 92px;
  border-radius: 1rem;
}

.product-actions-sticky {
  top: 5.4rem;
  padding: 0.8rem;
  border-radius: 0.85rem;
}

.comparison-card .button-row,
.saved-card .button-row,
.analysis-card .button-row {
  gap: 0.45rem;
}

@media (max-width: 1023px) {
  .hero-section,
  .dashboard-grid,
  .dashboard-overview-card,
  .analysis-start-hero-grid,
  .product-hero-refined,
  .overview-card,
  .compare-topbar {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 767px) {
  .hero-copy h1,
  .auth-card h1,
  .pricing-hero h1 {
    max-width: none;
    font-size: clamp(1.72rem, 4.2vw, 2.3rem);
  }

  .hero-section {
    padding-top: 1rem;
  }

  .saved-controls,
  .preview-summary,
  .preview-topbar,
  .cta-banner,
  .product-hero-refined,
  .dashboard-overview-card,
  .dashboard-overview-card-compact .dashboard-overview-side,
  .compare-topbar,
  .hero-proof,
  .analysis-start-quick-grid,
  .diagnostic-field-grid,
  .info-grid,
  .card-grid.grid-3,
  .card-grid.grid-4 {
    grid-template-columns: 1fr;
  }

  .data-table,
  .data-table-dense,
  .analysis-comparison-table .data-table {
    min-width: 680px;
  }
}

@media (max-width: 640px) {
  .section.dense-section {
    padding-top: 0.7rem;
    padding-bottom: 0.7rem;
  }

  .card,
  .analysis-card,
  .saved-card,
  .comparison-card,
  .dashboard-overview-card,
  .analysis-start-card,
  .compare-topbar,
  .analysis-status-card,
  .analysis-candidate-card,
  .hero-analysis-card {
    padding: 0.95rem;
    border-radius: 1rem;
  }

  .button,
  .button.button-small,
  .chip.chip-button,
  select,
  input,
  textarea {
    min-height: 44px;
  }

  .button-row,
  .saved-card .button-row,
  .analysis-card .button-row,
  .comparison-card .button-row,
  .analysis-action-row,
  .analysis-status-actions,
  .analysis-wing-batch-actions {
    grid-template-columns: 1fr;
  }

  .button-row .button,
  .saved-card .button-row .button,
  .analysis-card .button-row .button,
  .comparison-card .button-row .button,
  .analysis-action-row .button,
  .analysis-status-actions .button,
  .analysis-wing-batch-actions .button {
    width: 100%;
    justify-content: center;
  }

  .dashboard-grid,
  .two-column,
  .dashboard-overview-card,
  .analysis-start-hero-grid,
  .analysis-start-quick-grid,
  .analysis-mode-grid,
  .analysis-mode-grid-wide,
  .hero-analysis-board,
  .hero-analysis-board-compact,
  .card-grid,
  .card-grid.grid-3,
  .card-grid.grid-4,
  .saved-controls,
  .compare-save-form,
  .product-hero-refined,
  .compare-topbar,
  .mini-row,
  .analysis-page-result-head,
  .analysis-candidate-header {
    grid-template-columns: 1fr;
  }

  .product-hero-refined,
  .product-actions-sticky {
    position: static;
    top: auto;
  }

  .product-thumb {
    width: 72px;
    height: 72px;
  }

  .analysis-product-cell,
  .analysis-candidate-header {
    align-items: flex-start;
  }

  .analysis-product-cell {
    grid-template-columns: 36px minmax(0, 1fr);
    min-width: 0;
  }

  .analysis-product-thumb,
  .analysis-candidate-thumb,
  .analysis-candidate-thumb-image {
    width: 36px;
    height: 36px;
  }

  .analysis-product-copy,
  .analysis-candidate-copy,
  .analysis-meta-list,
  .analysis-meta-item,
  .analysis-field-cell,
  .analysis-field-cell-core,
  .analysis-status-cell,
  .analysis-metric-cluster,
  .analysis-diagnostics .mini-row-card,
  .mini-row > div,
  .saved-card,
  .analysis-card,
  .comparison-card,
  .analysis-status-card,
  .analysis-secondary-block,
  .analysis-page-result-block,
  .analysis-page-result-head,
  .compare-topbar,
  .dashboard-overview-main,
  .dashboard-overview-side,
  .analysis-start-copy,
  .analysis-search-shell {
    min-width: 0;
  }

  .analysis-card h3,
  .saved-card h3,
  .comparison-card h3,
  .product-hero-refined h2,
  .analysis-start-card h2,
  .compare-topbar h2,
  .analysis-product-title,
  .analysis-candidate-title,
  .analysis-status-input,
  .analysis-field-main,
  .analysis-field-note,
  .analysis-candidate-url,
  .analysis-page-result-note,
  .product-meta-line,
  .muted,
  .mini-row span,
  .mini-row a,
  .info-pair strong,
  .info-pair span {
    overflow-wrap: anywhere;
    word-break: break-word;
  }

  .table-shell,
  .analysis-comparison-table .table-shell,
  .analysis-page-result-table .table-shell {
    padding: 0.25rem;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }

  .analysis-comparison-table .data-table,
  .analysis-page-result-table .data-table {
    min-width: 560px;
  }

  .analysis-comparison-table .data-table td,
  .analysis-page-result-table .data-table td,
  .analysis-comparison-table .data-table th,
  .analysis-page-result-table .data-table th {
    padding: 0.72rem 0.65rem;
    vertical-align: top;
  }

  .analysis-comparison-table .data-table td:first-child,
  .analysis-page-result-table .data-table td:first-child,
  .analysis-comparison-table .data-table th:first-child,
  .analysis-page-result-table .data-table th:first-child {
    position: sticky;
    left: 0;
    z-index: 2;
    background: #f8fafc;
  }

  .data-table td[data-label]::before {
    content: attr(data-label);
    display: block;
    margin-bottom: 0.28rem;
    color: #64748b;
    font-size: 0.68rem;
    font-weight: 700;
    letter-spacing: 0.02em;
  }

  .analysis-comparison-block,
  .analysis-wing-batch-bar,
  .analysis-page-result-block {
    padding: 0.75rem;
    border-radius: 0.9rem;
  }

  .analysis-wing-batch-meta,
  .chip-row {
    gap: 0.42rem;
  }
}

/* Release-focused cleanup */
.app-shell {
  display: grid;
  grid-template-columns: 228px minmax(0, 1fr);
  min-height: 100vh;
  background: linear-gradient(180deg, #f7f5f1 0%, #f2f5f8 100%);
}

.app-main {
  display: block;
  min-width: 0;
  padding: 1.25rem 1.4rem 2.6rem;
}

.page-content {
  width: 100%;
  max-width: 1240px;
  margin: 0 auto;
  display: block !important;
}

.page-content > * {
  width: 100%;
  max-width: 100%;
}

.section {
  width: 100%;
  max-width: 100%;
  display: block !important;
}

.section + .section {
  margin-top: 1rem;
}

.app-header {
  width: 100%;
  max-width: 1240px;
  margin: 0 auto 0.35rem;
  padding: 0.1rem 0 0.9rem;
  align-items: flex-end;
}

.app-header h1 {
  font-size: clamp(1.44rem, 0.62vw + 1.24rem, 1.78rem);
  letter-spacing: -0.03em;
}

.sidebar {
  gap: 0.85rem;
  background: rgba(255, 255, 255, 0.78);
  border-right: 1px solid rgba(216, 225, 233, 0.9);
  box-shadow: none;
  backdrop-filter: blur(16px);
}

.sidebar-card {
  padding: 0.85rem;
  border-radius: 1.05rem;
  background: rgba(248, 250, 252, 0.88);
  border: 1px solid rgba(216, 225, 233, 0.92);
  box-shadow: none;
}

.sidebar-card .chip-row {
  margin-top: 0.15rem;
}

.hero-section-release {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(360px, 0.95fr);
  gap: 1rem;
  align-items: stretch;
}

.hero-section-release-single {
  grid-template-columns: 1fr;
}

.hero-section-release .hero-copy,
.service-panel-release {
  min-width: 0;
}

.hero-section-release .hero-copy {
  padding: 1.4rem 1.5rem;
  border-radius: 1.4rem;
  background: linear-gradient(170deg, rgba(255, 255, 255, 0.97) 0%, rgba(248, 251, 253, 0.96) 100%);
  border: 1px solid rgba(214, 223, 231, 0.92);
  box-shadow:
    0 28px 44px rgba(31, 80, 104, 0.08),
    0 10px 18px rgba(255, 255, 255, 0.85) inset,
    0 -10px 20px rgba(214, 223, 231, 0.28) inset;
  transform: translateZ(0);
}

.hero-section-release .hero-copy h1 {
  font-size: clamp(1.86rem, 0.88vw + 1.42rem, 2.4rem);
  line-height: 1.02;
  letter-spacing: -0.035em;
  max-width: 8ch;
  margin-bottom: 0.45rem;
}

.hero-section-release .hero-copy p {
  max-width: 24ch;
  color: #667085;
  font-size: 0.78rem;
  line-height: 1.48;
  margin-bottom: 0.8rem;
}

.marketing-analysis-form {
  max-width: 680px;
  margin-top: 0.15rem;
  background: rgba(246, 250, 252, 0.96);
  border: 1px solid rgba(214, 223, 231, 0.92);
}

.service-panel-release {
  padding: 1.15rem 1.2rem;
  border-radius: 1.35rem;
  background: linear-gradient(170deg, rgba(255, 255, 255, 0.96) 0%, rgba(247, 250, 252, 0.96) 100%);
  border: 1px solid rgba(214, 223, 231, 0.94);
  box-shadow:
    0 24px 38px rgba(31, 80, 104, 0.07),
    0 8px 14px rgba(255, 255, 255, 0.82) inset;
}

.hero-trust-row .chip:nth-child(n+3),
.analysis-start-keyword-pills .chip:nth-child(n+3) {
  display: none;
}

.hero-trust-row {
  margin-bottom: 0.8rem;
}

.home-status-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.8rem;
}

.home-status-card {
  display: grid;
  gap: 0.32rem;
  padding: 0.95rem 1rem;
  border-radius: 1.1rem;
  background: rgba(255, 255, 255, 0.95);
  border: 1px solid rgba(214, 223, 231, 0.92);
  box-shadow:
    0 14px 24px rgba(31, 80, 104, 0.05),
    0 1px 0 rgba(255, 255, 255, 0.9) inset;
}

.home-status-card strong {
  font-size: 0.92rem;
  line-height: 1.28;
  color: #0f172a;
}

.home-status-card p {
  margin: 0;
  max-width: 28ch;
}

.hero-reference-search {
  display: grid;
  gap: 0.45rem;
  margin-bottom: 0.85rem;
}

.hero-reference-search .eyebrow {
  display: none;
}

.hero-reference-search-box {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.8rem;
  min-height: 56px;
  padding: 0.85rem 0.95rem;
  border-radius: 1rem;
  background: rgba(246, 250, 252, 0.98);
  border: 1px solid rgba(214, 223, 231, 0.92);
}

.hero-reference-search-box span {
  color: #334155;
  font-size: 0.88rem;
  font-weight: 700;
}

.hero-reference-search-box strong {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2.35rem;
  padding: 0.45rem 0.8rem;
  border-radius: 0.9rem;
  background: linear-gradient(135deg, #1d4ed8, #1e40af);
  color: #fff;
  font-size: 0.74rem;
}

.preview-summary {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.55rem;
}

.preview-topbar .eyebrow,
.preview-topbar .badge {
  display: none;
}

.preview-topbar h3 {
  font-size: 0.88rem;
  margin: 0 0 0.2rem;
}

.preview-metric {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.8rem;
  padding: 0.8rem 0.9rem;
  border-radius: 0.9rem;
  background: rgba(247, 250, 252, 0.98);
  border: 1px solid rgba(214, 223, 231, 0.9);
}

.preview-metric span {
  font-size: 0.66rem;
  letter-spacing: 0.08em;
  color: #64748b;
}

.preview-metric strong {
  font-size: 0.76rem;
  line-height: 1.32;
  color: #0f172a;
}

.auth-page {
  width: 100%;
  max-width: 1120px;
  margin: 0 auto;
}

.auth-card,
.auth-aside,
.analysis-start-card {
  border-radius: 1.35rem;
  box-shadow:
    0 22px 36px rgba(31, 80, 104, 0.07),
    0 1px 0 rgba(255, 255, 255, 0.88) inset;
}

.analysis-start-card {
  max-width: 1120px;
  margin: 0 auto;
  padding: 1.25rem;
  background: linear-gradient(170deg, rgba(255, 255, 255, 0.97) 0%, rgba(248, 251, 253, 0.96) 100%);
  position: relative;
}

.analysis-start-card::after {
  content: "";
  position: absolute;
  inset: auto 18px -10px 18px;
  height: 18px;
  border-radius: 999px;
  background: radial-gradient(circle, rgba(31, 80, 104, 0.14) 0%, rgba(31, 80, 104, 0) 72%);
  filter: blur(10px);
  pointer-events: none;
}

.analysis-start-hero-grid {
  align-items: stretch;
}

.analysis-start-copy h2 {
  font-size: clamp(1.5rem, 0.78vw + 1.2rem, 1.92rem);
  line-height: 1.04;
  letter-spacing: -0.03em;
  margin-bottom: 0.35rem;
}

.analysis-start-copy p {
  font-size: 0.78rem;
  line-height: 1.48;
  max-width: 24ch;
}

.analysis-search-shell {
  display: grid;
  align-content: start;
  gap: 0.8rem;
}

.analysis-form.analysis-form-hero {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
}

.analysis-form.analysis-form-hero input {
  min-width: 0;
  font-size: 0.84rem;
}

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

.analysis-start-mini-card,
.analysis-mode-card {
  min-width: 0;
  background: rgba(248, 251, 253, 0.95);
  border: 1px solid rgba(214, 223, 231, 0.9);
  box-shadow:
    0 10px 18px rgba(31, 80, 104, 0.04),
    0 1px 0 rgba(255, 255, 255, 0.85) inset;
  transform: translateY(0);
}

.analysis-start-mini-card strong,
.analysis-mode-card strong {
  font-size: 0.8rem;
}

.analysis-start-mini-card .eyebrow,
.analysis-mode-card .eyebrow,
.analysis-start-metric-pill span {
  display: none;
}

.analysis-start-mini-card p,
.analysis-mode-card p {
  margin: 0.18rem 0 0;
  color: #6b7280;
  font-size: 0.68rem;
  line-height: 1.35;
}

.analysis-start-metric-strip {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.7rem;
}

.analysis-start-metric-pill {
  display: grid;
  gap: 0.15rem;
  padding: 0.78rem 0.88rem;
  border-radius: 0.9rem;
  background: rgba(248, 251, 253, 0.95);
  border: 1px solid rgba(214, 223, 231, 0.95);
}

.analysis-start-metric-pill span {
  color: #6b7280;
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.06em;
}

.analysis-start-metric-pill strong {
  color: #0f172a;
  font-size: 0.78rem;
  line-height: 1.3;
}

.pricing-hero {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(300px, 0.75fr);
  gap: 1rem;
  align-items: stretch;
}

.pricing-hero .hero-copy {
  background: linear-gradient(170deg, rgba(255, 255, 255, 0.97) 0%, rgba(248, 251, 253, 0.96) 100%);
  border: 1px solid rgba(214, 223, 231, 0.92);
  box-shadow: 0 12px 30px rgba(31, 80, 104, 0.06);
}

.pricing-hero .hero-copy h1 {
  font-size: clamp(1.82rem, 0.92vw + 1.38rem, 2.32rem);
  line-height: 1.02;
  letter-spacing: -0.03em;
  max-width: none;
}

.pricing-hero .hero-copy p {
  max-width: 30ch;
}

.pricing-note {
  display: grid;
  align-content: center;
  gap: 0.45rem;
  padding: 1.35rem;
  border-radius: 1.35rem;
  background: linear-gradient(160deg, #0f172a 0%, #172554 100%);
  color: #ffffff;
  border: 1px solid rgba(226, 232, 240, 0.94);
  box-shadow:
    0 28px 40px rgba(15, 23, 42, 0.18),
    0 1px 0 rgba(255, 255, 255, 0.08) inset;
}

.pricing-note .eyebrow,
.pricing-note h3,
.pricing-note p {
  color: #ffffff;
}

.pricing-note .eyebrow {
  opacity: 0.7;
}

.pricing-note h3 {
  font-size: 1.26rem;
  line-height: 1;
  letter-spacing: -0.04em;
}

.pricing-note-list {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
  margin-top: 0.25rem;
}

.pricing-note-list span {
  display: inline-flex;
  align-items: center;
  min-height: 1.8rem;
  padding: 0.2rem 0.6rem;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.1);
  color: #ffffff;
  font-size: 0.7rem;
}

.plan-card {
  position: relative;
  display: grid;
  align-content: start;
  gap: 0.8rem;
  min-height: 100%;
  padding: 1.2rem;
  border-radius: 1.35rem;
  background: linear-gradient(170deg, rgba(255, 255, 255, 0.97) 0%, rgba(248, 251, 253, 0.96) 100%);
  border: 1px solid rgba(214, 223, 231, 0.92);
  box-shadow:
    0 20px 34px rgba(31, 80, 104, 0.07),
    0 1px 0 rgba(255, 255, 255, 0.86) inset;
  transform: translateY(0);
  transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
}

.plan-card::before {
  content: "";
  display: block;
  width: 100%;
  height: 3px;
  border-radius: 999px;
  background: rgba(148, 163, 184, 0.3);
}

.plan-card .eyebrow {
  color: #64748b;
}

.plan-card h3 {
  font-size: clamp(1.5rem, 0.8vw + 1.16rem, 1.86rem);
  line-height: 1;
  letter-spacing: -0.05em;
  margin: 0;
}

.plan-card > p {
  min-height: 2.6rem;
  margin: 0;
}

.plan-card .button {
  margin-top: auto;
}

.plan-card-featured {
  border-color: rgba(37, 99, 235, 0.26);
  box-shadow:
    0 26px 44px rgba(37, 99, 235, 0.14),
    0 1px 0 rgba(255, 255, 255, 0.86) inset;
  transform: translateY(-4px);
}

.plan-card-featured::before {
  background: linear-gradient(90deg, #2563eb, #1d4ed8);
}

.feature-list {
  display: grid;
  gap: 0.5rem;
  padding: 0;
  margin: 0;
  list-style: none;
}

.feature-list li {
  position: relative;
  padding-left: 1.1rem;
  color: #334155;
  font-size: 0.78rem;
  line-height: 1.45;
}

.feature-list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.48rem;
  width: 0.38rem;
  height: 0.38rem;
  border-radius: 999px;
  background: #1d4ed8;
}

.section-surface .section-heading {
  margin-bottom: 0.8rem;
}

.section-surface .table-shell {
  padding: 0.45rem;
  border-radius: 1.2rem;
  background: rgba(255, 255, 255, 0.96);
  border: 1px solid rgba(214, 223, 231, 0.92);
  box-shadow: 0 10px 22px rgba(31, 80, 104, 0.04);
}

.section-surface .data-table {
  min-width: 0;
}

.section-surface .data-table th {
  background: #f8fafc;
  color: #64748b;
  font-size: 0.68rem;
  letter-spacing: 0.06em;
}

.section-surface .data-table td {
  font-size: 0.84rem;
}

.section-surface .data-table tbody tr:hover td {
  background: #f8fbff;
}

.faq-item {
  padding: 1rem 1.05rem;
  border-radius: 1.15rem;
  background: rgba(255, 255, 255, 0.96);
  border: 1px solid rgba(214, 223, 231, 0.9);
  box-shadow:
    0 12px 22px rgba(31, 80, 104, 0.05),
    0 1px 0 rgba(255, 255, 255, 0.86) inset;
}

.faq-item h3 {
  margin: 0 0 0.35rem;
  font-size: 0.88rem;
  line-height: 1.35;
}

.faq-item p {
  margin: 0;
  color: #667085;
  font-size: 0.76rem;
  line-height: 1.5;
}

.chip,
.badge,
.eyebrow {
  font-size: 0.64rem;
}

.button {
  font-size: 0.8rem;
  border-radius: 0.9rem;
  transform: translateY(0);
  transition: transform 0.16s ease, box-shadow 0.16s ease, background-color 0.16s ease, border-color 0.16s ease;
}

.card p,
.auth-card p,
.auth-aside p,
.sidebar-card p,
.muted {
  color: #667085;
  font-size: 0.78rem;
  line-height: 1.5;
}

.button-primary {
  background: #0f172a;
  border-color: #0f172a;
  box-shadow: 0 10px 18px rgba(15, 23, 42, 0.16);
}

.button-primary:hover {
  background: #111827;
  border-color: #111827;
  transform: translateY(-1px);
  box-shadow: 0 14px 22px rgba(15, 23, 42, 0.18);
}

.button-secondary {
  background: #ffffff;
  border-color: rgba(203, 213, 225, 0.95);
  color: #0f172a;
  box-shadow: 0 8px 14px rgba(31, 80, 104, 0.06);
}

.button-secondary:hover {
  transform: translateY(-1px);
  box-shadow: 0 12px 18px rgba(31, 80, 104, 0.08);
}

.home-status-card:hover,
.analysis-start-mini-card:hover,
.analysis-mode-card:hover,
.faq-item:hover {
  transform: translateY(-2px);
  box-shadow:
    0 18px 28px rgba(31, 80, 104, 0.08),
    0 1px 0 rgba(255, 255, 255, 0.86) inset;
}

.plan-card:hover {
  transform: translateY(-3px);
  box-shadow:
    0 26px 40px rgba(31, 80, 104, 0.1),
    0 1px 0 rgba(255, 255, 255, 0.86) inset;
}

.product-actions-sticky {
  display: grid;
  gap: 0.55rem;
}

.product-actions-sticky .button {
  min-height: 44px;
}

@media (max-width: 1199px) {
  .app-shell {
    grid-template-columns: 1fr;
  }

  .hero-section-release,
  .home-status-grid,
  .pricing-hero,
  .analysis-start-hero-grid,
  .analysis-start-quick-grid,
  .analysis-start-metric-strip {
    grid-template-columns: 1fr;
  }

  .app-main {
    padding-inline: 1rem;
  }
}

@media (max-width: 767px) {
  .page-content,
  .app-header,
  .auth-page,
  .analysis-start-card {
    max-width: none;
  }

  .app-main {
    padding: 0.9rem 0.8rem 2rem;
  }

  .app-header {
    margin-bottom: 0.2rem;
    padding-bottom: 0.55rem;
    align-items: start;
  }

  .app-header .header-actions {
    width: 100%;
    justify-content: flex-start;
    flex-wrap: wrap;
    gap: 0.45rem;
  }

  .hero-section-release .hero-copy,
  .service-panel-release,
  .analysis-start-card,
  .auth-card,
  .auth-aside {
    padding: 0.9rem;
  }

  .hero-section-release .hero-copy h1 {
    max-width: none;
    font-size: clamp(1.58rem, 4vw, 1.95rem);
  }

  .home-status-grid,
  .analysis-start-quick-grid,
  .analysis-start-metric-strip,
  .pricing-hero,
  .auth-page {
    gap: 0.7rem;
  }

  .marketing-analysis-form,
  .analysis-form.analysis-form-hero {
    grid-template-columns: 1fr;
    gap: 0.55rem;
  }

  .marketing-analysis-form .button,
  .analysis-form.analysis-form-hero .button {
    width: 100%;
  }

  .plan-card,
  .home-status-card,
  .pricing-note,
  .faq-item {
    padding: 0.9rem;
  }

  .section + .section {
    margin-top: 0.8rem;
  }
}

@media (max-width: 479px) {
  .app-main {
    padding: 0.8rem 0.7rem 1.8rem;
  }

  .hero-section-release .hero-copy,
  .service-panel-release,
  .analysis-start-card,
  .auth-card,
  .auth-aside,
  .plan-card,
  .pricing-note,
  .faq-item,
  .home-status-card {
    border-radius: 1rem;
  }

  .button {
    min-height: 42px;
  }
}

/* Premium dimensional redesign */
:root {
  --premium-bg-top: #f7f3ee;
  --premium-bg-bottom: #eef3f7;
  --premium-surface: rgba(255, 255, 255, 0.94);
  --premium-surface-soft: rgba(248, 251, 253, 0.9);
  --premium-border: rgba(210, 220, 228, 0.95);
  --premium-border-strong: rgba(188, 204, 216, 0.95);
  --premium-shadow-sm: 0 10px 22px rgba(31, 80, 104, 0.055);
  --premium-shadow-md: 0 18px 34px rgba(31, 80, 104, 0.075);
  --premium-shadow-lg: 0 28px 46px rgba(31, 80, 104, 0.1);
  --premium-inset: 0 1px 0 rgba(255, 255, 255, 0.88) inset, 0 12px 18px rgba(255, 255, 255, 0.18) inset;
  --premium-title: #182532;
  --premium-text: #2e4355;
  --premium-muted: #66788a;
  --premium-accent: #2f6a89;
  --premium-accent-strong: #1f5068;
}

body {
  background:
    radial-gradient(circle at 8% -10%, rgba(72, 169, 166, 0.12) 0%, rgba(72, 169, 166, 0) 26%),
    radial-gradient(circle at 96% 0%, rgba(39, 110, 108, 0.08) 0%, rgba(39, 110, 108, 0) 24%),
    linear-gradient(180deg, var(--premium-bg-top) 0%, var(--premium-bg-bottom) 100%);
  color: var(--premium-title);
}

.app-shell {
  background: transparent;
}

.sidebar {
  background: rgba(255, 255, 255, 0.72);
  border-right: 1px solid var(--premium-border);
  box-shadow: 10px 0 30px rgba(31, 80, 104, 0.06);
  backdrop-filter: blur(18px);
}

.brand-sidebar,
.sidebar-card,
.hero-section-release .hero-copy,
.service-panel-release,
.home-status-card,
.analysis-start-card,
.auth-card,
.auth-aside,
.product-hero-refined,
.action-panel,
.analysis-status-card,
.analysis-secondary-block,
.analysis-page-result-block,
.analysis-comparison-block,
.extension-status-panel,
.plan-card,
.pricing-note,
.faq-item,
.table-shell,
.table-shell-dense {
  background: linear-gradient(170deg, rgba(255, 255, 255, 0.97) 0%, rgba(248, 251, 253, 0.95) 100%);
  border: 1px solid var(--premium-border);
  box-shadow: var(--premium-shadow-md), var(--premium-inset);
}

.brand-sidebar {
  border-radius: 1.2rem;
  padding: 0.6rem 0.7rem 0.75rem;
  margin-bottom: 0.1rem;
}

.sidebar .nav-link {
  border: 1px solid transparent;
  transition: transform 0.18s ease, box-shadow 0.18s ease, background 0.18s ease, border-color 0.18s ease;
}

.sidebar .nav-link:hover {
  transform: translateY(-1px);
  background: rgba(255, 255, 255, 0.9);
  border-color: var(--premium-border);
  box-shadow: var(--premium-shadow-sm);
}

.sidebar .nav-link.is-active {
  background: linear-gradient(145deg, rgba(255, 255, 255, 0.96), rgba(235, 244, 249, 0.98));
  border-color: rgba(165, 189, 204, 0.95);
  color: var(--premium-accent-strong);
  box-shadow: 0 12px 24px rgba(31, 80, 104, 0.08), 0 1px 0 rgba(255, 255, 255, 0.92) inset;
}

.app-header {
  margin-bottom: 0.45rem;
}

.app-header h1,
.hero-section-release .hero-copy h1,
.analysis-start-copy h2,
.pricing-hero .hero-copy h1,
.product-copy h2 {
  color: var(--premium-title);
}

.app-header .muted,
.card p,
.auth-card p,
.auth-aside p,
.sidebar-card p,
.muted,
.analysis-field-note,
.analysis-page-result-note,
.analysis-candidate-url {
  color: var(--premium-muted);
}

.hero-section-release {
  gap: 1.05rem;
}

.hero-section-release .hero-copy {
  position: relative;
  overflow: hidden;
}

.hero-section-release .hero-copy::before,
.analysis-start-card::before,
.pricing-hero .hero-copy::before,
.product-hero-refined::before {
  content: "";
  position: absolute;
  inset: 0 0 auto 0;
  height: 44%;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.62) 0%, rgba(255, 255, 255, 0) 100%);
  pointer-events: none;
}

.hero-section-release .hero-copy::after,
.analysis-start-card::after,
.pricing-hero .hero-copy::after,
.product-hero-refined::after {
  content: "";
  position: absolute;
  left: 18px;
  right: 18px;
  bottom: -12px;
  height: 18px;
  background: radial-gradient(circle, rgba(31, 80, 104, 0.16) 0%, rgba(31, 80, 104, 0) 72%);
  filter: blur(10px);
  pointer-events: none;
}

.marketing-analysis-form,
.analysis-form.analysis-form-hero {
  background: rgba(246, 250, 252, 0.98);
  border: 1px solid var(--premium-border);
  box-shadow: 0 8px 18px rgba(31, 80, 104, 0.05) inset;
}

.analysis-form input,
.analysis-form textarea,
.compare-save-form input,
input,
select,
textarea {
  border-color: rgba(203, 215, 224, 0.95);
  background: rgba(255, 255, 255, 0.96);
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.95) inset;
}

.analysis-form input:focus,
textarea:focus,
select:focus,
input:focus {
  border-color: rgba(47, 106, 137, 0.62);
  box-shadow: 0 0 0 4px rgba(47, 106, 137, 0.12), 0 1px 0 rgba(255, 255, 255, 0.95) inset;
}

.home-status-grid,
.analysis-start-quick-grid,
.analysis-mode-grid,
.analysis-start-metric-strip {
  gap: 0.8rem;
}

.home-status-card,
.analysis-start-mini-card,
.analysis-mode-card,
.analysis-start-metric-pill,
.info-pair,
.mini-row-card {
  background: linear-gradient(170deg, rgba(255, 255, 255, 0.96) 0%, rgba(247, 250, 252, 0.95) 100%);
  border: 1px solid var(--premium-border);
  box-shadow: var(--premium-shadow-sm), 0 1px 0 rgba(255, 255, 255, 0.88) inset;
}

.analysis-start-mini-card:hover,
.analysis-mode-card:hover,
.home-status-card:hover,
.mini-row-card:hover,
.faq-item:hover {
  transform: translateY(-2px);
  box-shadow: var(--premium-shadow-md), 0 1px 0 rgba(255, 255, 255, 0.88) inset;
}

.product-hero-refined {
  position: relative;
  gap: 1rem;
  border-radius: 1.45rem;
}

.product-thumb {
  box-shadow: 0 16px 28px rgba(31, 80, 104, 0.14);
}

.product-actions-sticky {
  background: linear-gradient(170deg, rgba(255, 255, 255, 0.98) 0%, rgba(246, 250, 252, 0.97) 100%);
  border: 1px solid var(--premium-border);
  box-shadow: var(--premium-shadow-md), var(--premium-inset);
}

.action-panel,
.analysis-status-card,
.analysis-secondary-block,
.analysis-page-result-block,
.analysis-comparison-block,
.extension-status-panel {
  border-radius: 1.25rem;
}

.action-panel > .eyebrow,
.extension-status-panel .eyebrow,
.analysis-status-card .eyebrow {
  color: var(--premium-accent);
  letter-spacing: 0.08em;
}

.action-panel h3,
.extension-status-head h3,
.analysis-status-card h3,
.section-heading h2 {
  color: var(--premium-title);
  letter-spacing: -0.02em;
}

.meter,
.info-pair,
.mini-row-card,
.extension-guide-card,
.diagnostic-field,
.analysis-field-cell-core {
  border-radius: 1rem;
  border: 1px solid var(--premium-border);
}

.analysis-field-cell-core {
  background: linear-gradient(180deg, rgba(235, 244, 249, 0.98) 0%, rgba(255, 255, 255, 0.98) 100%);
  border-color: rgba(174, 201, 216, 0.92);
}

.extension-status-panel-compact .extension-guide-card,
.extension-status-panel .extension-guide-card {
  background: linear-gradient(170deg, rgba(247, 250, 252, 0.98) 0%, rgba(255, 255, 255, 0.98) 100%);
  box-shadow: var(--premium-shadow-sm), 0 1px 0 rgba(255, 255, 255, 0.88) inset;
}

.extension-status-head {
  align-items: start;
  gap: 0.75rem;
}

.chip {
  background: rgba(255, 255, 255, 0.92);
  border: 1px solid rgba(210, 220, 228, 0.92);
  color: var(--premium-text);
  box-shadow: 0 4px 10px rgba(31, 80, 104, 0.04);
}

.chip-highlight {
  background: linear-gradient(145deg, rgba(237, 244, 249, 1) 0%, rgba(255, 255, 255, 0.96) 100%);
  border-color: rgba(171, 191, 204, 0.95);
  color: var(--premium-accent-strong);
}

.badge,
.analysis-status-badge {
  box-shadow: 0 6px 12px rgba(31, 80, 104, 0.08);
}

.button {
  position: relative;
  overflow: hidden;
}

.button::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.16) 0%, rgba(255, 255, 255, 0) 50%);
  pointer-events: none;
}

.button-primary {
  background: linear-gradient(145deg, var(--premium-accent) 0%, var(--premium-accent-strong) 100%);
  border-color: rgba(31, 80, 104, 0.98);
  box-shadow: 0 14px 24px rgba(31, 80, 104, 0.18);
}

.button-primary:hover {
  background: linear-gradient(145deg, #377595 0%, #234f66 100%);
  border-color: rgba(31, 80, 104, 1);
  box-shadow: 0 18px 28px rgba(31, 80, 104, 0.22);
}

.button-secondary,
.button-ghost {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(244, 248, 251, 0.98) 100%);
  border-color: var(--premium-border-strong);
  box-shadow: 0 10px 18px rgba(31, 80, 104, 0.08);
}

.button-secondary:hover,
.button-ghost:hover {
  background: linear-gradient(180deg, rgba(255, 255, 255, 1) 0%, rgba(239, 245, 249, 0.98) 100%);
}

.pricing-note {
  background: linear-gradient(160deg, #1f4156 0%, #163549 100%);
  border-color: rgba(45, 92, 119, 0.72);
}

.plan-card {
  min-height: 100%;
}

.plan-card-featured {
  border-color: rgba(47, 106, 137, 0.42);
  box-shadow: 0 30px 48px rgba(31, 80, 104, 0.13), 0 1px 0 rgba(255, 255, 255, 0.88) inset;
}

.plan-card::before {
  background: linear-gradient(90deg, rgba(148, 163, 184, 0.45), rgba(148, 163, 184, 0.18));
}

.plan-card-featured::before {
  background: linear-gradient(90deg, var(--premium-accent), #3f82a7);
}

.table-shell,
.analysis-comparison-table .table-shell,
.analysis-page-result-table .table-shell {
  padding: 0.4rem;
  border-radius: 1.2rem;
  overflow: auto;
  background: linear-gradient(170deg, rgba(255, 255, 255, 0.97) 0%, rgba(248, 251, 253, 0.95) 100%);
  border: 1px solid var(--premium-border);
  box-shadow: var(--premium-shadow-md), var(--premium-inset);
}

.data-table,
.analysis-comparison-table .data-table,
.analysis-page-result-table .data-table {
  background: transparent;
  min-width: 920px;
}

.data-table th,
.data-table td {
  border-bottom: 1px solid rgba(223, 231, 237, 0.9);
}

.data-table th,
.data-table-dense th,
.analysis-comparison-table .data-table th,
.analysis-page-result-table .data-table th {
  background: linear-gradient(180deg, rgba(244, 248, 251, 0.98) 0%, rgba(237, 243, 247, 0.98) 100%);
  color: #5b6f81;
  font-weight: 700;
}

.data-table tbody tr:hover td,
.data-table-dense tbody tr:hover td,
.analysis-comparison-table .data-table tbody tr:hover td,
.analysis-page-result-table .data-table tbody tr:hover td {
  background: rgba(242, 247, 250, 0.88);
}

.analysis-comparison-table .data-table td,
.analysis-page-result-table .data-table td {
  background: rgba(255, 255, 255, 0.75);
}

.analysis-comparison-table .data-table td:first-child,
.analysis-page-result-table .data-table td:first-child,
.analysis-comparison-table .data-table th:first-child,
.analysis-page-result-table .data-table th:first-child {
  background: linear-gradient(180deg, rgba(248, 251, 253, 0.98) 0%, rgba(242, 247, 250, 0.98) 100%);
}

.analysis-product-thumb,
.analysis-candidate-thumb {
  box-shadow: 0 12px 18px rgba(31, 80, 104, 0.12);
}

.analysis-status-badge-success {
  background: rgba(72, 169, 166, 0.16);
  color: #165d5a;
}

.analysis-status-badge-progress {
  background: rgba(47, 106, 137, 0.14);
  color: #1f5068;
}

.analysis-status-badge-warning {
  background: rgba(242, 200, 122, 0.22);
  color: #8b5b0e;
}

.analysis-status-badge-neutral {
  background: rgba(182, 195, 204, 0.22);
  color: #516473;
}

.notice {
  border-radius: 1rem;
  box-shadow: 0 8px 18px rgba(31, 80, 104, 0.06);
}

@media (max-width: 1199px) {
  .product-hero-refined {
    grid-template-columns: 84px minmax(0, 1fr);
  }

  .product-actions-sticky {
    grid-column: 1 / -1;
    position: static;
  }
}

@media (max-width: 767px) {
  .app-shell {
    background: linear-gradient(180deg, #f6f3ee 0%, #eff3f6 100%);
  }

  .sidebar {
    backdrop-filter: blur(14px);
  }

  .product-hero-refined {
    grid-template-columns: 1fr;
  }

  .table-shell,
  .analysis-comparison-table .table-shell,
  .analysis-page-result-table .table-shell {
    padding: 0.28rem;
    border-radius: 1rem;
  }

  .data-table,
  .analysis-comparison-table .data-table,
  .analysis-page-result-table .data-table {
    min-width: 720px;
  }
}

/* Redesign.boy reference hybrid redesign */

:root {
  --editorial-bg: #f6f2eb;
  --editorial-bg-soft: #edf2f6;
  --editorial-surface: rgba(255, 255, 255, 0.92);
  --editorial-surface-strong: rgba(255, 255, 255, 0.98);
  --editorial-border: rgba(198, 209, 218, 0.92);
  --editorial-border-strong: rgba(160, 181, 196, 0.96);
  --editorial-title: #111e29;
  --editorial-text: #304352;
  --editorial-muted: #667889;
  --editorial-accent: #274f68;
  --editorial-accent-soft: #dbe7ef;
  --editorial-shadow-xs: 0 10px 20px rgba(17, 30, 41, 0.05);
  --editorial-shadow-sm: 0 18px 34px rgba(17, 30, 41, 0.08);
  --editorial-shadow-lg: 0 34px 72px rgba(17, 30, 41, 0.12);
  --editorial-inset: 0 1px 0 rgba(255, 255, 255, 0.95) inset, 0 18px 30px rgba(255, 255, 255, 0.16) inset;
}

body,
.app-shell,
.marketing-shell {
  background:
    radial-gradient(circle at top left, rgba(255, 255, 255, 0.72) 0%, rgba(255, 255, 255, 0) 32%),
    linear-gradient(180deg, var(--editorial-bg) 0%, var(--editorial-bg-soft) 100%);
  color: var(--editorial-title);
}

.app-main,
.marketing-main,
.page-content {
  width: 100%;
}

.page-content {
  max-width: 1420px;
  margin: 0 auto;
  padding: 0 clamp(1rem, 2vw, 2rem) 4.5rem;
  display: block;
}

.section {
  width: 100%;
  margin-bottom: 1.05rem;
}

.app-header {
  margin-bottom: 0.8rem;
  padding: 0 clamp(1rem, 2vw, 2rem);
}

.app-header h1 {
  font-size: clamp(1.7rem, 3vw, 2.6rem);
  letter-spacing: -0.045em;
  line-height: 0.96;
  margin-bottom: 0.3rem;
}

.app-header .muted,
.muted,
.analysis-field-note,
.analysis-candidate-url {
  color: var(--editorial-muted);
}

.hero-section-editorial,
.pricing-hero-editorial {
  display: grid;
  grid-template-columns: minmax(0, 1.04fr) minmax(340px, 0.96fr);
  gap: clamp(1rem, 2vw, 1.6rem);
  align-items: stretch;
}

.hero-copy-editorial,
.analysis-start-card-editorial,
.pricing-note,
.extension-status-panel,
.product-hero-refined,
.action-panel,
.analysis-status-card,
.analysis-secondary-block,
.analysis-page-result-block,
.analysis-comparison-block,
.plan-card,
.faq-item,
.table-shell,
.table-shell-dense {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(247, 250, 252, 0.94) 100%);
  border: 1px solid var(--editorial-border);
  box-shadow: var(--editorial-shadow-sm), var(--editorial-inset);
}

.hero-copy-editorial,
.analysis-start-card-editorial,
.pricing-note,
.product-hero-refined {
  position: relative;
  overflow: hidden;
}

.hero-copy-editorial::before,
.analysis-start-card-editorial::before,
.pricing-note::before,
.product-hero-refined::before {
  content: "";
  position: absolute;
  inset: 0 0 auto 0;
  height: 46%;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.64) 0%, rgba(255, 255, 255, 0) 100%);
  pointer-events: none;
}

.hero-copy-editorial {
  padding: clamp(1.4rem, 2vw, 2rem);
  border-radius: 1.75rem;
  min-height: 100%;
}

.hero-copy-editorial h1,
.pricing-hero .hero-copy h1 {
  color: var(--editorial-title);
  font-size: clamp(2rem, 4vw, 3.6rem);
  line-height: 0.96;
  letter-spacing: -0.055em;
  max-width: 11ch;
  margin-bottom: 0.72rem;
}

.analysis-start-copy h2 {
  color: var(--editorial-title);
  font-size: clamp(1.8rem, 3.2vw, 3rem);
  line-height: 0.98;
  letter-spacing: -0.05em;
  max-width: 13ch;
  margin-bottom: 0.62rem;
}

.hero-copy-editorial p,
.analysis-start-copy p,
.pricing-hero .hero-copy p {
  color: var(--editorial-text);
  font-size: 0.92rem;
  line-height: 1.58;
  max-width: 40rem;
  margin-bottom: 0.88rem;
}

.marketing-analysis-form,
.analysis-form.analysis-form-hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 0.8rem;
  padding: 0.72rem;
  border-radius: 1.35rem;
  background: rgba(246, 249, 251, 0.94);
  border: 1px solid var(--editorial-border);
  box-shadow: 0 10px 22px rgba(17, 30, 41, 0.05) inset;
}

.analysis-form input,
textarea,
select,
input {
  min-height: 3.25rem;
  border-radius: 0.95rem;
  border-color: rgba(201, 212, 221, 0.96);
  background: rgba(255, 255, 255, 0.96);
}

.button {
  border-radius: 999px;
  font-weight: 700;
  letter-spacing: -0.02em;
  transition: transform 0.18s ease, box-shadow 0.18s ease, background 0.18s ease, border-color 0.18s ease;
}

.button:hover {
  transform: translateY(-1px);
}

.button-primary {
  background: linear-gradient(145deg, #315f79 0%, #17394d 100%);
  border-color: rgba(23, 57, 77, 0.98);
  box-shadow: 0 18px 30px rgba(23, 57, 77, 0.24);
}

.button-primary:hover {
  background: linear-gradient(145deg, #3b6f8c 0%, #183648 100%);
  box-shadow: 0 22px 34px rgba(23, 57, 77, 0.28);
}

.button-secondary,
.button-ghost {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(243, 247, 250, 0.98) 100%);
  border-color: var(--editorial-border-strong);
  box-shadow: var(--editorial-shadow-xs);
}

.analysis-start-quick-grid-editorial {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.55rem;
  margin-top: 0.9rem;
}

.analysis-start-mini-card,
.analysis-mode-card {
  padding: 0.72rem 0.78rem;
  border-radius: 1rem;
  background: rgba(255, 255, 255, 0.66);
  border: 1px solid rgba(207, 217, 225, 0.78);
  box-shadow: none;
}

.analysis-start-mini-card strong,
.analysis-start-metric-pill strong {
  display: block;
  font-size: 0.88rem;
  color: var(--editorial-title);
  margin-bottom: 0.16rem;
}

.analysis-start-mini-card p,
.analysis-start-metric-pill span {
  margin: 0;
  color: var(--editorial-muted);
  font-size: 0.78rem;
}

.analysis-start-card-editorial {
  padding: clamp(0.9rem, 1.4vw, 1.15rem);
  border-radius: 1.45rem;
}

.analysis-start-hero-grid {
  display: grid;
  grid-template-columns: minmax(0, 0.98fr) minmax(340px, 1.02fr);
  gap: 1rem;
  align-items: stretch;
}

.analysis-start-copy,
.analysis-search-shell,
.pricing-hero-aside {
  min-width: 0;
}

.analysis-search-shell {
  display: grid;
  gap: 0.7rem;
}

.home-meta-strip,
.analysis-start-meta-strip,
.pricing-meta-strip {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
  margin-top: 0.78rem;
}

.editorial-visual {
  min-width: 0;
}

.editorial-visual-stage {
  position: relative;
  min-height: 100%;
  padding: 0.85rem;
  border-radius: 1.35rem;
  overflow: hidden;
  background:
    radial-gradient(circle at 18% 22%, rgba(232, 240, 245, 0.95) 0%, rgba(232, 240, 245, 0) 28%),
    radial-gradient(circle at 84% 14%, rgba(205, 219, 229, 0.48) 0%, rgba(205, 219, 229, 0) 24%),
    linear-gradient(145deg, rgba(255, 255, 255, 0.92) 0%, rgba(236, 242, 246, 0.84) 100%);
  border: 1px solid var(--editorial-border);
  box-shadow: var(--editorial-shadow-lg), var(--editorial-inset);
}

.editorial-visual-glow {
  position: absolute;
  border-radius: 999px;
  filter: blur(24px);
  opacity: 0.6;
  pointer-events: none;
}

.editorial-visual-glow-a {
  width: 180px;
  height: 180px;
  top: -24px;
  right: -24px;
  background: rgba(106, 151, 180, 0.28);
}

.editorial-visual-glow-b {
  width: 140px;
  height: 140px;
  left: -36px;
  bottom: -30px;
  background: rgba(245, 224, 206, 0.42);
}

.editorial-visual-stack {
  position: relative;
  z-index: 2;
  display: grid;
  gap: 0.5rem;
}

.editorial-media-card {
  display: grid;
  grid-template-columns: 82px minmax(0, 1fr);
  gap: 0.7rem;
  align-items: center;
  padding: 0.56rem;
  border-radius: 1rem;
  background: rgba(255, 255, 255, 0.72);
  border: 1px solid rgba(206, 216, 224, 0.82);
  box-shadow: 0 12px 22px rgba(17, 30, 41, 0.06), 0 1px 0 rgba(255, 255, 255, 0.9) inset;
  backdrop-filter: blur(12px);
}

.editorial-media-card-2 {
  transform: translateX(28px);
}

.editorial-media-card-3 {
  transform: translateX(10px);
}

.editorial-media-thumb {
  width: 82px;
  height: 82px;
  border-radius: 1rem;
  overflow: hidden;
  background: linear-gradient(145deg, rgba(230, 238, 243, 0.9), rgba(214, 227, 236, 0.85));
  display: grid;
  place-items: center;
  box-shadow: 0 16px 28px rgba(17, 30, 41, 0.12);
}

.editorial-media-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.editorial-media-thumb.is-fallback span {
  font-size: 1rem;
  font-weight: 800;
  color: var(--editorial-accent);
  letter-spacing: -0.04em;
}

.editorial-media-copy span {
  display: block;
  font-size: 0.62rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--editorial-accent);
  margin-bottom: 0.1rem;
}

.editorial-media-copy strong {
  display: block;
  font-size: 0.84rem;
  line-height: 1.2;
  letter-spacing: -0.03em;
  color: var(--editorial-title);
  margin-bottom: 0.12rem;
}

.editorial-media-copy p {
  margin: 0;
  font-size: 0.72rem;
  line-height: 1.35;
  color: var(--editorial-muted);
}

.pricing-hero-editorial {
  align-items: start;
}

.pricing-hero-aside {
  display: grid;
  gap: 0.95rem;
}

.pricing-note {
  padding: 0.95rem 1rem;
  border-radius: 1.2rem;
  color: var(--editorial-title);
}

.pricing-note h3 {
  font-size: 1.22rem;
  letter-spacing: -0.04em;
  margin-bottom: 0.28rem;
}

.pricing-note p {
  color: var(--editorial-text);
  font-size: 0.84rem;
  line-height: 1.45;
}

.plan-card {
  border-radius: 1.65rem;
  padding: 1.25rem;
}

.plan-card::before {
  content: "";
  display: block;
  width: 100%;
  height: 4px;
  border-radius: 999px;
  margin-bottom: 1rem;
  background: linear-gradient(90deg, rgba(160, 181, 196, 0.4), rgba(160, 181, 196, 0.08));
}

.plan-card-featured {
  transform: translateY(-4px);
  border-color: rgba(73, 115, 141, 0.44);
  box-shadow: 0 32px 58px rgba(17, 30, 41, 0.14), var(--editorial-inset);
}

.plan-card-featured::before {
  background: linear-gradient(90deg, #315f79 0%, #7ca5bf 100%);
}

.feature-list li {
  color: var(--editorial-text);
}

.faq-item {
  border-radius: 1.35rem;
  padding: 1.1rem 1.15rem;
}

.extension-status-panel {
  border-radius: 1.25rem;
  padding: 0.92rem 0.96rem;
}

.extension-status-head {
  align-items: start;
  gap: 0.8rem;
}

.extension-guide-card {
  margin-top: 0.9rem;
  padding: 0.95rem 1rem;
  border-radius: 1.2rem;
  background: linear-gradient(180deg, rgba(247, 250, 252, 0.98) 0%, rgba(255, 255, 255, 0.98) 100%);
  border: 1px solid var(--editorial-border);
  box-shadow: var(--editorial-shadow-xs), 0 1px 0 rgba(255, 255, 255, 0.9) inset;
}

.extension-guide-summary {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 0.9rem;
}

.extension-guide-summary .button-row {
  flex-wrap: nowrap;
}

.extension-guide-details {
  margin-top: 0.8rem;
  border-top: 1px solid rgba(205, 215, 223, 0.7);
  padding-top: 0.8rem;
}

.extension-guide-details summary {
  cursor: pointer;
  color: var(--editorial-accent);
  font-weight: 700;
  list-style: none;
}

.extension-guide-details summary::-webkit-details-marker {
  display: none;
}

.extension-guide-details[open] summary {
  margin-bottom: 0.7rem;
}

.product-hero-refined {
  display: grid;
  grid-template-columns: 104px minmax(0, 1fr) 248px;
  gap: 1rem;
  border-radius: 1.75rem;
  padding: 1.25rem;
}

.product-copy h2 {
  font-size: clamp(1.55rem, 2.2vw, 2.3rem);
  line-height: 1;
  letter-spacing: -0.045em;
  margin-bottom: 0.55rem;
  max-width: 18ch;
}

.product-meta-line {
  font-size: 0.84rem;
  line-height: 1.55;
}

.product-thumb {
  width: 104px;
  height: 104px;
  border-radius: 1.15rem;
  overflow: hidden;
  background: linear-gradient(145deg, rgba(232, 240, 245, 0.88), rgba(214, 227, 236, 0.78));
  box-shadow: 0 20px 34px rgba(17, 30, 41, 0.14);
}

.product-actions-sticky {
  border-radius: 1.35rem;
}

.analysis-detail-layout {
  grid-template-columns: minmax(0, 1.2fr) minmax(320px, 0.8fr);
  gap: 1rem;
  align-items: start;
}

.analysis-detail-main,
.analysis-detail-side {
  gap: 0.9rem;
}

.action-panel,
.analysis-status-card,
.analysis-secondary-block,
.analysis-page-result-block,
.analysis-comparison-block {
  border-radius: 1.35rem;
  padding: 1rem 1.05rem;
}

.action-panel > .eyebrow,
.analysis-status-card .eyebrow,
.extension-status-panel .eyebrow,
.section-heading .eyebrow {
  color: var(--editorial-accent);
  font-size: 0.68rem;
  letter-spacing: 0.12em;
}

.action-panel h3,
.analysis-status-card h3,
.extension-status-head h3,
.section-heading h2 {
  color: var(--editorial-title);
  letter-spacing: -0.03em;
}

.section-surface {
  background: transparent;
}

.section-surface .section-heading {
  margin-bottom: 0.7rem;
}

.table-shell,
.analysis-comparison-table .table-shell,
.analysis-page-result-table .table-shell {
  padding: 0.42rem;
  border-radius: 1.45rem;
  overflow: auto;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.96) 0%, rgba(247, 250, 252, 0.94) 100%);
  border: 1px solid var(--editorial-border);
  box-shadow: var(--editorial-shadow-sm), var(--editorial-inset);
}

.data-table,
.analysis-comparison-table .data-table,
.analysis-page-result-table .data-table {
  min-width: 980px;
  background: transparent;
}

.data-table th,
.analysis-comparison-table .data-table th,
.analysis-page-result-table .data-table th {
  position: sticky;
  top: 0;
  z-index: 1;
  padding: 0.82rem 0.72rem;
  background: linear-gradient(180deg, rgba(245, 248, 250, 0.98) 0%, rgba(237, 243, 247, 0.98) 100%);
  color: #607383;
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.data-table td,
.analysis-comparison-table .data-table td,
.analysis-page-result-table .data-table td {
  padding: 0.82rem 0.68rem;
  border-bottom: 1px solid rgba(223, 231, 237, 0.88);
  background: rgba(255, 255, 255, 0.76);
  vertical-align: middle;
}

.analysis-comparison-table .data-table th:first-child,
.analysis-comparison-table .data-table td:first-child,
.analysis-page-result-table .data-table th:first-child,
.analysis-page-result-table .data-table td:first-child {
  position: sticky;
  left: 0;
  z-index: 2;
  background: linear-gradient(180deg, rgba(247, 250, 252, 0.99) 0%, rgba(241, 246, 249, 0.99) 100%);
}

.analysis-comparison-table .analysis-product-cell,
.analysis-page-result-table .analysis-product-cell {
  gap: 0.7rem;
  align-items: center;
}

.analysis-product-thumb,
.analysis-candidate-thumb {
  width: 68px;
  height: 68px;
  border-radius: 1rem;
  overflow: hidden;
  box-shadow: 0 14px 24px rgba(17, 30, 41, 0.13);
}

.analysis-comparison-table .analysis-product-title,
.analysis-page-result-table .analysis-product-title {
  font-size: 0.78rem;
  line-height: 1.42;
  letter-spacing: -0.02em;
  -webkit-line-clamp: 2;
}

.analysis-comparison-table .analysis-field-main,
.analysis-page-result-table .analysis-field-main {
  font-size: 0.78rem;
  line-height: 1.3;
}

.analysis-comparison-table .analysis-field-note,
.analysis-page-result-table .analysis-field-note,
.analysis-comparison-table .analysis-candidate-url,
.analysis-page-result-table .analysis-candidate-url,
.analysis-comparison-table .analysis-product-chip-row,
.analysis-page-result-table .analysis-product-chip-row {
  display: none;
}

.analysis-comparison-table .analysis-action-row .button,
.analysis-page-result-table .analysis-action-row .button {
  min-height: auto;
  padding: 0.42rem 0.78rem;
}

.analysis-status-badge-success {
  background: rgba(72, 169, 166, 0.16);
  color: #155e5c;
}

.analysis-status-badge-progress {
  background: rgba(52, 99, 133, 0.12);
  color: #214e67;
}

.analysis-status-badge-warning {
  background: rgba(244, 203, 129, 0.24);
  color: #8a5a0a;
}

.analysis-status-badge-neutral {
  background: rgba(191, 202, 211, 0.2);
  color: #556a79;
}

@media (max-width: 1199px) {
  .hero-section-editorial,
  .pricing-hero-editorial,
  .analysis-start-hero-grid,
  .analysis-detail-layout {
    grid-template-columns: 1fr;
  }

  .hero-copy-editorial h1,
  .pricing-hero .hero-copy h1 {
    max-width: 12ch;
  }

  .product-hero-refined {
    grid-template-columns: 96px minmax(0, 1fr);
  }

  .product-actions-sticky {
    grid-column: 1 / -1;
    position: static;
  }
}

@media (max-width: 767px) {
  .page-content {
    padding: 0 0.85rem 4rem;
  }

  .app-header {
    padding: 0 0.85rem;
  }

  .hero-section-editorial,
  .pricing-hero-editorial,
  .analysis-start-quick-grid-editorial,
  .home-meta-strip,
  .analysis-start-meta-strip,
  .pricing-meta-strip {
    grid-template-columns: 1fr;
  }

  .hero-copy-editorial,
  .analysis-start-card-editorial,
  .editorial-visual-stage,
  .pricing-note,
  .extension-status-panel,
  .product-hero-refined,
  .action-panel,
  .plan-card,
  .faq-item {
    border-radius: 1.35rem;
  }

  .hero-copy-editorial h1,
  .pricing-hero .hero-copy h1,
  .product-copy h2 {
    font-size: clamp(1.75rem, 9vw, 2.7rem);
    max-width: none;
  }

  .analysis-start-copy h2 {
    font-size: clamp(1.6rem, 8vw, 2.4rem);
    max-width: none;
  }

  .marketing-analysis-form,
  .analysis-form.analysis-form-hero {
    grid-template-columns: 1fr;
  }

  .editorial-media-card,
  .product-hero-refined {
    grid-template-columns: 1fr;
  }

  .editorial-media-card-2,
  .editorial-media-card-3 {
    transform: none;
  }

  .editorial-media-thumb,
  .product-thumb {
    width: 100%;
    height: 160px;
  }

  .extension-guide-summary {
    flex-direction: column;
  }

  .table-shell,
  .analysis-comparison-table .table-shell,
  .analysis-page-result-table .table-shell {
    padding: 0.32rem;
    border-radius: 1.1rem;
  }

  .data-table,
  .analysis-comparison-table .data-table,
  .analysis-page-result-table .data-table {
    min-width: 760px;
  }
}

/* Final button and chip cleanup */

.button-primary {
  background: linear-gradient(145deg, #18212b 0%, #0c1218 100%);
  border-color: rgba(10, 15, 21, 0.98);
  color: #f8fafc;
  box-shadow: 0 16px 28px rgba(10, 15, 21, 0.22);
}

.button-primary:hover {
  background: linear-gradient(145deg, #222d39 0%, #10171f 100%);
  border-color: rgba(10, 15, 21, 1);
  box-shadow: 0 20px 34px rgba(10, 15, 21, 0.28);
}

.button-secondary,
.button-ghost {
  background: rgba(255, 255, 255, 0.84);
  border-color: rgba(184, 195, 204, 0.92);
  color: #22303b;
  box-shadow: 0 10px 18px rgba(17, 30, 41, 0.06);
}

.button-secondary:hover,
.button-ghost:hover {
  background: rgba(255, 255, 255, 0.96);
  border-color: rgba(158, 173, 184, 0.96);
}

.chip {
  background: rgba(255, 255, 255, 0.76);
  border: 1px solid rgba(206, 216, 224, 0.9);
  color: #4c5d6b;
  box-shadow: none;
}

.chip-highlight {
  background: rgba(237, 242, 246, 0.94);
  border-color: rgba(180, 194, 204, 0.94);
  color: #273946;
}

.home-meta-strip,
.analysis-start-meta-strip,
.pricing-meta-strip {
  gap: 0.34rem;
}

.home-meta-strip .chip,
.analysis-start-meta-strip .chip,
.pricing-meta-strip .chip {
  padding: 0.4rem 0.68rem;
  background: rgba(255, 255, 255, 0.58);
  border-color: rgba(205, 214, 221, 0.84);
  color: #495a67;
  font-size: 0.74rem;
  font-weight: 700;
}

.analysis-start-mini-card,
.analysis-mode-card {
  background: rgba(255, 255, 255, 0.52);
  border-color: rgba(205, 215, 223, 0.76);
}

.pricing-note {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.86) 0%, rgba(248, 250, 252, 0.82) 100%);
  box-shadow: 0 12px 22px rgba(17, 30, 41, 0.07);
}

/* Final type scale reduction */

.app-header {
  margin-bottom: 0.55rem;
}

.app-header h1 {
  font-size: clamp(1.25rem, 2.2vw, 1.9rem);
  line-height: 1;
  letter-spacing: -0.04em;
  margin-bottom: 0.18rem;
}

.app-header .muted {
  font-size: 0.84rem;
}

.hero-copy-editorial {
  padding: 1rem 1.05rem;
}

.hero-copy-editorial h1,
.pricing-hero .hero-copy h1 {
  font-size: clamp(1.7rem, 3vw, 2.45rem);
  line-height: 1;
  letter-spacing: -0.05em;
  max-width: 12ch;
  margin-bottom: 0.45rem;
}

.analysis-start-copy h2 {
  font-size: clamp(1.55rem, 2.5vw, 2.2rem);
  line-height: 1.02;
  letter-spacing: -0.045em;
  max-width: 12ch;
  margin-bottom: 0.38rem;
}

.hero-copy-editorial p,
.analysis-start-copy p,
.pricing-hero .hero-copy p {
  font-size: 0.84rem;
  line-height: 1.45;
  margin-bottom: 0.6rem;
}

.marketing-analysis-form,
.analysis-form.analysis-form-hero {
  padding: 0.55rem;
  gap: 0.55rem;
  border-radius: 1.05rem;
}

.analysis-form input,
textarea,
select,
input {
  min-height: 2.7rem;
  font-size: 0.92rem;
  border-radius: 0.82rem;
}

.button {
  min-height: 2.7rem;
  padding: 0.72rem 1rem;
  font-size: 0.9rem;
}

.button.button-small {
  min-height: 2.2rem;
  padding: 0.5rem 0.82rem;
  font-size: 0.8rem;
}

.analysis-start-card-editorial {
  padding: 0.82rem 0.9rem;
}

.analysis-start-hero-grid {
  gap: 0.75rem;
}

.analysis-search-shell {
  gap: 0.55rem;
}

.editorial-visual-stage {
  padding: 0.68rem;
  border-radius: 1.1rem;
}

.editorial-media-card {
  grid-template-columns: 68px minmax(0, 1fr);
  gap: 0.55rem;
  padding: 0.42rem;
  border-radius: 0.9rem;
}

.editorial-media-thumb {
  width: 68px;
  height: 68px;
}

.editorial-media-copy strong {
  font-size: 0.76rem;
}

.editorial-media-copy p {
  font-size: 0.68rem;
}

.analysis-start-mini-card {
  padding: 0.58rem 0.62rem;
}

.analysis-start-mini-card strong {
  font-size: 0.8rem;
}

.analysis-start-mini-card p,
.home-meta-strip .chip,
.analysis-start-meta-strip .chip,
.pricing-meta-strip .chip {
  font-size: 0.7rem;
}

@media (max-width: 767px) {
  .app-header h1 {
    font-size: 1.15rem;
  }

  .hero-copy-editorial h1,
  .pricing-hero .hero-copy h1 {
    font-size: clamp(1.45rem, 8vw, 2.05rem);
  }

  .analysis-start-copy h2 {
    font-size: clamp(1.32rem, 7vw, 1.85rem);
  }

  .button {
    min-height: 2.45rem;
    font-size: 0.86rem;
  }
}

/* marketgen-ai reference refinement */

:root {
  --editorial-bg: #f7f2e9;
  --editorial-bg-soft: #edf3f7;
  --editorial-surface: rgba(255, 253, 249, 0.92);
  --editorial-surface-strong: rgba(255, 255, 255, 0.97);
  --editorial-border: rgba(218, 210, 198, 0.92);
  --editorial-border-strong: rgba(206, 196, 182, 0.96);
  --editorial-title: #1d2735;
  --editorial-text: #28364a;
  --editorial-muted: #455569;
  --editorial-accent: #48a9a6;
  --editorial-accent-strong: #2f8481;
  --editorial-accent-soft: #dff3f2;
  --editorial-shadow-xs: 0 6px 18px rgba(16, 26, 43, 0.06);
  --editorial-shadow-sm: 0 12px 30px rgba(16, 26, 43, 0.08);
  --editorial-shadow-lg: 0 20px 44px rgba(16, 26, 43, 0.1);
  --editorial-inset: 0 1px 0 rgba(255, 255, 255, 0.9) inset;
}

body,
.app-shell,
.marketing-shell {
  background:
    radial-gradient(75vw 60vh at -8% -18%, #f4ecdf 0%, transparent 63%),
    radial-gradient(70vw 55vh at 112% -12%, #dce9f0 0%, transparent 66%),
    linear-gradient(135deg, #f7f2e9 0%, #edf3f7 48%, #f8f1e7 100%);
  color: var(--editorial-title);
}

.app-shell::before,
.marketing-shell::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  background: repeating-linear-gradient(
    140deg,
    rgba(255, 255, 255, 0.12) 0 1px,
    transparent 1px 22px
  );
  opacity: 0.38;
}

.app-shell,
.marketing-shell {
  position: relative;
  isolation: isolate;
}

.app-sidebar,
.sidebar-panel,
.workspace-plan-card,
.marketing-sidebar {
  background: linear-gradient(180deg, rgba(255, 253, 249, 0.88) 0%, rgba(255, 255, 255, 0.7) 100%);
  border-color: rgba(218, 210, 198, 0.8);
  box-shadow: var(--editorial-shadow-xs), var(--editorial-inset);
}

.app-header {
  margin-bottom: 0.48rem;
  padding: 0 clamp(0.82rem, 1.4vw, 1.2rem);
}

.app-header > div:first-child,
.app-header .header-actions {
  background: linear-gradient(180deg, rgba(255, 253, 249, 0.74) 0%, rgba(255, 255, 255, 0.56) 100%);
  border: 1px solid rgba(218, 210, 198, 0.68);
  box-shadow: var(--editorial-shadow-xs), var(--editorial-inset);
  backdrop-filter: blur(12px);
}

.app-header > div:first-child {
  padding: 0.62rem 0.86rem;
  border-radius: 1.05rem;
}

.app-header .header-actions {
  padding: 0.22rem;
  border-radius: 999px;
}

.app-header h1 {
  font-size: clamp(1.04rem, 1.45vw, 1.5rem);
  line-height: 1.04;
  letter-spacing: -0.05em;
  margin-bottom: 0.06rem;
}

.app-header .muted {
  font-size: 0.66rem;
  color: var(--editorial-muted);
}

.app-header .header-actions .button {
  min-height: 2rem;
  padding: 0.42rem 0.8rem;
  font-size: 0.76rem;
}

.app-header .header-actions .button-primary,
.app-header .header-actions .button-secondary,
.app-header .header-actions .button-ghost {
  box-shadow: none;
}

.app-header .header-actions .button-primary {
  padding-inline: 0.9rem;
}

.page-content {
  max-width: 1360px;
  padding: 0 clamp(1rem, 1.8vw, 1.8rem) 4rem;
}

.hero-copy-editorial,
.analysis-start-card-editorial,
.pricing-note,
.extension-status-panel,
.product-hero-refined,
.action-panel,
.analysis-status-card,
.analysis-secondary-block,
.analysis-page-result-block,
.analysis-comparison-block,
.plan-card,
.faq-item,
.table-shell,
.table-shell-dense,
.auth-card,
.auth-aside,
.analysis-card {
  background: linear-gradient(165deg, var(--editorial-surface-strong) 0%, var(--editorial-surface) 100%);
  border: 1px solid var(--editorial-border);
  box-shadow: var(--editorial-shadow-sm), var(--editorial-inset);
}

.hero-copy-editorial,
.analysis-start-card-editorial,
.pricing-note,
.product-hero-refined,
.extension-status-panel,
.plan-card {
  border-radius: 1.35rem;
}

.hero-copy-editorial::before,
.analysis-start-card-editorial::before,
.pricing-note::before,
.product-hero-refined::before {
  height: 3px;
  inset: 0 0 auto 0;
  background: linear-gradient(90deg, rgba(72, 169, 166, 0.85) 0%, rgba(154, 116, 64, 0.55) 50%, rgba(72, 169, 166, 0.85) 100%);
}

.hero-section-editorial,
.pricing-hero-editorial {
  gap: 0.95rem;
}

.hero-copy-editorial {
  padding: 1rem 1.05rem 0.92rem;
}

.hero-copy-editorial h1,
.pricing-hero .hero-copy h1 {
  font-size: clamp(1.52rem, 2.35vw, 2.32rem);
  line-height: 0.98;
  letter-spacing: -0.055em;
  margin-bottom: 0.36rem;
  max-width: 10ch;
}

.analysis-start-copy h2 {
  font-size: clamp(1.42rem, 2.1vw, 2.04rem);
  line-height: 1;
  letter-spacing: -0.052em;
  margin-bottom: 0.32rem;
  max-width: 11ch;
}

.hero-copy-editorial p,
.analysis-start-copy p,
.pricing-hero .hero-copy p,
.pricing-note p,
.extension-status-panel p,
.auth-card p,
.auth-aside p {
  font-size: 0.8rem;
  line-height: 1.52;
  color: var(--editorial-text);
}

.marketing-analysis-form,
.analysis-form.analysis-form-hero {
  padding: 0.42rem;
  gap: 0.42rem;
  border-radius: 1.15rem;
  background: rgba(255, 251, 246, 0.8);
  border: 1px solid rgba(218, 210, 198, 0.92);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.92), inset 0 8px 18px rgba(244, 239, 231, 0.7);
}

.analysis-form input,
textarea,
select,
input {
  min-height: 2.52rem;
  font-size: 0.88rem;
  border-radius: 0.9rem;
  border-color: rgba(218, 210, 198, 0.94);
  background: rgba(255, 255, 255, 0.96);
  color: var(--editorial-title);
  box-shadow: none;
}

.button {
  min-height: 2.5rem;
  padding: 0.62rem 0.96rem;
  border-radius: 999px;
  font-size: 0.84rem;
  font-weight: 800;
  letter-spacing: -0.025em;
}

.button:hover {
  transform: translateY(-1px);
}

.button-primary {
  background: linear-gradient(180deg, #48a9a6 0%, #2f8481 100%);
  border-color: #2f8481;
  color: #fffdf9;
  box-shadow: 0 10px 24px rgba(72, 169, 166, 0.26);
}

.button-primary:hover {
  background: linear-gradient(180deg, #54b8b5 0%, #337f7c 100%);
  border-color: #337f7c;
  box-shadow: 0 14px 28px rgba(72, 169, 166, 0.3);
}

.button-secondary,
.button-ghost {
  background: linear-gradient(180deg, rgba(255, 253, 249, 0.96) 0%, rgba(247, 243, 236, 0.96) 100%);
  border-color: rgba(218, 210, 198, 0.94);
  color: var(--editorial-title);
  box-shadow: var(--editorial-shadow-xs);
}

.button-secondary:hover,
.button-ghost:hover {
  background: rgba(255, 255, 255, 0.98);
  border-color: rgba(206, 196, 182, 0.98);
}

.chip,
.badge,
.analysis-status-badge,
.status-badge {
  background: #f7f3ec;
  border: 1px solid rgba(218, 210, 198, 0.92);
  color: var(--editorial-muted);
  box-shadow: none;
}

.chip-highlight,
.badge-success,
.analysis-status-badge-success {
  background: rgba(72, 169, 166, 0.14);
  border-color: rgba(72, 169, 166, 0.28);
  color: #216866;
}

.home-meta-strip,
.analysis-start-meta-strip,
.pricing-meta-strip,
.chip-row {
  gap: 0.35rem;
}

.home-meta-strip .chip,
.analysis-start-meta-strip .chip,
.pricing-meta-strip .chip {
  padding: 0.34rem 0.6rem;
  font-size: 0.68rem;
  font-weight: 700;
  background: #f7f3ec;
  border-color: rgba(218, 210, 198, 0.9);
  color: var(--editorial-text);
}

.analysis-start-card-editorial {
  padding: 0.8rem 0.86rem;
}

.analysis-start-hero-grid {
  gap: 0.7rem;
}

.analysis-search-shell {
  gap: 0.48rem;
}

.analysis-start-quick-grid-editorial {
  gap: 0.42rem;
  margin-top: 0.72rem;
}

.analysis-start-mini-card,
.analysis-mode-card {
  padding: 0.54rem 0.58rem;
  border-radius: 0.95rem;
  background: rgba(247, 243, 236, 0.74);
  border: 1px solid rgba(218, 210, 198, 0.78);
}

.analysis-start-mini-card strong,
.analysis-start-metric-pill strong {
  font-size: 0.76rem;
  margin-bottom: 0.08rem;
}

.analysis-start-mini-card p,
.analysis-start-metric-pill span {
  font-size: 0.68rem;
  line-height: 1.32;
}

.editorial-visual-stage {
  padding: 0.72rem;
  border-radius: 1.2rem;
  background:
    radial-gradient(circle at 16% 16%, rgba(244, 236, 223, 0.95) 0%, rgba(244, 236, 223, 0) 30%),
    radial-gradient(circle at 88% 12%, rgba(220, 233, 240, 0.88) 0%, rgba(220, 233, 240, 0) 28%),
    linear-gradient(165deg, rgba(255, 255, 255, 0.92) 0%, rgba(247, 243, 236, 0.88) 100%);
  border: 1px solid rgba(218, 210, 198, 0.9);
  box-shadow: var(--editorial-shadow-sm), var(--editorial-inset);
}

.editorial-visual-glow {
  opacity: 0.42;
  filter: blur(30px);
}

.editorial-media-card {
  grid-template-columns: 72px minmax(0, 1fr);
  gap: 0.58rem;
  padding: 0.46rem;
  border-radius: 0.95rem;
  background: rgba(255, 255, 255, 0.72);
  border: 1px solid rgba(218, 210, 198, 0.8);
  box-shadow: 0 8px 22px rgba(16, 26, 43, 0.08);
  backdrop-filter: blur(10px);
}

.editorial-media-card-2 {
  transform: translateX(18px);
}

.editorial-media-card-3 {
  transform: translateX(8px);
}

.editorial-media-thumb {
  width: 72px;
  height: 72px;
  border-radius: 0.95rem;
  box-shadow: 0 8px 20px rgba(16, 26, 43, 0.12);
}

.editorial-media-copy span {
  font-size: 0.56rem;
  color: var(--editorial-accent-strong);
}

.editorial-media-copy strong {
  font-size: 0.76rem;
  line-height: 1.22;
}

.editorial-media-copy p {
  font-size: 0.66rem;
  line-height: 1.34;
}

.pricing-note {
  padding: 0.82rem 0.9rem;
}

.pricing-note h3,
.plan-card h3,
.action-panel h3,
.analysis-status-card h3,
.extension-status-head h3,
.section-heading h2 {
  color: var(--editorial-title);
  font-size: 0.98rem;
  letter-spacing: -0.035em;
}

.pricing-note h3 {
  margin-bottom: 0.16rem;
}

.plan-card {
  padding: 1rem;
  border-radius: 1.3rem;
}

.plan-card::before {
  height: 3px;
  margin-bottom: 0.8rem;
  background: linear-gradient(90deg, rgba(72, 169, 166, 0.75) 0%, rgba(154, 116, 64, 0.35) 100%);
}

.plan-card-featured {
  transform: translateY(-2px);
  border-color: rgba(72, 169, 166, 0.36);
  box-shadow: 0 18px 38px rgba(16, 26, 43, 0.1), var(--editorial-inset);
}

.extension-status-panel,
.extension-guide-card,
.action-panel,
.analysis-status-card,
.analysis-secondary-block,
.analysis-page-result-block,
.analysis-comparison-block,
.faq-item,
.auth-card,
.auth-aside {
  border-radius: 1.2rem;
}

.extension-status-panel,
.action-panel,
.analysis-status-card,
.analysis-secondary-block,
.analysis-page-result-block,
.analysis-comparison-block,
.faq-item,
.auth-card,
.auth-aside {
  padding: 0.88rem 0.92rem;
}

.extension-guide-card {
  margin-top: 0.72rem;
  padding: 0.82rem 0.88rem;
  border-radius: 1rem;
  background: rgba(247, 243, 236, 0.64);
  border: 1px solid rgba(218, 210, 198, 0.84);
}

.extension-guide-details {
  margin-top: 0.62rem;
  padding-top: 0.62rem;
  border-top: 1px solid rgba(218, 210, 198, 0.7);
}

.extension-guide-details summary,
.section-heading .eyebrow,
.action-panel > .eyebrow,
.analysis-status-card .eyebrow,
.extension-status-panel .eyebrow {
  color: var(--editorial-accent-strong);
}

.product-hero-refined {
  grid-template-columns: 96px minmax(0, 1fr) 220px;
  gap: 0.86rem;
  padding: 1rem;
}

.product-copy h2 {
  font-size: clamp(1.28rem, 1.8vw, 1.8rem);
  line-height: 1.02;
  margin-bottom: 0.36rem;
}

.product-thumb {
  width: 96px;
  height: 96px;
  border-radius: 0.95rem;
  box-shadow: 0 8px 22px rgba(16, 26, 43, 0.1);
}

.product-meta-line,
.feature-list li,
.pricing-grid p,
.faq-item p,
.helper-text,
.analysis-field-note,
.analysis-candidate-url {
  font-size: 0.76rem;
  line-height: 1.48;
}

.analysis-detail-layout {
  grid-template-columns: minmax(0, 1.1fr) minmax(300px, 0.9fr);
  gap: 0.82rem;
}

.table-shell,
.analysis-comparison-table .table-shell,
.analysis-page-result-table .table-shell {
  padding: 0.34rem;
  border-radius: 1.15rem;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(255, 253, 249, 0.96) 100%);
  border: 1px solid rgba(218, 210, 198, 0.92);
  box-shadow: var(--editorial-shadow-sm), var(--editorial-inset);
}

.data-table,
.analysis-comparison-table .data-table,
.analysis-page-result-table .data-table {
  min-width: 960px;
}

.data-table th,
.analysis-comparison-table .data-table th,
.analysis-page-result-table .data-table th {
  padding: 0.72rem 0.58rem;
  background: linear-gradient(180deg, #f8f4f1 0%, #f2ece4 100%);
  color: var(--editorial-muted);
  font-size: 0.66rem;
  letter-spacing: 0.06em;
  text-transform: none;
}

.data-table td,
.analysis-comparison-table .data-table td,
.analysis-page-result-table .data-table td {
  padding: 0.72rem 0.56rem;
  border-bottom: 1px solid rgba(235, 229, 219, 0.92);
  background: rgba(255, 255, 255, 0.82);
}

.analysis-comparison-table .data-table th:first-child,
.analysis-comparison-table .data-table td:first-child,
.analysis-page-result-table .data-table th:first-child,
.analysis-page-result-table .data-table td:first-child {
  background: linear-gradient(180deg, rgba(255, 253, 249, 0.99) 0%, rgba(247, 243, 236, 0.99) 100%);
}

.analysis-product-thumb,
.analysis-candidate-thumb {
  width: 72px;
  height: 72px;
  border-radius: 0.9rem;
  box-shadow: 0 8px 18px rgba(16, 26, 43, 0.1);
}

.analysis-comparison-table .analysis-product-title,
.analysis-page-result-table .analysis-product-title {
  font-size: 0.72rem;
  line-height: 1.34;
}

.analysis-comparison-table .analysis-field-main,
.analysis-page-result-table .analysis-field-main {
  font-size: 0.74rem;
  line-height: 1.24;
}

.analysis-comparison-table .analysis-action-row .button,
.analysis-page-result-table .analysis-action-row .button {
  min-height: 2.02rem;
  padding: 0.42rem 0.7rem;
  font-size: 0.74rem;
}

@media (max-width: 1199px) {
  .app-header > div:first-child,
  .app-header .header-actions {
    background: transparent;
    border: 0;
    box-shadow: none;
    backdrop-filter: none;
    padding: 0;
  }

  .hero-section-editorial,
  .pricing-hero-editorial,
  .analysis-start-hero-grid,
  .analysis-detail-layout {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 767px) {
  .page-content {
    padding: 0 0.82rem 3.4rem;
  }

  .app-header {
    padding: 0 0.82rem;
  }

  .app-header h1 {
    font-size: 0.96rem;
  }

  .app-header .muted {
    font-size: 0.62rem;
  }

  .app-header .header-actions .button {
    min-height: 1.88rem;
    padding: 0.38rem 0.68rem;
    font-size: 0.72rem;
  }

  .hero-copy-editorial h1,
  .pricing-hero .hero-copy h1 {
    font-size: clamp(1.34rem, 8vw, 1.88rem);
    max-width: none;
  }

  .analysis-start-copy h2 {
    font-size: clamp(1.22rem, 7vw, 1.7rem);
    max-width: none;
  }

  .marketing-analysis-form,
  .analysis-form.analysis-form-hero {
    grid-template-columns: 1fr;
  }

  .editorial-media-card,
  .product-hero-refined {
    grid-template-columns: 1fr;
  }

  .editorial-media-card-2,
  .editorial-media-card-3 {
    transform: none;
  }

  .editorial-media-thumb,
  .product-thumb {
    width: 100%;
    height: 148px;
  }

  .button {
    min-height: 2.36rem;
    font-size: 0.82rem;
  }
}

/* analysis start simplification */

.analysis-start-card-editorial {
  padding: 0.82rem 0.86rem;
}

.analysis-start-topline {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 0.9rem;
  margin-bottom: 0.62rem;
}

.analysis-start-copy h2 {
  font-size: clamp(1.02rem, 1.35vw, 1.28rem);
  line-height: 1.08;
  letter-spacing: -0.05em;
  margin-bottom: 0.1rem;
  max-width: none;
}

.analysis-start-copy p {
  font-size: 0.72rem;
  line-height: 1.38;
  margin-bottom: 0;
  color: var(--editorial-muted);
}

.analysis-start-meta-strip {
  margin-top: 0;
  flex-shrink: 0;
}

.analysis-start-meta-strip .chip {
  padding: 0.3rem 0.52rem;
  font-size: 0.64rem;
}

.analysis-search-shell {
  gap: 0.28rem;
}

.analysis-search-shell-flat {
  padding: 0;
  border: 0;
  background: transparent;
}

.analysis-form.analysis-form-hero {
  padding: 0.22rem;
  border-radius: 999px;
}

.analysis-form.analysis-form-hero input {
  min-height: 2.28rem;
  font-size: 0.84rem;
  border-radius: 999px;
}

.analysis-form.analysis-form-hero .button {
  min-height: 2.28rem;
  padding-inline: 0.86rem;
  font-size: 0.8rem;
}

.analysis-start-quick-grid-editorial {
  display: flex;
  flex-wrap: wrap;
  gap: 0.34rem;
  margin-top: 0.44rem;
}

.analysis-start-mini-card-inline,
.analysis-start-quick-grid-editorial .analysis-start-mini-card {
  padding: 0.34rem 0.56rem;
  border-radius: 999px;
  background: #f7f3ec;
  border: 1px solid rgba(218, 210, 198, 0.82);
  min-height: auto;
}

.analysis-start-mini-card-inline strong,
.analysis-start-quick-grid-editorial .analysis-start-mini-card strong {
  font-size: 0.66rem;
  font-weight: 700;
  color: var(--editorial-text);
  margin: 0;
}

.analysis-start-quick-grid-editorial .analysis-start-mini-card p {
  display: none;
}

@media (max-width: 1199px) {
  .analysis-start-topline {
    flex-direction: column;
    align-items: start;
  }
}

@media (max-width: 767px) {
  .analysis-start-copy h2 {
    font-size: clamp(0.98rem, 5vw, 1.16rem);
    max-width: none;
  }
}

/* pencil-aligned final refinement */

.home-editorial-hero,
.pricing-hero-editorial {
  grid-template-columns: minmax(0, 1.08fr) minmax(320px, 0.92fr);
  gap: 0.72rem;
  align-items: stretch;
}

.hero-copy-editorial,
.analysis-start-card-editorial,
.pricing-note,
.home-utility-card,
.plan-card,
.product-hero-refined,
.action-panel,
.analysis-status-card,
.analysis-secondary-block,
.analysis-page-result-block,
.analysis-comparison-block,
.extension-status-panel,
.faq-item,
.auth-card,
.auth-aside,
.table-shell,
.table-shell-dense {
  border-radius: 1.05rem;
  border: 1px solid rgba(218, 210, 198, 0.88);
  box-shadow: 0 8px 24px rgba(16, 26, 43, 0.06), 0 1px 0 rgba(255, 255, 255, 0.9) inset;
}

.hero-copy-editorial {
  padding: 0.9rem 0.96rem;
  min-height: auto;
}

.hero-copy-editorial h1,
.pricing-hero .hero-copy h1 {
  font-size: clamp(1.28rem, 1.9vw, 1.8rem);
  line-height: 1.04;
  margin-bottom: 0.24rem;
  max-width: 10ch;
}

.hero-copy-editorial p,
.pricing-hero .hero-copy p {
  font-size: 0.78rem;
  line-height: 1.46;
  margin-bottom: 0.48rem;
}

.home-utility-row {
  display: grid;
  gap: 0.72rem;
}

.home-utility-card {
  padding: 0.88rem 0.92rem;
  background: linear-gradient(180deg, rgba(255, 253, 249, 0.96) 0%, rgba(247, 243, 236, 0.88) 100%);
}

.home-utility-card h3,
.pricing-note h3 {
  font-size: 0.9rem;
  line-height: 1.18;
  letter-spacing: -0.03em;
  margin-bottom: 0.12rem;
  color: var(--editorial-title);
}

.home-utility-card p,
.pricing-note p {
  margin: 0;
  font-size: 0.74rem;
  line-height: 1.42;
  color: var(--editorial-muted);
}

.pricing-hero-aside {
  gap: 0.72rem;
}

.pricing-note {
  padding: 0.86rem 0.92rem;
}

.pricing-note-secondary {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.88) 0%, rgba(247, 243, 236, 0.72) 100%);
}

.plan-card {
  padding: 0.92rem;
}

.plan-card::before {
  margin-bottom: 0.62rem;
}

.plan-card .eyebrow {
  font-size: 0.64rem;
  margin-bottom: 0.12rem;
}

.plan-card h3 {
  font-size: 1.08rem;
  margin-bottom: 0.18rem;
}

.plan-card p,
.feature-list li,
.faq-item p {
  font-size: 0.74rem;
  line-height: 1.42;
}

.analysis-start-card-editorial {
  padding: 0.74rem 0.8rem;
}

.analysis-start-copy h2 {
  font-size: clamp(0.98rem, 1.2vw, 1.18rem);
  line-height: 1.08;
}

.analysis-start-copy p {
  font-size: 0.7rem;
}

.analysis-form.analysis-form-hero {
  padding: 0.18rem;
  gap: 0.22rem;
  background: rgba(247, 243, 236, 0.9);
  border-color: rgba(218, 210, 198, 0.92);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.92);
}

.analysis-form.analysis-form-hero input {
  min-height: 2.18rem;
  font-size: 0.82rem;
}

.analysis-form.analysis-form-hero .button {
  min-height: 2.18rem;
  font-size: 0.78rem;
}

.analysis-start-quick-grid-editorial {
  margin-top: 0.36rem;
}

.analysis-start-mini-card-inline,
.analysis-start-quick-grid-editorial .analysis-start-mini-card {
  padding: 0.3rem 0.52rem;
}

.analysis-start-mini-card-inline strong,
.analysis-start-quick-grid-editorial .analysis-start-mini-card strong {
  font-size: 0.62rem;
}

.product-hero-refined {
  grid-template-columns: 88px minmax(0, 1fr) 208px;
  gap: 0.74rem;
  padding: 0.92rem;
}

.product-thumb {
  width: 88px;
  height: 88px;
  border-radius: 0.82rem;
}

.product-copy h2 {
  font-size: clamp(1.14rem, 1.4vw, 1.5rem);
  margin-bottom: 0.28rem;
}

.product-meta-line,
.helper-text,
.analysis-field-note,
.analysis-candidate-url {
  font-size: 0.72rem;
  line-height: 1.42;
}

.action-panel,
.analysis-status-card,
.analysis-secondary-block,
.analysis-page-result-block,
.analysis-comparison-block,
.extension-status-panel,
.faq-item,
.auth-card,
.auth-aside {
  padding: 0.82rem 0.88rem;
}

.action-panel h3,
.analysis-status-card h3,
.extension-status-head h3,
.section-heading h2 {
  font-size: 0.92rem;
  letter-spacing: -0.03em;
}

.table-shell,
.analysis-comparison-table .table-shell,
.analysis-page-result-table .table-shell {
  padding: 0.28rem;
  border-radius: 1rem;
}

.data-table th,
.analysis-comparison-table .data-table th,
.analysis-page-result-table .data-table th {
  padding: 0.64rem 0.5rem;
  font-size: 0.64rem;
}

.data-table td,
.analysis-comparison-table .data-table td,
.analysis-page-result-table .data-table td {
  padding: 0.64rem 0.48rem;
}

@media (max-width: 1199px) {
  .home-editorial-hero,
  .pricing-hero-editorial {
    grid-template-columns: 1fr;
  }

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

@media (max-width: 767px) {
  .home-utility-row {
    grid-template-columns: 1fr;
  }

  .hero-copy-editorial h1,
  .pricing-hero .hero-copy h1 {
    font-size: clamp(1.14rem, 6vw, 1.42rem);
    max-width: none;
  }

  .product-hero-refined {
    grid-template-columns: 1fr;
  }
}

/* swiss clean dashboard refinement */

:root {
  --swiss-bg: #f7f4ef;
  --swiss-panel: #ffffff;
  --swiss-panel-soft: #fbfaf7;
  --swiss-border: #e7e1d8;
  --swiss-text: #121212;
  --swiss-muted: #6f6b64;
  --swiss-accent: #ef3b2d;
}

body,
.app-shell,
.marketing-shell {
  background: var(--swiss-bg);
  color: var(--swiss-text);
}

.app-shell::before,
.marketing-shell::before {
  display: none;
}

.app-shell {
  display: grid;
  grid-template-columns: 220px minmax(0, 1fr);
  gap: 0;
  min-height: 100vh;
}

.sidebar {
  background: var(--swiss-panel);
  border-right: 1px solid var(--swiss-border);
  padding: 18px 16px 20px;
  gap: 18px;
}

.brand-sidebar {
  font-size: 0.92rem;
  font-weight: 700;
  color: var(--swiss-text);
}

.brand-mark {
  background: var(--swiss-accent);
  color: #fff;
  box-shadow: none;
}

.sidebar .eyebrow,
.sidebar-card .eyebrow,
.section-heading .eyebrow,
.action-panel > .eyebrow,
.analysis-status-card .eyebrow,
.extension-status-panel .eyebrow {
  color: var(--swiss-muted);
  letter-spacing: 0.08em;
}

.sidebar .nav-link {
  position: relative;
  padding: 0.62rem 0.72rem;
  border-radius: 0.7rem;
  color: var(--swiss-muted);
  font-size: 0.82rem;
  font-weight: 600;
}

.sidebar .nav-link.is-active {
  background: #f5f2ec;
  color: var(--swiss-text);
}

.sidebar .nav-link.is-active::before {
  content: "";
  position: absolute;
  left: -10px;
  top: 10px;
  bottom: 10px;
  width: 3px;
  border-radius: 999px;
  background: var(--swiss-accent);
}

.sidebar-card {
  background: var(--swiss-panel);
  border: 1px solid var(--swiss-border);
  border-radius: 0.9rem;
  box-shadow: none;
  padding: 0.82rem 0.86rem;
}

.sidebar-card strong {
  color: var(--swiss-text);
}

.sidebar-card p {
  color: var(--swiss-muted);
  font-size: 0.74rem;
  line-height: 1.42;
}

.app-main {
  padding: 0;
}

.app-header {
  margin: 0;
  padding: 24px 28px 12px;
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 20px;
}

.app-header > div:first-child,
.app-header .header-actions {
  background: transparent;
  border: 0;
  box-shadow: none;
  backdrop-filter: none;
  padding: 0;
}

.app-header h1 {
  font-size: clamp(1.45rem, 1.8vw, 2rem);
  line-height: 1.02;
  letter-spacing: -0.05em;
  margin-bottom: 0.14rem;
  color: var(--swiss-text);
}

.app-header .muted {
  font-size: 0.72rem;
  color: var(--swiss-muted);
}

.header-actions {
  gap: 8px;
}

.app-header .header-actions .button {
  min-height: 2rem;
  padding: 0.42rem 0.78rem;
  border-radius: 0.7rem;
  font-size: 0.75rem;
  font-weight: 700;
}

.page-content {
  max-width: 1280px;
  margin: 0;
  padding: 0 28px 36px;
}

.hero-section-editorial,
.pricing-hero-editorial,
.home-editorial-hero {
  grid-template-columns: minmax(0, 1fr);
  gap: 14px;
}

.hero-copy-editorial,
.analysis-start-card-editorial,
.pricing-note,
.home-utility-card,
.plan-card,
.product-hero-refined,
.action-panel,
.analysis-status-card,
.analysis-secondary-block,
.analysis-page-result-block,
.analysis-comparison-block,
.extension-status-panel,
.faq-item,
.auth-card,
.auth-aside,
.analysis-card,
.table-shell,
.table-shell-dense {
  background: var(--swiss-panel);
  border: 1px solid var(--swiss-border);
  box-shadow: none;
  border-radius: 0.95rem;
}

.hero-copy-editorial::before,
.analysis-start-card-editorial::before,
.pricing-note::before,
.product-hero-refined::before {
  display: none;
}

.hero-copy-editorial,
.analysis-start-card-editorial,
.pricing-note,
.plan-card,
.product-hero-refined,
.action-panel,
.analysis-status-card,
.analysis-secondary-block,
.analysis-page-result-block,
.analysis-comparison-block,
.extension-status-panel,
.faq-item,
.auth-card,
.auth-aside {
  padding: 0.92rem 0.96rem;
}

.hero-copy-editorial h1,
.pricing-hero .hero-copy h1 {
  font-size: clamp(1.28rem, 1.9vw, 1.82rem);
  line-height: 1.06;
  margin-bottom: 0.22rem;
  max-width: 12ch;
  color: var(--swiss-text);
}

.hero-copy-editorial p,
.analysis-start-copy p,
.pricing-hero .hero-copy p,
.pricing-note p,
.extension-status-panel p,
.auth-card p,
.auth-aside p,
.home-utility-card p {
  color: var(--swiss-muted);
  font-size: 0.76rem;
  line-height: 1.42;
}

.marketing-analysis-form,
.analysis-form.analysis-form-hero {
  background: var(--swiss-panel-soft);
  border: 1px solid var(--swiss-border);
  box-shadow: none;
  padding: 0.26rem;
  gap: 0.26rem;
  border-radius: 0.8rem;
}

.analysis-form input,
textarea,
select,
input {
  min-height: 2.18rem;
  border-radius: 0.68rem;
  border-color: var(--swiss-border);
  background: #fff;
  color: var(--swiss-text);
}

.button {
  min-height: 2.18rem;
  padding: 0.46rem 0.78rem;
  border-radius: 0.68rem;
  font-size: 0.76rem;
  font-weight: 700;
  letter-spacing: -0.01em;
  box-shadow: none;
}

.button:hover {
  transform: none;
}

.button-primary {
  background: #111111;
  border-color: #111111;
  color: #ffffff;
}

.button-primary:hover {
  background: #1d1d1d;
  border-color: #1d1d1d;
  box-shadow: none;
}

.button-secondary,
.button-ghost {
  background: #ffffff;
  border-color: var(--swiss-border);
  color: var(--swiss-text);
}

.chip,
.badge,
.analysis-status-badge,
.status-badge,
.home-meta-strip .chip,
.analysis-start-meta-strip .chip,
.pricing-meta-strip .chip {
  background: #faf8f4;
  border: 1px solid var(--swiss-border);
  color: var(--swiss-muted);
  font-size: 0.66rem;
  box-shadow: none;
}

.chip-highlight,
.badge-success,
.analysis-status-badge-success {
  background: #fff1ef;
  border-color: #f6c2bc;
  color: #b43328;
}

.home-utility-row {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.home-utility-card h3,
.pricing-note h3,
.plan-card h3,
.action-panel h3,
.analysis-status-card h3,
.extension-status-head h3,
.section-heading h2 {
  font-size: 0.92rem;
  letter-spacing: -0.03em;
  color: var(--swiss-text);
}

.analysis-start-copy h2 {
  font-size: clamp(1rem, 1.2vw, 1.2rem);
  color: var(--swiss-text);
}

.analysis-start-meta-strip .chip,
.analysis-start-mini-card-inline,
.analysis-start-quick-grid-editorial .analysis-start-mini-card {
  background: #faf8f4;
}

.product-hero-refined {
  grid-template-columns: 84px minmax(0, 1fr) 208px;
  gap: 14px;
}

.product-thumb {
  width: 84px;
  height: 84px;
  border-radius: 0.7rem;
  box-shadow: none;
}

.product-copy h2 {
  font-size: clamp(1.18rem, 1.45vw, 1.56rem);
  color: var(--swiss-text);
}

.analysis-detail-layout {
  grid-template-columns: minmax(0, 1.12fr) minmax(280px, 0.88fr);
  gap: 14px;
}

.table-shell,
.analysis-comparison-table .table-shell,
.analysis-page-result-table .table-shell {
  padding: 0.24rem;
  border-radius: 0.9rem;
}

.data-table th,
.analysis-comparison-table .data-table th,
.analysis-page-result-table .data-table th {
  background: #faf8f4;
  color: var(--swiss-muted);
  font-size: 0.64rem;
  padding: 0.58rem 0.48rem;
  text-transform: none;
}

.data-table td,
.analysis-comparison-table .data-table td,
.analysis-page-result-table .data-table td {
  background: #ffffff;
  border-bottom: 1px solid #f0ebe4;
  padding: 0.58rem 0.48rem;
}

.analysis-comparison-table .data-table th:first-child,
.analysis-comparison-table .data-table td:first-child,
.analysis-page-result-table .data-table th:first-child,
.analysis-page-result-table .data-table td:first-child {
  background: #fcfbf8;
}

.analysis-product-thumb,
.analysis-candidate-thumb {
  width: 64px;
  height: 64px;
  border-radius: 0.7rem;
  box-shadow: none;
}

.analysis-comparison-table .analysis-product-title,
.analysis-page-result-table .analysis-product-title {
  font-size: 0.72rem;
  line-height: 1.34;
}

.analysis-comparison-table .analysis-field-main,
.analysis-page-result-table .analysis-field-main,
.feature-list li,
.faq-item p,
.product-meta-line,
.helper-text,
.analysis-field-note,
.analysis-candidate-url {
  font-size: 0.72rem;
  line-height: 1.38;
}

@media (max-width: 1199px) {
  .app-shell {
    grid-template-columns: 1fr;
  }

  .sidebar {
    border-right: 0;
    border-bottom: 1px solid var(--swiss-border);
  }

  .page-content {
    padding: 0 18px 28px;
  }

  .home-utility-row,
  .analysis-detail-layout,
  .product-hero-refined {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 767px) {
  .app-header {
    padding: 16px 18px 10px;
  }

  .app-header h1 {
    font-size: 1.18rem;
  }

  .page-content {
    padding: 0 18px 28px;
  }

  .home-utility-row {
    grid-template-columns: 1fr;
  }
}

.compact-meta-text {
  margin: 0;
  font-size: 0.72rem;
  line-height: 1.42;
  color: #6f6b64;
}

.analysis-comparison-table .data-table th:nth-child(1),
.analysis-comparison-table .data-table td:nth-child(1),
.analysis-page-result-table .data-table th:nth-child(1),
.analysis-page-result-table .data-table td:nth-child(1) {
  width: 56px;
  min-width: 56px;
  max-width: 56px;
}

.analysis-comparison-table .data-table th:nth-child(2),
.analysis-comparison-table .data-table td:nth-child(2),
.analysis-page-result-table .data-table th:nth-child(2),
.analysis-page-result-table .data-table td:nth-child(2) {
  width: 40%;
}

.analysis-comparison-table .analysis-product-cell,
.analysis-page-result-table .analysis-product-cell {
  grid-template-columns: 56px minmax(0, 1fr);
  gap: 0.62rem;
  align-items: start;
}

.analysis-product-thumb,
.analysis-candidate-thumb {
  width: 56px;
  height: 56px;
  border-radius: 0.75rem;
}

.analysis-comparison-table .analysis-product-copy,
.analysis-page-result-table .analysis-product-copy {
  min-width: 0;
  gap: 0.18rem;
}

.analysis-comparison-table .analysis-product-title,
.analysis-page-result-table .analysis-product-title {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  font-size: 0.74rem;
  line-height: 1.34;
  word-break: keep-all;
}

.analysis-comparison-table .analysis-action-row,
.analysis-page-result-table .analysis-action-row {
  display: none;
}

/* Admin console + pre-auth refinements */
.home-preauth-hero {
  align-items: stretch;
  gap: 20px;
}

.home-preauth-copy {
  max-width: 720px;
}

.home-preauth-copy h1 {
  font-size: clamp(2.2rem, 4vw, 3.6rem);
  line-height: 0.96;
  letter-spacing: -0.05em;
}

.home-preauth-copy p {
  max-width: 640px;
  font-size: 1rem;
}

.home-preauth-actions {
  margin-top: 8px;
}

.home-meta-strip-compact {
  margin-top: 6px;
}

.home-utility-row-rich {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.home-utility-card-rich {
  min-height: 112px;
  padding: 18px 20px;
}

.home-utility-card-rich h3 {
  font-size: 1rem;
  margin-bottom: 6px;
}

.home-utility-card-rich p {
  margin: 0;
  font-size: 0.9rem;
  color: var(--color-text-muted);
}

.auth-card-premium {
  display: grid;
  gap: 18px;
}

.auth-primary-actions,
.auth-secondary-actions {
  margin-top: 0;
}

.auth-feature-list {
  display: grid;
  gap: 10px;
}

.auth-feature-item {
  display: grid;
  grid-template-columns: 140px minmax(0, 1fr);
  gap: 12px;
  padding: 12px 14px;
  border: 1px solid rgba(24, 35, 52, 0.08);
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.7);
}

.auth-feature-item strong {
  font-size: 0.94rem;
}

.auth-feature-item span {
  color: var(--color-text-muted);
  font-size: 0.9rem;
}

.admin-hero-card {
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(320px, 0.9fr);
  gap: 20px;
  align-items: start;
  padding: 28px 30px;
}

.admin-hero-copy h2 {
  margin: 6px 0 10px;
  font-size: clamp(1.6rem, 2.8vw, 2.4rem);
  line-height: 1.02;
  letter-spacing: -0.04em;
}

.admin-hero-copy p {
  margin: 0;
  max-width: 720px;
  color: var(--color-text-muted);
}

.admin-hero-meta {
  display: grid;
  gap: 10px;
}

.admin-mini-metric {
  padding: 14px 16px;
  border-radius: 16px;
  border: 1px solid rgba(24, 35, 52, 0.08);
  background: rgba(255, 255, 255, 0.82);
}

.admin-mini-metric span,
.admin-mini-metric small {
  display: block;
}

.admin-mini-metric span {
  color: var(--color-text-muted);
  font-size: 0.82rem;
}

.admin-mini-metric strong {
  display: block;
  margin: 4px 0;
  font-size: 1.06rem;
}

.admin-mini-metric small {
  color: var(--color-text-muted);
  font-size: 0.8rem;
}

.admin-console-grid {
  grid-template-columns: minmax(0, 1.4fr) minmax(320px, 0.9fr);
  align-items: start;
}

.admin-console-grid-single {
  grid-template-columns: minmax(0, 1fr);
}

.admin-panel {
  display: grid;
  gap: 16px;
  padding: 24px;
}

.admin-section-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
}

.admin-section-head h3 {
  margin: 0 0 6px;
  font-size: 1.05rem;
}

.admin-section-head p {
  margin: 0;
  color: var(--color-text-muted);
  font-size: 0.9rem;
}

.admin-summary-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.admin-summary-card {
  padding: 14px 16px;
  border-radius: 14px;
  border: 1px solid rgba(24, 35, 52, 0.08);
  background: rgba(248, 250, 252, 0.88);
}

.admin-summary-card strong {
  display: block;
  margin-bottom: 10px;
  font-size: 0.95rem;
}

.admin-list-compact {
  margin: 0;
  padding-left: 16px;
  color: var(--color-text-muted);
  font-size: 0.88rem;
}

.admin-list-compact li + li {
  margin-top: 6px;
}

.admin-notice-form {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 12px;
}

.admin-notice-row {
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.admin-panel select {
  min-width: 104px;
  border-radius: 12px;
  border: 1px solid rgba(24, 35, 52, 0.12);
  background: rgba(255, 255, 255, 0.96);
  color: var(--color-text);
  font: inherit;
  padding: 8px 10px;
}

.admin-panel .data-table td:nth-child(4),
.admin-panel .data-table td:nth-child(5),
.admin-panel .data-table td:nth-child(6) {
  white-space: nowrap;
}

.admin-stats-grid .stat-card {
  min-height: 148px;
}

@media (max-width: 1024px) {
  .home-utility-row-rich,
  .admin-summary-grid,
  .admin-hero-card,
  .admin-console-grid {
    grid-template-columns: 1fr;
  }

  .auth-feature-item {
    grid-template-columns: 1fr;
  }

  .admin-notice-form {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px) {
  .home-preauth-copy h1 {
    font-size: 2rem;
  }

  .auth-feature-item,
  .home-utility-card-rich,
  .admin-summary-card,
  .admin-mini-metric {
    padding: 12px 14px;
  }
}

/* Lean pre-auth screens */
.home-preauth-hero {
  min-height: 0;
  padding: 28px 30px;
}

.home-preauth-copy {
  max-width: 640px;
}

.home-preauth-copy h1 {
  font-size: clamp(1.9rem, 3.8vw, 3rem);
  line-height: 1.02;
  letter-spacing: -0.045em;
  margin-bottom: 10px;
}

.home-preauth-copy p {
  max-width: 520px;
  font-size: 0.98rem;
  color: var(--color-text-muted);
}

.home-inline-meta {
  margin: 6px 0 0;
  font-size: 0.88rem;
  color: var(--color-text-muted);
}

.auth-page {
  grid-template-columns: minmax(0, 760px);
  justify-content: start;
}

.auth-card-premium {
  gap: 14px;
  padding: 30px 30px 28px;
}

.auth-card-premium h1 {
  font-size: clamp(1.85rem, 3.4vw, 2.8rem);
  line-height: 1.04;
  letter-spacing: -0.045em;
}

.auth-card-premium p {
  max-width: 520px;
}

.auth-secondary-actions {
  display: none;
}

@media (max-width: 640px) {
  .home-preauth-hero,
  .auth-card-premium {
    padding: 22px 20px;
  }

  .auth-page {
    grid-template-columns: 1fr;
  }

  .admin-hero-card,
  .admin-panel {
    padding: 18px;
  }
}

/* Billing and subscription polish */
.pricing-hero-aside {
  display: grid;
  gap: 14px;
}

.pricing-note {
  display: grid;
  gap: 10px;
}

.pricing-note-secondary {
  gap: 6px;
}

.pricing-meta-strip {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.subscription-inline-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 10px 12px;
  border: 1px solid rgba(16, 26, 43, 0.08);
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.82);
}

.subscription-inline-meta span {
  color: var(--color-text-muted);
  font-size: 0.78rem;
}

.subscription-inline-meta strong {
  color: var(--color-text);
  font-size: 0.88rem;
  letter-spacing: -0.02em;
}

.pricing-note .button-block,
.plan-card .button-block {
  width: 100%;
}

.plan-card .feature-list {
  margin: 0;
  padding-left: 16px;
}

.plan-card .feature-list li {
  margin-top: 4px;
}

.plan-card .button[disabled] {
  opacity: 1;
  color: rgba(16, 26, 43, 0.48);
  background: rgba(255, 255, 255, 0.86);
  border-color: rgba(16, 26, 43, 0.08);
  cursor: not-allowed;
}

.analysis-page-result-head strong {
  letter-spacing: -0.03em;
}

@media (max-width: 768px) {
  .subscription-inline-meta {
    align-items: flex-start;
    flex-direction: column;
  }
}

/* SaaS redesign final overrides */
:root {
  --saas-bg-top: #f8fafc;
  --saas-bg-bottom: #eef2f6;
  --saas-surface: #ffffff;
  --saas-surface-soft: #f6f8fb;
  --saas-border: #d7dee7;
  --saas-border-strong: #c4cfdb;
  --saas-text: #17212d;
  --saas-muted: #667085;
  --saas-accent: #1f3a5f;
  --saas-accent-strong: #14283f;
  --saas-accent-soft: #e9eef6;
  --saas-shadow: 0 18px 44px rgba(15, 23, 42, 0.07);
}

html {
  background: var(--saas-bg-bottom);
}

body,
.site-shell,
.app-shell,
.marketing-shell {
  background: linear-gradient(180deg, var(--saas-bg-top) 0%, #f3f6fa 48%, var(--saas-bg-bottom) 100%);
  color: var(--saas-text);
}

.site-shell {
  min-height: 100vh;
}

.site-shell main {
  width: 100%;
  max-width: 1240px;
  margin: 0 auto;
  padding: 32px 24px 72px;
}

.marketing-header,
.site-footer {
  width: 100%;
  max-width: 1240px;
  margin: 0 auto;
  padding: 20px 24px;
}

.marketing-header {
  position: sticky;
  top: 0;
  z-index: 20;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  background: rgba(248, 250, 252, 0.9);
  backdrop-filter: blur(18px);
  border-bottom: 1px solid rgba(215, 222, 231, 0.92);
}

.site-footer {
  display: grid;
  gap: 18px;
  color: var(--saas-muted);
  border-top: 1px solid rgba(215, 222, 231, 0.92);
  padding-top: 24px;
  padding-bottom: 32px;
}

.site-footer-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
}

.site-footer-copy {
  color: var(--saas-text);
  font-size: 0.98rem;
  font-weight: 500;
}

.site-footer-meta {
  display: grid;
  gap: 10px;
  padding-top: 18px;
  border-top: 1px solid rgba(215, 222, 231, 0.82);
  text-align: center;
  font-size: 0.92rem;
  line-height: 1.75;
}

.site-footer strong,
.brand,
.brand-sidebar {
  color: var(--saas-text);
}

.brand-mark {
  background: var(--saas-accent);
  color: #fff;
  box-shadow: none;
}

.nav-links {
  display: flex;
  align-items: center;
  gap: 10px;
}

.nav-link {
  padding: 10px 14px;
  border-radius: 12px;
  color: var(--saas-muted);
  font-size: 0.9rem;
  font-weight: 600;
}

.nav-link:hover,
.nav-link.is-active {
  background: rgba(31, 58, 95, 0.08);
  color: var(--saas-text);
}

.nav-toggle {
  display: none;
  min-height: 42px;
  padding: 0 14px;
  border: 1px solid var(--saas-border);
  border-radius: 12px;
  background: var(--saas-surface);
  color: var(--saas-text);
  font: inherit;
  font-weight: 700;
}

.app-shell {
  grid-template-columns: 248px minmax(0, 1fr);
  min-height: 100vh;
}

.sidebar {
  background: rgba(255, 255, 255, 0.92);
  border-right: 1px solid rgba(215, 222, 231, 0.96);
  backdrop-filter: blur(18px);
  padding: 24px 18px;
  gap: 22px;
}

.sidebar .nav-link {
  padding: 10px 12px;
  border-radius: 12px;
  font-size: 0.86rem;
}

.sidebar .nav-link.is-active {
  background: rgba(31, 58, 95, 0.09);
  color: var(--saas-text);
}

.sidebar .nav-link.is-active::before {
  left: -8px;
  background: var(--saas-accent);
}

.sidebar-card,
.card,
.pricing-note,
.plan-card,
.feature-card,
.workflow-card,
.stat-card,
.analysis-start-card-editorial,
.analysis-status-card,
.analysis-secondary-block,
.analysis-page-result-block,
.analysis-comparison-block,
.extension-status-panel,
.auth-card,
.auth-aside,
.faq-item,
.table-shell,
.table-shell-dense,
.action-panel,
.product-hero-refined {
  background: rgba(255, 255, 255, 0.96);
  border: 1px solid rgba(215, 222, 231, 0.96);
  border-radius: 18px;
  box-shadow: var(--saas-shadow);
}

.app-header {
  margin: 0;
  padding: 28px 32px 18px;
  border-bottom: 1px solid rgba(215, 222, 231, 0.7);
}

.app-header > div:first-child,
.app-header .header-actions {
  background: transparent;
  border: 0;
  box-shadow: none;
  padding: 0;
}

.app-header h1 {
  color: var(--saas-text);
  font-size: clamp(1.7rem, 2vw, 2.2rem);
  line-height: 1.05;
  letter-spacing: -0.04em;
}

.app-header .muted,
.site-footer p,
.site-footer a {
  color: var(--saas-muted);
}

.page-content {
  max-width: none;
  padding: 24px 32px 48px;
}

.hero-section,
.auth-page {
  display: grid;
  grid-template-columns: minmax(0, 1.12fr) minmax(320px, 0.88fr);
  gap: 24px;
  align-items: stretch;
}

.home-saas-hero {
  grid-template-columns: minmax(0, 1.18fr) minmax(320px, 0.82fr);
}

.hero-copy-editorial,
.home-operations-card,
.pricing-note,
.analysis-start-card-editorial,
.auth-card,
.auth-aside,
.analysis-support-card,
.extension-status-panel,
.product-hero-refined,
.action-panel,
.analysis-status-card {
  padding: 30px 32px;
}

.hero-copy-editorial,
.home-operations-card,
.pricing-hero-main,
.pricing-operations-card,
.auth-card-saas,
.auth-account-card {
  display: grid;
  gap: 16px;
}

.hero-copy-editorial h1,
.pricing-hero-main h1,
.auth-card h1 {
  margin: 0;
  max-width: 15ch;
  color: var(--saas-text);
  font-size: clamp(2.35rem, 4vw, 4rem);
  line-height: 0.98;
  letter-spacing: -0.055em;
}

.auth-account-card h1 {
  max-width: none;
  font-size: clamp(1.95rem, 3.4vw, 3rem);
}

.hero-copy-editorial p,
.home-operations-card p,
.pricing-note p,
.auth-card p,
.auth-aside p,
.feature-card p,
.workflow-card p,
.faq-item p,
.analysis-start-copy p,
.analysis-start-mini-card .muted,
.analysis-support-card li,
.extension-status-panel p {
  margin: 0;
  color: var(--saas-muted);
  font-size: 0.96rem;
  line-height: 1.65;
  word-break: keep-all;
}

.home-inline-meta {
  margin: 0;
  color: var(--saas-muted);
}

.home-proof-list {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.home-proof-item {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 38px;
  padding: 0 14px;
  border: 1px solid var(--saas-border);
  border-radius: 999px;
  background: var(--saas-surface-soft);
  color: var(--saas-text);
  font-size: 0.84rem;
  font-weight: 700;
}

.home-summary-grid,
.pricing-summary-grid,
.auth-account-stats,
.home-benefit-grid,
.workflow-grid,
.pricing-plan-grid,
.analysis-ops-grid {
  gap: 16px;
}

.home-summary-grid .stat-card,
.pricing-summary-grid .stat-card {
  background: var(--saas-surface-soft);
  box-shadow: none;
}

.feature-card,
.workflow-card,
.plan-card,
.stat-card {
  padding: 22px;
  min-height: 100%;
}

.feature-card,
.workflow-card,
.plan-card {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.feature-card h3,
.workflow-card h3,
.plan-card h3,
.pricing-note h3,
.home-operations-card h2,
.analysis-support-card h3,
.extension-status-head h3,
.faq-item h3,
.section-heading h2 {
  margin: 0;
  color: var(--saas-text);
  letter-spacing: -0.03em;
}

.home-operations-card h2,
.pricing-note h3,
.analysis-support-card h3 {
  font-size: 1.3rem;
}

.workflow-step-number {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 42px;
  height: 42px;
  border-radius: 12px;
  background: var(--saas-accent-soft);
  color: var(--saas-accent);
  font-size: 0.84rem;
  font-weight: 800;
  letter-spacing: 0.02em;
}

.button {
  min-height: 44px;
  padding: 0 18px;
  border-radius: 14px;
  border: 1px solid var(--saas-border);
  background: var(--saas-surface);
  color: var(--saas-text);
  font-size: 0.88rem;
  font-weight: 700;
  box-shadow: none;
  transition:
    transform 160ms ease,
    box-shadow 160ms ease,
    background-color 160ms ease,
    border-color 160ms ease;
}

.button:hover {
  transform: translateY(-1px);
  box-shadow: 0 10px 18px rgba(15, 23, 42, 0.06);
}

.button-primary {
  background: var(--saas-accent);
  border-color: var(--saas-accent);
  color: #ffffff;
}

.button-primary:hover {
  background: var(--saas-accent-strong);
  border-color: var(--saas-accent-strong);
}

.button-secondary,
.button-ghost {
  background: var(--saas-surface);
  border-color: var(--saas-border);
  color: var(--saas-text);
}

.button[disabled] {
  opacity: 1;
  color: rgba(23, 33, 45, 0.46);
  background: rgba(255, 255, 255, 0.84);
  border-color: rgba(196, 207, 219, 0.8);
  cursor: not-allowed;
  box-shadow: none;
}

.button:focus-visible,
input:focus-visible,
textarea:focus-visible,
select:focus-visible,
summary:focus-visible {
  outline: 3px solid rgba(31, 58, 95, 0.16);
  outline-offset: 2px;
}

.marketing-analysis-form,
.analysis-form.analysis-form-hero {
  background: var(--saas-surface-soft);
  border: 1px solid var(--saas-border);
  border-radius: 18px;
  padding: 6px;
  gap: 8px;
  box-shadow: none;
}

input,
select,
textarea,
.analysis-form input {
  min-height: 48px;
  border-radius: 14px;
  border: 1px solid var(--saas-border);
  background: #ffffff;
  color: var(--saas-text);
}

::placeholder {
  color: rgba(102, 112, 133, 0.82);
}

.badge,
.chip,
.analysis-status-badge,
.status-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 28px;
  padding: 0 10px;
  border: 1px solid var(--saas-border);
  border-radius: 999px;
  background: var(--saas-surface-soft);
  color: var(--saas-muted);
  font-size: 0.72rem;
  font-weight: 700;
  box-shadow: none;
}

.badge-info,
.badge-success,
.chip-highlight,
.analysis-status-badge-success {
  background: var(--saas-accent-soft);
  border-color: rgba(31, 58, 95, 0.18);
  color: var(--saas-accent);
}

.badge-warning,
.analysis-status-badge-warning {
  background: #fff7ed;
  border-color: #ecd7bc;
  color: #8b5a23;
}

.badge-neutral,
.badge-default {
  background: var(--saas-surface-soft);
  color: var(--saas-muted);
}

.section-heading {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 16px;
}

.section-heading h2 {
  font-size: clamp(1.25rem, 2vw, 1.65rem);
}

.section-heading .muted {
  margin-top: 6px;
  max-width: 60ch;
  color: var(--saas-muted);
}

.stat-card {
  display: grid;
  gap: 12px;
}

.stat-card .card-topline {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.stat-value {
  color: var(--saas-text);
  font-size: clamp(1.4rem, 2vw, 1.85rem);
  letter-spacing: -0.04em;
}

.analysis-start-intro {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 20px;
  margin-bottom: 20px;
}

.analysis-start-copy {
  display: grid;
  gap: 10px;
  max-width: 720px;
}

.analysis-start-copy h2 {
  margin: 0;
  color: var(--saas-text);
  font-size: clamp(1.7rem, 2.8vw, 2.5rem);
  line-height: 1.05;
  letter-spacing: -0.045em;
}

.analysis-start-quick-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  margin-top: 18px;
}

.analysis-start-mini-card-inline {
  display: grid;
  gap: 6px;
  padding: 16px 18px;
  border-radius: 16px;
  border: 1px solid var(--saas-border);
  background: var(--saas-surface-soft);
}

.analysis-start-mini-card-inline strong {
  color: var(--saas-text);
  font-size: 0.94rem;
}

.analysis-support-grid {
  display: grid;
  grid-template-columns: minmax(280px, 0.82fr) minmax(0, 1.18fr);
  gap: 16px;
  align-items: start;
}

.analysis-support-card {
  display: grid;
  gap: 12px;
}

.analysis-usage-list {
  margin: 0;
  padding-left: 18px;
  color: var(--saas-muted);
}

.analysis-usage-list li + li {
  margin-top: 8px;
}

.analysis-status-card {
  display: grid;
  gap: 14px;
}

.analysis-progress-bar {
  height: 8px;
  border-radius: 999px;
  background: #e6edf5;
  overflow: hidden;
}

.analysis-progress-bar-fill {
  background: var(--saas-accent);
}

.extension-status-panel,
.extension-guide-card {
  display: grid;
  gap: 14px;
}

.extension-guide-card {
  padding: 16px 18px;
  border: 1px solid var(--saas-border);
  border-radius: 16px;
  background: var(--saas-surface-soft);
  box-shadow: none;
}

.extension-guide-summary {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
}

.extension-guide-details {
  border-top: 1px solid rgba(215, 222, 231, 0.9);
  padding-top: 12px;
}

.extension-guide-details summary {
  cursor: pointer;
  color: var(--saas-text);
  font-weight: 700;
}

.auth-page-saas {
  grid-template-columns: minmax(0, 1.08fr) minmax(320px, 0.92fr);
}

.auth-card-premium,
.auth-account-card {
  gap: 18px;
}

.auth-feature-list {
  display: grid;
  gap: 12px;
}

.auth-feature-item {
  display: grid;
  grid-template-columns: 136px minmax(0, 1fr);
  gap: 14px;
  padding: 16px 18px;
  border: 1px solid var(--saas-border);
  border-radius: 16px;
  background: var(--saas-surface-soft);
}

.auth-feature-item strong {
  color: var(--saas-text);
  font-size: 0.94rem;
}

.auth-feature-item span {
  color: var(--saas-muted);
  font-size: 0.92rem;
  line-height: 1.6;
}

.auth-secondary-actions {
  display: flex;
}

.pricing-hero-saas {
  grid-template-columns: minmax(0, 1.1fr) minmax(320px, 0.9fr);
}

.pricing-proof-list {
  margin-top: 2px;
}

.pricing-note,
.pricing-operations-card {
  gap: 14px;
}

.pricing-meta-strip {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.subscription-inline-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 12px 14px;
  border: 1px solid var(--saas-border);
  border-radius: 14px;
  background: var(--saas-surface-soft);
}

.subscription-inline-meta span {
  color: var(--saas-muted);
  font-size: 0.82rem;
}

.subscription-inline-meta strong {
  color: var(--saas-text);
  font-size: 0.92rem;
  letter-spacing: -0.02em;
}

.plan-card {
  gap: 16px;
}

.plan-card-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.plan-card h3 {
  font-size: clamp(1.55rem, 2.4vw, 2.1rem);
}

.plan-card-summary {
  margin: 0;
  color: var(--saas-text);
  font-size: 1rem;
  font-weight: 700;
}

.plan-card .feature-list {
  display: grid;
  gap: 8px;
  margin: 0;
  padding-left: 18px;
  color: var(--saas-muted);
}

.plan-card .button-block,
.pricing-note .button-block {
  width: 100%;
  margin-top: auto;
}

.plan-card-featured {
  border-color: rgba(31, 58, 95, 0.24);
  box-shadow: 0 20px 50px rgba(31, 58, 95, 0.08);
}

.plan-card::before,
.plan-card-featured::before,
.pricing-note::before,
.hero-copy-editorial::before,
.analysis-start-card-editorial::before,
.product-hero-refined::before {
  display: none;
}

.table-shell {
  overflow: auto;
  padding: 8px;
}

.data-table th {
  background: var(--saas-surface-soft);
  color: var(--saas-muted);
  font-size: 0.78rem;
  font-weight: 700;
  text-transform: none;
}

.data-table td {
  color: var(--saas-text);
  border-bottom-color: rgba(215, 222, 231, 0.9);
}

.faq-item {
  display: grid;
  gap: 10px;
}

@media (max-width: 1199px) {
  .app-shell,
  .hero-section,
  .auth-page,
  .analysis-support-grid,
  .analysis-detail-layout,
  .product-hero-refined,
  .pricing-hero-saas,
  .home-saas-hero {
    grid-template-columns: 1fr;
  }

  .sidebar {
    border-right: 0;
    border-bottom: 1px solid rgba(215, 222, 231, 0.96);
  }

  .home-benefit-grid,
  .workflow-grid,
  .auth-account-stats,
  .analysis-ops-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 767px) {
  .site-shell main,
  .marketing-header,
  .site-footer,
  .page-content,
  .app-header {
    padding-left: 18px;
    padding-right: 18px;
  }

  .marketing-header {
    align-items: flex-start;
    flex-wrap: wrap;
  }

  .nav-toggle {
    display: inline-flex;
  }

  .nav-links {
    display: none;
    width: 100%;
    padding-top: 8px;
  }

  .nav-links.is-open {
    display: grid;
  }

  .hero-copy-editorial,
  .home-operations-card,
  .pricing-note,
  .analysis-start-card-editorial,
  .auth-card,
  .auth-aside,
  .analysis-support-card,
  .extension-status-panel,
  .product-hero-refined,
  .action-panel,
  .analysis-status-card {
    padding: 22px 20px;
  }

  .hero-copy-editorial h1,
  .pricing-hero-main h1,
  .auth-card h1 {
    max-width: none;
    font-size: clamp(1.85rem, 9vw, 2.7rem);
  }

  .analysis-form.analysis-form-hero,
  .marketing-analysis-form,
  .admin-notice-form {
    grid-template-columns: 1fr;
  }

  .home-benefit-grid,
  .workflow-grid,
  .pricing-plan-grid,
  .auth-account-stats,
  .analysis-ops-grid,
  .analysis-start-quick-grid,
  .admin-summary-grid {
    grid-template-columns: 1fr;
  }

  .analysis-start-intro,
  .extension-guide-summary,
  .site-footer {
    display: grid;
    gap: 14px;
  }

  .site-footer-top,
  .footer-links {
    justify-content: flex-start;
  }

  .site-footer-meta {
    text-align: left;
  }

  .auth-feature-item,
  .subscription-inline-meta,
  .admin-hero-card,
  .admin-console-grid,
  .admin-console-grid-single {
    grid-template-columns: 1fr;
  }

  .button-row,
  .header-actions {
    flex-wrap: wrap;
  }
}

@media (max-width: 480px) {
  .home-proof-item {
    width: 100%;
  }

  .plan-card,
  .feature-card,
  .workflow-card,
  .stat-card {
    padding: 18px;
  }
}

/* Leaner product-facing polish */
:root {
  --saas-shadow: 0 8px 24px rgba(15, 23, 42, 0.05);
}

.page-content {
  padding: 20px 28px 44px;
}

.hero-section,
.auth-page {
  gap: 18px;
}

.card,
.pricing-note,
.plan-card,
.stat-card,
.auth-card,
.auth-aside,
.analysis-start-card-editorial,
.analysis-status-card,
.extension-status-panel {
  border-radius: 14px;
}

.hero-copy-editorial,
.home-operations-card,
.pricing-note,
.analysis-start-card-editorial,
.auth-card,
.auth-aside,
.extension-status-panel,
.analysis-status-card {
  padding: 24px;
}

.hero-copy-editorial h1,
.pricing-hero-main h1,
.auth-card h1 {
  font-size: clamp(2rem, 3.2vw, 3.1rem);
  line-height: 1.02;
  letter-spacing: -0.045em;
}

.auth-account-card h1 {
  font-size: clamp(1.7rem, 2.8vw, 2.4rem);
}

.home-hero-main h1 {
  max-width: 560px;
  font-family: "SUIT Variable", "Pretendard Variable", "Pretendard", "Noto Sans KR", "Apple SD Gothic Neo", "Malgun Gothic", sans-serif;
  font-weight: 780;
  font-size: clamp(2.1rem, 3.4vw, 3.3rem);
  line-height: 0.96;
  letter-spacing: -0.06em;
  word-break: keep-all;
  text-wrap: balance;
}

.home-hero-main p {
  max-width: 620px;
  color: #5f6f83;
  font-size: 0.96rem;
  line-height: 1.6;
}

.home-hero-main .eyebrow {
  color: var(--saas-accent);
  font-size: 0.78rem;
  letter-spacing: 0.04em;
}

.hero-copy-editorial p,
.pricing-note p,
.auth-card p,
.auth-aside p,
.analysis-start-copy p,
.extension-status-panel p {
  font-size: 0.9rem;
  line-height: 1.55;
}

.home-inline-meta,
.analysis-inline-note,
.pricing-inline-note {
  font-size: 0.82rem;
}

.compact-metric-strip {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(110px, 1fr));
  gap: 10px;
}

.compact-metric {
  display: grid;
  gap: 4px;
  padding: 12px 14px;
  border: 1px solid var(--saas-border);
  border-radius: 12px;
  background: var(--saas-surface-soft);
}

.compact-metric span {
  color: var(--saas-muted);
  font-size: 0.72rem;
  font-weight: 700;
}

.compact-metric strong {
  color: var(--saas-text);
  font-size: 1rem;
  letter-spacing: -0.02em;
}

.compact-feature-strip {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.compact-feature {
  display: grid;
  gap: 4px;
  padding: 12px 14px;
  border: 1px solid rgba(215, 222, 231, 0.96);
  border-radius: 12px;
  background: var(--saas-surface-soft);
}

.compact-feature strong {
  color: var(--saas-text);
  font-size: 0.88rem;
}

.compact-feature span {
  color: var(--saas-muted);
  font-size: 0.8rem;
  line-height: 1.4;
}

.home-preview-panel,
.auth-card-lean,
.analysis-start-card-lean,
.pricing-operations-card {
  gap: 14px;
}

.analysis-start-card-lean {
  display: grid;
}

.analysis-start-copy {
  gap: 8px;
  max-width: 640px;
}

.analysis-start-copy h2 {
  font-size: clamp(1.45rem, 2.2vw, 2rem);
  line-height: 1.08;
  letter-spacing: -0.035em;
}

.plan-card {
  gap: 12px;
  padding: 18px;
}

.plan-card h3 {
  font-size: clamp(1.35rem, 2vw, 1.85rem);
}

.plan-card-summary {
  font-size: 0.92rem;
}

.plan-card .feature-list {
  gap: 6px;
  font-size: 0.86rem;
}

.subscription-inline-meta {
  padding: 10px 12px;
  border-radius: 12px;
}

@media (max-width: 1199px) {
  .compact-feature-strip,
  .compact-metric-strip {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 767px) {
  .page-content {
    padding: 18px 18px 36px;
  }

  .hero-copy-editorial,
  .home-operations-card,
  .pricing-note,
  .analysis-start-card-editorial,
  .auth-card,
  .auth-aside,
  .extension-status-panel,
  .analysis-status-card {
    padding: 20px 18px;
  }

  .hero-copy-editorial h1,
  .pricing-hero-main h1,
  .auth-card h1 {
    font-size: clamp(1.65rem, 8vw, 2.35rem);
  }

  .compact-feature-strip,
  .compact-metric-strip,
  .pricing-plan-grid {
    grid-template-columns: 1fr;
  }
}

/* Home preview replaces mockup cards */
.home-hero-main {
  gap: 16px;
}

.inline-fact-row {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 12px;
}

.inline-fact {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 34px;
  padding: 0 12px;
  border: 1px solid rgba(215, 222, 231, 0.96);
  border-radius: 999px;
  background: rgba(246, 248, 251, 0.9);
}

.inline-fact strong {
  color: var(--saas-muted);
  font-size: 0.76rem;
  font-weight: 700;
}

.inline-fact em {
  color: var(--saas-text);
  font-size: 0.84rem;
  font-style: normal;
  font-weight: 700;
}

.home-preview-panel {
  padding: 18px;
}

.home-product-preview {
  display: grid;
}

.product-preview-frame {
  display: grid;
  gap: 14px;
  padding: 16px;
  border: 1px solid rgba(215, 222, 231, 0.96);
  border-radius: 14px;
  background: linear-gradient(180deg, #f7f9fc 0%, #ffffff 100%);
}

.product-preview-topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.product-preview-topbar strong {
  color: var(--saas-text);
  font-size: 0.84rem;
  letter-spacing: -0.02em;
}

.product-preview-dot {
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: #16a34a;
  box-shadow: 0 0 0 4px rgba(22, 163, 74, 0.12);
}

.product-preview-search {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 8px;
}

.product-preview-search-input,
.product-preview-search-button {
  display: inline-flex;
  align-items: center;
  min-height: 40px;
  border-radius: 12px;
  font-size: 0.84rem;
  font-weight: 600;
}

.product-preview-search-input {
  padding: 0 12px;
  border: 1px solid rgba(215, 222, 231, 0.96);
  background: #ffffff;
  color: var(--saas-text);
}

.product-preview-search-button {
  padding: 0 14px;
  background: var(--saas-accent);
  color: #ffffff;
}

.product-preview-metrics {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}

.product-preview-metric {
  display: grid;
  gap: 4px;
  padding: 10px 12px;
  border: 1px solid rgba(215, 222, 231, 0.96);
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.92);
}

.product-preview-metric span {
  color: var(--saas-muted);
  font-size: 0.7rem;
  font-weight: 700;
}

.product-preview-metric strong {
  color: var(--saas-text);
  font-size: 0.84rem;
  letter-spacing: -0.02em;
}

.product-preview-table {
  display: grid;
  border: 1px solid rgba(215, 222, 231, 0.96);
  border-radius: 12px;
  overflow: hidden;
  background: #ffffff;
}

.product-preview-table-head,
.product-preview-table-row {
  display: grid;
  grid-template-columns: minmax(0, 1.8fr) 72px 88px;
  gap: 12px;
  align-items: center;
  padding: 12px 14px;
}

.product-preview-table-head {
  background: #f3f6fa;
  color: var(--saas-muted);
  font-size: 0.72rem;
  font-weight: 700;
}

.product-preview-table-row {
  border-top: 1px solid rgba(215, 222, 231, 0.72);
}

.product-preview-table-row strong {
  color: var(--saas-text);
  font-size: 0.82rem;
  font-weight: 600;
  line-height: 1.35;
}

.product-preview-table-row span {
  color: var(--saas-muted);
  font-size: 0.78rem;
}

.utility-page-shell {
  width: min(100%, 1040px);
  margin: 0 auto;
}

.utility-page-section {
  width: 100%;
  margin-bottom: 0.72rem;
}

.utility-hero,
.utility-note-panel,
.utility-support-panel,
.support-history-card,
.support-ticket-card,
.admin-inquiry-card {
  border-radius: 1.1rem;
}

.utility-hero {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(280px, 0.8fr);
  gap: 0.85rem;
  align-items: stretch;
  padding: 0.9rem 1rem;
}

.utility-hero-copy,
.utility-hero-side,
.utility-step-body,
.utility-support-side {
  display: grid;
  gap: 0.72rem;
}

.utility-hero-copy h1 {
  margin: 0;
  font-size: clamp(1.34rem, 1.9vw, 1.96rem);
  line-height: 1.02;
  letter-spacing: -0.045em;
  max-width: 14ch;
}

.utility-hero-copy p,
.utility-step-copy p,
.utility-note-card p,
.utility-timeline-body p,
.support-faq-item p,
.support-form-card > p,
.support-history-card > p,
.support-ticket-card p,
.admin-inquiry-card p {
  margin: 0;
  color: var(--editorial-text);
  font-size: 0.79rem;
  line-height: 1.55;
}

.utility-summary-grid {
  display: grid;
  gap: 0.65rem;
}

.utility-summary-grid-tight {
  align-content: start;
}

.utility-summary-card {
  padding: 0.82rem 0.92rem;
  border-radius: 0.95rem;
  border: 1px solid rgba(215, 222, 231, 0.84);
  background: rgba(248, 250, 252, 0.94);
}

.utility-summary-card span,
.utility-summary-card small {
  display: block;
  color: var(--editorial-muted);
}

.utility-summary-card span {
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

.utility-summary-card strong {
  display: block;
  margin: 0.26rem 0;
  color: var(--editorial-title);
  font-size: 0.96rem;
  line-height: 1.2;
}

.utility-summary-card small {
  font-size: 0.75rem;
  line-height: 1.45;
}

.utility-step-list,
.updates-list,
.support-ticket-list,
.admin-inquiry-list,
.utility-timeline {
  gap: 0.8rem;
}

.utility-step-item {
  display: grid;
  grid-template-columns: 44px minmax(0, 1fr);
  gap: 0.9rem;
  align-items: start;
  padding: 0.86rem 0.96rem;
}

.utility-step-index {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  border-radius: 14px;
  background: linear-gradient(180deg, #f0f7ff 0%, #e2efff 100%);
  color: #1d4ed8;
  font-size: 0.96rem;
  font-weight: 800;
}

.utility-step-copy {
  display: grid;
  gap: 0.35rem;
}

.utility-step-copy h3,
.utility-note-card h3,
.utility-timeline-body h3,
.support-contact-card h3,
.support-form-card h3,
.support-faq-card h3,
.support-history-card h3,
.support-ticket-card h3,
.admin-inquiry-card h3 {
  margin: 0;
  color: var(--editorial-title);
  font-size: 0.95rem;
  line-height: 1.3;
  letter-spacing: -0.02em;
}

.utility-step-actions {
  margin-top: 0.1rem;
}

.utility-note-panel {
  padding: 0.9rem 1rem;
}

.utility-note-grid,
.guide-flow-grid,
.support-page-grid {
  align-items: stretch;
}

.utility-note-card {
  padding: 0.82rem 0.88rem;
  border-radius: 0.95rem;
  border: 1px solid rgba(215, 222, 231, 0.78);
  background: rgba(248, 250, 252, 0.92);
}

.utility-timeline-item {
  display: grid;
  grid-template-columns: 20px minmax(0, 1fr);
  gap: 0.78rem;
  padding: 0.86rem 0.96rem;
}

.utility-timeline-rail {
  position: relative;
  width: 20px;
}

.utility-timeline-rail::before {
  content: "";
  position: absolute;
  left: 8px;
  top: 0;
  bottom: 0;
  width: 2px;
  border-radius: 999px;
  background: rgba(191, 219, 254, 0.88);
}

.utility-timeline-rail::after {
  content: "";
  position: absolute;
  left: 3px;
  top: 10px;
  width: 12px;
  height: 12px;
  border-radius: 999px;
  background: #2563eb;
  box-shadow: 0 0 0 4px rgba(219, 234, 254, 0.7);
}

.utility-timeline-body {
  gap: 0.6rem;
}

.utility-feature-list {
  gap: 0.38rem;
}

.support-contact-rows {
  display: grid;
  gap: 0.55rem;
}

.support-panel-heading {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 0.7rem;
}

.support-count-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 1.75rem;
  padding: 0.2rem 0.65rem;
  border-radius: 999px;
  background: rgba(226, 232, 240, 0.9);
  color: var(--editorial-title);
  font-size: 0.72rem;
  font-weight: 700;
  white-space: nowrap;
}

.utility-support-grid {
  align-items: start;
}

.support-form-card,
.support-faq-card,
.support-history-card {
  padding: 0.9rem 0.96rem;
}

.support-form-card .button-row,
.utility-hero .button-row {
  gap: 0.5rem;
}

.support-inquiry-form {
  gap: 0.72rem;
}

.support-inquiry-form label {
  display: grid;
  gap: 0.38rem;
}

.support-inquiry-form span {
  color: var(--editorial-muted);
  font-size: 0.74rem;
  font-weight: 700;
}

.support-faq-item {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr);
  gap: 0.8rem;
  align-items: start;
  padding: 0.82rem 0;
  border-bottom: 1px solid rgba(215, 222, 231, 0.78);
}

.support-faq-list > :last-child {
  border-bottom: 0;
  padding-bottom: 0;
}

.support-faq-list > :first-child {
  padding-top: 0;
}

.support-faq-index {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 34px;
  border-radius: 12px;
  background: rgba(219, 234, 254, 0.78);
  color: #1d4ed8;
  font-size: 0.74rem;
  font-weight: 800;
}

.support-faq-copy {
  display: grid;
  gap: 0.28rem;
}

.support-faq-item strong {
  display: block;
  color: var(--editorial-title);
  font-size: 0.84rem;
  line-height: 1.35;
}

.support-faq-item p {
  margin-top: 0.34rem;
}

.support-contact-card .mini-row-card,
.support-contact-rows .mini-row-card,
.admin-inquiry-card {
  background: rgba(248, 250, 252, 0.95);
  border: 1px solid rgba(215, 222, 231, 0.78);
}

.support-ticket-card,
.admin-inquiry-card {
  padding: 0.82rem 0.88rem;
}

.support-ticket-card {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 0.9rem;
  align-items: start;
  background: rgba(248, 250, 252, 0.95);
  border: 1px solid rgba(215, 222, 231, 0.78);
}

.support-ticket-main {
  display: grid;
  gap: 0.32rem;
}

.support-ticket-topline {
  align-items: center;
}

.support-ticket-date {
  white-space: nowrap;
  font-size: 0.74rem;
}

.support-ticket-card .muted,
.admin-inquiry-card .muted,
.utility-timeline-body .muted {
  margin-top: -0.16rem;
}

.utility-support-side {
  gap: 0.8rem;
}

.admin-inquiry-card .button-row {
  margin-top: 0.1rem;
}

@media (max-width: 767px) {
  .product-preview-metrics,
  .product-preview-search {
    grid-template-columns: 1fr;
  }

  .product-preview-table-head,
  .product-preview-table-row {
    grid-template-columns: minmax(0, 1fr) 60px 76px;
    gap: 8px;
    padding: 10px 12px;
  }

  .home-hero-main h1 {
    max-width: none;
    font-size: clamp(1.8rem, 8.4vw, 2.6rem);
    line-height: 1.02;
  }

  .utility-hero,
  .utility-step-item,
  .utility-timeline-item,
  .guide-flow-grid,
  .support-page-grid {
    grid-template-columns: 1fr;
  }

  .support-panel-heading,
  .support-ticket-card {
    grid-template-columns: 1fr;
  }

  .support-ticket-date {
    white-space: normal;
  }

  .utility-step-index {
    width: 40px;
    height: 40px;
  }

  .utility-timeline-rail {
    display: none;
  }
}

@media (min-width: 1025px) and (max-width: 1199px) {
  .hero-section,
  .auth-page,
  .home-saas-hero,
  .pricing-hero-saas {
    grid-template-columns: minmax(0, 1fr) minmax(360px, 0.92fr);
  }
}

/* premium marketing refinement */

.site-shell main {
  display: grid;
  gap: 0.9rem;
}

.site-shell .card,
.site-shell .section-surface,
.site-shell .table-shell {
  border-radius: 1.6rem;
  border: 1px solid rgba(215, 222, 231, 0.72);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(248, 250, 253, 0.95) 100%);
  box-shadow:
    0 12px 30px rgba(15, 23, 42, 0.04),
    inset 0 1px 0 rgba(255, 255, 255, 0.88);
}

.marketing-header {
  margin-top: 18px;
  padding: 16px 22px;
  border: 1px solid rgba(215, 222, 231, 0.74);
  border-radius: 1.45rem;
  background: rgba(250, 251, 253, 0.82);
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.03);
}

.brand-copy {
  display: grid;
  gap: 2px;
  line-height: 1.05;
}

.brand-copy strong {
  color: var(--saas-text);
  font-size: 0.96rem;
  letter-spacing: -0.03em;
}

.brand-copy small {
  color: var(--saas-muted);
  font-size: 0.68rem;
  font-weight: 600;
  letter-spacing: 0.03em;
  text-transform: uppercase;
}

.site-footer {
  margin-top: 12px;
  padding: 26px 0 36px;
}

.site-footer-brand {
  display: grid;
  gap: 6px;
}

.site-footer-tagline {
  color: var(--saas-muted);
  font-size: 0.86rem;
  line-height: 1.6;
}

.footer-links {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.footer-links a {
  display: inline-flex;
  align-items: center;
  min-height: 38px;
  padding: 0 14px;
  border: 1px solid rgba(215, 222, 231, 0.92);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.72);
  color: var(--saas-text);
  font-size: 0.84rem;
  font-weight: 700;
}

.site-shell .section-surface {
  padding: 28px;
}

.home-premium-hero,
.pricing-premium-hero,
.auth-page-premium {
  align-items: stretch;
}

.home-premium-hero-single {
  grid-template-columns: minmax(0, 1fr);
}

.pricing-premium-hero-single {
  grid-template-columns: minmax(0, 1fr);
}

.home-hero-premium-card,
.pricing-hero-main-premium {
  padding: 34px 36px;
  gap: 18px;
}

.home-premium-hero-single .home-hero-premium-card {
  position: relative;
  max-width: 940px;
  margin: 0 auto;
  padding: 48px 52px 42px;
  overflow: hidden;
  background:
    radial-gradient(circle at 100% 0%, rgba(49, 130, 246, 0.1), transparent 28%),
    radial-gradient(circle at 0% 100%, rgba(31, 58, 95, 0.06), transparent 24%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.99) 0%, rgba(248, 250, 253, 0.96) 100%);
}

.pricing-hero-main-premium {
  position: relative;
  width: 100%;
  max-width: 1040px;
  margin: 0 auto;
  padding: 54px 60px 48px;
  overflow: hidden;
  background:
    radial-gradient(circle at 100% 0%, rgba(49, 130, 246, 0.08), transparent 30%),
    radial-gradient(circle at 0% 100%, rgba(31, 58, 95, 0.05), transparent 24%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.99) 0%, rgba(248, 250, 253, 0.96) 100%);
}

.pricing-hero-main-centered {
  align-items: center;
  text-align: center;
}

.home-hero-label-row {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 12px;
  flex-wrap: wrap;
}

.home-hero-main h1,
.pricing-hero-main h1,
.auth-card h1 {
  max-width: 12ch;
  font-size: clamp(2.7rem, 4.2vw, 4.6rem);
  line-height: 0.94;
  letter-spacing: -0.07em;
}

.home-hero-main p,
.pricing-hero-main p,
.auth-card p,
.auth-aside p,
.home-story-card p,
.home-aside-card p,
.pricing-fit-card p,
.utility-hero-copy p,
.utility-note-card p,
.support-faq-item p,
.support-ticket-card p {
  font-size: 0.96rem;
  line-height: 1.72;
}

.home-hero-main h1 {
  max-width: none;
  font-family: "SUIT Variable", "Pretendard Variable", "Pretendard", "Noto Sans KR", sans-serif;
  font-size: clamp(2.2rem, 3vw, 3.35rem);
  font-weight: 760;
  line-height: 0.98;
  letter-spacing: -0.06em;
  text-wrap: balance;
}

.home-hero-main p {
  max-width: 44ch;
  color: #5f6f83;
  font-size: 1rem;
  line-height: 1.8;
}

.pricing-hero-label-row,
.pricing-hero-main-centered .button-row {
  justify-content: center;
}

.pricing-hero-main h1 {
  max-width: 8ch;
  margin: 0 auto;
  font-size: clamp(2.8rem, 4.1vw, 4.5rem);
  line-height: 0.92;
  letter-spacing: -0.075em;
}

.pricing-hero-main p {
  max-width: 48ch;
  margin: 0 auto;
  color: #5f6f83;
}

.pricing-hero-main-centered .compact-metric-strip,
.pricing-hero-main-centered .pricing-cap-grid,
.pricing-hero-main-centered .pricing-summary-copy,
.pricing-hero-main-centered .pricing-subscription-stack {
  width: min(100%, 760px);
  margin-left: auto;
  margin-right: auto;
}

.home-premium-hero-single .analysis-form.analysis-form-hero,
.home-premium-hero-single .home-preauth-actions {
  max-width: 560px;
}

.home-premium-hero-single .inline-fact-row {
  margin-top: 2px;
}

.home-hero-side-premium,
.auth-aside-stack,
.pricing-hero-aside-premium {
  display: grid;
  gap: 16px;
}

.home-hero-side-premium {
  align-content: start;
}

.home-aside-card,
.home-story-card,
.pricing-fit-card,
.auth-glance-card {
  padding: 22px 24px;
}

.home-aside-card h3,
.home-story-card h3,
.pricing-fit-card h3,
.auth-glance-card strong {
  color: var(--saas-text);
  letter-spacing: -0.03em;
}

.home-aside-card h3,
.home-story-card h3,
.pricing-fit-card h3 {
  margin: 0;
  font-size: 1.12rem;
  line-height: 1.3;
}

.home-premium-section {
  margin-top: 4px;
}

.home-story-grid,
.pricing-fit-grid,
.home-workflow-grid-premium {
  gap: 18px;
}

.home-story-card,
.home-workflow-card,
.pricing-fit-card,
.plan-card,
.support-history-card,
.utility-support-panel,
.utility-note-panel,
.utility-step-item,
.utility-timeline-item,
.utility-summary-card {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.96) 0%, rgba(244, 247, 251, 0.92) 100%);
}

.home-preview-layout {
  grid-template-columns: minmax(0, 1.08fr) minmax(280px, 0.92fr);
  gap: 18px;
  align-items: stretch;
}

.home-focus-card,
.home-brief-card,
.home-story-band,
.home-flow-panel,
.pricing-fit-band,
.home-summary-strip {
  padding: 24px;
}

.home-focus-card {
  display: grid;
  gap: 0;
}

.home-focus-row {
  display: grid;
  grid-template-columns: 92px minmax(0, 1fr);
  gap: 14px;
  padding: 14px 0;
  border-top: 1px solid rgba(215, 222, 231, 0.82);
}

.home-focus-card > :first-child {
  padding-top: 0;
  border-top: 0;
}

.home-focus-row h3,
.home-brief-head h3,
.home-flow-step h3,
.pricing-fit-item h3 {
  margin: 0;
  color: var(--saas-text);
  font-size: 1.04rem;
  line-height: 1.3;
  letter-spacing: -0.03em;
}

.home-focus-row p,
.home-brief-item p,
.home-flow-step p,
.pricing-fit-item p,
.auth-minimal-fact span {
  margin: 0;
  color: var(--saas-muted);
  font-size: 0.9rem;
  line-height: 1.62;
}

.home-story-band,
.pricing-fit-band,
.home-flow-panel {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0;
}

.home-flow-panel {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.home-story-item,
.pricing-fit-item,
.home-flow-step {
  display: grid;
  gap: 10px;
  padding: 2px 18px;
  border-left: 1px solid rgba(215, 222, 231, 0.82);
}

.home-story-band > :first-child,
.pricing-fit-band > :first-child,
.home-flow-panel > :first-child {
  padding-left: 0;
  border-left: 0;
}

.home-story-band > :last-child,
.pricing-fit-band > :last-child,
.home-flow-panel > :last-child {
  padding-right: 0;
}

.home-story-item h3 {
  margin: 0;
  color: var(--saas-text);
  font-size: 1.08rem;
  line-height: 1.34;
  letter-spacing: -0.03em;
}

.home-preview-shell {
  padding: 24px 24px 26px;
  display: grid;
  gap: 18px;
}

.home-preview-shell-hero {
  min-height: 100%;
}

.home-preview-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(220px, 0.54fr);
  gap: 14px;
  align-items: end;
}

.home-preview-head-simple {
  grid-template-columns: 1fr;
}

.home-preview-head h2 {
  margin: 6px 0 0;
  color: var(--saas-text);
  font-size: clamp(1.32rem, 2vw, 1.85rem);
  line-height: 1.08;
  letter-spacing: -0.05em;
}

.home-preview-kicker {
  text-align: right;
}

.home-summary-column {
  display: grid;
  gap: 16px;
  align-content: start;
}

.home-brief-card {
  display: grid;
  gap: 18px;
  align-content: start;
}

.home-brief-head {
  display: grid;
  gap: 6px;
}

.home-brief-list {
  display: grid;
  gap: 14px;
}

.home-brief-item {
  display: grid;
  gap: 6px;
  padding-top: 14px;
  border-top: 1px solid rgba(215, 222, 231, 0.82);
}

.home-brief-list > :first-child {
  padding-top: 0;
  border-top: 0;
}

.home-brief-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.home-brief-item span {
  color: var(--saas-muted);
  font-size: 0.82rem;
}

.home-brief-item strong {
  color: var(--saas-text);
  font-size: clamp(1.44rem, 2vw, 1.9rem);
  line-height: 1;
  letter-spacing: -0.05em;
}

.home-summary-strip {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0;
  padding: 22px 26px;
  background: rgba(255, 255, 255, 0.84);
}

.home-summary-strip-item {
  display: grid;
  gap: 8px;
  padding: 4px 18px;
  border-left: 1px solid rgba(215, 222, 231, 0.82);
}

.home-summary-strip > :first-child {
  padding-left: 0;
  border-left: 0;
}

.home-summary-strip > :last-child {
  padding-right: 0;
}

.home-summary-strip-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.home-summary-strip-item span {
  color: var(--saas-muted);
  font-size: 0.8rem;
}

.home-summary-strip-item strong {
  color: var(--saas-text);
  font-size: clamp(1.3rem, 1.8vw, 1.8rem);
  line-height: 1;
  letter-spacing: -0.05em;
}

.home-summary-strip-item p {
  margin: 0;
  color: var(--saas-muted);
  max-width: 22ch;
  font-size: 0.86rem;
  line-height: 1.6;
}

.home-workflow-card {
  padding: 22px;
}

.home-workflow-card h3 {
  margin: 0;
  color: var(--saas-text);
  font-size: 1.02rem;
  letter-spacing: -0.03em;
}

.home-workflow-card p {
  margin: 0;
  color: var(--saas-muted);
  font-size: 0.9rem;
  line-height: 1.65;
}

.auth-glance-list {
  display: grid;
  gap: 14px;
}

.auth-page-minimal {
  grid-template-columns: minmax(0, 1fr);
  justify-items: center;
  gap: 18px;
  padding-top: 16px;
}

.auth-card-minimal {
  width: min(100%, 820px);
  justify-items: stretch;
  text-align: left;
  padding: 40px 42px 34px;
  gap: 14px;
}

.auth-card-minimal h1 {
  max-width: none;
  margin: 0;
  font-size: clamp(2rem, 3vw, 3.05rem);
  line-height: 0.96;
  letter-spacing: -0.06em;
}

.auth-login-topline {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
}

.auth-login-brand {
  color: #607085;
  font-size: 0.82rem;
  font-weight: 600;
  letter-spacing: -0.02em;
}

.auth-primary-actions-compact {
  justify-content: flex-start;
}

.auth-status-inline {
  width: 100%;
  display: grid;
  gap: 6px;
  padding: 14px 16px;
  border: 1px solid rgba(214, 222, 232, 0.86);
  border-radius: 16px;
  background: rgba(248, 250, 253, 0.68);
  text-align: left;
}

.auth-status-inline-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
}

.auth-status-inline-state {
  color: var(--saas-text);
  font-size: 0.84rem;
  font-weight: 700;
  letter-spacing: -0.02em;
}

.auth-status-inline p {
  margin: 0;
  color: var(--saas-muted);
  font-size: 0.86rem;
  line-height: 1.58;
}

.auth-minimal-facts {
  width: 100%;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  margin-top: 4px;
}

.auth-minimal-facts-strip {
  gap: 0;
  margin-top: 2px;
}

.auth-minimal-fact {
  display: grid;
  gap: 4px;
  padding: 12px 16px 12px 0;
  border-radius: 0;
  background: transparent;
  border: 0;
  border-left: 1px solid rgba(214, 222, 232, 0.82);
  text-align: left;
}

.auth-minimal-facts-strip > :first-child {
  border-left: 0;
  padding-left: 0;
}

.auth-minimal-facts-strip > :not(:first-child) {
  padding-left: 16px;
}

.auth-minimal-fact strong {
  color: var(--saas-text);
  font-size: 0.92rem;
}

.auth-minimal-fact span {
  font-size: 0.82rem;
  line-height: 1.55;
}

.auth-aside-stack-minimal {
  width: min(100%, 760px);
}

.auth-card-login-refined,
.auth-card-account-refined {
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(circle at 100% 0%, rgba(49, 130, 246, 0.08), transparent 28%),
    radial-gradient(circle at 0% 100%, rgba(31, 58, 95, 0.05), transparent 22%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.99) 0%, rgba(248, 250, 253, 0.96) 100%);
}

.auth-card-login-refined .button-row,
.auth-card-account-refined .button-row {
  justify-content: flex-start;
}

.auth-card-login-refined .compact-metric-strip,
.auth-card-account-refined .compact-metric-strip {
  width: min(100%, 620px);
}

.auth-link-row {
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
}

.auth-link-row a {
  color: #607085;
  font-size: 0.84rem;
  font-weight: 600;
}

.auth-glance-item {
  display: grid;
  gap: 4px;
  padding-top: 14px;
  border-top: 1px solid rgba(215, 222, 231, 0.82);
}

.auth-glance-list > :first-child {
  padding-top: 0;
  border-top: 0;
}

.auth-glance-item strong {
  font-size: 0.98rem;
}

.pricing-summary-panel,
.pricing-fit-summary-card {
  padding: 24px 24px 22px;
}

.pricing-summary-panel {
  display: grid;
  gap: 16px;
  align-content: start;
}

.pricing-summary-head {
  display: grid;
  gap: 8px;
}

.pricing-summary-head h3 {
  margin: 0;
  color: var(--saas-text);
  font-size: 1.2rem;
  letter-spacing: -0.04em;
}

.pricing-summary-head p {
  margin: 0;
  color: var(--saas-muted);
  font-size: 0.92rem;
  line-height: 1.68;
}

.pricing-cap-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.pricing-cap-item {
  display: grid;
  gap: 6px;
  padding: 14px 14px 13px;
  border: 1px solid rgba(214, 222, 232, 0.88);
  border-radius: 14px;
  background: rgba(248, 250, 253, 0.8);
}

.pricing-cap-item span {
  color: var(--saas-muted);
  font-size: 0.72rem;
  font-weight: 700;
}

.pricing-cap-item strong {
  color: var(--saas-text);
  font-size: 0.94rem;
  letter-spacing: -0.03em;
}

.pricing-summary-copy {
  display: grid;
  gap: 6px;
  padding-top: 14px;
  border-top: 1px solid rgba(214, 222, 232, 0.82);
}

.pricing-summary-copy strong {
  color: var(--saas-text);
  font-size: 0.82rem;
  letter-spacing: -0.01em;
}

.pricing-summary-copy p {
  margin: 0;
  color: var(--saas-muted);
  font-size: 0.9rem;
  line-height: 1.68;
}

.pricing-summary-copy-centered {
  justify-items: center;
  text-align: center;
}

.pricing-subscription-stack {
  display: grid;
  gap: 12px;
}

.pricing-hero-ghost {
  min-width: 180px;
  justify-self: center;
}

.pricing-fit-summary-card h3 {
  margin: 0;
  color: var(--saas-text);
  font-size: 1.08rem;
  letter-spacing: -0.03em;
}

.plan-card {
  display: flex;
  flex-direction: column;
  padding: 26px 24px;
  min-height: 100%;
  gap: 14px;
  border-radius: 22px;
}

.plan-card h3 {
  font-size: clamp(1.7rem, 2.4vw, 2.3rem);
  letter-spacing: -0.05em;
}

.plan-card-summary {
  font-size: 1.02rem;
  line-height: 1.55;
}

.plan-card-note {
  margin: -2px 0 2px;
  color: #5f6f83;
  font-size: 0.84rem;
  line-height: 1.58;
}

.pricing-plan-surface {
  width: 100%;
  max-width: 1120px;
  margin: 0 auto;
  padding: 34px 36px 38px;
}

.pricing-plan-surface .section-heading,
.pricing-comparison-section .section-heading {
  justify-content: center;
  text-align: center;
}

.pricing-plan-surface .section-heading > div,
.pricing-comparison-section .section-heading > div {
  max-width: 520px;
}

.pricing-plan-grid {
  gap: 18px;
  align-items: stretch;
}

.plan-card .feature-list {
  margin-top: 2px;
}

.plan-card .button-block {
  margin-top: auto;
}

.pricing-comparison-section {
  width: min(100%, 1040px);
  margin-left: auto;
  margin-right: auto;
}

.utility-page-shell {
  width: min(100%, 1100px);
}

.utility-page-section {
  margin-bottom: 0.85rem;
}

.utility-hero {
  grid-template-columns: minmax(0, 1.12fr) minmax(280px, 0.88fr);
  gap: 18px;
  padding: 26px 28px;
}

.utility-hero-copy h1 {
  max-width: 12ch;
  font-size: clamp(2rem, 3vw, 3rem);
  line-height: 0.98;
  letter-spacing: -0.06em;
}

.utility-summary-grid {
  gap: 12px;
}

.utility-summary-card {
  padding: 18px 18px 16px;
}

.utility-summary-card strong {
  font-size: 1.08rem;
}

.utility-step-item,
.utility-timeline-item {
  padding: 20px 22px;
}

.utility-step-copy h3,
.utility-note-card h3,
.utility-timeline-body h3,
.support-form-card h3,
.support-faq-card h3,
.support-history-card h3,
.support-ticket-card h3 {
  font-size: 1.08rem;
}

.support-form-card,
.support-faq-card,
.support-history-card {
  padding: 22px 24px;
}

.support-faq-item {
  padding: 16px 0;
}

.support-ticket-card {
  padding: 18px 18px 16px;
}

@media (max-width: 1199px) {
  .home-preview-layout,
  .home-preview-head {
    grid-template-columns: 1fr;
  }

  .home-story-band,
  .pricing-fit-band,
  .home-flow-panel,
  .auth-minimal-facts,
  .home-summary-strip {
    grid-template-columns: 1fr;
  }

  .home-story-item,
  .pricing-fit-item,
  .home-flow-step {
    padding: 16px 0;
    border-left: 0;
    border-top: 1px solid rgba(215, 222, 231, 0.82);
  }

  .home-story-band > :first-child,
  .pricing-fit-band > :first-child,
  .home-flow-panel > :first-child {
    padding-top: 0;
    border-top: 0;
  }

  .home-focus-row {
    grid-template-columns: 1fr;
  }

  .home-summary-strip-item {
    padding: 16px 0;
    border-left: 0;
    border-top: 1px solid rgba(215, 222, 231, 0.82);
  }

  .home-summary-strip > :first-child {
    padding-top: 0;
    border-top: 0;
  }
}

@media (max-width: 767px) {
  .marketing-header {
    margin-top: 12px;
    padding: 14px 16px;
  }

  .home-hero-premium-card,
  .pricing-hero-main-premium,
  .home-preview-shell,
  .home-story-card,
  .auth-glance-card,
  .pricing-summary-panel,
  .pricing-fit-summary-card,
  .support-form-card,
  .support-faq-card,
  .support-history-card {
    padding: 20px 18px;
  }

  .home-hero-main h1,
  .pricing-hero-main h1,
  .auth-card h1,
  .utility-hero-copy h1 {
    max-width: none;
    font-size: clamp(2rem, 10vw, 2.8rem);
  }

  .home-hero-main h1 {
    font-size: clamp(1.9rem, 9vw, 2.45rem);
    line-height: 1;
  }

  .pricing-hero-main h1 {
    font-size: clamp(2.1rem, 10vw, 3rem);
    max-width: none;
  }

  .site-shell .section-surface {
    padding: 20px 18px;
  }

  .home-focus-card,
  .home-brief-card,
  .home-story-band,
  .home-flow-panel,
  .pricing-fit-band,
  .auth-card-minimal {
    padding: 20px 18px;
  }

  .home-premium-hero-single .home-hero-premium-card {
    padding: 28px 24px 26px;
  }

  .pricing-hero-main-premium,
  .pricing-plan-surface {
    padding: 28px 24px 26px;
  }

  .auth-card-minimal {
    width: 100%;
    padding: 28px 24px 24px;
  }

  .auth-status-inline {
    width: 100%;
    padding: 14px 15px;
  }

  .auth-login-topline {
    align-items: flex-start;
  }

  .auth-minimal-facts {
    grid-template-columns: 1fr;
  }

  .auth-minimal-fact {
    border-left: 0;
    border-top: 1px solid rgba(214, 222, 232, 0.82);
    padding: 12px 0;
  }

  .auth-minimal-facts-strip > :first-child {
    border-top: 0;
    padding-top: 0;
  }

  .auth-minimal-facts-strip > :not(:first-child) {
    padding-left: 0;
  }

  .pricing-cap-grid {
    grid-template-columns: 1fr;
  }

  .site-footer-top {
    align-items: flex-start;
  }

  .footer-links {
    width: 100%;
  }
}

/* 2026 Compact SaaS System Layer */
:root {
  --system-bg: #f4f7fb;
  --system-bg-soft: #edf3fb;
  --system-surface: rgba(255, 255, 255, 0.96);
  --system-surface-strong: rgba(255, 255, 255, 0.99);
  --system-surface-muted: rgba(247, 250, 253, 0.92);
  --system-border: rgba(140, 159, 186, 0.18);
  --system-border-strong: rgba(109, 132, 168, 0.24);
  --system-text: #172334;
  --system-text-soft: #4f6177;
  --system-text-faint: #72839a;
  --system-accent: #214fdb;
  --system-accent-strong: #173fb6;
  --system-accent-soft: rgba(33, 79, 219, 0.08);
  --system-success-soft: rgba(12, 156, 105, 0.12);
  --system-warning-soft: rgba(217, 138, 33, 0.12);
  --system-radius-xl: 28px;
  --system-radius-lg: 22px;
  --system-radius-md: 16px;
  --system-radius-sm: 12px;
  --system-shadow-lg: 0 18px 48px rgba(18, 33, 61, 0.08);
  --system-shadow-md: 0 10px 26px rgba(18, 33, 61, 0.06);
  --system-shadow-sm: 0 4px 12px rgba(18, 33, 61, 0.04);
  --system-ring: 0 0 0 4px rgba(33, 79, 219, 0.12);
  --system-max-marketing: 1180px;
  --system-max-workspace: 1440px;
  --system-gutter: clamp(18px, 2vw, 28px);
}

html {
  color: var(--system-text);
}

body {
  font-family: var(--font-sans, "SUIT Variable", "Pretendard Variable", "Pretendard", "Noto Sans KR", sans-serif);
  color: var(--system-text);
  background:
    radial-gradient(circle at top left, rgba(33, 79, 219, 0.1), transparent 28%),
    radial-gradient(circle at top right, rgba(182, 206, 255, 0.35), transparent 24%),
    linear-gradient(180deg, #f9fbff 0%, var(--system-bg) 40%, #eef3fa 100%);
}

.site-shell,
.app-shell {
  position: relative;
  min-height: 100vh;
}

.site-shell::before,
.app-shell::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.18), rgba(255, 255, 255, 0)),
    radial-gradient(circle at 50% 0%, rgba(255, 255, 255, 0.45), transparent 42%);
  opacity: 0.72;
}

.marketing-shell {
  padding: 0 var(--system-gutter) 56px;
}

.workspace-shell {
  display: grid;
  grid-template-columns: 252px minmax(0, 1fr);
  gap: 18px;
  width: min(100%, var(--system-max-workspace));
  margin: 0 auto;
  padding: 16px var(--system-gutter) 44px;
}

.workspace-main {
  min-width: 0;
}

.site-main {
  display: grid;
  gap: 12px;
}

.marketing-header,
.site-footer,
.hero-section,
.section {
  width: min(100%, var(--system-max-marketing));
}

.page-content,
.page-content-workspace {
  width: min(100%, var(--system-max-workspace));
  margin: 0 auto;
  padding: 0 0 48px;
}

.page-content > .section,
.site-main > .section,
.site-main > .hero-section {
  position: relative;
  z-index: 1;
}

.marketing-header,
.app-header,
.sidebar,
.site-footer,
.notice,
.card,
.section-surface,
.table-shell,
.auth-status-inline,
.utility-summary-card,
.utility-note-card,
.support-faq-item,
.compact-metric,
.info-pair,
.mini-row-card {
  background: linear-gradient(180deg, var(--system-surface-strong) 0%, var(--system-surface) 100%);
  border: 1px solid var(--system-border);
  box-shadow: var(--system-shadow-md);
}

.marketing-header {
  position: sticky;
  top: 14px;
  z-index: 40;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  margin-top: 14px;
  padding: 14px 18px;
  border-radius: 24px;
  backdrop-filter: blur(18px);
}

.brand {
  gap: 12px;
}

.brand-mark {
  width: 34px;
  height: 34px;
  border-radius: 12px;
  background: linear-gradient(180deg, var(--system-accent) 0%, var(--system-accent-strong) 100%);
  box-shadow: 0 10px 20px rgba(33, 79, 219, 0.18);
}

.brand-copy strong {
  color: var(--system-text);
  font-size: 0.98rem;
  letter-spacing: -0.03em;
}

.brand-copy small {
  color: var(--system-text-faint);
  font-size: 0.74rem;
}

.nav-links {
  gap: 8px;
}

.nav-link {
  min-height: 40px;
  padding: 10px 14px;
  border-radius: 999px;
  color: var(--system-text-soft);
  font-size: 0.9rem;
  font-weight: 600;
}

.nav-link:hover,
.nav-link.is-active {
  background: var(--system-accent-soft);
  color: var(--system-accent-strong);
}

.workspace-sidebar {
  position: sticky;
  top: 16px;
  align-self: start;
  display: grid;
  gap: 18px;
  padding: 18px;
  border-radius: 28px;
  max-height: calc(100vh - 32px);
  overflow: auto;
}

.brand-sidebar {
  padding-bottom: 4px;
}

.sidebar-block {
  display: grid;
  gap: 10px;
}

.sidebar .nav-link {
  justify-content: flex-start;
  min-height: 44px;
  padding: 11px 14px;
  border-radius: 14px;
}

.sidebar .nav-link.is-active {
  position: relative;
  background: rgba(24, 57, 144, 0.08);
  color: var(--system-text);
}

.workspace-sidebar-card {
  display: grid;
  gap: 12px;
  padding: 18px;
  border-radius: 20px;
}

.workspace-sidebar-card strong {
  color: var(--system-text);
  font-size: 1rem;
  letter-spacing: -0.03em;
}

.workspace-sidebar-card p {
  color: var(--system-text-soft);
  font-size: 0.84rem;
  line-height: 1.6;
}

.workspace-sidebar-links {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.workspace-sidebar-links .button {
  flex: 1 1 auto;
}

.app-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 14px;
  padding: 0;
}

.app-header > div:first-child,
.app-header .header-actions {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.94) 0%, rgba(248, 250, 253, 0.9) 100%);
  border: 1px solid var(--system-border);
  box-shadow: var(--system-shadow-sm);
  backdrop-filter: blur(16px);
}

.app-header > div:first-child {
  flex: 1 1 auto;
  padding: 16px 18px;
  border-radius: 22px;
}

.app-header h1 {
  color: var(--system-text);
  font-size: clamp(1.22rem, 1.6vw, 1.62rem);
  line-height: 1.04;
  letter-spacing: -0.055em;
  margin-bottom: 4px;
}

.app-header .muted {
  color: var(--system-text-faint);
  font-size: 0.8rem;
}

.app-header .header-actions {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px;
  border-radius: 999px;
}

.page-content > * + * {
  margin-top: 4px;
}

.button-row,
.chip-row,
.header-actions {
  gap: 10px;
}

.button {
  min-height: 42px;
  padding: 10px 16px;
  border-radius: 14px;
  border: 1px solid transparent;
  font-size: 0.9rem;
  font-weight: 700;
  letter-spacing: -0.03em;
  transition: transform 0.16s ease, box-shadow 0.16s ease, background-color 0.16s ease, border-color 0.16s ease, color 0.16s ease;
}

.button:hover {
  transform: translateY(-1px);
}

.button:focus-visible,
.chip-button:focus-visible,
.nav-link:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible,
a:focus-visible {
  outline: none;
  box-shadow: var(--system-ring);
}

.button-primary {
  background: linear-gradient(180deg, var(--system-accent) 0%, var(--system-accent-strong) 100%);
  color: #ffffff;
  box-shadow: 0 12px 24px rgba(33, 79, 219, 0.2);
}

.button-primary:hover {
  background: linear-gradient(180deg, #2b5eeb 0%, #193fbb 100%);
  box-shadow: 0 16px 26px rgba(33, 79, 219, 0.24);
}

.button-secondary,
.button-ghost {
  background: rgba(255, 255, 255, 0.92);
  border-color: var(--system-border-strong);
  color: var(--system-text);
  box-shadow: none;
}

.button-ghost {
  background: transparent;
  color: var(--system-text-soft);
}

.button-small {
  min-height: 36px;
  padding: 8px 13px;
  font-size: 0.82rem;
}

.button[disabled],
button[disabled] {
  opacity: 0.58;
  cursor: not-allowed;
  transform: none;
  box-shadow: none;
}

input,
select,
textarea {
  min-height: 44px;
  border-radius: 14px;
  padding: 11px 14px;
  border: 1px solid var(--system-border-strong);
  background: rgba(255, 255, 255, 0.96);
  color: var(--system-text);
  transition: border-color 0.16s ease, box-shadow 0.16s ease, background-color 0.16s ease;
}

textarea {
  min-height: 116px;
}

input::placeholder,
textarea::placeholder {
  color: #96a4b8;
}

input:hover,
select:hover,
textarea:hover {
  border-color: rgba(33, 79, 219, 0.24);
}

input:focus,
select:focus,
textarea:focus {
  border-color: rgba(33, 79, 219, 0.44);
  box-shadow: var(--system-ring);
}

.card,
.section-surface,
.table-shell,
.sidebar-card,
.notice {
  border-radius: var(--system-radius-lg);
}

.card {
  padding: 22px;
  gap: 14px;
}

.section {
  padding: 8px 0;
}

.section-surface {
  padding: 28px;
}

.section-heading {
  align-items: flex-end;
  gap: 14px;
  margin-bottom: 20px;
}

.section-heading-copy {
  display: grid;
  gap: 6px;
}

.section-heading h2 {
  color: var(--system-text);
  font-size: clamp(1.34rem, 2vw, 1.9rem);
  line-height: 1.06;
  letter-spacing: -0.05em;
}

.eyebrow {
  color: var(--system-accent);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.08em;
}

.muted,
.card p,
.site-footer p,
.hero-copy p,
.auth-card p,
.pricing-note p {
  color: var(--system-text-soft);
}

.chip,
.badge,
.support-count-pill,
.analysis-status-badge,
.status-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 28px;
  padding: 6px 10px;
  border-radius: 999px;
  background: rgba(243, 247, 252, 0.92);
  border: 1px solid rgba(140, 159, 186, 0.2);
  color: var(--system-text-soft);
  font-size: 0.72rem;
  font-weight: 700;
  box-shadow: none;
}

.chip-highlight,
.chip-active,
.badge-info,
.badge-success {
  background: var(--system-accent-soft);
  border-color: rgba(33, 79, 219, 0.18);
  color: var(--system-accent-strong);
}

.badge-warning {
  background: var(--system-warning-soft);
  border-color: rgba(217, 138, 33, 0.18);
  color: #b56f13;
}

.chip-button {
  cursor: pointer;
  transition: background-color 0.16s ease, border-color 0.16s ease, color 0.16s ease, transform 0.16s ease;
}

.chip-button:hover {
  transform: translateY(-1px);
  background: rgba(245, 248, 253, 0.98);
  border-color: rgba(33, 79, 219, 0.16);
}

.notice {
  width: min(100%, var(--system-max-marketing));
  margin: 12px auto 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 14px 16px;
  background: rgba(255, 255, 255, 0.96);
}

.notice-info {
  border-color: rgba(33, 79, 219, 0.18);
}

.notice-success {
  border-color: rgba(12, 156, 105, 0.18);
}

.notice-warning {
  border-color: rgba(217, 138, 33, 0.18);
}

.hero-section {
  grid-template-columns: minmax(0, 1fr);
  gap: 18px;
  padding: 18px 0 8px;
}

.hero-copy,
.auth-card,
.auth-aside,
.pricing-note {
  gap: 14px;
}

.home-premium-hero-single .home-hero-premium-card,
.pricing-hero-main-premium,
.auth-card-login-refined,
.auth-card-account-refined {
  width: 100%;
  max-width: 1040px;
  margin: 0 auto;
  padding: 36px 40px;
  border-radius: 30px;
}

.home-hero-main h1,
.pricing-hero-main h1,
.auth-card h1,
.utility-hero-copy h1 {
  color: var(--system-text);
  margin: 0;
  font-size: clamp(1.72rem, 3.15vw, 2.92rem);
  line-height: 1.02;
  letter-spacing: -0.058em;
  text-wrap: balance;
}

.home-hero-main p,
.pricing-hero-main p,
.auth-card p {
  max-width: 44ch;
  font-size: 1rem;
  line-height: 1.72;
}

.inline-fact-row,
.compact-metric-strip {
  gap: 10px;
}

.inline-fact-row {
  display: flex;
  flex-wrap: wrap;
}

.inline-fact {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(244, 247, 252, 0.94);
  border: 1px solid rgba(140, 159, 186, 0.18);
}

.inline-fact strong {
  color: var(--system-text-faint);
  font-size: 0.76rem;
}

.inline-fact em {
  color: var(--system-text);
  font-style: normal;
  font-size: 0.82rem;
  font-weight: 700;
}

.compact-metric-strip {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
}

.compact-metric {
  gap: 6px;
  padding: 14px 14px 13px;
  border-radius: 16px;
  background: rgba(248, 250, 253, 0.8);
}

.compact-metric span {
  color: var(--system-text-faint);
  font-size: 0.72rem;
}

.compact-metric strong {
  color: var(--system-text);
  font-size: 1rem;
  letter-spacing: -0.03em;
}

.home-summary-strip,
.pricing-cap-grid,
.auth-minimal-facts-strip {
  width: min(100%, 1080px);
  margin-left: auto;
  margin-right: auto;
}

.home-summary-strip {
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.9);
  box-shadow: var(--system-shadow-md);
}

.home-summary-strip-item {
  gap: 10px;
}

.home-summary-strip-item strong {
  color: var(--system-text);
  font-size: clamp(1.4rem, 2.2vw, 2rem);
  letter-spacing: -0.06em;
}

.home-summary-strip-item p {
  color: var(--system-text-soft);
}

.pricing-premium-hero-single,
.auth-page-minimal {
  padding-top: 8px;
}

.pricing-hero-main-centered,
.auth-card-minimal {
  justify-items: stretch;
}

.pricing-hero-main-centered {
  align-items: center;
  text-align: center;
}

.pricing-hero-label-row,
.pricing-hero-main-centered .button-row,
.auth-card-login-refined .button-row,
.auth-card-account-refined .button-row {
  justify-content: flex-start;
}

.pricing-hero-label-row,
.pricing-hero-main-centered .button-row {
  justify-content: center;
}

.pricing-cap-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.pricing-cap-item {
  padding: 16px;
  border-radius: 18px;
  background: rgba(248, 250, 253, 0.82);
  border: 1px solid rgba(140, 159, 186, 0.16);
}

.pricing-cap-item strong {
  color: var(--system-text);
  font-size: 0.92rem;
}

.pricing-hero-main h1 {
  max-width: 12ch;
  margin-left: auto;
  margin-right: auto;
}

.pricing-hero-main p,
.pricing-hero-note {
  max-width: 56ch;
  margin-left: auto;
  margin-right: auto;
}

.pricing-hero-note {
  color: var(--system-text-faint);
  font-size: 0.8rem;
  line-height: 1.5;
}

.pricing-plan-surface,
.pricing-comparison-section,
.utility-page-shell {
  width: min(100%, 1180px);
  margin-left: auto;
  margin-right: auto;
}

.pricing-plan-surface,
.pricing-comparison-section,
.pricing-faq-section {
  max-width: 1120px;
}

.pricing-plan-grid,
.utility-summary-grid,
.utility-note-grid,
.support-page-grid,
.admin-stats-grid {
  gap: 16px;
}

.pricing-plan-intro {
  margin: -2px 0 18px;
  color: var(--system-text-faint);
  font-size: 0.88rem;
  text-align: center;
}

.plan-card {
  padding: 22px;
  gap: 12px;
  border-radius: 24px;
}

.plan-card-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.plan-card h3 {
  color: var(--system-text);
  font-size: clamp(1.9rem, 2.5vw, 2.5rem);
  line-height: 0.96;
}

.plan-card-summary {
  color: var(--system-text);
  font-size: 0.96rem;
}

.plan-card-note,
.pricing-summary-copy p,
.utility-hero-copy p,
.utility-note-card p,
.support-faq-copy p,
.support-ticket-card p {
  color: var(--system-text-soft);
}

.plan-card .feature-list {
  list-style: none;
  padding: 0;
  margin-bottom: 0;
  margin-top: 2px;
}

.plan-card .feature-list li {
  padding-left: 0;
  color: var(--system-text-soft);
  font-size: 0.84rem;
  line-height: 1.5;
}

.plan-card .feature-list li::before {
  display: none;
}

.plan-card .button-block {
  margin-top: auto;
  min-height: 40px;
}

.pricing-faq-section {
  margin-bottom: 8px;
}

.pricing-faq-list {
  gap: 0;
}

.pricing-faq-item {
  padding: 18px 0;
  border-top: 1px solid rgba(140, 159, 186, 0.14);
}

.pricing-faq-list > :first-child {
  padding-top: 0;
  border-top: 0;
}

.pricing-faq-question {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
}

.pricing-faq-question strong {
  color: var(--system-text);
  font-size: 0.98rem;
  letter-spacing: -0.03em;
}

.pricing-faq-question span {
  color: var(--system-text-faint);
  font-size: 1rem;
  font-weight: 700;
}

.pricing-faq-item p {
  margin-top: 8px;
  max-width: 78ch;
  color: var(--system-text-soft);
  font-size: 0.88rem;
  line-height: 1.64;
}

.utility-hero {
  grid-template-columns: minmax(0, 1.05fr) minmax(280px, 0.95fr);
  gap: 18px;
  padding: 28px 30px;
  border-radius: 30px;
}

.utility-hero-copy {
  display: grid;
  align-content: start;
  gap: 14px;
}

.utility-hero-copy h1 {
  max-width: 11ch;
}

.utility-summary-card,
.utility-note-card,
.utility-step-item,
.utility-timeline-item,
.support-form-card,
.support-faq-card,
.support-history-card,
.support-ticket-card {
  border-radius: 22px;
}

.utility-step-item,
.utility-timeline-item,
.support-form-card,
.support-faq-card,
.support-history-card {
  padding: 22px 24px;
}

.support-contact-rows,
.support-ticket-list,
.utility-step-list,
.utility-timeline,
.support-faq-list {
  gap: 12px;
}

.support-faq-item {
  grid-template-columns: 40px minmax(0, 1fr);
  gap: 14px;
  padding: 16px 0;
  background: transparent;
  border: 0;
  border-top: 1px solid rgba(140, 159, 186, 0.14);
  box-shadow: none;
}

.support-faq-list > :first-child {
  border-top: 0;
  padding-top: 0;
}

.support-faq-index {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border-radius: 999px;
  background: var(--system-accent-soft);
  color: var(--system-accent-strong);
  font-size: 0.72rem;
  font-weight: 700;
}

.auth-card-minimal {
  width: min(100%, 860px);
  padding: 34px 36px;
  gap: 14px;
}

.auth-login-topline {
  align-items: center;
}

.auth-login-brand {
  color: var(--system-text-faint);
}

.auth-status-inline {
  box-shadow: none;
}

.auth-minimal-facts-strip {
  border-top: 1px solid rgba(140, 159, 186, 0.14);
  padding-top: 12px;
}

.auth-minimal-fact strong {
  color: var(--system-text);
}

.dashboard-grid,
.analysis-detail-layout,
.support-page-grid,
.admin-console-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(280px, 0.4fr);
  gap: 16px;
}

.analysis-detail-layout {
  grid-template-columns: minmax(0, 1.25fr) minmax(300px, 0.75fr);
}

.admin-console-grid-single {
  grid-template-columns: minmax(0, 1fr);
}

.analysis-start-card,
.compare-topbar,
.filter-card,
.admin-hero-card,
.product-hero-refined,
.extension-status-panel,
.analysis-status-card,
.action-panel,
.saved-card,
.comparison-card,
.admin-panel {
  padding: 22px 24px;
  border-radius: 24px;
}

.analysis-start-card {
  gap: 16px;
}

.analysis-start-copy h2 {
  color: var(--system-text);
  font-size: clamp(1.7rem, 2.4vw, 2.4rem);
  line-height: 0.98;
  letter-spacing: -0.06em;
  margin: 0;
}

.analysis-start-copy p,
.analysis-inline-note {
  color: var(--system-text-soft);
}

.analysis-search-shell-flat {
  padding: 0;
  background: transparent;
  border: 0;
  box-shadow: none;
}

.analysis-form.analysis-form-hero,
.marketing-analysis-form {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
  padding: 8px;
  border-radius: 18px;
  background: rgba(246, 249, 253, 0.9);
  border: 1px solid rgba(140, 159, 186, 0.16);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.76);
}

.analysis-form.analysis-form-hero input,
.marketing-analysis-form input {
  border: 0;
  background: transparent;
  box-shadow: none;
  min-height: 44px;
}

.analysis-form.analysis-form-hero input:focus,
.marketing-analysis-form input:focus {
  box-shadow: none;
}

.product-hero-refined {
  display: grid;
  grid-template-columns: 112px minmax(0, 1fr) 220px;
  gap: 20px;
  align-items: start;
}

.product-thumb {
  width: 112px;
  height: 112px;
  border-radius: 24px;
  background: rgba(244, 247, 252, 0.94);
  color: var(--system-accent-strong);
  font-size: 1.6rem;
  font-weight: 700;
  box-shadow: inset 0 0 0 1px rgba(140, 159, 186, 0.12);
}

.product-thumb img {
  border-radius: 24px;
}

.product-copy h2 {
  color: var(--system-text);
  font-size: clamp(1.8rem, 2.4vw, 2.5rem);
  line-height: 1.03;
  letter-spacing: -0.055em;
  margin: 0;
}

.product-meta-line,
.analysis-field-note,
.analysis-inline-note,
.compact-meta-text {
  color: var(--system-text-faint);
  font-size: 0.82rem;
}

.product-actions-sticky,
.analysis-detail-side,
.stack {
  gap: 12px;
}

.info-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.info-pair {
  display: grid;
  gap: 6px;
  padding: 14px;
  border-radius: 18px;
}

.info-pair span {
  color: var(--system-text-faint);
  font-size: 0.76rem;
}

.info-pair strong {
  color: var(--system-text);
  font-size: 1rem;
  letter-spacing: -0.03em;
}

.feature-list,
.detail-list,
.analysis-diagnostics {
  display: grid;
  gap: 10px;
}

.feature-list li,
.detail-row,
.mini-row-card,
.bullet-row {
  padding: 10px 0;
  border-top: 1px solid rgba(140, 159, 186, 0.12);
}

.feature-list > :first-child,
.detail-list > :first-child,
.analysis-diagnostics > :first-child,
.support-ticket-list > :first-child {
  border-top: 0;
  padding-top: 0;
}

.detail-row {
  display: grid;
  gap: 10px;
}

.meter {
  display: grid;
  gap: 8px;
}

.meter-topline {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.meter-topline span {
  color: var(--system-text-soft);
  font-size: 0.82rem;
}

.meter-topline strong {
  color: var(--system-text);
  font-size: 0.92rem;
}

.meter-track {
  height: 10px;
  border-radius: 999px;
  background: rgba(225, 233, 245, 0.9);
  overflow: hidden;
}

.meter-fill {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--system-accent) 0%, #6f94ff 100%);
}

.comparison-card,
.saved-card,
.admin-inquiry-card {
  padding: 20px 22px;
  border-radius: 22px;
}

.saved-controls,
.compact-panel-head,
.support-panel-heading,
.admin-hero-meta,
.admin-hero-card {
  gap: 12px;
}

.compare-topbar {
  display: grid;
  gap: 16px;
}

.compare-save-form {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
}

.filter-card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}

.saved-card textarea {
  min-height: 96px;
}

.empty-state {
  display: grid;
  gap: 12px;
  justify-items: start;
  padding: 28px;
}

.empty-state-copy {
  display: grid;
  gap: 8px;
}

.empty-state h3 {
  color: var(--system-text);
  font-size: 1.08rem;
  letter-spacing: -0.03em;
}

.empty-state p {
  color: var(--system-text-soft);
  max-width: 48ch;
}

.table-shell-scroll {
  overflow: auto;
}

.table-shell,
.table-shell-dense {
  padding: 8px;
  border-radius: 22px;
}

.data-table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  overflow: hidden;
}

.data-table th,
.data-table td {
  padding: 14px 14px;
  border-bottom: 1px solid rgba(140, 159, 186, 0.12);
  vertical-align: top;
  text-align: left;
}

.data-table th {
  color: var(--system-text-faint);
  font-size: 0.76rem;
  font-weight: 700;
  background: rgba(246, 249, 253, 0.96);
}

.data-table td {
  color: var(--system-text);
  font-size: 0.9rem;
  background: rgba(255, 255, 255, 0.94);
}

.data-table tbody tr:hover td {
  background: rgba(248, 251, 255, 0.98);
}

.admin-hero-card {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(300px, 0.9fr);
  gap: 18px;
}

.admin-hero-copy h2 {
  color: var(--system-text);
  font-size: clamp(1.8rem, 2.3vw, 2.5rem);
  line-height: 0.98;
  letter-spacing: -0.06em;
  margin: 0 0 6px;
}

.admin-mini-metric {
  display: grid;
  gap: 6px;
  padding: 16px 18px;
  border-radius: 18px;
  background: rgba(247, 250, 254, 0.88);
  border: 1px solid rgba(140, 159, 186, 0.16);
}

.admin-mini-metric span,
.admin-mini-metric small {
  color: var(--system-text-faint);
}

.admin-mini-metric strong {
  color: var(--system-text);
  font-size: 1rem;
  letter-spacing: -0.03em;
}

.site-footer {
  margin-top: 18px;
  padding: 20px 0 8px;
  border: 0;
  box-shadow: none;
  background: transparent;
}

.site-footer-top {
  padding-top: 18px;
  border-top: 1px solid rgba(140, 159, 186, 0.16);
}

.site-footer-copy,
.site-footer-meta p {
  color: #8a98ab;
  font-size: 0.74rem;
}

.footer-links a,
.site-footer a {
  color: var(--system-text-soft);
}

@media (max-width: 1199px) {
  .workspace-shell {
    grid-template-columns: 1fr;
    padding-top: 12px;
  }

  .workspace-sidebar {
    position: fixed;
    left: 12px;
    top: 12px;
    bottom: 12px;
    width: min(320px, calc(100vw - 24px));
    transform: translateX(calc(-100% - 20px));
    transition: transform 0.18s ease;
    z-index: 70;
  }

  .workspace-sidebar.is-open {
    transform: translateX(0);
  }

  .app-header {
    position: sticky;
    top: 12px;
    z-index: 35;
  }

  .dashboard-grid,
  .analysis-detail-layout,
  .support-page-grid,
  .admin-hero-card {
    grid-template-columns: 1fr;
  }

  .utility-hero,
  .product-hero-refined {
    grid-template-columns: 1fr;
  }

  .product-actions-sticky {
    grid-column: 1 / -1;
  }
}

@media (max-width: 767px) {
  .marketing-shell {
    padding-inline: 14px;
  }

  .workspace-shell {
    padding-inline: 14px;
    padding-bottom: 28px;
  }

  .marketing-header {
    top: 10px;
    padding: 12px 14px;
    border-radius: 18px;
  }

  .nav-toggle,
  .mobile-only {
    display: inline-flex;
  }

  .nav-links {
    position: fixed;
    top: 72px;
    left: 14px;
    right: 14px;
    display: none;
    flex-direction: column;
    align-items: stretch;
    padding: 14px;
    border-radius: 20px;
    background: rgba(255, 255, 255, 0.98);
    border: 1px solid var(--system-border);
    box-shadow: var(--system-shadow-lg);
    z-index: 60;
  }

  .nav-links.is-open {
    display: flex;
  }

  .card,
  .section-surface,
  .analysis-start-card,
  .compare-topbar,
  .filter-card,
  .admin-hero-card,
  .product-hero-refined,
  .action-panel,
  .saved-card,
  .comparison-card,
  .admin-panel,
  .support-form-card,
  .support-faq-card,
  .support-history-card,
  .utility-step-item,
  .utility-timeline-item {
    padding: 18px;
  }

  .home-hero-main h1,
  .pricing-hero-main h1,
  .auth-card h1,
  .utility-hero-copy h1 {
    font-size: clamp(1.86rem, 8.8vw, 2.6rem);
  }

  .home-premium-hero-single .home-hero-premium-card,
  .pricing-hero-main-premium,
  .auth-card-login-refined,
  .auth-card-account-refined,
  .auth-card-minimal {
    padding: 26px 22px;
  }

  .pricing-cap-grid,
  .home-summary-strip,
  .auth-minimal-facts,
  .utility-summary-grid,
  .compare-save-form,
  .filter-card,
  .pricing-plan-grid {
    grid-template-columns: 1fr;
  }

  .home-summary-strip,
  .auth-minimal-facts-strip {
    gap: 0;
  }

  .home-summary-strip-item,
  .auth-minimal-fact {
    padding: 14px 0;
    border-left: 0;
    border-top: 1px solid rgba(140, 159, 186, 0.14);
  }

  .home-summary-strip > :first-child,
  .auth-minimal-facts-strip > :first-child {
    border-top: 0;
    padding-top: 0;
  }

  .compare-save-form,
  .analysis-form.analysis-form-hero,
  .marketing-analysis-form {
    grid-template-columns: 1fr;
  }

  .info-grid {
    grid-template-columns: 1fr;
  }

  .data-table th,
  .data-table td {
    padding: 12px;
    font-size: 0.84rem;
  }

  .site-footer {
    padding-bottom: 0;
  }

  .site-footer-top {
    flex-direction: column;
    gap: 12px;
  }
}

/* 2026-04-29 Workspace/UI refinement */
.site-shell {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

.site-main {
  flex: 1 1 auto;
  align-content: start;
}

.workspace-main {
  display: flex;
  flex-direction: column;
  min-height: calc(100vh - 32px);
}

.page-content-workspace {
  flex: 1 1 auto;
  padding-bottom: 34px;
}

.workspace-intro-card {
  display: grid;
  grid-template-columns: minmax(0, 1.16fr) minmax(280px, 0.84fr);
  gap: 18px;
  align-items: stretch;
  padding: 24px 26px;
  border-radius: 28px;
}

.workspace-intro-copy {
  display: grid;
  align-content: start;
  gap: 14px;
}

.workspace-intro-copy h2 {
  color: var(--system-text);
  margin: 0;
  font-size: clamp(1.64rem, 2.45vw, 2.38rem);
  line-height: 1.03;
  letter-spacing: -0.052em;
  text-wrap: balance;
}

.workspace-intro-copy p {
  max-width: 58ch;
  color: var(--system-text-soft);
  font-size: 0.96rem;
  line-height: 1.7;
}

.workspace-intro-actions {
  align-items: center;
  flex-wrap: wrap;
}

.workspace-intro-aside {
  display: grid;
  gap: 12px;
  align-content: start;
  padding: 18px 18px 20px;
  border-radius: 22px;
  background: rgba(247, 250, 254, 0.88);
  border: 1px solid rgba(140, 159, 186, 0.16);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.76);
}

.workspace-intro-note {
  display: grid;
  gap: 12px;
}

.workspace-intro-note strong {
  color: var(--system-text);
  font-size: 0.96rem;
  letter-spacing: -0.03em;
}

.workspace-point-list {
  display: grid;
  gap: 0;
}

.workspace-point-item {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr);
  gap: 12px;
  align-items: start;
  padding: 12px 0;
  border-top: 1px solid rgba(140, 159, 186, 0.14);
}

.workspace-point-list > :first-child {
  padding-top: 0;
  border-top: 0;
}

.workspace-point-item span {
  color: var(--system-accent-strong);
  font-size: 0.74rem;
  font-weight: 700;
  letter-spacing: 0.08em;
}

.workspace-point-item p {
  margin: 0;
  color: var(--system-text-soft);
  font-size: 0.84rem;
  line-height: 1.68;
}

.workspace-intro-card-locked .workspace-intro-copy h2 {
  max-width: 18ch;
}

.workspace-intro-card-locked .compact-metric-strip,
.admin-hero-card-refined .compact-metric-strip {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.analysis-start-layout,
.comparison-hero-grid,
.saved-hero-grid {
  grid-template-columns: minmax(0, 1.1fr) minmax(320px, 0.9fr);
}

.analysis-start-main-card .workspace-intro-actions {
  display: block;
}

.analysis-start-main-card .analysis-form.analysis-form-hero {
  max-width: none;
}

.analysis-start-side,
.saved-results-stack {
  gap: 14px;
}

.analysis-support-card,
.comparison-side-panel,
.saved-side-card {
  padding: 22px 24px;
  border-radius: 24px;
}

.analysis-support-card h3,
.comparison-side-panel h3,
.saved-side-card h3 {
  color: var(--system-text);
  margin: 2px 0 4px;
  font-size: 1.08rem;
  letter-spacing: -0.035em;
}

.analysis-recent-surface,
.comparison-table-surface {
  padding: 24px 26px;
}

.workspace-locked-surface {
  padding: 24px 26px;
}

.workspace-locked-grid {
  align-items: stretch;
}

.workspace-locked-card {
  gap: 12px;
  padding: 22px;
  border-radius: 22px;
}

.workspace-locked-card h3 {
  color: var(--system-text);
  margin: 0;
  font-size: 1.04rem;
  letter-spacing: -0.035em;
}

.workspace-locked-card p {
  color: var(--system-text-soft);
  font-size: 0.86rem;
  line-height: 1.66;
}

.saved-filter-card-refined .workspace-intro-note {
  gap: 10px;
}

.saved-filter-row {
  gap: 8px;
}

.comparison-card-grid {
  align-items: stretch;
}

.comparison-side-panel .compare-save-form {
  margin-top: 4px;
}

.comparison-table-surface .table-shell {
  margin-top: 0;
}

.empty-state {
  padding: 28px 30px;
  border-radius: 24px;
}

.page-content-workspace .empty-state {
  max-width: 780px;
}

.admin-hero-card-refined .workspace-intro-aside {
  padding: 0;
  background: transparent;
  border: 0;
  box-shadow: none;
}

.admin-hero-meta {
  display: grid;
  gap: 12px;
}

@media (max-width: 1199px) {
  .workspace-main {
    min-height: auto;
  }

  .workspace-intro-card,
  .analysis-start-layout,
  .comparison-hero-grid,
  .saved-hero-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 767px) {
  .workspace-intro-card,
  .analysis-support-card,
  .comparison-side-panel,
  .saved-side-card,
  .workspace-locked-surface,
  .analysis-recent-surface,
  .comparison-table-surface {
    padding: 18px;
  }

  .workspace-intro-copy h2 {
    font-size: clamp(1.48rem, 7.2vw, 2rem);
  }

  .workspace-intro-card-locked .compact-metric-strip,
  .admin-hero-card-refined .compact-metric-strip {
    grid-template-columns: 1fr;
  }

  .workspace-intro-aside {
    padding: 16px;
  }

  .workspace-point-item {
    grid-template-columns: 28px minmax(0, 1fr);
    gap: 10px;
  }
}

/* 2026-04-29 Motion refinement */
@keyframes motionFadeLift {
  from {
    opacity: 0;
    transform: translate3d(0, 18px, 0);
  }

  to {
    opacity: 1;
    transform: translate3d(0, 0, 0);
  }
}

@keyframes motionFadeDown {
  from {
    opacity: 0;
    transform: translate3d(0, -10px, 0);
  }

  to {
    opacity: 1;
    transform: translate3d(0, 0, 0);
  }
}

@keyframes motionSoftGlow {
  0%,
  100% {
    box-shadow: 0 18px 42px rgba(15, 23, 42, 0.06);
  }

  50% {
    box-shadow: 0 24px 56px rgba(33, 79, 219, 0.08);
  }
}

@keyframes motionAmbientFloat {
  0%,
  100% {
    transform: translate3d(0, 0, 0);
  }

  50% {
    transform: translate3d(0, -4px, 0);
  }
}

.marketing-header,
.workspace-sidebar,
.app-header > div:first-child,
.app-header .header-actions {
  animation: motionFadeDown 0.48s cubic-bezier(0.22, 1, 0.36, 1) both;
}

.site-main > .hero-section,
.site-main > .section,
.page-content-workspace > .section {
  opacity: 0;
  animation: motionFadeLift 0.62s cubic-bezier(0.22, 1, 0.36, 1) both;
}

.site-main > .hero-section {
  animation-delay: 0.06s;
}

.site-main > .section:nth-of-type(2),
.page-content-workspace > .section:nth-of-type(2) {
  animation-delay: 0.11s;
}

.site-main > .section:nth-of-type(3),
.page-content-workspace > .section:nth-of-type(3) {
  animation-delay: 0.17s;
}

.site-main > .section:nth-of-type(4),
.page-content-workspace > .section:nth-of-type(4) {
  animation-delay: 0.23s;
}

.home-premium-hero-single .home-hero-premium-card,
.pricing-hero-main-premium,
.auth-card-login-refined,
.auth-card-account-refined,
.workspace-intro-card,
.product-hero-refined {
  position: relative;
  overflow: hidden;
}

.home-premium-hero-single .home-hero-premium-card::after,
.pricing-hero-main-premium::after,
.auth-card-login-refined::after,
.auth-card-account-refined::after,
.workspace-intro-card::after,
.product-hero-refined::after {
  content: "";
  position: absolute;
  inset: -20% auto auto -10%;
  width: 38%;
  height: 60%;
  pointer-events: none;
  background: linear-gradient(135deg, rgba(120, 153, 255, 0.12) 0%, rgba(120, 153, 255, 0) 72%);
  filter: blur(10px);
  opacity: 0.72;
}

.home-premium-hero-single .home-hero-premium-card,
.pricing-hero-main-premium {
  animation: motionFadeLift 0.72s cubic-bezier(0.22, 1, 0.36, 1) both, motionSoftGlow 7.2s ease-in-out 0.8s infinite;
}

.auth-card-login-refined,
.auth-card-account-refined {
  animation: motionFadeLift 0.68s cubic-bezier(0.22, 1, 0.36, 1) both;
}

.workspace-intro-aside,
.compact-metric,
.utility-summary-card,
.workspace-locked-card,
.plan-card,
.stat-card {
  animation: motionFadeLift 0.64s cubic-bezier(0.22, 1, 0.36, 1) both;
}

.workspace-intro-aside {
  animation-delay: 0.12s;
}

.card,
.section-surface,
.table-shell,
.utility-summary-card,
.utility-note-card,
.support-faq-item,
.mini-row-card,
.compact-metric,
.info-pair {
  transition: transform 0.22s ease, box-shadow 0.22s ease, border-color 0.22s ease, background-color 0.22s ease;
}

.site-shell .card:hover,
.site-shell .section-surface:hover,
.site-shell .table-shell:hover {
  transform: translate3d(0, -3px, 0);
  box-shadow: 0 20px 44px rgba(15, 23, 42, 0.08);
  border-color: rgba(33, 79, 219, 0.16);
}

.workspace-sidebar-card,
.workspace-locked-card,
.utility-summary-card {
  animation: motionFadeLift 0.7s cubic-bezier(0.22, 1, 0.36, 1) both;
}

.brand-mark {
  animation: motionAmbientFloat 5.8s ease-in-out 1.2s infinite;
}

.button-primary {
  position: relative;
  overflow: hidden;
}

.button-primary::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(110deg, rgba(255, 255, 255, 0) 24%, rgba(255, 255, 255, 0.24) 50%, rgba(255, 255, 255, 0) 76%);
  transform: translateX(-120%);
  transition: transform 0.7s ease;
}

.button-primary:hover::after,
.button-primary:focus-visible::after {
  transform: translateX(120%);
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation: none !important;
    transition-duration: 0.01ms !important;
    transition-delay: 0ms !important;
    scroll-behavior: auto !important;
  }
}
