@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,700;0,800;1,700&family=DM+Sans:ital,opsz,wght@0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700;1,9..40,400&display=swap');

/* ─── Variables ─────────────────────────────────────── */
:root {
    --green:        #5F6DB0;
    --green-dark:   #4A5694;
    --green-light:  #ECEEF9;
    --green-mid:    #7481BF;
    --amber:        #C47B52;
    --amber-light:  #FDF1E8;

    --bg:           #F5F4EF;
    --surface:      #FFFFFF;
    --border:       #E0DBD3;
    --border-strong:#B8B3AA;

    --text:         #1A1918;
    --text-2:       #5C5855;
    --text-3:       #9C9894;

    --shadow-xs: 0 1px 3px rgba(0,0,0,.05);
    --shadow-sm: 0 2px 8px rgba(0,0,0,.07);
    --shadow-md: 0 6px 24px rgba(0,0,0,.09);
    --shadow-lg: 0 16px 48px rgba(0,0,0,.11);

    --r-sm: 8px;
    --r-md: 12px;
    --r-lg: 18px;
    --r-xl: 24px;
}

/* ─── Reset ─────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
body {
    font-family: 'DM Sans', system-ui, sans-serif;
    color: var(--text);
    background: var(--bg);
    -webkit-font-smoothing: antialiased;
}
a { text-decoration: none; color: inherit; }

/* ─── Animations ─────────────────────────────────────── */
@keyframes fadeDown {
    from { opacity: 0; transform: translateY(-14px); }
    to   { opacity: 1; transform: translateY(0); }
}
@keyframes floatSlow {
    0%, 100% { transform: translateY(0); }
    50%       { transform: translateY(-10px); }
}
@keyframes cardIn {
    from { opacity: 0; transform: translateY(18px); }
    to   { opacity: 1; transform: translateY(0); }
}

/* ─── Header ─────────────────────────────────────────── */
.header {
    position: sticky; top: 0; z-index: 100;
    background: rgba(245,244,239,.94);
    backdrop-filter: blur(14px);
    border-bottom: 1px solid var(--border);
    padding: 14px 32px;
    display: flex; align-items: center; justify-content: space-between;
}
.header__logo {
    font-family: 'Playfair Display', serif;
    font-size: 1.35rem; font-weight: 800;
    color: var(--text);
    letter-spacing: -.01em;
}
.header__logo span { color: var(--green); }

/* ─── Buttons ─────────────────────────────────────────── */
.btn-hero {
    display: inline-block;
    background: var(--green);
    color: #fff; font-weight: 600; font-size: .95rem;
    padding: 13px 28px; border-radius: 60px;
    border: none; cursor: pointer;
    box-shadow: 0 2px 12px rgba(95,109,176,.28);
    transition: background .2s, transform .15s, box-shadow .2s;
}
.btn-hero:hover {
    background: var(--green-dark);
    transform: translateY(-1px);
    box-shadow: 0 4px 20px rgba(95,109,176,.38);
}

.btn-outline {
    display: inline-block;
    border: 1.5px solid var(--border-strong); color: var(--text-2);
    font-weight: 600; font-size: .9rem;
    padding: 11px 24px; border-radius: 60px;
    background: transparent; cursor: pointer;
    transition: border-color .2s, color .2s, background .2s;
}
.btn-outline:hover {
    border-color: var(--green);
    color: var(--green);
    background: var(--green-light);
}

/* ─── Hero ─────────────────────────────────────────── */
.hero {
    text-align: center;
    padding: 92px 24px 76px;
    background: var(--surface);
    position: relative; overflow: hidden;
    animation: fadeDown .5s ease;
    border-bottom: 1px solid var(--border);
}
.hero::before {
    content: '';
    position: absolute; inset: 0;
    background-image: radial-gradient(circle, var(--border) 1px, transparent 1px);
    background-size: 28px 28px;
    opacity: .5;
    pointer-events: none;
}
.hero > * { position: relative; }

.hero__decor { display: none; }

.hero__badge {
    display: inline-block;
    background: var(--green-light);
    color: var(--green);
    font-size: .72rem; font-weight: 700;
    letter-spacing: .07em; text-transform: uppercase;
    padding: 6px 16px; border-radius: 60px;
    margin-bottom: 24px;
    border: 1px solid rgba(95,109,176,.2);
}

