/* ==========================================================================
   Arkilaskuri – Rakkauslaskuri / Viihde-teema
   Sivukohtainen custom CSS
   ========================================================================== */

/* Sivun pehmeä pinkki ylätausta */
.love-page {
    background:
        radial-gradient(circle at 12% 120px, rgba(244, 114, 182, .16), transparent 34%),
        radial-gradient(circle at 88% 180px, rgba(251, 113, 133, .12), transparent 30%),
        linear-gradient(180deg, #fff4f8 0%, #fff7fb 360px, #ffffff 860px);
}

.love-page main {
    position: relative;
}

.love-page main::before {
    content: "";
    position: absolute;
    inset: 0 0 auto 0;
    height: 520px;
    background:
        linear-gradient(135deg, rgba(253, 242, 248, .92), rgba(255, 255, 255, .22)),
        radial-gradient(circle at 18% 20%, rgba(244, 114, 182, .14), transparent 34%),
        radial-gradient(circle at 82% 16%, rgba(236, 72, 153, .10), transparent 32%);
    pointer-events: none;
    z-index: 0;
}

.love-page main > * {
    position: relative;
    z-index: 1;
}

/* ==========================================================================
   Hero
   ========================================================================== */

.love-page .calculator-hero.love-hero {
    position: relative;
    overflow: hidden;
    border-radius: 24px;
    border: 1px solid rgba(236, 72, 153, .12);
    background:
        radial-gradient(circle at 16% 18%, rgba(244, 114, 182, .18), transparent 32%),
        radial-gradient(circle at 82% 20%, rgba(251, 113, 133, .14), transparent 34%),
        linear-gradient(135deg, rgba(255, 244, 248, .78) 0%, rgba(255, 250, 252, .70) 58%, rgba(255, 255, 255, .62) 100%);
    box-shadow:
        0 14px 36px rgba(236, 72, 153, .06),
        0 4px 14px rgba(15, 23, 42, .035);
}

.love-page .calculator-hero.love-hero::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
        linear-gradient(90deg, rgba(255, 255, 255, .20), transparent 54%),
        radial-gradient(circle at 92% 8%, rgba(255, 255, 255, .46), transparent 26%);
    pointer-events: none;
}

.love-page .calculator-hero.love-hero > * {
    position: relative;
    z-index: 1;
}

.love-page .love-hero .eyebrow,
.love-page .calculator-hero.love-hero .eyebrow {
    color: #be185d;
    letter-spacing: .12em;
}

.love-page .calculator-hero.love-hero h1 {
    color: #831843;
}

.love-page .calculator-hero.love-hero p {
    color: #64748b;
}

.love-page .love-hero__visual,
.love-page .calculator-hero__visual {
    opacity: .96;
}

/* ==========================================================================
   Laskuripaneeli ja lomake
   ========================================================================== */

.love-page .calculator-panel {
    border-color: rgba(236, 72, 153, .16);
    box-shadow:
        0 18px 44px rgba(236, 72, 153, .06),
        0 8px 24px rgba(15, 23, 42, .04);
}

.love-page .field-group input:focus,
.love-page .field-group select:focus,
.love-page .field-group textarea:focus {
    border-color: rgba(236, 72, 153, .42);
    box-shadow:
        0 0 0 4px rgba(244, 114, 182, .13),
        0 10px 24px rgba(236, 72, 153, .06);
}

.love-page .calculator-extra-options {
    border-color: rgba(244, 114, 182, .22);
}

.love-page .calculator-extra-options > summary {
    color: #9d174d;
}

.love-page .calculator-extra-options > summary::after {
    background: rgba(244, 114, 182, .14);
    color: #db2777;
}

/* ==========================================================================
   Painikkeet
   ========================================================================== */

.love-page .button,
.love-page .btn,
.love-page button[type="button"],
.love-page button[type="submit"] {
    border-color: rgba(236, 72, 153, .24);
}

