/* ═══════════════════════════════════════════════════
   POSITANO HOME — Editorial Redesign
   Photography-first · flat surfaces · one accent
═══════════════════════════════════════════════════ */

:root {
    --bg:          #f8f6f2;
    --bg-soft:     #faf9f6;
    --surface:     #fdfcfa;
    --surface-alt: #f3f1ed;
    --text:        #261d14;
    --muted:       #7a6a5e;
    --accent:      #9a5032;
    --accent-dark: #7c3d25;
    --line:        rgba(38, 29, 20, 0.10);
    --line-strong: rgba(38, 29, 20, 0.18);
    --shadow:      0 4px 18px rgba(38, 29, 20, 0.09);
    --shadow-lift: 0 12px 34px rgba(38, 29, 20, 0.12);
    --radius-xl:   20px;
    --radius-lg:   14px;
    --radius-md:   10px;
    --radius-sm:   7px;
    --max-width:   1240px;
}

*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }

body {
    margin: 0;
    min-width: 320px;
    font-family: "Manrope", sans-serif;
    color: var(--text);
    background: var(--bg);
}

a { color: inherit; text-decoration: none; }
button, input, select { font: inherit; }
img { display: block; max-width: 100%; }
.site-gradient { display: none; }

/* Layout */
.site-header, .site-footer, .section {
    width: min(calc(100% - 48px), var(--max-width));
    margin: 0 auto;
}
.section { padding: 100px 0 0; }

/* Header — flat strip */
.site-header {
    position: sticky;
    top: 0;
    z-index: 30;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 22px;
    width: 100%;
    max-width: 100%;
    padding: 14px clamp(20px, 3vw, 44px);
    background: var(--bg);
    border-bottom: 1px solid var(--line);
    border-radius: 0;
    box-shadow: none;
    backdrop-filter: none;
}

.brandmark { display: inline-flex; align-items: center; gap: 12px; min-width: fit-content; }

.brandmark__symbol, .footer-brand__symbol {
    display: inline-flex; align-items: center; justify-content: center;
    width: 40px; height: 40px; border-radius: 9px;
    background: var(--surface-alt); border: 1px solid var(--line);
}
.brandmark__symbol::before, .footer-brand__symbol::before { display: none; }

.brandmark__logo, .footer-brand__symbol img {
    width: 24px; height: 24px; object-fit: contain; opacity: 0.82; filter: none;
}

.brandmark__text { display: flex; flex-direction: column; }
.brandmark__text strong {
    font-family: "Manrope", sans-serif; font-size: 0.94rem; font-weight: 800;
    line-height: 1; letter-spacing: 0.2em; text-transform: uppercase;
}
.brandmark__text small {
    color: var(--muted); font-size: 0.60rem; font-weight: 600;
    letter-spacing: 0.2em; text-transform: uppercase; margin-top: 5px;
}

.site-nav, .header-actions, .hero__actions, .hero__stats, .hero-card__chips,
.footer-links, .sticky-marketplace__actions, .giveaway-copy__actions { display: flex; }

.site-nav { align-items: center; gap: 28px; font-size: 0.82rem; font-weight: 600; color: var(--muted); }
.site-nav a, .footer-links a, .path-card a { transition: color 0.2s ease; white-space: nowrap; }
.site-nav a:hover, .footer-links a:hover, .path-card a:hover { color: var(--accent); }
.header-actions, .hero__actions, .sticky-marketplace__actions, .giveaway-copy__actions { gap: 10px; }
.header-actions .button { min-height: 40px; padding-inline: 18px; }

