/* ============================================================
   loves.quest -- Muted McBling Bento Treasure Hunt
   Palette: vintage frost-pink chrome
   Fonts: Nunito (display), Lora (body)
   ============================================================ */

:root {
    --frost-pink: #f0dce0;
    --frost-lavender: #e0d4e8;
    --frost-cream: #f0e8dc;
    --chrome-light: #f0f0ff;
    --chrome-highlight: #e0e0f0;
    --chrome-mid: #a0a0b8;
    --chrome-shadow: #6a6a80;
    --text-primary: #2a1a20;
    --text-secondary: #6a4a58;
    --mountain-silhouette: #b8a0ac;
    --vintage-sepia: #d4c0a8;

    --grid-gap: 12px;
    --module-pad: 20px;

    --ease-soft: cubic-bezier(0.22, 1, 0.36, 1);
    --ease-lift: cubic-bezier(0.34, 1.56, 0.64, 1);
}

* {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

html, body {
    background: var(--frost-pink);
    color: var(--text-primary);
    font-family: 'Lora', Georgia, serif;
    font-size: clamp(15px, 1.5vw, 18px);
    line-height: 1.7;
    overflow-x: hidden;
}

body {
    min-height: 100vh;
    background:
        radial-gradient(ellipse at top left, rgba(224, 212, 232, 0.55), transparent 50%),
        radial-gradient(ellipse at bottom right, rgba(240, 232, 220, 0.45), transparent 55%),
        var(--frost-pink);
}

img { max-width: 100%; display: block; }

/* ============================================================
   Sparkle field
   ============================================================ */

.sparkle-field {
    position: fixed;
    inset: 0;
    pointer-events: none;
    z-index: 1;
    overflow: hidden;
}

.sparkle {
    position: absolute;
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: radial-gradient(circle at 30% 30%, var(--chrome-light) 0%, var(--chrome-highlight) 40%, var(--chrome-mid) 100%);
    box-shadow:
        0 0 6px rgba(240, 240, 255, 0.7),
        0 0 12px rgba(160, 160, 184, 0.35);
    opacity: 0;
    animation-name: sparkle-drift;
    animation-iteration-count: infinite;
    animation-timing-function: linear;
    will-change: transform, opacity;
}

@keyframes sparkle-drift {
    0%   { opacity: 0; transform: translate(0, 0) scale(0.6) rotate(0deg); }
    10%  { opacity: 0.85; }
    50%  { opacity: 1; transform: translate(var(--dx, 30px), var(--dy, -40px)) scale(1) rotate(180deg); }
    90%  { opacity: 0.85; }
    100% { opacity: 0; transform: translate(calc(var(--dx, 30px) * 2), calc(var(--dy, -40px) * 2)) scale(0.6) rotate(360deg); }
}

.sparkles-paused .sparkle {
    animation-play-state: paused;
}

/* ============================================================
   Hero -- Chrome Heart
   ============================================================ */

.hero {
    position: relative;
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: clamp(40px, 8vh, 96px) 24px;
    z-index: 2;
}

.hero-inner {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 28px;
}

.chrome-heart {
    position: relative;
    width: clamp(260px, 50vw, 460px);
    aspect-ratio: 1 / 1;
    filter: drop-shadow(0 14px 28px rgba(106, 74, 88, 0.18));
    animation: heart-bloom 800ms var(--ease-lift) both;
}

@keyframes heart-bloom {
    0%   { transform: scale(0.4); opacity: 0; }
    60%  { transform: scale(1.04); opacity: 1; }
    100% { transform: scale(1); opacity: 1; }
}

.chrome-heart-surface,
.chrome-heart-shine {
    position: absolute;
    inset: 0;
    /* Heart shape via CSS clip-path */
    clip-path: path("M 200,360 C 60,260 10,180 10,110 C 10,50 60,10 110,10 C 150,10 180,30 200,70 C 220,30 250,10 290,10 C 340,10 390,50 390,110 C 390,180 340,260 200,360 Z");
}

.chrome-heart-surface {
    background:
        linear-gradient(135deg,
            #f6f6ff 0%,
            #d8d8ec 18%,
            #a0a0b8 38%,
            #6a6a80 50%,
            #a0a0b8 62%,
            #d8d8ec 82%,
            #f6f6ff 100%);
    background-size: 300% 300%;
    animation: chrome-shift 6s linear infinite;
}

@keyframes chrome-shift {
    0%   { background-position: 0% 50%; }
    50%  { background-position: 100% 50%; }
    100% { background-position: 0% 50%; }
}

.chrome-heart-shine {
    background:
        radial-gradient(ellipse 70% 35% at 35% 28%, rgba(255,255,255,0.85), transparent 70%),
        radial-gradient(ellipse 40% 18% at 70% 70%, rgba(255,255,255,0.45), transparent 70%),
        linear-gradient(160deg, rgba(255,255,255,0.35), transparent 35%, transparent 65%, rgba(255,255,255,0.18));
    mix-blend-mode: screen;
    pointer-events: none;
}

.chrome-heart::before {
    /* Bedazzled outline */
    content: "";
    position: absolute;
    inset: -8px;
    clip-path: path("M 208,374 C 60,268 0,182 0,108 C 0,42 56,0 110,0 C 152,0 184,22 208,68 C 232,22 264,0 306,0 C 360,0 416,42 416,108 C 416,182 356,268 208,374 Z");
    background:
        repeating-conic-gradient(from 0deg at 50% 50%,
            #f0f0ff 0deg, #a0a0b8 6deg, #f0f0ff 12deg);
    opacity: 0.55;
    z-index: -1;
    filter: blur(0.4px);
}

.hero-text {
    position: absolute;
    inset: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 4px;
    pointer-events: none;
}

.hero-brand {
    font-family: 'Nunito', system-ui, sans-serif;
    font-weight: 800;
    font-size: clamp(36px, 6.5vw, 88px);
    letter-spacing: 0.04em;
    color: var(--text-primary);
    text-shadow:
        0 1px 0 rgba(255,255,255,0.7),
        0 -1px 0 rgba(106,74,88,0.4);
    transform: scale(0.9);
    opacity: 0;
    animation: hero-text-in 400ms var(--ease-soft) 800ms forwards;
    line-height: 1;
}

.hero-tld {
    font-family: 'Nunito', system-ui, sans-serif;
    font-weight: 500;
    font-size: clamp(16px, 2.4vw, 32px);
    letter-spacing: 0.18em;
    color: var(--text-secondary);
    text-transform: uppercase;
    transform: scale(0.9);
    opacity: 0;
    animation: hero-text-in 400ms var(--ease-soft) 1000ms forwards;
}

@keyframes hero-text-in {
    to { transform: scale(1); opacity: 1; }
}

.hero-tagline {
    font-family: 'Lora', serif;
    font-style: italic;
    color: var(--text-secondary);
    font-size: clamp(14px, 1.6vw, 18px);
    max-width: 32ch;
    opacity: 0;
    animation: fade-in 600ms var(--ease-soft) 1200ms forwards;
}

@keyframes fade-in { to { opacity: 1; } }

.hero-meta {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    justify-content: center;
    gap: 12px;
    opacity: 0;
    animation: fade-in 600ms var(--ease-soft) 1400ms forwards;
}

.meta-pill {
    font-family: 'Nunito', sans-serif;
    font-weight: 500;
    font-size: 11px;
    letter-spacing: 0.15em;
    text-transform: uppercase;
    color: var(--text-secondary);
    padding: 6px 14px;
    border-radius: 999px;
    background: rgba(255,255,255,0.45);
    border: 1px solid rgba(106,74,88,0.18);
    backdrop-filter: blur(4px);
}

.meta-dot {
    width: 4px;
    height: 4px;
    border-radius: 50%;
    background: var(--chrome-mid);
    box-shadow: 0 0 4px var(--chrome-highlight);
}

.scroll-cue {
    position: absolute;
    bottom: 28px;
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    font-family: 'Nunito', sans-serif;
    font-size: 11px;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: var(--text-secondary);
    opacity: 0;
    animation: fade-in 600ms var(--ease-soft) 1600ms forwards;
}

.cue-arrow {
    width: 1px;
    height: 32px;
    background: linear-gradient(to bottom, transparent, var(--chrome-shadow));
    animation: cue-pulse 2.4s ease-in-out infinite;
}

@keyframes cue-pulse {
    0%, 100% { transform: scaleY(0.6); opacity: 0.5; }
    50%      { transform: scaleY(1);   opacity: 1; }
}

/* ============================================================
   Section heads
   ============================================================ */

.section-head {
    max-width: 720px;
    margin: 0 auto clamp(28px, 4vh, 48px);
    text-align: center;
    padding: 0 24px;
}

.section-eyebrow {
    display: inline-block;
    font-family: 'Nunito', sans-serif;
    font-weight: 500;
    font-size: 12px;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--chrome-shadow);
    margin-bottom: 12px;
    padding: 4px 12px;
    border-top: 1px solid var(--chrome-mid);
    border-bottom: 1px solid var(--chrome-mid);
}

.section-title {
    font-family: 'Nunito', sans-serif;
    font-weight: 700;
    font-size: clamp(24px, 3vw, 40px);
    color: var(--text-primary);
    letter-spacing: -0.01em;
    margin-bottom: 12px;
}

.section-lede {
    font-family: 'Lora', serif;
    font-style: italic;
    color: var(--text-secondary);
    max-width: 56ch;
    margin: 0 auto;
}

/* ============================================================
   Discoveries -- Bento grid
   ============================================================ */

.discoveries {
    position: relative;
    padding: clamp(40px, 6vh, 80px) clamp(16px, 4vw, 56px);
    z-index: 2;
}

.bento-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    grid-auto-rows: minmax(180px, auto);
    gap: var(--grid-gap);
    max-width: 1280px;
    margin: 0 auto;
}

.size-1x1 { grid-column: span 1; grid-row: span 1; }
.size-2x1 { grid-column: span 2; grid-row: span 1; }
.size-1x2 { grid-column: span 1; grid-row: span 2; }
.size-2x2 { grid-column: span 2; grid-row: span 2; }

@media (max-width: 960px) {
    .bento-grid { grid-template-columns: repeat(2, 1fr); }
    .size-2x2 { grid-column: span 2; grid-row: span 2; }
    .size-2x1 { grid-column: span 2; grid-row: span 1; }
    .size-1x2 { grid-column: span 1; grid-row: span 2; }
}

@media (max-width: 560px) {
    .bento-grid { grid-template-columns: 1fr; }
    .size-2x2, .size-2x1, .size-1x2, .size-1x1 {
        grid-column: span 1;
        grid-row: span 1;
    }
}

.bento-cell {
    position: relative;
    padding: var(--module-pad);
    border-radius: 18px;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    gap: 10px;
    box-shadow:
        0 1px 2px rgba(106,74,88,0.06),
        0 4px 10px rgba(106,74,88,0.05),
        inset 0 1px 0 rgba(255,255,255,0.65);
    border: 1px solid rgba(255,255,255,0.55);
    transition:
        transform 200ms var(--ease-soft),
        box-shadow 200ms var(--ease-soft);
    opacity: 0;
    transform: translateY(20px);
}

.bento-cell.is-visible {
    opacity: 1;
    transform: translateY(0);
    transition:
        opacity 400ms var(--ease-soft),
        transform 400ms var(--ease-soft),
        box-shadow 200ms var(--ease-soft);
}

.bento-cell:hover {
    transform: translateY(-4px);
    box-shadow:
        0 6px 16px rgba(106,74,88,0.10),
        0 2px 4px rgba(106,74,88,0.06),
        inset 0 1px 0 rgba(255,255,255,0.85);
}

.cell-pink     { background: linear-gradient(160deg, var(--frost-pink), #f6e4e8); }
.cell-lavender { background: linear-gradient(160deg, var(--frost-lavender), #ecdef2); }
.cell-cream    { background: linear-gradient(160deg, var(--frost-cream), #f8f0e2); }

.cell-tag {
    font-family: 'Nunito', sans-serif;
    font-weight: 500;
    font-size: 11px;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--text-secondary);
    display: inline-flex;
    align-items: center;
}

.cell-title {
    font-family: 'Nunito', sans-serif;
    font-weight: 800;
    font-size: clamp(18px, 1.8vw, 24px);
    line-height: 1.2;
    color: var(--text-primary);
    letter-spacing: -0.01em;
}

.cell-body {
    font-family: 'Lora', serif;
    font-size: clamp(14px, 1.3vw, 16px);
    color: var(--text-primary);
    line-height: 1.65;
}

.cell-body em {
    font-style: italic;
    color: var(--text-secondary);
}

.cell-quote p {
    font-family: 'Lora', serif;
    font-weight: 700;
    font-style: italic;
    font-size: clamp(15px, 1.4vw, 18px);
    line-height: 1.5;
    color: var(--text-primary);
    text-indent: -0.4em;
}

.cell-list {
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 8px;
    font-family: 'Lora', serif;
    font-size: 14px;
    color: var(--text-primary);
}

.cell-list li {
    padding-left: 16px;
    position: relative;
}

.cell-list li::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0.7em;
    width: 6px;
    height: 6px;
    transform: rotate(45deg);
    background: linear-gradient(135deg, var(--chrome-light), var(--chrome-mid));
    border-radius: 1px;
}

.cell-list strong {
    font-family: 'Nunito', sans-serif;
    font-weight: 700;
    color: var(--text-primary);
    letter-spacing: 0.01em;
}

.cell-no {
    margin-top: auto;
    align-self: flex-end;
    font-family: 'Nunito', sans-serif;
    font-weight: 500;
    font-size: 10px;
    letter-spacing: 0.2em;
    color: var(--chrome-shadow);
    opacity: 0.7;
}

/* ============================================================
   Chrome accent shapes (heart, diamond, star)
   ============================================================ */

.cell-accent {
    position: absolute;
    top: 16px;
    right: 16px;
    width: 16px;
    height: 16px;
    transform: scale(0);
    transition: transform 200ms var(--ease-lift);
    filter: drop-shadow(0 1px 1px rgba(106,74,88,0.25));
}

.bento-cell.is-visible .cell-accent {
    transform: scale(1);
    transition-delay: 200ms;
}

.accent-heart {
    background: linear-gradient(135deg, var(--chrome-light), var(--chrome-mid));
    clip-path: path("M 8,15 C 1,10 -1,6 1,3 C 3,0 6,1 8,4 C 10,1 13,0 15,3 C 17,6 15,10 8,15 Z");
}

.accent-diamond {
    background: linear-gradient(135deg, var(--chrome-light), var(--chrome-mid));
    clip-path: polygon(50% 0%, 100% 50%, 50% 100%, 0% 50%);
}

.accent-star {
    background: linear-gradient(135deg, var(--chrome-light), var(--chrome-mid));
    clip-path: polygon(
        50% 0%, 61% 35%, 98% 35%, 68% 57%,
        79% 91%, 50% 70%, 21% 91%, 32% 57%,
        2% 35%, 39% 35%
    );
}

/* ============================================================
   Summit -- Mountain Section
   ============================================================ */

.summit {
    position: relative;
    height: clamp(540px, 90vh, 760px);
    overflow: hidden;
    margin-top: clamp(40px, 6vh, 80px);
    z-index: 2;
}

.summit-sky {
    position: absolute;
    inset: 0;
    background:
        linear-gradient(180deg,
            #f5e4e8 0%,
            #ead7e2 35%,
            #d8c8d8 70%,
            #c4b4c4 100%);
}

.mountains {
    position: absolute;
    inset: 0;
    pointer-events: none;
}

.mountain {
    position: absolute;
    left: -10%;
    right: -10%;
    bottom: 0;
    height: 100%;
    will-change: transform;
}

.mountain-far {
    background: var(--mountain-silhouette);
    opacity: 0.45;
    clip-path: polygon(
        0% 100%, 0% 70%, 8% 60%, 14% 65%, 22% 50%,
        30% 60%, 38% 45%, 48% 55%, 58% 42%, 68% 52%,
        78% 40%, 86% 50%, 94% 44%, 100% 56%, 100% 100%
    );
}

.mountain-mid {
    background: var(--mountain-silhouette);
    opacity: 0.7;
    clip-path: polygon(
        0% 100%, 0% 80%, 6% 72%, 12% 78%, 20% 65%,
        28% 75%, 36% 58%, 46% 70%, 54% 50%, 62% 65%,
        72% 55%, 82% 68%, 92% 60%, 100% 70%, 100% 100%
    );
    filter: brightness(0.92);
}

.mountain-near {
    background: linear-gradient(180deg, #8a7280 0%, #6a4a58 100%);
    opacity: 0.95;
    clip-path: polygon(
        0% 100%, 0% 92%, 8% 85%, 16% 90%, 26% 78%,
        36% 88%, 48% 70%, 58% 82%, 68% 75%, 78% 86%,
        88% 78%, 96% 88%, 100% 84%, 100% 100%
    );
}

.summit-text {
    position: absolute;
    top: 18%;
    left: 50%;
    transform: translateX(-50%);
    text-align: center;
    z-index: 5;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 14px;
    padding: 0 24px;
}

.summit-eyebrow {
    font-family: 'Nunito', sans-serif;
    font-weight: 500;
    font-size: 12px;
    letter-spacing: 0.3em;
    text-transform: uppercase;
    color: var(--text-secondary);
    opacity: 0;
    transform: translateY(8px);
    transition: opacity 600ms var(--ease-soft), transform 600ms var(--ease-soft);
}

.summit-word {
    font-family: 'Nunito', sans-serif;
    font-weight: 800;
    font-size: clamp(72px, 16vw, 200px);
    letter-spacing: 0.02em;
    line-height: 1;
    background: linear-gradient(135deg,
        #f6f6ff 0%,
        #d8d8ec 22%,
        #a0a0b8 42%,
        #6a6a80 50%,
        #a0a0b8 58%,
        #d8d8ec 78%,
        #f6f6ff 100%);
    background-size: 300% 300%;
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    -webkit-text-fill-color: transparent;
    animation: chrome-shift 6s linear infinite;
    filter: drop-shadow(0 4px 12px rgba(106,74,88,0.25));
    opacity: 0;
    transform: translateY(20px) scale(0.96);
    transition: opacity 800ms var(--ease-soft), transform 800ms var(--ease-soft);
}

.summit-caption {
    font-family: 'Lora', serif;
    font-style: italic;
    font-size: clamp(14px, 1.4vw, 16px);
    color: var(--text-secondary);
    max-width: 36ch;
    opacity: 0;
    transform: translateY(8px);
    transition: opacity 600ms var(--ease-soft) 200ms, transform 600ms var(--ease-soft) 200ms;
}

.summit.is-visible .summit-eyebrow,
.summit.is-visible .summit-word,
.summit.is-visible .summit-caption {
    opacity: 1;
    transform: translateY(0) scale(1);
}

/* ============================================================
   Reflection / Closing
   ============================================================ */

.reflection {
    position: relative;
    padding: clamp(48px, 8vh, 96px) clamp(16px, 4vw, 56px) clamp(40px, 6vh, 64px);
    z-index: 2;
}

.reflection-card {
    position: relative;
    max-width: 900px;
    margin: 0 auto;
    padding: clamp(32px, 5vw, 64px);
    background:
        linear-gradient(135deg,
            rgba(212, 192, 168, 0.18),
            rgba(212, 192, 168, 0.32)),
        var(--frost-cream);
    border-radius: 24px;
    border: 1px solid rgba(212, 192, 168, 0.5);
    box-shadow:
        0 1px 0 rgba(255,255,255,0.7) inset,
        0 12px 30px rgba(106, 74, 88, 0.08),
        0 2px 6px rgba(106, 74, 88, 0.04);
    overflow: hidden;
    filter: sepia(0.18) saturate(0.9);
    text-align: center;
}

.grain-overlay {
    position: absolute;
    inset: 0;
    pointer-events: none;
    opacity: 0.08;
    mix-blend-mode: multiply;
    background-image:
        radial-gradient(rgba(106,74,88,0.55) 1px, transparent 1px),
        radial-gradient(rgba(106,74,88,0.45) 1px, transparent 1px);
    background-size: 3px 3px, 5px 5px;
    background-position: 0 0, 1px 1px;
}

.reflection-eyebrow {
    display: inline-block;
    font-family: 'Nunito', sans-serif;
    font-weight: 500;
    font-size: 11px;
    letter-spacing: 0.3em;
    text-transform: uppercase;
    color: var(--chrome-shadow);
    padding: 4px 14px;
    margin-bottom: 22px;
    border: 1px solid var(--chrome-mid);
    border-radius: 999px;
    background: rgba(255,255,255,0.4);
}

.reflection-quote p {
    font-family: 'Lora', serif;
    font-style: italic;
    font-weight: 400;
    font-size: clamp(18px, 2vw, 26px);
    line-height: 1.55;
    color: var(--text-primary);
    max-width: 30ch;
    margin: 0 auto 18px;
}

.reflection-quote em {
    font-weight: 700;
    color: var(--text-primary);
}

.reflection-attrib {
    font-family: 'Nunito', sans-serif;
    font-weight: 500;
    font-size: 11px;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--text-secondary);
    margin-top: 12px;
}

.reflection-ornament {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    margin-top: 28px;
}

.orn-heart, .orn-diamond {
    width: 12px;
    height: 12px;
    background: linear-gradient(135deg, var(--chrome-light), var(--chrome-mid));
    filter: drop-shadow(0 1px 1px rgba(106,74,88,0.25));
}

.orn-heart {
    clip-path: path("M 6,11 C 0,7 -1,4 1,2 C 2,1 4,1 6,3 C 8,1 10,1 11,2 C 13,4 12,7 6,11 Z");
}

.orn-diamond {
    clip-path: polygon(50% 0%, 100% 50%, 50% 100%, 0% 50%);
}

.orn-line {
    width: 60px;
    height: 1px;
    background: linear-gradient(to right, transparent, var(--chrome-mid), transparent);
}

/* ============================================================
   Footer
   ============================================================ */

.page-footer {
    margin: clamp(40px, 6vh, 64px) auto 0;
    text-align: center;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    gap: 12px;
    font-family: 'Nunito', sans-serif;
    font-size: 11px;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: var(--text-secondary);
}

.footer-brand {
    font-weight: 800;
    color: var(--text-primary);
    letter-spacing: 0.12em;
}

.footer-sep {
    color: var(--chrome-mid);
    font-size: 10px;
}

/* ============================================================
   Reduced motion
   ============================================================ */

@media (prefers-reduced-motion: reduce) {
    *,
    *::before,
    *::after {
        animation-duration: 0.001ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.001ms !important;
    }
    .sparkle { display: none; }
}