.love-page .love-button,
.love-page .calculator-panel button {
    color: #9d174d;
    border-color: rgba(236, 72, 153, .24);
    background:
        linear-gradient(135deg, rgba(253, 242, 248, .92), rgba(255, 255, 255, .88));
}

@media (hover: hover) {
    .love-page .love-button:hover,
    .love-page .calculator-panel button:hover {
        border-color: rgba(236, 72, 153, .38);
        background:
            linear-gradient(135deg, rgba(252, 231, 243, .96), rgba(255, 255, 255, .90));
        box-shadow: 0 10px 24px rgba(236, 72, 153, .10);
    }
}

/* ==========================================================================
   Tuloskortti
   ========================================================================== */

.love-page .result-box {
    border-color: rgba(236, 72, 153, .18);
    background:
        radial-gradient(circle at top left, rgba(244, 114, 182, .10), transparent 34%),
        linear-gradient(180deg, rgba(255, 255, 255, .98), rgba(255, 247, 251, .84));
    box-shadow:
        0 18px 46px rgba(236, 72, 153, .07),
        0 8px 22px rgba(15, 23, 42, .035);
}

.love-page .result-box .result-label,
.love-page .result-box small {
    color: #64748b;
}

.love-page .result-box strong,
.love-page #love-result-main {
    color: #9d174d;
}

.love-page .love-result-title {
    color: #9d174d;
}

.love-page .love-result-text {
    color: #64748b;
}

/* ==========================================================================
   Pienet tuloskortit / dynamiikka
   ========================================================================== */

.love-page .result-stats {
    gap: 12px;
}

.love-page .result-stats > div,
.love-page .love-metric-card {
    border-color: rgba(236, 72, 153, .14);
    background:
        linear-gradient(180deg, rgba(255, 255, 255, .98), rgba(255, 247, 251, .74));
}

.love-page .love-metric-icon {
    background: rgba(244, 114, 182, .13);
    color: #db2777;
}

/* ==========================================================================
   Breakdown-kaavio: yhteensopivuus / haasteet
   ========================================================================== */

.love-page .breakdown-card {
    border-color: rgba(236, 72, 153, .18);
    background:
        radial-gradient(circle at top left, rgba(244, 114, 182, .13), transparent 34%),
        #ffffff;
    box-shadow:
        0 16px 40px rgba(236, 72, 153, .06),
        0 6px 18px rgba(15, 23, 42, .035);
}

.love-page .breakdown-card__eyebrow {
    color: #db2777;
}

.love-page .breakdown-segment--primary {
    background: #ec4899;
}

.love-page .breakdown-segment--dark {
    background: #831843;
}

.love-page .breakdown-dot--primary {
    background: #ec4899;
}

.love-page .breakdown-dot--dark {
    background: #831843;
}

/* ==========================================================================
   Top 3 nimiehdotukset
   ========================================================================== */

.love-page .love-suggestions,
.love-page .love-name-suggestions {
    display: grid;
    gap: 12px;
}

.love-page .love-suggestion-card,
.love-page .love-name-suggestion {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    padding: 14px 16px;
    border: 1px solid rgba(236, 72, 153, .14);
    border-radius: 18px;
    background:
        linear-gradient(135deg, rgba(255, 255, 255, .98), rgba(255, 247, 251, .82));
    box-shadow: 0 8px 20px rgba(236, 72, 153, .045);
}

.love-page .love-suggestion-card strong,
.love-page .love-name-suggestion strong {
    color: #831843;
}

.love-page .love-suggestion-card span,
.love-page .love-name-suggestion span {
    color: #9d174d;
    font-weight: 850;
}

/* ==========================================================================
   Nimianalyysi ja jaettava tulos
   ========================================================================== */