.hero__title {
    font-family: 'Playfair Display', serif;
    font-size: clamp(2.2rem, 5.5vw, 3.6rem);
    font-weight: 800; color: var(--text);
    line-height: 1.14; margin-bottom: 20px;
    letter-spacing: -.025em;
}
.hero__title span { color: var(--green); font-style: italic; }
.hero__sub {
    font-size: 1.05rem; color: var(--text-2);
    margin-bottom: 36px;
    max-width: 460px; margin-left: auto; margin-right: auto;
    line-height: 1.65;
}

/* ─── Section ─────────────────────────────────────────── */
.section { padding: 72px 32px; max-width: 1080px; margin: 0 auto; }
.section__title {
    font-family: 'Playfair Display', serif;
    font-size: clamp(1.5rem, 3vw, 2rem);
    font-weight: 800; color: var(--text);
    text-align: center; margin-bottom: 40px;
    letter-spacing: -.02em;
}

/* ─── Steps grid ─────────────────────────────────────── */
.steps-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.step-card {
    background: var(--surface);
    border-radius: var(--r-lg);
    padding: 32px 28px;
    border: 1.5px solid var(--border);
    box-shadow: var(--shadow-xs);
    transition: transform .2s, box-shadow .2s, border-color .2s;
    position: relative; overflow: hidden;
}
.step-card::after {
    content: '';
    position: absolute; top: 0; left: 0; right: 0; height: 3px;
    background: var(--green);
    opacity: 0; transition: opacity .2s;
}
.step-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); }
.step-card:hover::after { opacity: 1; }
.step-card__icon { font-size: 2rem; margin-bottom: 16px; display: block; }
.step-card__title { font-weight: 700; font-size: 1rem; color: var(--text); margin-bottom: 8px; }
.step-card__text { font-size: .87rem; color: var(--text-2); line-height: 1.6; }

/* ─── Occasions grid ─────────────────────────────────── */
.occasion-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; }
.occasion-card {
    display: flex; flex-direction: column; align-items: center; justify-content: center;
    padding: 24px 12px; border-radius: var(--r-md);
    border: 1.5px solid var(--border);
    cursor: pointer; background: var(--surface);
    transition: border-color .18s, background .18s, transform .15s;
}
.occasion-card:hover {
    border-color: var(--green);
    background: var(--green-light);
    transform: translateY(-2px);
}
.occasion-card__emoji { font-size: 1.8rem; margin-bottom: 8px; }
.occasion-card__label { font-weight: 600; font-size: .8rem; color: var(--text); text-align: center; }

/* ─── CTA banner ─────────────────────────────────────── */
.cta-banner {
    background: linear-gradient(145deg, #2D3580 0%, #4A57A0 55%, #5F6DB0 100%);
    color: #fff; text-align: center;
    padding: 76px 32px;
}
.cta-banner__title {
    font-family: 'Playfair Display', serif;
    font-size: clamp(1.6rem, 3.5vw, 2.2rem);
    font-weight: 800; margin-bottom: 12px;
    letter-spacing: -.02em;
}
.cta-banner__sub { font-size: 1rem; opacity: .72; margin-bottom: 32px; }
.cta-banner .btn-hero {
    background: #fff; color: var(--green);
    box-shadow: 0 4px 20px rgba(0,0,0,.2);
}
.cta-banner .btn-hero:hover {
    background: var(--green-light); color: var(--green-dark);
    transform: translateY(-1px);
}

/* ─── Footer ─────────────────────────────────────────── */
.footer {
    text-align: center; padding: 28px 32px;
    font-size: .82rem; color: var(--text-3);
    border-top: 1px solid var(--border);
    background: var(--surface);
}

/* ─── Quiz ─────────────────────────────────────────── */
.progress-bar-wrap {
    position: sticky; top: 57px; z-index: 90;
    height: 3px; background: var(--border);
}
.progress-bar-fill {
    height: 100%;
    background: var(--green);
    transition: width .4s ease;
}

.quiz-wrap { max-width: 960px; margin: 0 auto; padding: 56px 40px 80px; }
.quiz-step { display: none; animation: fadeDown .3s ease; }
.quiz-step.active { display: block; }

.quiz__title {
    font-family: 'Playfair Display', serif;
    font-size: 2.1rem; font-weight: 800; color: var(--text);
    margin-bottom: 10px; letter-spacing: -.02em;
}
.quiz__sub { font-size: 1rem; color: var(--text-2); margin-bottom: 32px; }
.quiz__counter {
    font-size: .75rem; color: var(--text-3);
    margin-bottom: 8px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .07em;
}

.choice-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px; }
.choice-grid.col3 { grid-template-columns: repeat(3, 1fr); }
.choice-grid.col4 { grid-template-columns: repeat(4, 1fr); }
.choice-grid.col5 { grid-template-columns: repeat(5, 1fr); }
.choice-btn {
    padding: 26px 16px; border-radius: var(--r-md);
    border: 1.5px solid var(--border); background: var(--surface);
    font-family: 'DM Sans', sans-serif; font-weight: 600; font-size: 1rem;
    color: var(--text); cursor: pointer; text-align: center;
    transition: border-color .15s, background .15s, color .15s;
    line-height: 1.3;
}
.choice-btn:hover { border-color: var(--green); }
.choice-btn.selected {
    border-color: var(--green);
    background: var(--green-light);
    color: var(--green);
}