/* Buttons */
.button {
    display: inline-flex; align-items: center; justify-content: center;
    min-height: 46px; padding: 0 22px; border: 1px solid transparent;
    border-radius: 6px; cursor: pointer; font-size: 0.84rem; font-weight: 700;
    letter-spacing: 0.04em;
    transition: background-color 0.18s ease, border-color 0.18s ease, transform 0.18s ease;
}
.button:hover { transform: translateY(-1px); }
.button:disabled { opacity: 0.45; cursor: not-allowed; transform: none; }
.button--primary { color: #fffaf5; background: var(--accent); border-color: var(--accent-dark); }
.button--primary:hover { background: var(--accent-dark); }
.button--secondary { color: var(--text); background: var(--surface); border-color: var(--line-strong); }
.button--secondary:hover { border-color: var(--accent); }
.button--ghost { color: var(--text); background: transparent; border-color: var(--line-strong); }
.button--ghost:hover { border-color: var(--accent); color: var(--accent); }

.icon-button {
    display: inline-flex; align-items: center; justify-content: center;
    width: 42px; height: 42px; border-radius: var(--radius-md);
    border: 1px solid var(--line); background: var(--surface); color: var(--text);
    cursor: pointer; transition: border-color 0.18s ease, transform 0.18s ease;
}
.icon-button:hover { transform: translateY(-1px); border-color: var(--accent); }
.icon-button svg { width: 18px; height: 18px; stroke: currentColor; }

/* Cards — flat, no blur */
.card {
    position: relative; overflow: hidden;
    background: var(--surface); border: 1px solid var(--line);
    border-radius: var(--radius-lg); box-shadow: none;
}
.card::before { display: none; }

/* Typography */
.eyebrow, .card__eyebrow, .path-card__index, .sticky-marketplace__label {
    display: inline-flex; align-items: center;
    letter-spacing: 0.16em; text-transform: uppercase;
    font-size: 0.68rem; font-weight: 700; color: var(--accent);
}

h1, h2, h3 { margin: 0; font-family: "Cormorant Garamond", serif; line-height: 0.96; }
h1 { margin-top: 14px; font-size: clamp(3.4rem, 6vw, 5.5rem); max-width: 8.7ch; }
h2 { font-size: clamp(2.2rem, 4vw, 4rem); }
h3 { font-size: clamp(1.6rem, 3vw, 2.3rem); }

.hero__lead, .section-heading p, .path-card p, .story-card p,
.buy-banner p, .card p, .more-scents p { color: var(--muted); line-height: 1.72; }

.section-heading { max-width: 820px; margin-bottom: 38px; }
.section-heading h2 { margin-top: 10px; }
.section-heading p:last-child { margin-top: 12px; }

/* Hero */
.hero {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(470px, 0.9fr);
    gap: clamp(34px, 5vw, 72px);
    align-items: start;
    min-height: calc(100vh - 80px);
    padding-top: clamp(32px, 5vw, 60px);
}
.hero__lead { max-width: 62ch; margin: 22px 0 0; font-size: 1.04rem; }

.hero__stats {
    display: grid; grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 10px; margin-top: 26px; max-width: 820px;
}
.hero__stats article {
    min-width: 0; display: grid; grid-template-columns: auto minmax(0, 1fr);
    gap: 10px; align-items: start; padding: 16px;
    border-radius: var(--radius-md); background: var(--surface); border: 1px solid var(--line);
}
.hero__stats strong { display: block; min-width: 40px; color: var(--accent); font-size: 1.3rem; line-height: 1; }
.hero__stats span { color: var(--muted); font-size: 0.9rem; line-height: 1.5; }
.hero__visual { display: grid; gap: 16px; align-content: start; min-width: 0; }

.hero > .hero__copy:not(.hero__copy--new), .hero__stage, .hero-spotlight { display: none; }

.hero__copy--new { display: grid; align-content: center; padding-top: clamp(18px, 3vw, 34px); }
.hero__copy--new h1 {
    max-width: 760px; font-size: clamp(3.45rem, 5.2vw, 5.6rem);
    line-height: 0.92; letter-spacing: -0.04em;
}
.hero__copy--new .hero__lead { max-width: 66ch; margin-top: 22px; }

.hero-routes {
    display: grid; grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px; margin-top: 28px;
}
.hero-routes a {
    position: relative; min-height: 112px; display: grid; align-content: end;
    gap: 6px; padding: 16px 16px 15px; border-radius: var(--radius-md);
    color: inherit; background: var(--surface); border: 1px solid var(--line);
    transition: border-color 0.22s ease, box-shadow 0.22s ease, transform 0.22s ease;
}
.hero-routes a::after { display: none; }
.hero-routes a:hover { transform: translateY(-2px); border-color: rgba(154,80,50,0.3); box-shadow: var(--shadow); }
.hero-routes span { color: var(--accent); font-size: 0.68rem; font-weight: 800; letter-spacing: 0.14em; text-transform: uppercase; }
.hero-routes strong { font-size: 0.96rem; }
.hero-routes small { color: var(--muted); line-height: 1.45; font-size: 0.78rem; }

/* Hero product photo */
.hero-product {
    position: relative; min-height: clamp(500px, 47vw, 640px); padding: 0;
    border-radius: var(--radius-xl); overflow: hidden; background: #e8ddd0;
    box-shadow: var(--shadow-lift); isolation: isolate;
}
.hero-product::before {
    content: ""; position: absolute; inset: 0; z-index: 1;
    background: linear-gradient(0deg, rgba(30,18,10,0.32), transparent 40%),
                linear-gradient(90deg, rgba(20,13,8,0.16), transparent 36%);
    pointer-events: none;
}
.hero-product img {
    position: absolute; inset: 0; width: 100%; height: 100%;
    object-fit: cover; object-position: 50% 58%;
    animation: productHeroBreath 11s ease-in-out infinite;
}
.hero-product__label, .hero-product__badge {
    position: absolute; z-index: 2;
    border: 1px solid rgba(255,255,255,0.48);
    background: rgba(250,245,238,0.93); box-shadow: none;
}
.hero-product__label {
    right: clamp(18px, 2.6vw, 30px); bottom: clamp(18px, 2.6vw, 30px);
    width: min(292px, calc(100% - 44px)); padding: clamp(16px, 2vw, 22px);
    border-radius: var(--radius-lg);
}
.hero-product__label span, .hero-product__badge small {
    display: block; color: var(--accent); font-size: 0.68rem; font-weight: 800;
    letter-spacing: 0.14em; text-transform: uppercase;
}
.hero-product__label strong {
    display: block; margin-top: 8px; font-family: "Cormorant Garamond", serif;
    font-size: clamp(2rem, 3.25vw, 3.25rem); line-height: 0.9; letter-spacing: -0.03em;
}
.hero-product__label small { display: block; margin-top: 10px; color: var(--muted); font-size: 0.86rem; line-height: 1.45; }
.hero-product__badge {
    display: grid; grid-template-columns: auto minmax(0, 1fr); align-items: center;
    gap: 10px; padding: 10px 14px; border-radius: 999px;
}
.hero-product__badge span { color: var(--accent); font-family: "Cormorant Garamond", serif; font-size: 1.68rem; line-height: 1; }
.hero-product__badge small { color: var(--text); letter-spacing: 0; text-transform: none; font-size: 0.82rem; }
.hero-product__badge--top { top: clamp(18px, 2.5vw, 28px); left: clamp(18px, 2.5vw, 28px); }
.hero-product__badge--bottom { top: clamp(82px, 6vw, 96px); left: clamp(18px, 2.5vw, 28px); bottom: auto; max-width: 224px; }

@keyframes productHeroBreath {
    0%, 100% { transform: scale(1.02); }
    50% { transform: scale(1.06) translate3d(1%, -0.6%, 0); }
}

/* Pathways */
.path-grid {
    display: grid; grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1px; background: var(--line); border: 1px solid var(--line);
    border-radius: var(--radius-lg); overflow: hidden;
}
.path-card { padding: 28px 24px; background: var(--surface); border-radius: 0; border: none; box-shadow: none; }
.path-card__index { margin-bottom: 18px; font-size: 0.65rem; }
.path-card h3 { font-size: 1.7rem; }
.path-card a {
    display: inline-flex; margin-top: 14px; font-size: 0.8rem; font-weight: 700;
    letter-spacing: 0.08em; color: var(--accent); text-decoration: underline; text-underline-offset: 3px;
}

/* Catalog */
.catalog-tabs {
    display: grid; grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 8px; margin: 0 0 20px;
}
.catalog-tab {
    display: grid; gap: 3px; min-height: 72px; padding: 13px 14px;
    border: 1px solid var(--line); border-radius: var(--radius-md);
    background: var(--surface); color: var(--text); text-align: left; cursor: pointer;
    transition: border-color 0.18s ease, background 0.18s ease;
}
.catalog-tab:hover, .catalog-tab.is-active { border-color: rgba(154,80,50,0.35); background: var(--bg-soft); }
.catalog-tab strong { font-size: 0.94rem; line-height: 1.2; }
.catalog-tab span { color: var(--muted); font-size: 0.74rem; line-height: 1.35; }
.catalog-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 12px; }

.scent-card { display: flex; flex-direction: column; min-height: 100%; cursor: pointer; transition: border-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease; }
.scent-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-lift); border-color: var(--line-strong); }
.scent-card.is-active { border-color: rgba(154,80,50,0.28); box-shadow: var(--shadow); }

.scent-card__visual {
    position: relative; display: flex; align-items: flex-end; justify-content: center;
    min-height: 230px; padding: 14px 14px 8px; background: var(--surface-alt); overflow: hidden;
}
.scent-card__visual::before { display: none; }
.scent-card__visual::after {
    content: ""; position: absolute; inset: 0 0 auto; height: 28%;
    background: linear-gradient(180deg, rgba(255,255,255,0.14), transparent); pointer-events: none;
}

.scent-card__tag {
    position: absolute; top: 10px; left: 10px; padding: 5px 10px; border-radius: 4px;
    background: var(--surface); border: 1px solid var(--line);
    font-size: 0.68rem; font-weight: 700; color: var(--accent); letter-spacing: 0.08em; text-transform: uppercase;
}
.scent-card__image {
    width: 90%; max-height: 290px; object-fit: contain; transform-origin: 50% 86%;
    transition: transform 0.28s ease;
    filter: drop-shadow(0 14px 22px rgba(38,29,20,0.18));
}
.scent-card:hover .scent-card__image {
    transform: translateY(-6px) rotate(-1deg) scale(1.03);
    filter: drop-shadow(0 22px 32px rgba(38,29,20,0.22));
}
.scent-card__placeholder {
    display: grid; place-items: center; width: 100%; height: 220px;
    border-radius: var(--radius-lg); background: var(--surface-alt); color: var(--muted); text-align: center; padding: 20px; font-weight: 700;
}
.scent-card__body { display: flex; flex: 1; flex-direction: column; padding: 14px 14px 12px; gap: 8px; }
.scent-card__topline, .compare-card__topline { display: flex; align-items: center; justify-content: space-between; gap: 10px; }
.scent-card__topline span, .compare-card__topline span { color: var(--accent); font-size: 0.68rem; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; }
.scent-card__topline strong, .sticky-marketplace__price { font-size: 1rem; font-weight: 800; }
.scent-card__body h3 { font-size: 1.6rem; line-height: 0.94; }
.scent-card__chips { display: flex; flex-wrap: wrap; gap: 5px; }
.hero-card__chips span, .scent-card__chips span, .set-card__list span, .more-scents__list span {
    display: inline-flex; align-items: center; padding: 5px 10px; border-radius: 4px;
    background: var(--surface-alt); border: 1px solid var(--line); color: var(--muted); font-size: 0.76rem; font-weight: 600;
}
.scent-card__meta { color: var(--muted); font-size: 0.86rem; line-height: 1.5; display: -webkit-box; -webkit-box-orient: vertical; -webkit-line-clamp: 2; overflow: hidden; }
.scent-card__actions { display: flex; align-items: center; gap: 8px; margin-top: auto; }
.scent-card__buy { flex: 1; }
.scent-card__market { flex: 0 0 auto; }