.love-page .love-analysis,
.love-page .love-share-box {
    border: 1px solid rgba(236, 72, 153, .14);
    border-radius: 22px;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, .98), rgba(255, 247, 251, .72));
    box-shadow: 0 12px 30px rgba(236, 72, 153, .05);
}

.love-page .love-share-text {
    color: #831843;
}

.love-page .love-disclaimer {
    color: #64748b;
    background: rgba(255, 247, 251, .72);
    border-color: rgba(236, 72, 153, .14);
}

/* ==========================================================================
   Sisältöosiot
   ========================================================================== */

.love-page .content-section {
    border-color: rgba(236, 72, 153, .12);
}

.love-page .content-section h2,
.love-page .content-section h3 {
    color: #831843;
}

.love-page .faq {
    border-color: rgba(236, 72, 153, .12);
}

/* ==========================================================================
   Sivupalkki ja aiheeseen liittyvät laskurit
   ========================================================================== */

.love-page aside .calculator-card,
.love-page .related-calculators,
.love-page .related-calculator-card {
    border-color: rgba(236, 72, 153, .12);
}

.love-page .calculator-card:hover,
.love-page .related-calculator-card:hover {
    border-color: rgba(236, 72, 153, .24);
}

/* ==========================================================================
   Katso myös -kortit, jos sivulla käytössä
   ========================================================================== */

.love-page .calculator-grid .calculator-card {
    border-color: rgba(236, 72, 153, .12);
    background:
        linear-gradient(180deg, rgba(255, 255, 255, .98), rgba(255, 247, 251, .68));
}

@media (hover: hover) {
    .love-page .calculator-grid .calculator-card:hover {
        border-color: rgba(236, 72, 153, .26);
        box-shadow: 0 14px 34px rgba(236, 72, 153, .08);
    }
}

/* ==========================================================================
   Viihde-kategoriasivu
   ========================================================================== */