.tag-grid { display: flex; flex-wrap: wrap; gap: 10px; }
.tag-btn {
    padding: 11px 22px; border-radius: 60px;
    border: 1.5px solid var(--border); background: var(--surface);
    font-family: 'DM Sans', sans-serif; font-weight: 600; font-size: .95rem;
    color: var(--text); cursor: pointer;
    transition: border-color .15s, background .15s, color .15s;
}
.tag-btn:hover { border-color: var(--green); }
.tag-btn.selected { border-color: var(--green); background: var(--green); color: #fff; }

.quiz-nav {
    display: flex; justify-content: space-between; align-items: center;
    margin-top: 32px; gap: 12px;
}
.interests-custom {
    width: 100%; margin-top: 14px;
    padding: 12px 16px; border-radius: var(--r-md);
    border: 1.5px solid var(--border);
    font-family: 'DM Sans', sans-serif;
    font-size: .9rem; outline: none;
    transition: border-color .15s;
    background: var(--surface);
    color: var(--text);
}
.interests-custom:focus { border-color: var(--green); }
.interests-custom::placeholder { color: var(--text-3); }

/* ─── Loading screen ─────────────────────────────────── */
.loading-screen {
    display: none; text-align: center; padding: 80px 24px;
    animation: fadeDown .4s ease;
}
.loading-screen.active { display: block; }
.loading-screen__emoji { font-size: 3rem; margin-bottom: 16px; animation: floatSlow 1.8s ease-in-out infinite; }
.loading-screen__title {
    font-family: 'Playfair Display', serif;
    font-size: 1.5rem; font-weight: 800; color: var(--text); margin-bottom: 8px;
}
.loading-screen__sub { color: var(--text-2); font-size: .9rem; }

/* ─── Results ─────────────────────────────────────────── */
.results-wrap { max-width: 1080px; margin: 0 auto; padding: 40px 32px 80px; }

.summary-card {
    background: var(--surface);
    border: 1.5px solid var(--border);
    border-radius: var(--r-xl);
    padding: 28px 32px;
    margin-bottom: 40px;
    box-shadow: var(--shadow-xs);
}
.summary-card__header { display: flex; align-items: center; gap: 12px; margin-bottom: 14px; }
.summary-card__icon { font-size: 1.8rem; }
.summary-card__title {
    font-family: 'Playfair Display', serif;
    font-size: 1.35rem; font-weight: 800; color: var(--text);
}
.summary-card__params { font-size: .87rem; color: var(--text-2); margin-bottom: 12px; }
.summary-card__params span { font-weight: 600; color: var(--text); }
.summary-card__tags { display: flex; flex-wrap: wrap; gap: 7px; }
.summary-tag {
    padding: 5px 12px; border-radius: 60px;
    background: var(--green-light); color: var(--green);
    font-size: .76rem; font-weight: 700;
    border: 1px solid rgba(95,109,176,.2);
}

.gifts-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }

.gift-card {
    border-radius: var(--r-lg); border: 1.5px solid var(--border);
    overflow: hidden; background: var(--surface);
    box-shadow: var(--shadow-xs);
    animation: cardIn .45s ease both;
    transition: transform .2s, box-shadow .2s, border-color .2s;
    display: flex; flex-direction: column;
}
.gift-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-md);
    border-color: var(--border-strong);
}

