:root{
    --bg:#ffffff; /* светлый фон */
    --panel:#fff7f9; /* очень светлый розовый */
    --panel-2:#ffeef3;
    --soft:#ffe6ec;
    --text:#222222;
    --muted:#666666;
    --brand:#ff4b8b; /* CTA розово-коралловый */
    --brand-2:#ff7da5;
    --accent:#e7fbff; /* лёгкая бирюза для подсветок */
    --badge:#ffd6e1; /* розовый бейдж */
    --ok:#20c997;
    --warning:#ffb54a;
    --shadow: 0 10px 24px rgba(255,75,139,.18);
    --radius: 18px;
    --radius-lg: 22px;
    --container: 1200px;
}
*{box-sizing:border-box}
html,body{height:100%}
body{
    margin:0; font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,"Helvetica Neue",Arial,"Apple Color Emoji","Segoe UI Emoji"; color:var(--text); background:var(--bg);
}
a{color:inherit;text-decoration:none}
img{max-width:100%; display:block}
.container{width:100%; max-width:var(--container); margin-inline:auto; padding-inline:20px}

/* Header */
.site-header{position:sticky; top:0; z-index:50; backdrop-filter:saturate(120%) blur(8px); background:rgba(255,255,255,.85); border-bottom:1px solid rgba(0,0,0,.06)}
.nav{display:flex; align-items:center; justify-content:space-between; height:64px}
.brand{display:flex; gap:12px; align-items:center}
.brand-logo{width:36px;height:36px;border-radius:10px;background:linear-gradient(135deg,#ff6b86,#ffc371); display:grid; place-items:center; box-shadow: var(--shadow)}
.brand-logo:after{content:"❤";font-weight:700;color:#fff}
.brand-title{font-weight:800; letter-spacing:.4px}
.nav-links{display:flex; gap:22px}
.nav-links a{opacity:.9}
.nav-links a:hover{opacity:1}

/* Hero */
.hero{
    position:relative; overflow:hidden;
    background:
            radial-gradient(1200px 500px at 80% 20%, rgba(163, 237, 239, .28), transparent 70%),
            linear-gradient(180deg,#eafcff 0%, #fff 60%); /* бирюзово-белый как на скрине */
}
.hero-inner{display:grid; grid-template-columns:1.3fr .7fr; gap:20px; align-items:center; min-height:420px; padding:40px 0}
.hero h1{font-size:54px; line-height:1.03; margin:0 0 12px; letter-spacing:.3px}
.hero p{color:var(--muted); margin:0 0 24px}
.hero-badge{display:inline-flex; align-items:center; gap:8px; padding:6px 12px; background:#ffe9f0; border:1px solid #ffd4e0; border-radius:999px; color:#b23a62; font-weight:600; font-size:13px}
.hero-cta{display:flex; gap:12px; flex-wrap:wrap}
.btn{appearance:none; border:none; border-radius:14px; padding:14px 18px; font-weight:700; cursor:pointer; transition:.2s transform,.2s box-shadow,.2s background}
.btn-primary{background:var(--brand); color:#fff; box-shadow:0 8px 20px rgba(255,75,139,.35)}
.btn-primary:hover{transform:translateY(-1px); background:#ff367d}
.btn-ghost{background:#ffffff; border:1px solid rgba(0,0,0,.08); color:#222}
.hero-art{position:relative}
.hero-img{width:100%; aspect-ratio: 4/5; object-fit:cover; border-radius:24px; background:#f8f1f3 url('../../img/banner.webp') center/cover no-repeat; box-shadow:0 40px 120px rgba(255,105,130,.18)}

/* TOP 3 strip */
.strip{background:linear-gradient(180deg, #fff, #fdf7f9); border-top:1px solid rgba(0,0,0,.06); border-bottom:1px solid rgba(0,0,0,.06)}
.strip-inner{padding:28px 0}
.strip h3{font-size:18px; letter-spacing:.4px; text-transform:uppercase; opacity:.9; margin:0 0 14px; color:#333}
.card-row{display:grid; grid-template-columns:repeat(3,1fr); gap:18px}
.topcard{background:#ffffff; border:1px solid rgba(0,0,0,.06); border-radius:var(--radius); padding:16px; display:grid; grid-template-columns:1fr auto; align-items:center; gap:10px; box-shadow:0 8px 20px rgba(0,0,0,.04)}
.topcard h4{margin:2px 0 10px; font-size:20px; color:#222}
.rating{display:flex; align-items:center; gap:8px; font-weight:800; color:#111}
.stars{display:inline-flex; gap:2px; font-size:14px; opacity:.95}
.stars i{color:#ffc04d}
.get-btn{display:inline-block; padding:10px 14px; background:#ff4b8b; color:#fff; border-radius:12px; font-weight:800}

/* Disclosure */
.disclosure{font-size:13px; color:var(--muted); text-align:center; margin:8px 0 0}

/* Reviews list (big panels) */
.list{padding:36px 0}
.panel{
    background:linear-gradient(180deg,#ffffff,#fff);
    border:1px solid rgba(0,0,0,.08); border-radius:var(--radius-lg);
    padding:26px; display:grid; grid-template-columns:140px 1fr auto; align-items:center; gap:22px; margin:16px 0;
    box-shadow:0 16px 36px rgba(0,0,0,.06)
}
.logo {
    width: 140px;
    height: 64px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 12px;
    overflow: hidden;
    background: #ffe0e6;
}
.logo img { max-width: 100%; max-height: 100%; object-fit: contain; }
.panel h5{margin:0 0 8px; font-size:20px; color:#1d1d1f}
.panel ul{margin:0; padding-left:20px; line-height:1.6; color:#333}
.score{display:grid; place-items:center; width:96px; height:96px; border-radius:999px; border:4px solid #ff8aa6; color:#111; background:#fff; font-weight:900; font-size:28px}
.visit{display:inline-block; padding:14px 22px; border-radius:14px; background:var(--brand); color:#fff; font-weight:800}

/* Offer of the month */
.offer{padding:36px; background:#ffe4e7; border-radius:24px}
.offer .card{background:#ffffff; border-radius:18px; padding:22px; display:grid; grid-template-columns:170px 1fr auto auto; align-items:center; gap:20px; border:1px solid rgba(0,0,0,.06); box-shadow:0 8px 24px rgba(0,0,0,.05)}
.offer .score{border-color:#ffb4c2}

/* FAQ + Sidebar */
.faq-wrap{display:grid; grid-template-columns:1.1fr .6fr; gap:28px; align-items:start; margin-top:36px}

.faq{background:#ffffff; border:1px solid rgba(0,0,0,.08); border-radius:22px; padding:22px; box-shadow:0 10px 24px rgba(0,0,0,.04)}
.faq h2{margin:0 0 14px; font-size:32px; color:#171717}
.faq-item{border:1px solid rgba(0,0,0,.08); border-radius:14px; background:#fff7fa; margin:12px 0; overflow:hidden}
.faq-q{display:flex; justify-content:space-between; align-items:center; gap:12px; padding:18px; cursor:pointer; font-weight:700; color:#222}
.faq-q .plus{width:32px; height:32px; display:grid; place-items:center; font-size:20px; border-radius:10px; background:#ffe2ea; color:#b23a62}
.faq-a{display:none; padding:0 18px 18px; color:#444}

.sidebar{position:static;}
.side-card{background:#ffffff; border:2px solid #ffd2dc; border-radius:20px; padding:18px; position:sticky; top:24px; box-shadow:0 10px 24px rgba(0,0,0,.05)}
.side-card h3{margin:0 0 10px; text-transform:uppercase; letter-spacing:.4px; font-size:18px; color:#333}
.side-item{display:grid; grid-template-columns:70px 1fr auto; align-items:center; gap:12px; border:1px solid rgba(0,0,0,.08); background:#ffffff; border-radius:14px; padding:12px; margin:10px 0; box-shadow:0 6px 14px rgba(0,0,0,.04)}
.side-logo {
    width: 70px; height: 40px; display: flex; align-items: center; justify-content: center;
    border-radius: 8px; overflow: hidden; background: #ffe0e6;
}
.side-logo img { width:100%; height:100%; object-fit: contain; }
.side-rating{font-weight:800; background:#fff2f6; padding:6px 10px; border-radius:10px; color:#b23a62}
.side-cta{display:block; text-align:center; font-weight:800; background:var(--brand); color:#fff; border-radius:12px; padding:12px; margin-top:10px}

/* Footer */
footer{border-top:1px solid rgba(0,0,0,.08); margin-top:40px; padding:34px 0 70px; color:var(--muted); background:#fff}
.footer-grid{display:flex; justify-content:space-between; align-items:center; gap:20px; flex-wrap:wrap}
.foot-links{display:flex; gap:20px}

/* Responsive */
@media (max-width: 1024px){
    .hero-inner{grid-template-columns:1fr}
    .card-row{grid-template-columns:1fr}
    .panel{grid-template-columns:110px 1fr; grid-auto-rows: auto}
    .score{order:3}
    .offer .card{grid-template-columns:120px 1fr auto}
    .faq-wrap{grid-template-columns:1fr}
    .side-card{position:static}
}

/* ========== Inline media (figure with image) ========== */
.inline-media{
    --media-radius: 18px;
    --media-shadow: 0 14px 36px rgba(0,0,0,.08);
    --media-shadow-hover: 0 18px 42px rgba(0,0,0,.10);

    margin: 24px auto;
    display: block;
    max-width: 960px;              /* ограничиваем ширину, чтобы не «плыло» */
    width: 100%;
    background: #fff;              /* карточка под картинкой */
    border: 1px solid rgba(0,0,0,.06);
    border-radius: var(--media-radius);
    box-shadow: var(--media-shadow);
    overflow: clip;                /* аккуратная обрезка углов, лучше чем hidden */
}

.inline-media img{
    display:block;
    width:100%;
    height:auto;                   /* сохраняем пропорции из width/height атрибутов */
    object-fit:cover;
    background:#ffe6ec;            /* нежный бэкграунд на случай пустого src */
    aspect-ratio: 16/9;            /* подсказка браузеру для расчёта места */
}

/* Необязательная видимая подпись (если уберёшь sr-only): */
.inline-media figcaption{
    padding: 10px 14px 14px;
    font-size: 14px;
    line-height: 1.4;
    color: #666;
}

/* Sr-only утилита (оставь, если используешь невидимую подпись для SEO/а11y) */
.sr-only{
    position:absolute!important;
    width:1px!important;
    height:1px!important;
    padding:0!important;
    margin:-1px!important;
    overflow:hidden!important;
    clip:rect(0,0,0,0)!important;
    white-space:nowrap!important;
    border:0!important;
}

/* ---------- Модификаторы (по желанию через классы) ---------- */

/* «Во всю ширину» контейнера контента */
.inline-media.is-wide{
    max-width: 1200px;
}

/* Полноширинный (для hero-секции, растягивается на весь экран по краям) */
.inline-media.is-fullbleed{
    max-width: none;
    width: 100vw;
    margin-left: 50%;
    transform: translateX(-50%);
    border-radius: 0;
}

/* Мягкий hover для десктопов */
@media (hover:hover){
    .inline-media:hover{ box-shadow: var(--media-shadow-hover); }
}

/* ---------- Адаптив ---------- */
@media (max-width: 1024px){
    .inline-media{ margin: 20px auto; }
}

@media (max-width: 640px){
    .inline-media{
        margin: 16px auto;
        border-radius: 16px;
    }
    .inline-media img{ aspect-ratio: auto; } /* на телефонах опираемся на реальные атрибуты */
}

/* Учитываем предпочтения пользователя по анимациям */
@media (prefers-reduced-motion: reduce){
    .inline-media{ transition: none; }
}

/* ======== Table Block ======== */

.table-wrap {
    width: 100%;
    margin: 32px auto;
    overflow-x: auto; /* адаптив для телефонов */
    -webkit-overflow-scrolling: touch;
    border-radius: 18px;
    background: #fff;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.05);
    border: 1px solid rgba(0, 0, 0, 0.06);
}

.mini-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 16px;
    color: #222;
    text-align: left;
    min-width: 600px; /* для плавного скролла на телефоне */
}

.mini-table thead {
    background: linear-gradient(90deg, #ffe8ef, #fff4f7);
}

.mini-table th {
    padding: 16px 20px;
    font-weight: 700;
    color: #b23a62;
    border-bottom: 2px solid #ffd6e3;
    font-size: 15px;
    letter-spacing: 0.3px;
}

.mini-table td {
    padding: 14px 20px;
    vertical-align: top;
    border-bottom: 1px solid rgba(0, 0, 0, 0.05);
    line-height: 1.6;
}

/* — чередование строк для читабельности */
.mini-table tbody tr:nth-child(even) {
    background: #fff9fb;
}

/* — hover эффект */
@media (hover: hover) {
    .mini-table tbody tr:hover {
        background: #ffeef4;
        transition: background 0.25s ease;
    }
}

/* — округление краёв */
.mini-table thead tr:first-child th:first-child {
    border-top-left-radius: 18px;
}
.mini-table thead tr:first-child th:last-child {
    border-top-right-radius: 18px;
}
.mini-table tbody tr:last-child td:first-child {
    border-bottom-left-radius: 18px;
}
.mini-table tbody tr:last-child td:last-child {
    border-bottom-right-radius: 18px;
}

/* — адаптивные размеры шрифта и паддингов */
@media (max-width: 768px) {
    .mini-table {
        font-size: 14px;
        min-width: 100%;
    }
    .mini-table th,
    .mini-table td {
        padding: 12px 14px;
    }
}

/* — узкие экраны: небольшая подсветка при скролле */
@media (max-width: 640px) {
    .table-wrap {
        border-radius: 14px;
        box-shadow: 0 6px 18px rgba(0, 0, 0, 0.04);
    }
    .table-wrap::after {
        content: "→";
        position: absolute;
        right: 12px;
        top: 12px;
        color: #ff4b8b;
        font-weight: 600;
        opacity: 0.4;
        font-size: 18px;
    }
}