/* Interior */
.interior-panel { display: grid; grid-template-columns: minmax(280px, 0.7fr) minmax(0, 1.3fr); gap: 0; padding: 0; overflow: hidden; background: var(--surface); border-radius: var(--radius-xl); }
.interior-copy { display: grid; align-content: center; gap: 18px; padding: clamp(28px, 4vw, 48px); background: var(--surface); }
.interior-copy h2 { max-width: 14ch; }
.interior-copy p { max-width: 52ch; }
.interior-copy__actions { display: flex; flex-wrap: wrap; gap: 10px; }
.interior-copy__note {
    display: grid; gap: 5px; max-width: 440px; padding: 14px 16px;
    border-radius: var(--radius-md); background: var(--surface-alt); border: 1px solid var(--line); color: var(--muted); line-height: 1.58; font-size: 0.9rem;
}
.interior-copy__note strong { color: var(--text); }
.interior-gallery {
    display: grid; grid-template-columns: minmax(280px, 1.14fr) repeat(2, minmax(160px, 0.86fr));
    grid-template-rows: repeat(2, minmax(0, 1fr)); gap: 2px; min-height: 580px; background: var(--line);
}
.interior-card { position: relative; min-height: 0; overflow: hidden; border-radius: 0; background: #d5c8ba; border: none; }
.interior-card--large { grid-row: 1 / -1; }
.interior-card img { width: 100%; height: 100%; object-fit: cover; transform: scale(1.02); transition: transform 0.42s ease; }
.interior-card:hover img { transform: scale(1.06); }
.interior-card::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, transparent 48%, rgba(20,12,7,0.56)); pointer-events: none; }
.interior-card div { position: absolute; left: 18px; right: 18px; bottom: 18px; z-index: 1; display: grid; gap: 4px; color: #fff8ef; }
.interior-card span { font-size: 0.68rem; font-weight: 800; letter-spacing: 0.14em; text-transform: uppercase; opacity: 0.82; text-shadow: 0 2px 8px rgba(0,0,0,0.4); }
.interior-card strong { font-family: "Cormorant Garamond", serif; font-size: clamp(1.6rem, 2.8vw, 3rem); line-height: 0.9; text-shadow: 0 4px 16px rgba(0,0,0,0.3); }

/* Sets */
.set-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 1px; background: var(--line); border: 1px solid var(--line); border-radius: var(--radius-lg); overflow: hidden; }
.set-card { display: grid; gap: 14px; padding: 20px; background: var(--surface); }
.set-card__visual { position: relative; min-height: 280px; padding: 16px 14px 12px; border-radius: var(--radius-md); background: var(--surface-alt); overflow: hidden; }
.set-card__visual::before { display: none; }
.set-card__associations { position: absolute; inset: 12px 12px auto 12px; display: flex; flex-wrap: wrap; gap: 7px; }
.set-card__associations span {
    display: inline-flex; align-items: center; padding: 5px 9px; border-radius: 4px;
    background: var(--surface); border: 1px solid var(--line); color: var(--muted); font-size: 0.7rem; font-weight: 700;
    animation: drift 9s ease-in-out infinite;
}
.set-card__associations span:nth-child(2) { animation-delay: -2s; }
.set-card__associations span:nth-child(3) { animation-delay: -4s; }
.set-card__bottles { position: absolute; inset: auto 6px 8px 6px; display: flex; align-items: flex-end; justify-content: center; gap: 4px; }
.set-card__bottle { --set-card-x: 0px; --set-card-shift: 0px; --set-card-tilt: 0deg; width: 176px; transform: translateX(var(--set-card-x)) translateY(var(--set-card-shift)) rotate(var(--set-card-tilt)); filter: drop-shadow(0 16px 22px rgba(38,29,20,0.16)); animation: setCardBottleFloat 7.4s ease-in-out infinite; }
.set-card__bottle--middle { width: 206px; z-index: 2; animation-delay: -1.2s; }
.set-card__bottle--left { --set-card-x: 22px; --set-card-shift: 18px; --set-card-tilt: -5deg; }
.set-card__bottle--right { --set-card-x: -22px; --set-card-shift: 18px; --set-card-tilt: 5deg; animation-delay: -2.2s; }
.set-card__bottle:not(img), .set-modal__bottle:not(img) {
    position: relative; display: flex; align-items: flex-end; justify-content: center;
    min-height: 210px; padding: 0 12px 18px; border-radius: 28px 28px 20px 20px;
    background: linear-gradient(180deg, transparent 0 17%, rgba(17,16,16,0.92) 17% 29%, rgba(100,55,26,0.36) 29%, rgba(72,42,22,0.6) 100%);
    border: 1px solid rgba(100,75,50,0.18); color: var(--text); text-align: center; line-height: 1.3; overflow: visible;
}
.set-card__bottle:not(img)::before, .set-modal__bottle:not(img)::before {
    content: ""; position: absolute; top: -72px; left: 50%; width: 88px; height: 96px; transform: translateX(-50%);
    background: linear-gradient(78deg, transparent 10%, rgba(17,17,17,0.96) 10% 18%, transparent 18% 28%, rgba(17,17,17,0.96) 28% 36%, transparent 36% 46%, rgba(17,17,17,0.96) 46% 54%, transparent 54% 64%, rgba(17,17,17,0.96) 64% 72%, transparent 72% 82%, rgba(17,17,17,0.96) 82% 90%, transparent 90%);
    opacity: 0.92; pointer-events: none;
}
.set-card__bottle:not(img) span, .set-modal__bottle:not(img) span {
    display: inline-flex; align-items: center; justify-content: center; min-height: 64px; width: calc(100% - 12px);
    padding: 10px 12px; border-radius: 14px; background: var(--surface); border: 1px solid var(--line); font-size: 0.82rem; font-weight: 800;
}
.set-card h3 { margin-top: 0; }
.set-card__meta { display: flex; flex-wrap: wrap; gap: 8px; margin: 0; color: var(--muted); font-size: 0.9rem; }
.set-card__list, .more-scents__list { display: flex; flex-wrap: wrap; gap: 7px; }
.set-card__actions { display: flex; gap: 8px; }
.set-card__actions .button { width: 100%; }
.more-scents { margin-top: 18px; padding: 24px; }
.more-scents h3 { margin-top: 8px; }
.more-scents__list { margin-top: 16px; }

/* Layouts */
.quiz-layout, .gift-layout, .giveaway-layout { display: grid; gap: 16px; }
.quiz-layout { grid-template-columns: 0.9fr 1.1fr; }
.gift-layout { grid-template-columns: 0.9fr 1.1fr; }
.giveaway-layout { grid-template-columns: 0.86fr 1fr 0.82fr; align-items: start; }
.persona-layout { display: grid; grid-template-columns: 1fr 0.92fr; gap: 16px; }
.persona-options { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; }