.entertainment-page,
.viihde-page {
    background:
        radial-gradient(circle at 12% 120px, rgba(244, 114, 182, .14), transparent 34%),
        radial-gradient(circle at 88% 180px, rgba(251, 113, 133, .10), transparent 30%),
        linear-gradient(180deg, #fff4f8 0%, #fff8fb 360px, #ffffff 860px);
}

.entertainment-page .calculator-hero,
.viihde-page .calculator-hero {
    border-color: rgba(236, 72, 153, .12);
    background:
        radial-gradient(circle at 16% 18%, rgba(244, 114, 182, .18), transparent 32%),
        linear-gradient(135deg, rgba(255, 244, 248, .84), rgba(255, 255, 255, .72));
}

/* ==========================================================================
   Mobiili
   ========================================================================== */

@media (max-width: 760px) {
    .love-page {
        background:
            radial-gradient(circle at 20% 120px, rgba(244, 114, 182, .13), transparent 36%),
            linear-gradient(180deg, #fff4f8 0%, #fff8fb 320px, #ffffff 760px);
    }

    .love-page main::before {
        height: 440px;
    }

    .love-page .calculator-hero.love-hero {
        border-radius: 22px;
        background:
            radial-gradient(circle at 18% 12%, rgba(244, 114, 182, .14), transparent 34%),
            linear-gradient(135deg, rgba(255, 244, 248, .82), rgba(255, 255, 255, .70));
    }

    .love-page .love-suggestion-card,
    .love-page .love-name-suggestion {
        align-items: flex-start;
        flex-direction: column;
    }
}
/* Hero ilman erottuvaa boksia */
.love-page .calculator-hero.love-hero {
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
    border-radius: 0 !important;
}

.love-page .calculator-hero.love-hero::before {
    display: none !important;
}
/* Top 3 nimet */
.love-top3 {
    margin-top: 1.5rem;
}

.love-top3 h3 {
    margin: 0 0 0.35rem;
    font-size: 2rem;
    line-height: 1.1;
    color: #8f1656;
}

.love-top3 p {
    margin: 0 0 1rem;
    color: #6b7280;
}

.love-top3 ol {
    margin: 0;
    padding-left: 1.25rem;
}

.love-top3 li {
    margin-bottom: 0.65rem;
    padding-left: 0.15rem;
}

.love-top3__row {
    display: inline-flex;
    align-items: center;
    gap: 0.65rem;
    flex-wrap: wrap;
}

.love-top3__name {
    font-weight: 600;
    color: #1f2937;
}

.love-top3__score {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 68px;
    padding: 0.2rem 0.65rem;
    border-radius: 999px;
    background: linear-gradient(135deg, #f9a8d4, #f472b6);
    color: #7a1247;
    font-weight: 800;
    line-height: 1;
    box-shadow: 0 8px 18px rgba(244, 114, 182, 0.18);
}

/* Kopioitava tuloslause */
.love-copy-box {
    margin-top: 1.4rem;
}

.love-copy-box label {
    display: block;
    margin-bottom: 0.5rem;
    font-weight: 700;
    color: #8f1656;
}

.love-copy-box__row {
    display: flex;
    gap: 0.75rem;
    align-items: stretch;
    flex-wrap: wrap;
}

.love-copy-box textarea,
.love-copy-box input[type="text"] {
    flex: 1 1 320px;
    min-height: 54px;
    padding: 0.9rem 1rem;
    border: 1px solid #f3b3cf;
    border-radius: 16px;
    background: linear-gradient(180deg, #fff8fc 0%, #fff1f7 100%);
    color: #7a1247;
    font: inherit;
    resize: vertical;
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.7);
}

.love-copy-box textarea:focus,
.love-copy-box input[type="text"]:focus {
    outline: none;
    border-color: #ec4899;
    box-shadow:
        0 0 0 4px rgba(236, 72, 153, 0.12),
        inset 0 1px 0 rgba(255,255,255,0.7);
}

.love-copy-box button {
    align-self: center;
    padding: 0.85rem 1rem;
    border: 1px solid #f3b3cf;
    border-radius: 14px;
    background: linear-gradient(180deg, #fff7fb 0%, #ffe8f2 100%);
    color: #a61b64;
    font-weight: 700;
    cursor: pointer;
    transition: background 0.18s ease, transform 0.12s ease, border-color 0.18s ease;
}

.love-copy-box button:hover {
    background: linear-gradient(180deg, #ffeef7 0%, #ffd9ea 100%);
    border-color: #ec4899;
}

.love-copy-box button:active {
    transform: translateY(1px);
}

@media (max-width: 640px) {
    .love-copy-box__row {
        flex-direction: column;
    }

    .love-copy-box button {
        width: 100%;
    }
}
/* Top 3 -listan lopullinen välistys */
.love-page .love-top-list {
    display: grid;
    gap: 0.75rem;
    margin: 1rem 0 0;
    padding-left: 1.5rem;
}

.love-page .love-top-list li {
    padding-left: 0.25rem;
}

.love-page .love-top3__row {
    display: inline-flex;
    align-items: center;
    gap: 0.9rem;
}

.love-page .love-top3__name {
    min-width: 90px;
    font-weight: 700;
    color: #1f2937;
}

.love-page .love-top3__score {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 62px;
    padding: 0.25rem 0.65rem;
    border-radius: 999px;
    background: rgba(244, 114, 182, .14);
    color: #9d174d;
    font-weight: 900;
}
/* Hero oikealle: korvataan nykyinen kuva yhdellä isolla sydämellä */
.love-page .calculator-hero__visual {
    position: relative;
    min-height: 220px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
    overflow: visible;
}

/* Piilotetaan nykyinen sisällä oleva kuvio/kortti */
.love-page .calculator-hero__visual > * {
    display: none !important;
}

/* Näytetään yksi iso sydän */
.love-page .calculator-hero__visual::before {
    content: "❤";
    display: block;
    font-size: 170px;
    line-height: 1;
    color: #e11d48;
    text-shadow: 0 10px 30px rgba(225, 29, 72, 0.18);
}
/* Hero oikean puolen sydän ilman mitään taustaa */
.love-page .calculator-hero__visual,
.love-page .love-hero__visual,
.love-page .hero-visual {
    background: none !important;
    background-color: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
    filter: none !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
}

.love-page .calculator-hero__visual::before,
.love-page .love-hero__visual::before,
.love-page .hero-visual::before {
    background: none !important;
    background-color: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
    filter: none !important;
}

/* Piilotetaan mahdolliset alkuperäisen kuvituksen sisäosat */
.love-page .calculator-hero__visual > *,
.love-page .love-hero__visual > *,
.love-page .hero-visual > * {
    display: none !important;
}

/* Sydän yksinään */
.love-page .calculator-hero__visual::after,
.love-page .love-hero__visual::after,
.love-page .hero-visual::after {
    content: "❤";
    display: block;
    font-size: 170px;
    line-height: 1;
    color: #e11d48;
    text-shadow: 0 10px 30px rgba(225, 29, 72, 0.18);
}
.love-page .calculator-hero__visual::before {
    content: none !important;
}

.love-page .calculator-hero__visual {
    isolation: isolate;
}
/* Viihde-teeman yleinen tausta myös kategoriasivulle */
.viihde-theme {
    background:
        radial-gradient(circle at 12% 120px, rgba(244, 114, 182, .16), transparent 34%),
        radial-gradient(circle at 88% 180px, rgba(251, 113, 133, .12), transparent 30%),
        linear-gradient(180deg, #fff4f8 0%, #fff7fb 360px, #ffffff 860px);
}

.viihde-theme main {
    position: relative;
}

.viihde-theme main::before {
    content: "";
    position: absolute;
    inset: 0 0 auto 0;
    height: 520px;
    background:
        linear-gradient(135deg, rgba(253, 242, 248, .92), rgba(255, 255, 255, .22)),
        radial-gradient(circle at 18% 20%, rgba(244, 114, 182, .14), transparent 34%),
        radial-gradient(circle at 82% 16%, rgba(236, 72, 153, .10), transparent 32%);
    pointer-events: none;
    z-index: 0;
}

.viihde-theme main > * {
    position: relative;
    z-index: 1;
}

/* Viihde-kategoriasivun hero ilman erottuvaa valkoista boksia */
.viihde-theme .hero,
.viihde-theme .category-hero,
.viihde-theme .calculator-hero {
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
}

.viihde-theme .hero::before,
.viihde-theme .category-hero::before,
.viihde-theme .calculator-hero::before {
    display: none !important;
}
/* Piilota viihde-kategoriasivun turha oikean yläkulman symboli */
.viihde-theme .category-hero__visual {
    display: none;
}
.category-hero__icon { display:none; }
/* Satunnaislukugeneraattori: hero-kuvaksi noppa sydämen sijaan */
.random-page .calculator-hero__visual::after,
.random-page .love-hero__visual::after {
    content: "🎲" !important;
    font-size: 150px;
    color: inherit;
    text-shadow: 0 10px 30px rgba(15, 23, 42, .10);
}
/* Noppalaskuri: hero-kuvaksi noppa sydämen sijaan */
.dice-page .calculator-hero__visual::after,
.dice-page .love-hero__visual::after {
    content: "🎲" !important;
    font-size: 150px;
    color: inherit;
    text-shadow: 0 10px 30px rgba(15, 23, 42, .10);
}
/* Fantasianimigeneraattori: hero-kuvaksi taikasauva */
.fantasy-name-page .calculator-hero__visual::after,
.fantasy-name-page .love-hero__visual::after {
    content: "🪄" !important;
    font-size: 150px;
    color: inherit;
    text-shadow: 0 10px 30px rgba(15, 23, 42, .10);
}
