/*
 * «Зелена стрічка» — дизайн-система ratsiony.com.ua
 *
 * Правила:
 *  - кожна сторінка починається темною стрічкою .band (--xl / --m / --s)
 *  - кольори мають закріплені ролі: ink = стрічка + дані-акцент,
 *    green = все клікабельне, sage = групування (теги/hover), ніколи панелі
 *  - радіуси лише 16px (поверхні) та 100px (чипи/кнопки)
 *  - ритм: секції 64, заголовок→контент 24, між картками 16, всередині 12
 */

:root {
    --bg: #FAFAF7;
    --surface: #FFFFFF;
    --sage: #EBF0E8;
    --ink: #14201A;
    --ink-60: #4E5B53;
    --ink-35: #93A098;
    --green: #1E6B44;
    --green-deep: #144A2F;
    --green-light: #8FD9AC;
    --tomato: #D94F2B;
    --line: #DDE3DB;

    --radius: 16px;
    --radius-pill: 100px;
}

* { box-sizing: border-box; margin: 0; }
body {
    background: var(--bg);
    color: var(--ink);
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", "Helvetica Neue", Arial, sans-serif;
    line-height: 1.55;
    font-size: 16px;
    -webkit-font-smoothing: antialiased;
}
a { color: inherit; text-decoration: none; }
a:focus-visible, button:focus-visible, summary:focus-visible { outline: 2px solid var(--green); outline-offset: 2px; border-radius: 2px; }
.wrap { max-width: 1200px; margin: 0 auto; padding: 0 28px; }

/* ── header ─────────────────────────────────────────────────────────── */
.site-header {
    position: sticky; top: 0; z-index: 50;
    background: rgba(250, 250, 247, .94);
    backdrop-filter: blur(8px);
    border-bottom: 1px solid var(--line);
}
.header-inner { display: flex; align-items: center; gap: 22px; height: 64px; }
.logo { font-weight: 800; font-size: 22px; letter-spacing: -.03em; }
.logo-dot { color: var(--green); }
.main-nav { display: flex; gap: 4px; margin-left: auto; }
.nav-link { font-size: 14.5px; color: var(--ink-60); padding: 8px 14px; border-radius: var(--radius-pill); }
.nav-link:hover { color: var(--ink); background: var(--sage); }
.nav-cta {
    font-size: 14px; font-weight: 600; color: var(--green);
    border: 1.5px solid var(--green); padding: 8px 18px; border-radius: var(--radius-pill);
    transition: background .15s, color .15s; white-space: nowrap;
}
.nav-cta:hover { background: var(--green); color: #fff; }

/* dropdowns (no-JS: details/summary) */
.dropdown { position: relative; }
.dropdown > summary {
    list-style: none; cursor: pointer; font-size: 14.5px; color: var(--ink-60);
    padding: 8px 14px; border-radius: var(--radius-pill); user-select: none;
    white-space: nowrap;
}
.dropdown > summary::-webkit-details-marker { display: none; }
.dropdown > summary::after { content: " ▾"; font-size: 11px; color: var(--ink-35); }
.dropdown > summary:hover, .dropdown[open] > summary { color: var(--ink); background: var(--sage); }
.dropdown-menu {
    position: absolute; top: calc(100% + 6px); left: 0; z-index: 60;
    min-width: 200px; padding: 8px;
    background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius);
    box-shadow: 0 8px 24px rgba(20, 32, 26, .1);
    display: flex; flex-direction: column;
}
/* dropdowns у правій частині шапки розкриваються вліво, щоб не впиратись у край екрана */
.main-nav .dropdown-menu { left: auto; right: 0; }
.dropdown-menu a { font-size: 14px; padding: 7px 12px; border-radius: 8px; color: var(--ink-60); }
.dropdown-menu a:hover { background: var(--sage); color: var(--ink); }
.dropdown-menu a.active { color: var(--green); font-weight: 600; }
.dropdown-cols { flex-direction: row; gap: 18px; min-width: 400px; }
.dropdown-cols > div { display: flex; flex-direction: column; min-width: 180px; }
.dropdown-label {
    font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .08em;
    color: var(--ink-35); padding: 6px 12px 4px;
}
.city-picker { flex-shrink: 0; }
.city-picker > summary { font-weight: 600; color: var(--ink); border: 1px solid var(--line); }