.persona-option { padding: 20px; border-radius: var(--radius-md); border: 1px solid var(--line); background: var(--surface); cursor: pointer; transition: border-color 0.18s ease, transform 0.18s ease; text-align: left; }
.persona-option:hover, .persona-option.is-active { transform: translateY(-1px); border-color: rgba(154,80,50,0.36); }
.persona-option strong { display: block; margin-bottom: 8px; font-size: 1.08rem; }
.persona-option p { margin: 0; color: var(--muted); line-height: 1.6; }

.persona-result { display: grid; align-content: start; gap: 14px; padding: 26px; }
.persona-result__note { color: var(--muted); line-height: 1.72; }
.persona-result__chips { display: flex; flex-wrap: wrap; gap: 7px; }
.persona-result__chips span { display: inline-flex; align-items: center; padding: 7px 12px; border-radius: 4px; background: var(--surface-alt); border: 1px solid var(--line); color: var(--muted); font-size: 0.82rem; font-weight: 700; }
.persona-result__actions { display: flex; flex-wrap: wrap; gap: 10px; }

.quiz-intro, .quiz-card, .gift-form, .gift-result, .giveaway-copy, .giveaway-wheel, .giveaway-result, .buy-banner, .story-card, .room-panel, .compare-controls { padding: 26px; }

.feature-list { display: grid; gap: 12px; padding: 0; margin: 16px 0 0; list-style: none; }
.feature-list li { position: relative; padding-left: 16px; color: var(--muted); line-height: 1.65; font-size: 0.9rem; }
.feature-list li::before { content: ""; position: absolute; top: 10px; left: 0; width: 6px; height: 6px; border-radius: 50%; background: var(--accent); }

.quiz-card__topline { display: flex; align-items: center; gap: 16px; margin-bottom: 20px; }
.quiz-progress { flex: 1; height: 3px; background: var(--line-strong); border-radius: 999px; overflow: hidden; }
.quiz-progress__bar { width: 25%; height: 100%; border-radius: inherit; background: var(--accent); transition: width 0.28s ease; }

.option-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; margin-top: 20px; }
.option-card { padding: 16px; border-radius: var(--radius-md); border: 1px solid var(--line); background: var(--surface); cursor: pointer; transition: border-color 0.18s ease, transform 0.18s ease; }
.option-card:hover, .option-card.is-selected { transform: translateY(-1px); border-color: rgba(154,80,50,0.36); }
.option-card strong { display: block; font-size: 1.04rem; margin-bottom: 7px; }
.option-card p { margin: 0; color: var(--muted); font-size: 0.9rem; line-height: 1.55; }
.quiz-actions { display: flex; justify-content: space-between; gap: 10px; margin-top: 20px; }
.quiz-result, .gift-match-grid, .room-picks, .compare-grid { margin-top: 20px; }
.result-grid, .gift-match-grid, .room-picks, .compare-grid, .story-grid { display: grid; gap: 14px; }
.result-grid, .gift-match-grid, .story-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }

.result-card, .gift-match, .compare-card { position: relative; overflow: hidden; padding: 18px; border-radius: var(--radius-md); background: var(--surface); border: 1px solid var(--line); cursor: pointer; transition: border-color 0.18s ease, transform 0.18s ease, box-shadow 0.18s ease; }
.result-card:hover, .gift-match:hover, .compare-card:hover { transform: translateY(-1px); box-shadow: var(--shadow); border-color: var(--line-strong); }
.result-card__visual, .compare-card__visual { display: flex; align-items: flex-end; justify-content: center; min-height: 170px; margin-bottom: 14px; border-radius: var(--radius-md); background: var(--surface-alt); }
.result-card__visual img, .compare-card__visual img { width: 58%; max-height: 160px; object-fit: contain; filter: drop-shadow(0 12px 18px rgba(38,29,20,0.16)); }
.result-card h4, .gift-match h4, .compare-card h4 { margin: 0; font-size: 1.4rem; font-family: "Cormorant Garamond", serif; }
.result-card p, .gift-match p, .compare-card p { margin: 8px 0 0; }
.result-card__actions, .gift-match__actions, .compare-card__actions { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 14px; }

/* Rooms */
.room-layout { display: grid; grid-template-columns: 260px 1fr; gap: 16px; }
.room-tabs { display: grid; gap: 8px; }
.room-tab { display: flex; align-items: center; justify-content: space-between; padding: 13px 15px; border-radius: var(--radius-md); border: 1px solid var(--line); background: var(--surface); cursor: pointer; text-align: left; transition: border-color 0.18s ease, transform 0.18s ease; }
.room-tab:hover, .room-tab.is-active { transform: translateY(-1px); border-color: rgba(154,80,50,0.35); }
.room-tab strong { font-size: 0.96rem; }
.room-tab span { color: var(--accent); font-weight: 700; font-size: 0.8rem; }
.room-panel__top { display: flex; align-items: flex-start; justify-content: space-between; gap: 14px; }
.room-panel__copy p { margin-top: 10px; }
.room-panel__goal { min-width: 200px; padding: 13px 15px; border-radius: var(--radius-md); background: var(--surface-alt); border: 1px solid var(--line); color: var(--muted); line-height: 1.6; font-size: 0.88rem; }
.room-picks { grid-template-columns: repeat(3, minmax(0, 1fr)); }

/* Compare */
.compare-controls { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 14px; }
.compare-controls label, .gift-form label { display: grid; gap: 7px; }
.compare-controls span, .gift-form span { font-size: 0.82rem; font-weight: 700; color: var(--muted); letter-spacing: 0.04em; text-transform: uppercase; }
select { width: 100%; min-height: 48px; padding: 0 14px; border-radius: var(--radius-md); border: 1px solid var(--line-strong); background: var(--surface); color: var(--text); }
input { width: 100%; min-height: 48px; padding: 0 14px; border-radius: var(--radius-md); border: 1px solid var(--line-strong); background: var(--surface); color: var(--text); }
select:focus, input:focus { outline: none; border-color: var(--accent); }
.compare-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.compare-card__meta { display: grid; gap: 7px; margin-top: 12px; color: var(--muted); font-size: 0.9rem; }

/* Gift */
.gift-form { display: grid; gap: 16px; }
.gift-form button { margin-top: 4px; }
.gift-match { display: grid; gap: 10px; }
.gift-match__meta { color: var(--muted); font-size: 0.9rem; }

