:root {
    --bg: #f4f7fb;
    --surface: #ffffff;
    --surface-alt: #f8fbff;
    --text: #12202f;
    --muted: #5f6f81;
    --line: #d7e0e7;
    --primary: #0d3b66;
    --primary-dark: #0b3154;
    --primary-soft: #e9f2fb;
    --accent: #f59e0b;
    --success: #15803d;
    --danger: #b91c1c;
    --shadow: 0 18px 45px rgba(10, 27, 44, 0.08);
    --radius: 22px;
    --container: 1220px;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
    margin: 0;
    font-family: 'Inter', Arial, sans-serif;
    color: var(--text);
    background: var(--bg);
    line-height: 1.65;
}
a { color: var(--primary); text-decoration: none; }
a:hover { color: var(--primary-dark); }
img { max-width: 100%; display: block; }
.container { width: min(var(--container), calc(100% - 32px)); margin: 0 auto; }
.site-header {
    position: sticky;
    top: 0;
    z-index: 30;
    background: rgba(255,255,255,0.94);
    border-bottom: 1px solid rgba(215,224,231,0.8);
    backdrop-filter: blur(12px);
}
.header-inner { display: flex; align-items: center; justify-content: space-between; min-height: 78px; gap: 24px; }
.brand { font-weight: 800; letter-spacing: -0.02em; font-size: 1.3rem; color: var(--text); }
.brand span { color: var(--accent); }
.brand-logo { max-height: 64px; width: auto; }
.main-nav { display: flex; flex-wrap: wrap; gap: 20px; }
.main-nav a { font-weight: 600; color: var(--text); }
.hero, .page-hero { padding: 74px 0 52px; background: linear-gradient(180deg, #fff 0%, #f5f8fb 100%); }
.page-hero.compact { padding: 56px 0 30px; }
.hero-home { padding-bottom: 32px; }
.hero-grid { display: grid; grid-template-columns: 1.15fr 0.95fr; gap: 50px; align-items: center; }
.hero-grid-visual { align-items: start; }
.eyebrow, .section-kicker {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 7px 12px;
    border-radius: 999px;
    background: #edf4fb;
    color: var(--primary);
    font-weight: 700;
    font-size: 0.82rem;
    margin-bottom: 16px;
}
.hero h1, .page-hero h1 { margin: 0 0 18px; font-size: clamp(2.2rem, 4vw, 4.2rem); line-height: 1.04; letter-spacing: -0.05em; }
.hero-text { font-size: 1.08rem; color: var(--muted); max-width: 690px; }
.hero-actions { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 26px; }
.hero-points { display: grid; gap: 10px; margin-top: 24px; }
.hero-points span {
    padding-left: 18px;
    position: relative;
    color: var(--text);
    font-weight: 600;
}
.hero-points span::before {
    content: "";
    width: 8px; height: 8px;
    border-radius: 50%;
    background: var(--accent);
    position: absolute; left: 0; top: 11px;
}
.hero-visual-stack { display: grid; gap: 18px; }
.hero-visual-card { padding: 22px; }
.hero-mini-trust { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 16px; }
.hero-mini-trust .surface, .benefit-card, .list-card { padding: 20px; }
.hero-mini-trust strong, .benefit-card strong { display: block; margin-bottom: 6px; }
.hero-mini-trust span, .benefit-card p { color: var(--muted); }
.surface, .table-surface {
    background: var(--surface);
    border: 1px solid rgba(215,224,231,0.9);
    border-radius: var(--radius);
    box-shadow: var(--shadow);
}
.diagnosis-form { padding: 28px; display: grid; gap: 18px; }
.diagnosis-form-home { padding: 30px; }
.form-grid { display: grid; gap: 14px; }
.form-grid.two { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.form-grid.three { grid-template-columns: repeat(3, minmax(0, 1fr)); }
label { display: grid; gap: 8px; font-weight: 600; color: var(--text); }
input, select, textarea {
    width: 100%;
    border: 1px solid var(--line);
    background: #fff;
    border-radius: 14px;
    min-height: 52px;
    padding: 12px 16px;
    font: inherit;
    color: var(--text);
    outline: none;
}
textarea { min-height: 136px; resize: vertical; }
input:focus, select:focus, textarea:focus { border-color: var(--primary); box-shadow: 0 0 0 4px rgba(13,59,102,0.08); }
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 52px;
    border-radius: 14px;
    padding: 0 18px;
    font-weight: 700;
    border: none;
    cursor: pointer;
    transition: transform .15s ease, background .15s ease, color .15s ease;
}
.btn:hover { transform: translateY(-1px); }
.btn-primary { background: var(--primary); color: #fff; }
.btn-primary:hover { background: var(--primary-dark); color: #fff; }
.btn-secondary { background: #edf2f7; color: var(--text); }
.btn-block { width: 100%; }
.fineprint, .small-text { color: var(--muted); font-size: 0.92rem; }
.trust-bar { padding: 18px 0 30px; }
.trust-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 16px; }
.trust-grid.four { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.trust-grid > div {
    background: #fff;
    border: 1px solid rgba(215,224,231,0.9);
    border-radius: 18px;
    padding: 18px 20px;
}
.trust-grid strong { display: block; font-size: 1rem; margin-bottom: 4px; }
.trust-grid span { color: var(--muted); font-size: 0.95rem; }
.section { padding: 72px 0; }
.section.light { background: #f7fafc; }
.section-tight { padding: 24px 0; }
.section-overlap { padding-top: 30px; }
.split-headline {
    display: grid;
    grid-template-columns: 1fr 0.9fr;
    gap: 36px;
    align-items: end;
    margin-bottom: 26px;
}
.split-headline h2 { margin: 0; font-size: clamp(1.8rem, 3vw, 2.8rem); letter-spacing: -0.04em; line-height: 1.1; }
.split-headline p { margin: 0; color: var(--muted); font-size: 1.02rem; }
.home-diagnosis-grid,
.feature-rows,
.content-visual-grid,
.benefits-grid,
.contact-grid { display: grid; gap: 22px; }
.home-diagnosis-grid { grid-template-columns: 1.1fr 0.9fr; align-items: start; }
.feature-rows { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.feature-rows article, .affiliate-item, .small-surface {
    background: #fff;
    border: 1px solid rgba(215,224,231,0.9);
    border-radius: 18px;
    padding: 24px;
}
.feature-icon { width: 72px; height: 72px; margin-bottom: 16px; }
.feature-rows h3, .affiliate-item h3, .small-surface h3 { margin-top: 0; margin-bottom: 10px; font-size: 1.14rem; }
.process-card { padding: 26px; }
.process-card h3 { margin-top: 0; font-size: 1.45rem; }
.process-steps { display: grid; gap: 14px; margin: 18px 0 20px; }
.process-steps article { display: grid; grid-template-columns: 46px 1fr; gap: 14px; align-items: start; }
.process-steps strong {
    width: 46px; height: 46px; border-radius: 14px; display: grid; place-items: center;
    background: var(--primary); color: #fff; font-size: 1rem;
}
.process-steps h4 { margin: 0 0 4px; font-size: 1rem; }
.process-steps p { margin: 0; color: var(--muted); }
.process-image { margin-top: 14px; border-radius: 20px; }
.content-visual-grid { grid-template-columns: 1fr 0.95fr; align-items: stretch; }
.seo-copy-card, .content-visual-card, .legal-card { padding: 28px; }
.benefits-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.three-columns-list { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 24px; }
.three-columns-list h3 { margin-top: 0; }
.three-columns-list ul, .bullet-list { margin: 0; padding-left: 18px; }
.three-columns-list li, .bullet-list li { margin-bottom: 10px; }
.ad-slot { padding: 0 0 24px; }
.ad-slot-box {
    padding: 18px 22px;
    background: linear-gradient(180deg, #fff, #f7fafc);
    border: 1px dashed #bfd0df;
    border-radius: 18px;
}
.result-grid, .workshop-grid { display: grid; grid-template-columns: 1.3fr 0.7fr; gap: 22px; align-items: start; }
.content-panel, .sidebar-panel { padding: 28px; }
.result-headline { display: flex; align-items: center; justify-content: space-between; gap: 20px; }
.score-badge {
    min-width: 94px;
    height: 94px;
    border-radius: 50%;
    display: grid;
    place-items: center;
    background: radial-gradient(circle at 30% 30%, #eff6ff, #dbeafe 60%, #bfdbfe);
    color: var(--primary);
    font-size: 1.1rem;
    font-weight: 800;
}
.result-facts {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
    margin: 22px 0;
}
.result-facts div {
    padding: 16px;
    background: var(--surface-alt);
    border: 1px solid var(--line);
    border-radius: 16px;
}
.result-facts span, .data-list span { display: block; color: var(--muted); font-size: 0.92rem; margin-bottom: 6px; }
.result-block { padding-top: 22px; border-top: 1px solid var(--line); margin-top: 22px; }
.result-block h3 { margin-top: 0; }
.price-range { font-size: 1.7rem; font-weight: 800; letter-spacing: -0.03em; margin: 12px 0; }
.result-list { display: grid; gap: 16px; }
.result-list article { padding: 18px; border: 1px solid var(--line); border-radius: 16px; background: #fff; }
.result-list strong { display: block; }
.steps-list { margin: 0; padding-left: 22px; }
.steps-list li { margin-bottom: 10px; }
.sidebar-panel { position: sticky; top: 92px; }
.data-list { margin: 0 0 22px; padding: 0; list-style: none; display: grid; gap: 12px; }
.data-list li { display: flex; justify-content: space-between; gap: 14px; padding: 12px 0; border-bottom: 1px solid var(--line); }
.affiliate-grid, .simple-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 18px; }
.partner { margin-top: 12px; color: var(--muted); font-size: 0.95rem; }
.text-link { display: inline-block; margin-top: 10px; font-weight: 700; }
.table-surface { overflow: hidden; }
.data-table { width: 100%; border-collapse: collapse; background: #fff; }
.data-table th, .data-table td { padding: 16px 18px; text-align: left; border-bottom: 1px solid var(--line); vertical-align: top; }
.data-table th { background: #f8fafc; font-size: 0.93rem; }
.data-table.compact th, .data-table.compact td { padding: 12px 14px; }
.admin-body { background: #0f172a; }
.admin-shell { display: grid; grid-template-columns: 280px 1fr; min-height: 100vh; }
.admin-sidebar {
    background: #0b1220;
    padding: 30px 24px;
    border-right: 1px solid rgba(148,163,184,0.18);
}
.admin-sidebar .brand { color: #fff; margin-bottom: 24px; display: inline-block; }
.admin-sidebar nav { display: grid; gap: 12px; }
.admin-sidebar nav a { color: #cbd5e1; font-weight: 600; }
.admin-sidebar nav a:hover { color: #fff; }
.admin-content { padding: 28px; background: #f4f7fb; }
.admin-stats { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 18px; }
.admin-stats .surface { padding: 24px; }
.admin-stats strong { display: block; font-size: 2rem; margin-bottom: 6px; }
.admin-grid-two { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 18px; }
.mini-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 14px; }
.mini-grid article { padding: 16px; border-radius: 16px; border: 1px solid var(--line); background: #fff; }
.mini-table-wrap { overflow: auto; }
.inline-form { grid-template-columns: 1fr auto; align-items: end; }
.alert { padding: 14px 16px; border-radius: 14px; margin-bottom: 18px; font-weight: 600; }
.alert-success { background: #dcfce7; color: #166534; }
.alert-error { background: #fee2e2; color: #991b1b; }
.admin-login-wrap { min-height: 100vh; display: grid; place-items: center; padding: 24px; }
.admin-login-box { width: min(520px, 100%); padding: 34px; }
.site-footer { padding: 48px 0; background: #0f172a; color: #cbd5e1; }
.footer-grid { display: grid; grid-template-columns: 1.2fr 0.7fr 0.7fr 0.9fr; gap: 28px; }
.site-footer h3, .site-footer h4 { color: #fff; margin-top: 0; }
.site-footer ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 8px; }
.site-footer a { color: #cbd5e1; }
code { background: #eef2f7; padding: 3px 8px; border-radius: 8px; }

@media (max-width: 1080px) {
    .hero-grid, .split-headline, .result-grid, .workshop-grid, .admin-grid-two, .footer-grid, .simple-grid, .affiliate-grid, .three-columns-list, .feature-rows, .home-diagnosis-grid, .content-visual-grid, .benefits-grid, .contact-grid {
        grid-template-columns: 1fr;
    }
    .form-grid.three, .form-grid.two, .trust-grid, .admin-stats, .mini-grid, .result-facts, .hero-mini-trust {
        grid-template-columns: 1fr;
    }
    .sidebar-panel { position: static; }
    .admin-shell { grid-template-columns: 1fr; }
    .admin-sidebar { border-right: none; border-bottom: 1px solid rgba(148,163,184,0.18); }
}

@media (max-width: 760px) {
    .main-nav { display: none; }
    .hero, .section, .page-hero.compact { padding-top: 44px; padding-bottom: 34px; }
    .diagnosis-form, .content-panel, .sidebar-panel, .surface, .table-surface, .affiliate-item, .feature-rows article, .small-surface, .process-card, .seo-copy-card, .content-visual-card, .legal-card { padding: 20px; }
    .price-range { font-size: 1.4rem; }
    .hero h1, .page-hero h1 { letter-spacing: -0.04em; }
    .hero-actions { flex-direction: column; }
}

.hero-grid-premium { grid-template-columns: 1.02fr 0.98fr; align-items: start; }
.hero-grid-page { align-items: center; }
.hero-side-stack { display: grid; gap: 20px; }
.hero-form-panel h2 { margin: 0 0 16px; font-size: 1.6rem; letter-spacing: -0.03em; }
.mini-kicker { font-size: 0.82rem; font-weight: 800; color: var(--primary); text-transform: uppercase; letter-spacing: .08em; margin-bottom: 10px; }
.compact-form { gap: 14px; }
.hero-home-premium { padding-bottom: 24px; background: radial-gradient(circle at top left, #ffffff 0%, #f6f9fd 48%, #edf3f9 100%); }
.premium-visual { background: linear-gradient(180deg, #ffffff 0%, #f7fbff 100%); }
.hero-side-illustration { padding: 18px; }
.split-hero-head { display: grid; grid-template-columns: 1.02fr 0.98fr; gap: 28px; align-items: center; }
.filter-surface { padding: 8px 8px 2px; }
.search-action { align-self: end; }
.pagination-wrap { display: flex; flex-wrap: wrap; gap: 10px; }
.pagination-link { min-width: 46px; height: 46px; display: inline-flex; align-items: center; justify-content: center; border-radius: 12px; background: #fff; border: 1px solid var(--line); font-weight: 700; color: var(--text); }
.pagination-link.active { background: var(--primary); color: #fff; border-color: var(--primary); }
.process-grid-4 { display: grid; grid-template-columns: repeat(4, minmax(0,1fr)); gap: 18px; }
.step-card { padding: 24px; }
.step-card strong { width: 48px; height: 48px; display: inline-grid; place-items: center; border-radius: 14px; background: linear-gradient(135deg, #0d3b66, #1f5f9a); color: #fff; margin-bottom: 16px; }
.step-card h3 { margin: 0 0 8px; font-size: 1.1rem; }
.content-visual-grid-equal { align-items: center; }
.causes-grid { grid-template-columns: repeat(3, minmax(0,1fr)); }
.symptom-grid-premium { grid-template-columns: repeat(3, minmax(0,1fr)); }
.workshop-grid-wide { grid-template-columns: 1.02fr 0.98fr; }
.result-panel-premium { padding: 28px; }
.compact-list li { margin-bottom: 8px; }
.section-tight + .section-tight { padding-top: 0; }
.table-surface + .pagination-wrap { margin-top: 16px; }

@media (max-width: 1080px) {
    .split-hero-head, .workshop-grid-wide, .process-grid-4, .causes-grid, .symptom-grid-premium, .hero-grid-premium { grid-template-columns: 1fr; }
}

/* === Premium FO Refresh Step === */
.hero-home-refined,
.page-hero.compact,
.section,
.section-tight {
    background: #f4f7fb;
}

.hero-home-shell,
.split-hero-head,
.editorial-split,
.unified-columns {
    align-items: start;
}

.hero-home-shell {
    display: grid;
    grid-template-columns: minmax(0, 1.02fr) minmax(440px, 0.98fr);
    gap: 52px;
    padding: 42px 0 24px;
}

.hero-home-copy h1,
.page-hero h1 {
    max-width: 780px;
    line-height: 0.96;
    letter-spacing: -0.045em;
}

.hero-home-copy .hero-text,
.page-hero p,
.editorial-split p,
.unified-columns p,
.timeline-item p,
.symptom-row p,
.contact-side-text p,
.text-band p {
    color: #586d8a;
    line-height: 1.72;
    font-size: 1.07rem;
}

.hero-home-side {
    display: grid;
    gap: 24px;
}

.unified-panel,
.text-band {
    background: transparent;
    border: 1px solid #d6e2f0;
    border-radius: 24px;
    padding: 28px;
    box-shadow: none;
}

.hero-home-visual,
.plain-illustration {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 320px;
}

.hero-home-visual img,
.plain-illustration img {
    width: 100%;
    max-width: 520px;
    height: auto;
    display: block;
}

.hero-inline-list,
.compact-inline-list {
    display: grid;
    gap: 12px;
    margin-top: 26px;
}

.hero-inline-list span,
.compact-inline-list span,
.plain-check-list li,
.inline-check-list li {
    position: relative;
    padding-left: 22px;
    color: #10233f;
    font-weight: 500;
}

.hero-inline-list span::before,
.compact-inline-list span::before,
.plain-check-list li::before,
.inline-check-list li::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0.72em;
    width: 8px;
    height: 8px;
    border-radius: 999px;
    background: #f2a31b;
    transform: translateY(-50%);
}

.section-density {
    padding-top: 34px;
    padding-bottom: 34px;
}

.editorial-split,
.unified-columns {
    display: grid;
    grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.1fr);
    gap: 40px;
}

.line-section {
    border-top: 1px solid #d8e3f0;
    border-bottom: 1px solid #d8e3f0;
}

.section-intro,
.aligned-intro {
    max-width: 920px;
    margin-bottom: 28px;
}

.timeline-list {
    display: grid;
    gap: 0;
    border-top: 1px solid #d8e3f0;
}

.timeline-item {
    display: grid;
    grid-template-columns: 96px minmax(0, 1fr);
    gap: 24px;
    padding: 24px 0;
    border-bottom: 1px solid #d8e3f0;
}

.timeline-item strong {
    display: inline-flex;
    width: 64px;
    height: 64px;
    border-radius: 16px;
    align-items: center;
    justify-content: center;
    background: #103f7c;
    color: #fff;
    font-size: 1rem;
}

.timeline-item h3,
.symptom-row h3,
.plain-link-lists h3,
.contact-side-text h2,
.workshop-result-panel h3 {
    margin: 0 0 8px;
    color: #10233f;
}

.plain-link-lists {
    display: grid;
    gap: 30px;
}

.plain-link-lists.three,
.combo-columns {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.plain-link-lists ul,
.plain-check-list,
.inline-check-list {
    list-style: none;
    padding: 0;
    margin: 16px 0 0;
}

.plain-link-lists li {
    margin: 0;
    padding: 12px 0;
    border-bottom: 1px solid #dbe6f2;
    color: #10233f;
    line-height: 1.55;
}

.plain-link-lists li a {
    color: inherit;
    text-decoration: none;
}

.plain-link-lists li a:hover {
    color: #103f7c;
}

.symptom-stream {
    display: grid;
    gap: 0;
    border-top: 1px solid #d8e3f0;
}

.symptom-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 28px;
    align-items: center;
    padding: 22px 0;
    border-bottom: 1px solid #d8e3f0;
}

.symptom-row a {
    color: #103f7c;
    font-weight: 700;
    text-decoration: none;
    white-space: nowrap;
}

.no-card-hero .hero-side-illustration,
.no-card-hero .plain-illustration {
    border: 1px solid #d6e2f0;
    border-radius: 28px;
    padding: 18px;
}

.contact-layout-refined {
    display: grid;
    grid-template-columns: minmax(0, 1.05fr) minmax(320px, 0.95fr);
    gap: 42px;
}

.contact-info-inline {
    display: grid;
    gap: 18px;
    align-self: center;
    justify-self: end;
    text-align: left;
}

.contact-info-inline div {
    display: grid;
    gap: 4px;
}

.contact-info-inline strong,
.footer-bottom-center {
    color: #10233f;
}

.alert {
    margin-bottom: 18px;
    border-radius: 18px;
    padding: 16px 18px;
    border: 1px solid #d5e1ef;
}

.alert-success {
    background: #eef8f2;
    color: #1d5c37;
}

.alert-error {
    background: #fff2f2;
    color: #8d2931;
}

.footer-bottom-bar {
    border-top: 1px solid rgba(255,255,255,0.12);
    padding: 18px 0 26px;
}

.footer-bottom-center {
    text-align: center;
    color: rgba(255,255,255,0.84);
    font-size: 0.94rem;
}

.footer-bottom-center strong,
.footer-bottom-center a,
.site-footer .footer-bottom-center {
    color: rgba(255,255,255,0.84);
}

.form-loading-overlay {
    position: absolute;
    inset: 0;
    background: rgba(244, 247, 251, 0.94);
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 24px;
    z-index: 9;
}

.form-loading-box {
    text-align: center;
    max-width: 340px;
    color: #10233f;
}

.loader-spinner {
    width: 48px;
    height: 48px;
    border-radius: 999px;
    border: 4px solid #d1e1f4;
    border-top-color: #103f7c;
    display: inline-block;
    animation: foSpin 0.9s linear infinite;
    margin-bottom: 14px;
}

@keyframes foSpin {
    from { transform: rotate(0deg); }
    to { transform: rotate(360deg); }
}

.table-surface {
    background: transparent;
    border: 1px solid #d6e2f0;
    border-radius: 24px;
    overflow: hidden;
}

.data-table thead th {
    background: #f8fbff;
}

.workshop-grid.refined-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(360px, 0.9fr);
    gap: 30px;
}

.workshop-result-panel .price-range {
    font-size: 2rem;
    font-weight: 800;
    color: #10233f;
    line-height: 1.15;
}

.search-inline-grid {
    align-items: end;
}

.compact-lines .plain-link-lists li {
    padding-top: 10px;
    padding-bottom: 10px;
}

@media (max-width: 1100px) {
    .hero-home-shell,
    .editorial-split,
    .unified-columns,
    .contact-layout-refined,
    .workshop-grid.refined-grid,
    .split-hero-head,
    .plain-link-lists.three,
    .combo-columns {
        grid-template-columns: 1fr;
    }

    .contact-info-inline {
        justify-self: start;
    }

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

@media (max-width: 760px) {
    .timeline-item,
    .symptom-row {
        grid-template-columns: 1fr;
    }

    .symptom-row a {
        white-space: normal;
    }

    .hero-home-shell {
        padding-top: 24px;
    }
}


/* === DTC page stability and refinement === */
.dtc-hero-grid {
    align-items: center;
}

.dtc-search-panel {
    display: grid;
    gap: 18px;
}

.dtc-search-form {
    padding: 0;
}

.dtc-search-meta {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
    padding-top: 6px;
}

.dtc-search-meta div {
    border-top: 1px solid #d8e3f0;
    padding-top: 16px;
}

.dtc-search-meta strong {
    display: block;
    font-size: 1.5rem;
    line-height: 1.1;
    color: #10233f;
}

.dtc-search-meta span {
    display: block;
    margin-top: 6px;
    color: #586d8a;
}

.dtc-data-table .dtc-code-cell strong {
    font-size: 1.06rem;
}

.dtc-table-title {
    font-weight: 700;
    color: #10233f;
    margin-bottom: 6px;
}

.severity-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 38px;
    padding: 8px 12px;
    border-radius: 999px;
    font-weight: 700;
    border: 1px solid #d8e3f0;
    background: #f8fbff;
    color: #10233f;
}

.severity-pill.severity-low {
    background: #eef8f2;
    color: #1d5c37;
    border-color: #cfe8d6;
}

.severity-pill.severity-medium {
    background: #fff7e9;
    color: #8b5a00;
    border-color: #f4dba5;
}

.severity-pill.severity-high,
.severity-pill.severity-critical {
    background: #fff1f1;
    color: #9d2020;
    border-color: #efc7c7;
}

.empty-state-inline {
    padding: 10px 0;
}

.empty-state-inline strong {
    display: block;
    margin-bottom: 6px;
    color: #10233f;
}

.empty-state-inline p {
    margin: 0;
    color: #586d8a;
}

@media (max-width: 760px) {
    .dtc-search-meta {
        grid-template-columns: 1fr;
    }
}


.site-main-shell {
    padding: 0;
}
.layout-with-side-ads {
    width: min(1640px, calc(100% - 24px));
    margin: 0 auto;
    display: grid;
    grid-template-columns: minmax(120px, 180px) minmax(0, 1220px) minmax(120px, 180px);
    gap: 20px;
    align-items: start;
}
.site-content-column {
    min-width: 0;
}
.site-ad-rail {
    min-height: 100%;
    padding-top: 108px;
}
.site-ad-rail.left {
    padding-right: 4px;
}
.site-ad-rail.right {
    padding-left: 4px;
}
.site-ad-rail > * {
    position: sticky;
    top: 104px;
}
.ad-rail-placeholder {
    min-height: 600px;
    border-radius: 24px;
    border: 1px dashed rgba(13,59,102,0.16);
    background: linear-gradient(180deg, rgba(255,255,255,0.65), rgba(244,247,251,0.45));
}
.repair-search-first {
    padding-bottom: 18px;
}
.repair-results-anchor {
    padding-top: 0;
}
.repair-results-card {
    padding: 28px;
}
.repair-results-heading {
    display: grid;
    grid-template-columns: minmax(0, 0.95fr) minmax(0, 1.05fr);
    gap: 24px;
    align-items: start;
}
.repair-results-heading h2 {
    margin: 0;
    font-size: clamp(1.7rem, 2.8vw, 2.5rem);
    line-height: 1.08;
    letter-spacing: -0.04em;
}
.repair-results-note p {
    margin: 0 0 12px;
    color: var(--muted);
}
.repair-empty-state {
    margin-top: 18px;
    padding-top: 22px;
    border-top: 1px solid var(--line);
}
.repair-empty-state h3 {
    margin-top: 0;
    margin-bottom: 10px;
}
.repair-action-links {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 18px;
}
.repair-conversion-zone {
    padding-top: 22px;
    padding-bottom: 26px;
}
.repair-opportunity-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 18px;
}
.repair-opportunity-card {
    padding: 24px;
}
.repair-opportunity-card h3 {
    margin-top: 0;
    margin-bottom: 10px;
    font-size: 1.15rem;
    line-height: 1.25;
}
.repair-opportunity-card p {
    margin-top: 0;
    color: var(--muted);
}
.repair-opportunity-card .btn {
    margin-top: 12px;
}
.repair-insight-section {
    padding-top: 30px;
    padding-bottom: 36px;
}
.repair-insight-grid {
    align-items: start;
}
.repair-insight-panels {
    display: grid;
    gap: 18px;
}
.repair-seo-section {
    padding-top: 46px;
}
@media (max-width: 1480px) {
    .layout-with-side-ads {
        width: min(1280px, calc(100% - 24px));
        grid-template-columns: 1fr minmax(0, 1220px) 1fr;
    }
    .site-ad-rail {
        padding-top: 96px;
    }
}
@media (max-width: 1260px) {
    .layout-with-side-ads {
        width: 100%;
        grid-template-columns: minmax(0, 1fr);
    }
    .site-ad-rail {
        display: none;
    }
}
@media (max-width: 980px) {
    .repair-results-heading {
        grid-template-columns: 1fr;
    }
    .repair-opportunity-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}
@media (max-width: 680px) {
    .repair-results-card {
        padding: 20px;
    }
    .repair-opportunity-grid {
        grid-template-columns: 1fr;
    }
    .repair-action-links {
        flex-direction: column;
    }
}

.search-inline-grid-extended { margin-top: 14px; }
.repair-auto-price-card, .premium-lead-surface, .monetization-card { padding: 24px; }
.repair-auto-price-factors { display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:12px; margin:18px 0; }
.repair-auto-price-factors div { border:1px solid #d9e5f4; border-radius:14px; padding:14px 16px; background:#f8fbff; }
.repair-auto-price-factors span { display:block; font-size:13px; color:#5b7191; margin-bottom:4px; }
.repair-auto-price-factors strong { font-size:20px; color:#10233f; }
.monetization-zone { background: linear-gradient(180deg, #f7fbff 0%, #eef5fc 100%); }
.monetization-grid { display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:18px; }
.monetization-card-premium { border:1px solid #dbe7f7; }
.package-topline { display:flex; justify-content:space-between; gap:12px; align-items:flex-start; margin-bottom:10px; }
.compact-top { margin-top: 14px; }
.premium-lead-form { margin-top: 12px; }
.workshop-adjustment-card { margin: 18px 0; }
@media (max-width: 980px) {
  .repair-auto-price-factors, .monetization-grid { grid-template-columns:1fr; }
}

.tire-hero-panel {
    padding: 28px;
    box-shadow: none;
}

.tire-hero-panel h2,
.tire-feature-rows h3,
.tire-legal-note h2 {
    margin-top: 0;
}

.tire-hero-facts {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
    margin-top: 20px;
}

.tire-hero-facts div {
    background: #f8fbff;
    border: 1px solid #d8e3f0;
    border-radius: 18px;
    padding: 16px;
}

.tire-hero-facts strong {
    display: block;
    margin-bottom: 6px;
    color: #10233f;
}

.tire-hero-facts span {
    color: #586d8a;
    font-size: 0.95rem;
}

.tire-embed-shell {
    margin-top: 20px;
    background: #ffffff;
    border: 1px solid #d6e2f0;
    border-radius: 28px;
    padding: 18px;
}

.tire-finder-frame {
    width: 100%;
    min-height: 1180px;
    border: 0;
    border-radius: 18px;
    background: #ffffff;
}

.tire-feature-rows {
    margin-top: 18px;
}

.tire-faq-list {
    margin-top: 6px;
}

.tire-legal-note {
    background: #ffffff;
    border: 1px solid #d6e2f0;
    border-radius: 24px;
    padding: 28px;
}

@media (max-width: 980px) {
    .tire-hero-facts {
        grid-template-columns: 1fr;
    }

    .tire-finder-frame {
        min-height: 1380px;
    }
}


.symptom-card-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 22px;
    margin-top: 28px;
}

.symptom-card {
    background: #ffffff;
    border: 1px solid #d9e2ec;
    border-radius: 22px;
    padding: 26px;
    box-shadow: 0 10px 28px rgba(16, 35, 63, 0.05);
}

.symptom-card-top {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 20px;
    margin-bottom: 12px;
}

.symptom-card h3,
.symptom-list-item h3 {
    margin: 0;
    color: #10233f;
    font-size: 30px;
    line-height: 1.1;
}

.symptom-card p,
.symptom-list-item p {
    margin: 0;
    color: #5f738c;
    font-size: 17px;
    line-height: 1.7;
}

.symptom-quick-link,
.symptom-list-action a {
    color: #0d3b66;
    font-weight: 700;
    text-decoration: none;
    white-space: nowrap;
}

.symptom-list-clean {
    display: grid;
    gap: 0;
    margin-top: 20px;
    background: #ffffff;
    border: 1px solid #d9e2ec;
    border-radius: 22px;
    overflow: hidden;
}

.symptom-list-item {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 24px;
    padding: 24px 26px;
    border-top: 1px solid #e7edf4;
}

.symptom-list-item:first-child {
    border-top: 0;
}

.premium-inline-box {
    display: grid;
    grid-template-columns: 1.05fr 0.95fr;
    gap: 28px;
    align-items: start;
    background: #ffffff;
    border: 1px solid #d9e2ec;
    border-radius: 24px;
    padding: 30px;
    box-shadow: 0 10px 28px rgba(16, 35, 63, 0.05);
}

.premium-inline-copy h2 {
    margin: 0 0 14px;
}

.premium-benefit-list {
    margin: 20px 0 0;
    padding-left: 20px;
    color: #5f738c;
    line-height: 1.8;
}

.premium-inline-form.unified-panel {
    background: #f8fbff;
    border: 1px solid #d9e2ec;
    border-radius: 20px;
    padding: 22px;
    box-shadow: none;
}

.tires-entry-panel {
    padding: 24px;
}

.tire-entry-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
    margin: 22px 0;
}

.tire-entry-mini-card {
    background: #f8fbff;
    border: 1px solid #d9e2ec;
    border-radius: 18px;
    padding: 18px;
}

.tire-entry-mini-card h3 {
    margin: 0 0 8px;
    font-size: 18px;
    color: #10233f;
}

.tire-entry-mini-card p {
    margin: 0;
    font-size: 15px;
    line-height: 1.5;
    color: #5f738c;
}

@media (max-width: 1100px) {
    .symptom-card-grid,
    .premium-inline-box {
        grid-template-columns: 1fr;
    }

    .tire-entry-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 760px) {
    .symptom-card-top,
    .symptom-list-item {
        grid-template-columns: 1fr;
        display: grid;
    }

    .symptom-card h3,
    .symptom-list-item h3 {
        font-size: 24px;
    }
}


/* === Workshop-Check redesign === */
.workshop-hero-clean {
    padding-bottom: 20px;
}

.workshop-hero-shell {
    align-items: center;
    gap: 38px;
}

.workshop-hero-copy h1 {
    max-width: 700px;
    margin-bottom: 18px;
}

.workshop-hero-copy .hero-text {
    max-width: 690px;
}

.workshop-hero-points {
    list-style: none;
    margin: 26px 0 0;
    padding: 0;
    display: grid;
    gap: 14px;
}

.workshop-hero-points li {
    position: relative;
    padding-left: 26px;
    color: #10233f;
    font-weight: 600;
    line-height: 1.5;
}

.workshop-hero-points li::before {
    content: '';
    position: absolute;
    left: 0;
    top: 10px;
    width: 9px;
    height: 9px;
    border-radius: 999px;
    background: #f0a31a;
}

.workshop-hero-visual {
    display: grid;
    gap: 18px;
}

.workshop-hero-visual-card {
    background: linear-gradient(180deg, #ffffff 0%, #f7fbff 100%);
    border: 1px solid #d9e5f4;
    border-radius: 28px;
    padding: 18px;
    box-shadow: 0 12px 30px rgba(16, 35, 63, 0.05);
}

.workshop-hero-visual-card img {
    display: block;
    width: 100%;
    height: auto;
    border-radius: 18px;
}

.workshop-hero-trustbar {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
}

.workshop-hero-trustbar div,
.workshop-empty-grid article,
.workshop-package-item {
    background: #ffffff;
    border: 1px solid #d9e5f4;
    border-radius: 18px;
    padding: 18px;
}

.workshop-hero-trustbar strong,
.workshop-empty-grid h3,
.workshop-package-item strong {
    display: block;
    color: #10233f;
    margin-bottom: 6px;
}

.workshop-hero-trustbar span,
.workshop-empty-grid p,
.workshop-package-item p,
.workshop-panel-head p {
    color: #5f738c;
    line-height: 1.7;
}

.workshop-main-section {
    padding-top: 10px;
}

.workshop-main-grid {
    grid-template-columns: minmax(0, 1.15fr) minmax(360px, 0.85fr);
    gap: 28px;
    align-items: start;
}

.workshop-form-panel,
.workshop-result-panel-clean {
    padding: 30px;
    border-radius: 26px;
}

.workshop-panel-head {
    margin-bottom: 20px;
}

.workshop-panel-head h2,
.workshop-result-panel-clean h2,
.workshop-followup-head h2,
.workshop-premium-copy h2 {
    margin: 0 0 12px;
}

.workshop-submit-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    margin-top: 6px;
}

.workshop-submit-row .helper-text {
    max-width: 560px;
    margin: 0;
}

.workshop-result-panel-clean {
    min-height: 100%;
}

.workshop-result-highlight {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
    margin: 18px 0 20px;
}

.workshop-result-highlight div {
    background: #f8fbff;
    border: 1px solid #d9e5f4;
    border-radius: 18px;
    padding: 18px;
}

.workshop-result-highlight span {
    display: block;
    color: #5f738c;
    font-size: 14px;
    margin-bottom: 8px;
}

.workshop-result-highlight strong {
    display: block;
    color: #10233f;
    font-size: 28px;
    line-height: 1.2;
}

.workshop-adjustment-card-clean {
    border-radius: 20px;
}

.workshop-detail-block {
    margin-top: 22px;
    padding-top: 20px;
    border-top: 1px solid #dbe6f3;
}

.workshop-empty-grid {
    display: grid;
    gap: 14px;
    margin-top: 22px;
}

.workshop-followup-zone {
    padding-top: 12px;
}

.workshop-followup-head {
    align-items: end;
    margin-bottom: 18px;
}

.workshop-followup-head p {
    max-width: 700px;
}

.workshop-followup-cards {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    margin-bottom: 26px;
}

.workshop-next-card {
    display: flex;
    flex-direction: column;
    gap: 12px;
    min-height: 100%;
}

.workshop-next-card .btn {
    margin-top: auto;
    align-self: flex-start;
}

.workshop-premium-box {
    margin-top: 0;
}

.workshop-package-list {
    display: grid;
    gap: 14px;
    margin: 22px 0;
}

@media (max-width: 1100px) {
    .workshop-main-grid,
    .workshop-followup-cards,
    .workshop-hero-trustbar,
    .workshop-result-highlight {
        grid-template-columns: 1fr;
    }

    .workshop-submit-row {
        flex-direction: column;
        align-items: flex-start;
    }
}

@media (max-width: 760px) {
    .workshop-form-panel,
    .workshop-result-panel-clean,
    .workshop-hero-visual-card {
        padding: 20px;
    }
}