.gift-card__img-wrap {
    height: 200px; overflow: hidden; background: var(--bg);
    display: flex; align-items: center; justify-content: center;
}
.gift-card__img { width: 100%; height: 100%; object-fit: contain; }
.gift-card__fallback {
    width: 100%; height: 100%;
    display: flex; align-items: center; justify-content: center;
    background: linear-gradient(135deg, var(--green-light), var(--amber-light));
    font-size: 2.8rem;
}

.gift-card__body { padding: 18px 20px; flex: 1; display: flex; flex-direction: column; }
.gift-card__category {
    font-size: .68rem; font-weight: 700; letter-spacing: .09em;
    text-transform: uppercase; color: var(--green); margin-bottom: 7px;
}
.gift-card__title {
    font-weight: 700; font-size: .97rem; color: var(--text);
    margin-bottom: 8px; line-height: 1.35;
}
.gift-card__reason {
    font-size: .84rem; color: var(--text-2);
    line-height: 1.6; margin-bottom: 14px; flex: 1;
}

.gift-card__price { margin-bottom: 12px; }
.gift-card__price-val { font-size: 1.15rem; font-weight: 800; color: var(--text); }
.gift-card__price-note { font-size: .7rem; color: var(--text-3); margin-left: 4px; }

.gift-card__links { display: flex; flex-direction: column; gap: 7px; margin-top: auto; }
.gift-card__legal { font-size: .64rem; color: var(--text-3); margin-top: 10px; line-height: 1.45; }

.ml-btn {
    display: block; text-align: center;
    padding: 9px 14px; border-radius: var(--r-sm);
    font-weight: 600; font-size: .84rem;
    transition: opacity .15s, transform .1s;
}
.ml-btn:hover { opacity: .86; transform: translateY(-1px); }
.ml-wb         { background: #CB11AB; color: #fff; }
.ml-ozon       { background: #005BFF; color: #fff; }
.ml-ya         { background: #FFCC00; color: #333; }
.ml-aliexpress { background: #FF4747; color: #fff; }
.ml-joom       { background: #f5f5f5; color: #555; border: 1.5px solid #ddd; }
.ml-mif        { background: var(--surface); color: var(--text); border: 1.5px solid var(--border); }
.ml-chitai     { background: #29ABE2; color: #fff; }
.ml-bookvoed   { background: #2E7D32; color: #fff; }

/* ─── Share buttons ──────────────────────────────────── */
.share-btn {
    display: inline-flex; align-items: center; gap: 7px;
    padding: 10px 20px; border-radius: 60px;
    font-family: 'DM Sans', sans-serif;
    font-weight: 600; font-size: .85rem;
    cursor: pointer; border: none;
    transition: opacity .15s, transform .1s;
    text-decoration: none;
}
.share-btn:hover { opacity: .86; transform: translateY(-1px); }
.share-btn--native { background: var(--green); color: #fff; }
.share-btn--tg     { background: #2AABEE; color: #fff; }
.share-btn--vk     { background: #0077FF; color: #fff; }
.share-btn--wa     { background: #25D366; color: #fff; }
.share-btn--copy   { background: var(--surface); color: var(--text); border: 1.5px solid var(--border); }

/* ─── Responsive ─────────────────────────────────────── */
@media (max-width: 768px) {
    .header { padding: 12px 20px; }
    .steps-grid { grid-template-columns: 1fr; gap: 12px; }
    .occasion-grid { grid-template-columns: repeat(2, 1fr); }
    .gifts-grid { grid-template-columns: 1fr; }
    .choice-grid { grid-template-columns: 1fr; }
    .choice-grid.col3 { grid-template-columns: repeat(2, 1fr); }
    .choice-grid.col4 { grid-template-columns: repeat(2, 1fr); }
    .choice-grid.col5 { grid-template-columns: repeat(2, 1fr); }
    .hero { padding: 56px 20px 48px; }
    .section { padding: 48px 20px; }
    .results-wrap { padding: 24px 20px 60px; }
    .quiz-wrap { padding: 32px 20px 60px; max-width: 100%; }
    .summary-card { padding: 20px; }
}