/* Wheel */
.wheel-shell { position: relative; display: grid; place-items: center; min-height: 380px; }
.wheel-disc { position: relative; width: min(100%, 310px); aspect-ratio: 1; border-radius: 50%; border: 12px solid var(--surface); background: conic-gradient(from -30deg, #f0d5c4 0deg 60deg, #f0e4b4 60deg 120deg, #d5e0c9 120deg 180deg, #d6e8e4 180deg 240deg, #e3d2e8 240deg 300deg, #f3d5d8 300deg 360deg); box-shadow: var(--shadow); transition: transform 4.2s cubic-bezier(0.12, 0.78, 0.12, 1); }
.wheel-disc::before { content: ""; position: absolute; inset: 18%; border-radius: 50%; background: var(--surface); border: 1px solid var(--line); }
.wheel-pointer { position: absolute; top: 28px; width: 0; height: 0; border-left: 12px solid transparent; border-right: 12px solid transparent; border-top: 22px solid var(--accent-dark); z-index: 2; }
.wheel-button { position: absolute; z-index: 3; min-width: 128px; }
.wheel-legend { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 8px; margin-top: 10px; }
.wheel-legend span { display: inline-flex; align-items: center; gap: 9px; padding: 9px 12px; border-radius: var(--radius-md); background: var(--surface); border: 1px solid var(--line); color: var(--muted); font-size: 0.86rem; }
.wheel-legend span::before { content: ""; width: 9px; height: 9px; border-radius: 50%; background: var(--legend-color, var(--accent)); flex: none; }

.giveaway-entry { grid-column: 1 / -1; display: grid; grid-template-columns: 1.05fr 1fr 0.82fr; gap: 16px; padding: 26px; }
.giveaway-entry__copy, .giveaway-entry__form, .giveaway-entry__status { display: grid; gap: 12px; }
.giveaway-entry__form label { display: grid; gap: 7px; }
.giveaway-entry__form span { font-size: 0.82rem; font-weight: 700; color: var(--muted); }
.giveaway-entry__hint { margin: 0; color: var(--muted); font-size: 0.86rem; line-height: 1.6; }
.giveaway-entry__status { align-self: stretch; padding: 18px; border-radius: var(--radius-md); background: var(--surface-alt); border: 1px solid var(--line); }
.giveaway-entry__status strong { font-size: 1rem; }
.giveaway-entry__status p { margin: 0; color: var(--muted); line-height: 1.65; }
.giveaway-entry__status.is-success { background: rgba(240,248,234,0.9); border-color: rgba(100,130,80,0.28); }
.giveaway-result__code { display: inline-flex; align-items: center; margin-top: 12px; padding: 9px 13px; border-radius: var(--radius-md); background: var(--surface-alt); border: 1px solid var(--line); font-size: 0.96rem; font-weight: 800; letter-spacing: 0.1em; }
.giveaway-result__actions { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 16px; }

/* Reviews */
.review-section { position: relative; }
.review-layout { display: grid; grid-template-columns: 1fr; gap: 16px; align-items: stretch; }
.review-stats { display: grid; grid-template-columns: minmax(280px, 0.82fr) minmax(0, 1fr); gap: 16px; align-items: center; padding: 24px 26px; background: var(--surface); }
.review-stats__copy { display: grid; gap: 8px; }
.review-stats h3 { max-width: 24ch; font-size: clamp(1.4rem, 2.4vw, 2.6rem); line-height: 1; }
.review-stats p { max-width: 680px; margin: 0; color: var(--muted); font-size: 0.9rem; line-height: 1.6; }
.review-stats__grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 8px; }
.review-stats__grid article { min-height: 96px; padding: 14px 16px; border: 1px solid var(--line); border-radius: var(--radius-md); background: var(--surface-alt); }
.review-stats__grid strong { display: block; color: var(--accent); font-size: 1.2rem; line-height: 1; }
.review-stats__grid span { display: block; margin-top: 6px; color: var(--muted); font-size: 0.82rem; line-height: 1.4; }

.review-showcase { position: relative; display: grid; grid-template-columns: minmax(250px, 0.56fr) minmax(0, 1fr); min-height: 350px; padding: 2px; overflow: hidden; background: var(--surface); border-radius: var(--radius-lg); }
.review-showcase::before { display: none; }
.review-showcase__stage { position: relative; min-height: 326px; overflow: hidden; border-radius: calc(var(--radius-lg) - 2px); background: var(--surface-alt); }
.review-showcase__stage::after { content: ""; position: absolute; right: 20%; bottom: 36px; left: 20%; height: 16px; border-radius: 999px; background: rgba(60,42,28,0.14); filter: blur(12px); }
.review-showcase__glow { position: absolute; inset: 16% 14% auto; height: 48%; border-radius: 999px; background: radial-gradient(circle, rgba(205,165,115,0.2), transparent 68%); animation: reviewGlow 5s ease-in-out infinite; }
.review-showcase__bottle { position: absolute; top: 50%; left: 50%; z-index: 1; width: min(70%, 268px); opacity: 0; filter: drop-shadow(0 16px 20px rgba(70,46,28,0.2)); transform: translate(-50%, -50%) scale(0.94); animation: reviewBottle 20s infinite; }
.review-showcase__bottle--two { animation-delay: 5s; }
.review-showcase__bottle--three { animation-delay: 10s; }
.review-showcase__bottle--four { animation-delay: 15s; }
.review-showcase__copy { position: relative; display: flex; flex-direction: column; justify-content: center; min-height: 326px; padding: 24px clamp(22px, 3.2vw, 42px); }
.review-slides { position: relative; min-height: 216px; margin-top: 4px; }
.review-slide { position: absolute; inset: 0; display: flex; flex-direction: column; justify-content: center; gap: 8px; opacity: 0; transform: translateY(14px); animation: reviewSlide 20s infinite; }
.review-slide--two { animation-delay: 5s; }
.review-slide--three { animation-delay: 10s; }
.review-slide--four { animation-delay: 15s; }
.review-slide__stars { width: fit-content; color: var(--accent); font-size: 0.72rem; letter-spacing: 0.12em; white-space: nowrap; opacity: 0; clip-path: inset(0 100% 0 0); animation: reviewStars 20s infinite; }
.review-slide h3 { color: var(--accent); font-family: "Manrope", sans-serif; font-size: 0.68rem; font-weight: 900; letter-spacing: 0.18em; text-transform: uppercase; }
.review-slide p { max-width: 23ch; margin: 0; font-family: "Cormorant Garamond", serif; font-size: clamp(1.3rem, 1.8vw, 2.1rem); font-weight: 600; line-height: 1.04; letter-spacing: -0.02em; opacity: 0; clip-path: inset(0 100% 0 0); animation: reviewTextWrite 20s infinite; }
.review-slide__associations { display: flex; flex-wrap: wrap; gap: 5px; max-width: 480px; }
.review-slide__associations span { display: inline-flex; align-items: center; gap: 5px; padding: 4px 8px 4px 5px; border-radius: 4px; background: var(--surface-alt); border: 1px solid var(--line); color: var(--text); font-size: 0.7rem; font-weight: 700; }
.review-slide__associations i { display: inline-flex; align-items: center; justify-content: center; width: 20px; height: 20px; border-radius: 4px; background: var(--surface); font-style: normal; font-size: 0.78rem; }
.review-slide small { display: block; max-width: 400px; color: var(--muted); font-size: 0.74rem; line-height: 1.4; opacity: 0; transform: translateY(8px); animation: reviewCaption 20s infinite; }
.review-slide--two .review-slide__stars, .review-slide--two p, .review-slide--two small { animation-delay: 5s; }
.review-slide--three .review-slide__stars, .review-slide--three p, .review-slide--three small { animation-delay: 10s; }
.review-slide--four .review-slide__stars, .review-slide--four p, .review-slide--four small { animation-delay: 15s; }

.objection-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 1px; background: var(--line); border: 1px solid var(--line); border-radius: var(--radius-lg); overflow: hidden; margin-top: 16px; }
.objection-card { min-height: 220px; padding: 24px; background: var(--surface); border-radius: 0; border: none; box-shadow: none; }
.objection-card > span { display: inline-flex; align-items: center; justify-content: center; width: 36px; height: 36px; border-radius: 6px; background: var(--surface-alt); border: 1px solid var(--line); color: var(--accent); font-size: 0.8rem; font-weight: 900; }
.objection-card h3 { margin-top: 16px; font-size: 1.45rem; line-height: 1.04; }
.objection-card p { margin: 12px 0 0; color: var(--muted); font-size: 0.88rem; line-height: 1.62; }