/* ── band: темна стрічка, один паттерн у трьох розмірах ─────────────── */
.band { background: var(--ink); color: #F2F5F1; }
.band--xl { padding: 76px 0 68px; }
.band--m { padding: 30px 0 26px; }
.band--s { padding: 20px 0 18px; }

.band-inner { display: flex; align-items: center; justify-content: space-between; gap: 48px; flex-wrap: wrap; }

.band h1 { color: #fff; font-weight: 800; letter-spacing: -.03em; line-height: 1.06; text-wrap: balance; margin: 0; }
.band--xl h1 { font-size: clamp(34px, 5vw, 56px); max-width: 16ch; }
.band--m h1 { font-size: clamp(24px, 3.4vw, 34px); }
.band--s h1 { font-size: clamp(19px, 2.6vw, 24px); }
.band h1 em { font-style: normal; color: var(--green-light); }

.band-sub { margin-top: 16px; font-size: 17px; color: #A9B7AD; max-width: 54ch; }
.band-meta { font-size: 14px; color: #A9B7AD; margin-top: 8px; display: flex; flex-wrap: wrap; gap: 6px 18px; align-items: baseline; }
.freshness { color: var(--green); font-weight: 600; }
.band .freshness { color: var(--green-light); }
.band .crumbs { color: #7E8B81; padding: 0 0 10px; font-size: 12.5px; }
.band .crumbs a:hover { color: #A9B7AD; }

.trust-list {
    list-style: none; padding: 0;
    display: flex; flex-wrap: wrap; gap: 22px;
    margin-top: 26px; font-size: 14px; color: #DCE5DE;
}
.trust-list li { display: inline-flex; align-items: center; gap: 8px; }
.trust-list li::before {
    content: ""; width: 7px; height: 7px; border-radius: 50%;
    background: var(--green-light); flex-shrink: 0;
}
.stat-card {
    display: grid; grid-template-columns: repeat(3, 1fr);
    background: rgba(255, 255, 255, .06);
    border-radius: var(--radius);
    min-width: 400px;
}
.stat-card > div { padding: 26px 30px; text-align: center; }
.stat-card > div + div { border-left: 1px solid rgba(255, 255, 255, .09); }
.stat-card b {
    display: block; font-size: 36px; font-weight: 800;
    letter-spacing: -.02em; color: var(--green-light);
    font-variant-numeric: tabular-nums;
}
.stat-card span { font-size: 13px; color: #A9B7AD; }

/* ── ритм секцій: 64 між, 24 заголовок→контент ──────────────────────── */
main .wrap section { padding: 64px 0 0; }
.sec-head { display: flex; align-items: baseline; justify-content: space-between; gap: 20px; margin-bottom: 24px; }
h2 { font-size: 22px; font-weight: 800; letter-spacing: -.02em; }
.result-count { font-size: 14px; color: var(--ink-35); font-weight: 400; margin-left: 8px; }
.sec-head a { font-size: 14px; font-weight: 600; color: var(--green); white-space: nowrap; }
.sec-head a:hover { text-decoration: underline; }

.crumbs { font-size: 13px; color: var(--ink-35); padding-top: 22px; }
.crumbs a:hover { color: var(--ink-60); }
.crumbs-sep { margin: 0 7px; }

.sort-nav { display: flex; gap: 4px; font-size: 13.5px; white-space: nowrap; }
.sort-nav a { color: var(--ink-35); padding: 4px 12px; border-radius: var(--radius-pill); }
.sort-nav a:hover { color: var(--ink); }
.sort-nav a.on { background: var(--sage); color: var(--green-deep); font-weight: 600; }

/* ── фільтр: липкий тулбар під шапкою ───────────────────────────────── */
.filterbar {
    margin-top: 24px; background: var(--surface); border: 1px solid var(--line);
    border-radius: var(--radius); padding: 16px 20px;
    box-shadow: 0 1px 2px rgba(20, 32, 26, .04);
}
.filter-row { display: flex; flex-wrap: wrap; gap: 8px; align-items: center; }
.filter-row + .filter-row { margin-top: 12px; padding-top: 12px; border-top: 1px dashed var(--line); }
.filter-label {
    font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .08em;
    color: var(--ink-35); margin-right: 6px;
}
.chip {
    font-size: 14px; padding: 7px 15px; border-radius: var(--radius-pill);
    border: 1px solid var(--line); background: var(--bg); color: var(--ink-60);
    transition: border-color .12s, color .12s;
}
.chip:hover { border-color: var(--ink-35); color: var(--ink); }
.chip.on { background: var(--green); border-color: var(--green); color: #fff; font-weight: 600; }
.chip.on.chip--x::after { content: " ✕"; font-size: 11px; opacity: .75; }
.filter-field {
    display: inline-flex; align-items: center; gap: 8px;
    font-size: 13.5px; color: var(--ink-60);
}
.filterbar input[type="number"] {
    font: inherit; font-size: 14px; padding: 8px 12px; width: 110px;
    border: 1px solid var(--line); border-radius: 10px; background: var(--bg);
}
.filter-check {
    display: inline-flex; align-items: center; gap: 7px;
    font-size: 13.5px; color: var(--ink-60); cursor: pointer;
}
.filter-check input { accent-color: var(--green); width: 16px; height: 16px; }
.filter-apply {
    font: inherit; background: var(--green); color: #fff; border: none;
    font-size: 14.5px; font-weight: 600; padding: 9px 24px; border-radius: var(--radius-pill); cursor: pointer;
}
.filter-apply:hover { background: var(--green-deep); }
.filter-reset { font-size: 13.5px; color: var(--ink-35); text-decoration: underline; }

/* ── картки: єдина анатомія ─────────────────────────────────────────── */
.cards { display: grid; grid-template-columns: repeat(auto-fill, minmax(290px, 1fr)); gap: 26px 16px; }
.card {
    background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius);
    padding: 18px; display: flex; flex-direction: column;
    transition: border-color .15s, box-shadow .15s;
}
.card:hover { border-color: var(--ink-35); box-shadow: 0 6px 20px rgba(20, 32, 26, .07); }
/* бейдж сидить на верхньому ребрі картки, поза потоком – контент карток вирівняний */
.card { position: relative; }
.card-badge {
    position: absolute; top: -11px; left: 16px;
    font-size: 11px; font-weight: 700; background: var(--green); color: #fff;
    border-radius: var(--radius-pill); padding: 3px 12px;
    box-shadow: 0 1px 4px rgba(20, 32, 26, .18);
}
.card-badge--alt { background: var(--ink); }
.card:has(> .card-badge) { border-color: var(--green); }
.card:has(> .card-badge--alt) { border-color: var(--line); }
.cards { padding-top: 11px; margin-top: -11px; }
.card-top { display: flex; justify-content: space-between; align-items: flex-start; }
.brand { display: flex; justify-content: space-between; align-items: baseline; gap: 10px; width: 100%; }
.brand-name { font-weight: 700; font-size: 14px; color: var(--ink-60); }
.rating {
    font-size: 12.5px; font-weight: 700; background: var(--sage);
    padding: 3px 10px; border-radius: var(--radius-pill); white-space: nowrap; font-variant-numeric: tabular-nums;
}
.rating span { color: var(--ink-35); font-weight: 400; }
.card-title { font-size: 17px; font-weight: 700; letter-spacing: -.01em; margin-top: 10px; }
.card-goal { font-size: 12.5px; color: var(--green); font-weight: 600; margin-top: 2px; }
.card-desc { font-size: 14px; color: var(--ink-60); margin-top: 10px; }
.specs {
    display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 8px;
    margin: 12px 0; padding: 11px 0; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line);
}
.spec b { display: block; font-size: 15px; font-weight: 700; font-variant-numeric: tabular-nums; }
.spec span { font-size: 10.5px; color: var(--ink-35); text-transform: uppercase; letter-spacing: .05em; }
.tags { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 12px; }
.tag { font-size: 12px; padding: 3px 10px; border-radius: var(--radius-pill); background: var(--sage); color: var(--green-deep); font-weight: 500; }
.card-foot { margin-top: auto; display: flex; justify-content: space-between; align-items: center; }
.price b { font-size: 19px; font-weight: 800; letter-spacing: -.02em; font-variant-numeric: tabular-nums; }
.price span { font-size: 13px; color: var(--ink-35); }
.card-link { font-size: 14px; font-weight: 600; color: var(--green); }
.card-link:hover { text-decoration: underline; }
.empty-state { color: var(--ink-60); padding: 24px 0; }
.empty-state a { color: var(--green); text-decoration: underline; }

/* ── швидкий підбір (головна) ───────────────────────────────────────── */
.quick-pick { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.qp-col {
    background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius);
    padding: 18px 16px; display: flex; flex-direction: column; gap: 2px;
}
.qp-h {
    font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .08em;
    color: var(--ink-35); margin: 0 0 10px; padding: 0 10px;
}
.qp-link {
    display: flex; justify-content: space-between; align-items: baseline;
    font-size: 14.5px; padding: 7px 10px; border-radius: 8px; color: var(--ink);
}
.qp-link:hover { background: var(--sage); }
.qp-link span { font-size: 12.5px; color: var(--ink-35); font-variant-numeric: tabular-nums; }
.qp-link.is-empty { color: var(--ink-35); }
.qp-link.qp-more { color: var(--green); font-weight: 600; margin-top: 4px; }

/* ── сторінка сервісу ───────────────────────────────────────────────── */
.service-cta {
    display: inline-block;
    font-size: 14.5px; font-weight: 600; border-radius: var(--radius-pill);
    padding: 10px 24px; background: var(--green); color: #fff;
}
.service-cta:hover { background: var(--green-deep); }
.service-actions { padding-top: 24px; display: flex; align-items: center; gap: 16px; flex-wrap: wrap; }

/* ── таблиці: світла (дані) і темна (порівняння) ────────────────────── */
.table-wrap { overflow-x: auto; border: 1px solid var(--line); border-radius: var(--radius); background: var(--surface); }
table { width: 100%; min-width: 560px; border-collapse: collapse; font-size: 14px; }
th {
    text-align: left; font-size: 11px; text-transform: uppercase; letter-spacing: .07em;
    color: var(--ink-35); padding: 11px 14px; border-bottom: 1px solid var(--line); font-weight: 700;
}
td { padding: 11px 14px; border-bottom: 1px solid var(--line); font-variant-numeric: tabular-nums; }
tr:last-child td { border-bottom: none; }
td a { color: var(--green); }
td a:hover { text-decoration: underline; }
td small { color: var(--ink-35); }

.compare-wrap { overflow-x: auto; border-radius: var(--radius); }
table.compare { min-width: 560px; font-size: 13.5px; background: var(--ink); color: #DCE5DE; }
.compare th { color: #8B978E; border-bottom: 1px solid #2C3B31; }
.compare td { border-bottom: 1px solid #24312A; }
.compare tr:last-child td { border-bottom: none; }
.compare td:first-child { font-weight: 700; color: #fff; }
.compare td:first-child a { color: #fff; }
.compare td:first-child a:hover { color: var(--green-light); }
.compare .best { color: var(--green-light); font-weight: 700; }

/* ── seo text / footer ──────────────────────────────────────────────── */
.seo-block { max-width: 68ch; color: var(--ink-60); font-size: 15.5px; }
.seo-block p { margin-bottom: 14px; }
.seo-block a { color: var(--green); }
.seo-block a:hover { text-decoration: underline; }

.site-footer { margin-top: 64px; border-top: 1px solid var(--line); padding: 40px 0 48px; background: var(--surface); }
.footer-grid { display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr 1fr; gap: 32px; }
.footer-h {
    font-size: 11px; text-transform: uppercase; letter-spacing: .08em;
    color: var(--ink-35); margin-bottom: 12px; font-weight: 700;
}
.footer-grid ul { list-style: none; padding: 0; font-size: 14px; display: grid; gap: 8px; color: var(--ink-60); }
.footer-grid a:hover { color: var(--ink); }
.footer-about { font-size: 13.5px; color: var(--ink-60); max-width: 34ch; margin-top: 10px; }
.footer-bottom {
    margin-top: 36px; padding-top: 18px; border-top: 1px solid var(--line);
    font-size: 12.5px; color: var(--ink-35);
    display: flex; justify-content: space-between; flex-wrap: wrap; gap: 10px;
}

/* ── responsive / a11y ──────────────────────────────────────────────── */
@media (max-width: 820px) {
    .header-inner { gap: 10px; }
    .main-nav { gap: 0; }
    .nav-cta { display: none; }
    .footer-grid { grid-template-columns: 1fr 1fr; }
    .quick-pick { grid-template-columns: 1fr; }
    .dropdown-cols { flex-direction: column; min-width: 220px; }
    .band--xl { padding: 48px 0 44px; }
    .stat-card { min-width: 100%; }
    .stat-card > div { padding: 18px 12px; }
    .stat-card b { font-size: 28px; }
}
@media (prefers-reduced-motion: reduce) {
    * { transition: none !important; }
}

/* ── faq ────────────────────────────────────────────────────────────── */
.faq { display: grid; gap: 10px; max-width: 820px; }
.faq-item { background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius); }
.faq-item summary {
    cursor: pointer; font-weight: 600; font-size: 15.5px; padding: 16px 20px;
    list-style: none; display: flex; justify-content: space-between; align-items: center; gap: 12px;
}
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary::after { content: "+"; font-size: 20px; font-weight: 400; color: var(--ink-35); flex-shrink: 0; }
.faq-item[open] summary::after { content: "–"; }
.faq-item p { padding: 0 20px 16px; color: var(--ink-60); font-size: 14.5px; max-width: 64ch; }

/* ── brand mark: лого сервісу або згенерована літера ────────────────── */
.brand-id { display: inline-flex; align-items: center; gap: 10px; min-width: 0; }
.mark {
    width: 40px; height: 40px; border-radius: 10px; flex-shrink: 0;
    display: inline-grid; place-items: center;
    color: #fff; font-size: 17px; font-weight: 800;
}
img.mark {
    background: #fff; border: 1px solid var(--line);
    object-fit: contain; padding: 4px;
}
/* велика плашка на сторінці сервісу */
.mark--lg { width: 56px; height: 56px; border-radius: 14px; font-size: 24px; }
img.mark--lg { padding: 6px; }
.band-brand { display: flex; align-items: center; gap: 16px; }
.band .mark { box-shadow: 0 2px 10px rgba(0, 0, 0, .25); border: none; }