/* Guide */
.guide-section { padding-top: 86px; }
.section-heading--compact { max-width: 740px; margin-bottom: 24px; }
.guide-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 1px; background: var(--line); border: 1px solid var(--line); border-radius: var(--radius-lg); overflow: hidden; }
.guide-card { display: flex; flex-direction: column; gap: 12px; min-height: 210px; padding: 22px; background: var(--surface); border-radius: 0; border: none; box-shadow: none; color: inherit; transition: background 0.2s ease; }
.guide-card::after { content: "Читать →"; display: inline-flex; align-items: center; width: fit-content; margin-top: auto; font-size: 0.78rem; font-weight: 700; color: var(--accent); text-decoration: underline; text-underline-offset: 3px; }
.guide-card:hover { background: var(--surface-alt); }
.guide-card h3 { max-width: 16ch; font-size: clamp(1.35rem, 2vw, 1.9rem); line-height: 1; }
.guide-card p { margin: 0; font-size: 0.88rem; }
.guide-card--wide { grid-column: span 2; }

/* Brand story */
.story-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 1px; background: var(--line); border: 1px solid var(--line); border-radius: var(--radius-lg); overflow: hidden; }
.story-card { padding: 28px 24px; background: var(--surface); border-radius: 0; border: none; }

/* Buy banner */
.buy-banner { display: flex; align-items: center; justify-content: space-between; gap: 24px; }
.buy-banner__actions { display: grid; gap: 8px; min-width: 230px; }

/* Footer */
.site-footer { display: grid; gap: 2px; background: var(--line); border: 1px solid var(--line); border-radius: var(--radius-xl); overflow: hidden; margin-top: 80px; margin-bottom: 40px; }
.footer-brand { display: grid; gap: 22px; padding: 32px 30px; background: var(--surface); }
.footer-brand__row { display: flex; align-items: center; gap: 14px; }
.footer-brand__symbol { flex: none; }
.site-footer p { max-width: none; margin: 0; color: var(--muted); line-height: 1.68; }
.footer-brand strong, .footer-column h3, .footer-bottom span { color: var(--text); }
.footer-brand strong { display: block; margin-bottom: 4px; font-family: "Manrope", sans-serif; font-size: 0.94rem; font-weight: 800; letter-spacing: 0.2em; text-transform: uppercase; }
.footer-brand__subtitle { font-size: 0.64rem; font-weight: 700; letter-spacing: 0.16em; text-transform: uppercase; color: var(--muted); }
.footer-brand__copy { display: grid; gap: 16px; }
.footer-brand__copy p { max-width: 58ch; }
.footer-brand__actions { display: flex; flex-wrap: wrap; gap: 10px; }
.footer-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 2px; background: var(--line); }
.footer-column { display: grid; align-content: start; gap: 12px; padding: 24px 22px; background: var(--surface); border-radius: 0; border: none; box-shadow: none; }
.footer-column h3 { margin: 0; font-size: 1.4rem; }
.footer-column p { max-width: none; }
.footer-links { flex-wrap: wrap; gap: 12px 16px; color: var(--muted); }
.footer-links--stack { display: grid; gap: 8px; }
.footer-links--stack a { width: fit-content; }
.footer-column--legal { background: var(--bg-soft); }
.footer-legal { display: grid; gap: 8px; }
.footer-legal div { display: flex; align-items: center; justify-content: space-between; gap: 14px; padding: 10px 13px; border-radius: var(--radius-md); background: var(--surface); border: 1px solid var(--line); }
.footer-legal span { color: var(--muted); font-size: 0.78rem; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; }
.footer-legal strong { display: block; margin: 0; font-size: 0.92rem; font-weight: 800; }
.footer-legal__hint { font-size: 0.86rem; }
.footer-bottom { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 18px 30px; background: var(--surface-alt); border-radius: 0; border: none; box-shadow: none; }
.footer-bottom span { font-family: "Manrope", sans-serif; font-size: 0.9rem; font-weight: 800; letter-spacing: 0.2em; text-transform: uppercase; line-height: 1; }
.footer-bottom small { color: var(--muted); line-height: 1.5; font-size: 0.82rem; }

/* Sticky bar */
.sticky-marketplace { position: fixed; left: 24px; right: 24px; bottom: 24px; z-index: 24; display: flex; align-items: center; justify-content: space-between; gap: 16px; padding: 14px 18px; background: var(--surface); border: 1px solid var(--line-strong); border-radius: var(--radius-lg); box-shadow: var(--shadow-lift); }
.sticky-marketplace[hidden] { display: none !important; }
.sticky-marketplace strong, .sticky-marketplace small { display: block; }
.sticky-marketplace strong { margin: 3px 0; font-size: 1.05rem; }
.sticky-marketplace small { color: var(--muted); line-height: 1.5; font-size: 0.82rem; }
.mobile-top-button { display: none; }

/* Modal */
.set-modal { position: fixed; inset: 0; z-index: 60; }
.set-modal[hidden] { display: none; }
.set-modal__backdrop { position: absolute; inset: 0; background: rgba(25,18,12,0.44); }
.set-modal__dialog { position: relative; width: min(calc(100% - 32px), 1060px); max-height: calc(100vh - 36px); margin: 18px auto; overflow: auto; padding: 28px; border-radius: var(--radius-xl); background: var(--surface); border: 1px solid var(--line); box-shadow: 0 32px 64px rgba(25,18,12,0.22); }
.set-modal__close { position: sticky; top: 0; margin-left: auto; display: grid; place-items: center; width: 42px; height: 42px; border: 1px solid var(--line); border-radius: var(--radius-md); background: var(--surface-alt); color: var(--text); font-size: 1.4rem; cursor: pointer; z-index: 2; transition: border-color 0.18s ease; }
.set-modal__close:hover { border-color: var(--accent); }
.set-modal__layout { display: grid; gap: 20px; }
.set-modal__hero { display: grid; grid-template-columns: minmax(0, 1.02fr) minmax(360px, 0.98fr); gap: 0; min-height: 520px; border-radius: var(--radius-lg); overflow: hidden; border: 1px solid var(--line); }
.set-modal__hero-stage { position: relative; min-height: 100%; padding: 22px 26px 16px; display: grid; grid-template-rows: auto 1fr; align-content: stretch; background: linear-gradient(180deg, #1c1310 0%, #4a2410 55%, #c0702a 100%); }
.set-modal__hero-stage::before { content: ""; position: absolute; left: 0; right: 0; bottom: 0; height: 100px; background: linear-gradient(180deg, rgba(50,28,14,0), rgba(28,16,8,0.36)); }
.set-modal__hero-stage::after { content: ""; position: absolute; inset: 0; background: radial-gradient(circle at 50% 18%, rgba(255,255,255,0.07), transparent 44%); pointer-events: none; }
.set-modal__hero-tags { display: flex; flex-wrap: wrap; gap: 8px; position: relative; z-index: 1; }
.set-modal__hero-tags span, .set-modal__pill, .set-modal__facts span { display: inline-flex; align-items: center; padding: 7px 12px; border-radius: 4px; background: rgba(250,244,236,0.88); border: 1px solid rgba(255,255,255,0.5); color: #5a3e2c; font-size: 0.78rem; font-weight: 700; }
.set-modal__bottles { position: relative; z-index: 1; display: flex; align-items: flex-end; justify-content: center; gap: 6px; min-height: 410px; padding: 38px 0 0; }
.set-modal__bottle { --set-modal-x: 0px; --set-modal-shift: 0px; --set-modal-tilt: 0deg; width: 240px; transform: translateX(var(--set-modal-x)) translateY(var(--set-modal-shift)) rotate(var(--set-modal-tilt)); filter: drop-shadow(0 22px 30px rgba(38,29,20,0.18)); animation: setModalBottleFloat 8.2s ease-in-out infinite; }
.set-modal__bottle--two-left { --set-modal-x: 18px; --set-modal-shift: 8px; --set-modal-tilt: -5deg; animation-delay: -0.7s; }
.set-modal__bottle--two-right { --set-modal-x: -18px; --set-modal-shift: 8px; --set-modal-tilt: 5deg; animation-delay: -1.8s; }
.set-modal__bottle--three-left { width: 220px; --set-modal-x: 30px; --set-modal-shift: 24px; --set-modal-tilt: -6deg; animation-delay: -0.5s; }
.set-modal__bottle--three-middle { width: 290px; z-index: 2; animation-delay: -1.3s; }
.set-modal__bottle--three-right { width: 220px; --set-modal-x: -30px; --set-modal-shift: 24px; --set-modal-tilt: 6deg; animation-delay: -2.2s; }
.set-modal__hero-summary { display: grid; align-content: start; gap: 14px; padding: 26px 28px 28px; background: #e8c090; color: #2a1810; }
.set-modal__hero-summary p { margin: 0; color: rgba(44,24,12,0.86); line-height: 1.68; }
.set-modal__body { display: grid; gap: 16px; }
.set-modal__topline { display: flex; flex-wrap: wrap; gap: 8px; }
.set-modal__hero-summary h2, .set-modal__body h2 { font-size: clamp(2.1rem, 3.8vw, 3.3rem); }
.set-modal__metrics { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 14px; padding-top: 16px; border-top: 1px solid rgba(65,38,20,0.18); }
.set-modal__metric { display: grid; gap: 5px; }
.set-modal__metric strong { font-family: "Cormorant Garamond", serif; font-size: clamp(2.4rem, 3.8vw, 3.2rem); line-height: 0.86; }
.set-modal__metric span { color: rgba(44,24,12,0.82); font-size: 0.94rem; line-height: 1.45; }
.set-modal__facts { display: flex; flex-wrap: wrap; gap: 8px; padding-top: 4px; }
.set-modal__hero-note { padding-top: 2px; color: rgba(44,24,12,0.8); font-size: 0.94rem; font-weight: 700; line-height: 1.5; }
.set-modal__columns { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; }
.set-modal__block { padding: 18px; border-radius: var(--radius-md); background: var(--surface-alt); border: 1px solid var(--line); }
.set-modal__block h3 { font-size: 1.55rem; }
.set-modal__block p { margin: 10px 0 0; color: var(--muted); line-height: 1.62; }
.set-modal__block ul { display: grid; gap: 8px; padding-left: 16px; margin: 12px 0 0; color: var(--muted); line-height: 1.65; }
.set-modal__notes { display: flex; flex-wrap: wrap; gap: 7px; margin-top: 12px; }
.set-modal__notes span { display: inline-flex; align-items: center; padding: 7px 12px; border-radius: 4px; background: var(--surface); border: 1px solid var(--line); color: var(--muted); font-size: 0.8rem; font-weight: 700; }
.set-modal__actions { display: flex; flex-wrap: wrap; gap: 10px; }
.set-modal__layout--scent .set-modal__hero { grid-template-columns: minmax(320px, 0.82fr) minmax(380px, 1.18fr); }
.set-modal__hero--scent .set-modal__hero-stage { background: linear-gradient(180deg, #f8f2e8 0%, #ede0cc 100%); }
.set-modal__hero--scent .set-modal__hero-stage::before { background: linear-gradient(180deg, transparent, rgba(86,58,34,0.12)); }
.set-modal__bottles--single { min-height: 430px; padding-top: 26px; }
.set-modal__bottle--single { width: min(75%, 350px); --set-modal-shift: 0px; --set-modal-tilt: -1deg; filter: drop-shadow(0 26px 34px rgba(38,29,20,0.2)); }

/* Guide page */
.guide-hero { display: grid; grid-template-columns: minmax(0, 0.96fr) minmax(380px, 0.78fr); gap: 32px; align-items: center; min-height: auto; padding-top: 60px; }
.guide-hero h1 { max-width: 10.5ch; }
.guide-hero__visual { min-height: 420px; padding: 0; border-radius: var(--radius-xl); overflow: hidden; }
.guide-hero__visual img { width: 100%; height: 100%; min-height: 404px; object-fit: cover; }
.guide-page { display: grid; grid-template-columns: 270px minmax(0, 1fr); gap: 20px; align-items: start; padding-top: 36px; }
.guide-toc { position: sticky; top: 80px; display: grid; gap: 6px; padding: 16px; }
.guide-toc a { display: block; padding: 10px 12px; border-radius: var(--radius-md); background: var(--surface); border: 1px solid var(--line); color: var(--muted); font-size: 0.88rem; font-weight: 700; line-height: 1.36; transition: color 0.18s ease, border-color 0.18s ease; }
.guide-toc a:hover { color: var(--accent); border-color: rgba(154,80,50,0.28); }
.guide-articles { display: grid; gap: 20px; }
.seo-article { padding: clamp(24px, 3.8vw, 50px); background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius-lg); }
.seo-article__meta { display: flex; align-items: center; justify-content: space-between; gap: 10px; flex-wrap: wrap; margin-bottom: 16px; }
.seo-article__meta span:last-child { display: inline-flex; align-items: center; min-height: 32px; padding: 0 12px; border-radius: 4px; background: var(--surface-alt); border: 1px solid var(--line); color: var(--muted); font-size: 0.78rem; font-weight: 700; }
.seo-article h2 { max-width: 14ch; margin-bottom: 22px; }
.seo-article h3 { margin: 26px 0 9px; font-size: clamp(1.38rem, 1.9vw, 1.95rem); line-height: 1.04; }
.seo-article p { max-width: 74ch; margin: 0 0 12px; color: var(--muted); line-height: 1.78; }
.seo-article__cta { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 22px; }

/* Animations */
@keyframes drift { 0%, 100% { transform: translateY(0); } 50% { transform: translateY(-5px); } }
@keyframes heroSceneReveal { 0% { opacity: 0; transform: translateY(14px) scale(0.98); } 100% { opacity: 1; transform: translateY(0) scale(1); } }
@keyframes setCardBottleFloat { 0%, 100% { transform: translateX(var(--set-card-x)) translateY(var(--set-card-shift)) rotate(var(--set-card-tilt)); } 50% { transform: translateX(var(--set-card-x)) translateY(calc(var(--set-card-shift) - 8px)) rotate(var(--set-card-tilt)); } }
@keyframes setModalBottleFloat { 0%, 100% { transform: translateX(var(--set-modal-x)) translateY(var(--set-modal-shift)) rotate(var(--set-modal-tilt)); } 50% { transform: translateX(var(--set-modal-x)) translateY(calc(var(--set-modal-shift) - 11px)) rotate(var(--set-modal-tilt)); } }
@keyframes reviewGlow { 0%, 100% { opacity: 0.6; transform: scale(0.95); } 50% { opacity: 1; transform: scale(1.05); } }
@keyframes reviewBottle { 0%, 22% { opacity: 1; transform: translate(-50%, -50%) scale(1); } 26%, 100% { opacity: 0; transform: translate(-50%, calc(-50% - 12px)) scale(0.97); } }
@keyframes reviewSlide { 0%, 22% { opacity: 1; transform: translateY(0); } 26%, 100% { opacity: 0; transform: translateY(-8px); } }
@keyframes reviewStars { 0%, 1% { opacity: 0; clip-path: inset(0 100% 0 0); transform: translateY(6px); } 4%, 22% { opacity: 1; clip-path: inset(0 0 0 0); transform: translateY(0); } 26%, 100% { opacity: 0; clip-path: inset(0 0 0 0); transform: translateY(-3px); } }
@keyframes reviewTextWrite { 0%, 2% { opacity: 0; clip-path: inset(0 100% 0 0); } 7%, 22% { opacity: 1; clip-path: inset(0 0 0 0); } 26%, 100% { opacity: 0; clip-path: inset(0 0 0 0); } }
@keyframes reviewCaption { 0%, 5% { opacity: 0; transform: translateY(8px); } 9%, 22% { opacity: 1; transform: translateY(0); } 26%, 100% { opacity: 0; transform: translateY(-5px); } }

/* Responsive */
@media (max-width: 1180px) {
    .hero, .quiz-layout, .gift-layout, .persona-layout, .room-layout, .interior-panel, .giveaway-layout, .giveaway-entry, .buy-banner, .set-modal__layout { grid-template-columns: 1fr; flex-direction: column; }
    .interior-panel { border-radius: var(--radius-xl); }
    .interior-gallery { min-height: auto; grid-template-columns: 1fr 1fr; }
    .interior-card--large { grid-row: auto; grid-column: 1 / -1; min-height: 360px; }
    .catalog-grid, .set-grid, .story-grid, .compare-grid, .result-grid, .gift-match-grid, .room-picks, .guide-grid, .objection-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .path-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .guide-toc { position: static; grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .footer-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .compare-controls { grid-template-columns: 1fr; }
    .hero-product { max-width: 820px; min-height: min(700px, 76vw); }
    .catalog-tabs { grid-template-columns: repeat(3, minmax(0, 1fr)); }
    .set-modal__layout--scent .set-modal__hero { grid-template-columns: 1fr; }
    .set-modal__hero { grid-template-columns: 1fr; min-height: auto; }
    .set-modal__columns { grid-template-columns: 1fr; }
}

@media (max-width: 980px) {
    .review-stats { grid-template-columns: 1fr; }
    .review-stats__grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
    .review-showcase { grid-template-columns: 1fr; min-height: auto; }
    .review-showcase__stage { min-height: 320px; }
    .review-showcase__copy { min-height: 280px; }
}

@media (max-width: 820px) {
    .site-header { position: static; top: auto; z-index: 10; padding: 14px 16px; border-radius: 0; }
    .site-header, .site-footer, .section { width: min(calc(100% - 28px), var(--max-width)); }
    .section { padding-top: 80px; }
    .site-nav { display: none; }
    .header-actions { width: 100%; justify-content: stretch; }
    .header-actions .button { flex: 1; padding-inline: 14px; }
    .persona-options, .footer-grid, .review-stats, .review-stats__grid, .set-modal__metrics { grid-template-columns: 1fr; }
    .hero { gap: 24px; min-height: auto; padding-top: 32px; }
    h1 { font-size: clamp(2.9rem, 13vw, 4.4rem); }
    .catalog-tabs { display: flex; gap: 8px; margin-inline: -14px; padding: 0 14px 8px; overflow-x: auto; scroll-snap-type: x mandatory; }
    .catalog-tab { min-width: 160px; min-height: 68px; scroll-snap-align: start; }
    .catalog-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 8px; }
    .scent-card__visual { min-height: 175px; padding: 12px 10px 6px; }
    .scent-card__image { width: 100%; max-height: 210px; }
    .scent-card__body { padding: 12px; gap: 6px; }
    .scent-card__topline { align-items: flex-start; flex-direction: column; gap: 3px; }
    .scent-card__topline span { font-size: 0.62rem; }
    .scent-card__topline strong { font-size: 0.9rem; }
    .scent-card__body h3 { font-size: 1.2rem; line-height: 0.98; }
    .scent-card__meta { font-size: 0.76rem; }
    .scent-card__chips span { padding: 5px 8px; font-size: 0.68rem; }
    .scent-card__actions .button { min-height: 36px; padding: 8px 10px; font-size: 0.74rem; }
    .room-tabs { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .room-panel__top { flex-direction: column; }
    .sticky-marketplace { left: 12px; right: 12px; bottom: 12px; flex-direction: column; align-items: stretch; }
    .sticky-marketplace__actions { flex-direction: column; align-items: stretch; }
    .set-modal__dialog { width: min(calc(100% - 18px), 1060px); margin: 9px auto; padding: 18px; }
    .set-modal__hero-stage { min-height: 310px; padding: 18px 20px 14px; }
    .set-modal__bottles--single { min-height: 310px; padding-top: 18px; }
    .set-modal__bottle--single { width: min(70%, 240px); }
    .set-modal__hero-summary { padding: 22px 18px; }
    .review-showcase { padding: 2px; }
    .review-showcase__stage { min-height: 260px; }
    .review-showcase__copy { min-height: 220px; padding: 16px 4px 4px; }
    .review-showcase__bottle { width: min(58%, 200px); }
    .review-slides { min-height: 200px; }
    .review-slide p { max-width: 26ch; font-size: clamp(1.28rem, 7vw, 2rem); }
    .mobile-top-button { position: fixed; right: 14px; bottom: 14px; z-index: 32; display: grid; place-items: center; width: 40px; height: 40px; border: 1px solid var(--line-strong); border-radius: 8px; background: var(--surface); color: var(--accent); font-size: 1.1rem; font-weight: 900; box-shadow: var(--shadow); }
    .guide-grid { grid-template-columns: 1fr; }
    .objection-grid { grid-template-columns: 1fr; }
}

@media (max-width: 760px) {
    .hero__copy--new h1 { max-width: 10.8ch; font-size: clamp(2.9rem, 14vw, 5.2rem); }
    .hero-routes { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .hero-product { min-height: 500px; }
    .hero-product__badge--bottom { display: none; }
    .hero-product__label { right: 16px; bottom: 16px; }
}

@media (max-width: 560px) {
    .brandmark { justify-content: center; gap: 10px; }
    .header-actions { flex-direction: column; }
    .brandmark__symbol, .footer-brand__symbol { width: 38px; height: 38px; border-radius: 8px; }
    .brandmark__logo, .footer-brand__symbol img { width: 22px; height: 22px; }
    .brandmark__text strong { font-size: 0.86rem; }
    .hero-routes { grid-template-columns: 1fr; }
    .hero-product { min-height: 440px; }
    .catalog-grid { grid-template-columns: 1fr; }
    .catalog-tab { min-width: 148px; }
    .scent-card__visual { min-height: 210px; }
    .scent-card__image { max-height: 246px; }
    .guide-card--wide { grid-column: auto; }
    .hero-product__badge--top { display: none; }
    .set-modal__dialog { padding: 14px; border-radius: var(--radius-lg); }
    .set-modal__hero-tags span, .set-modal__pill, .set-modal__facts span { padding: 6px 10px; font-size: 0.72rem; }
    .set-modal__block { padding: 14px; border-radius: var(--radius-md); }
    .path-grid { grid-template-columns: 1fr; }
    .story-grid { grid-template-columns: 1fr; }
}

@media (prefers-reduced-motion: reduce) {
    html { scroll-behavior: auto; }
    *, *::before, *::after { animation: none !important; transition: none !important; }
}