/* ═══════════════════════════════════════════════════════
   Lucky Name Numerology Calculator — Tarot with Lavanya
   Mystical, spiritual, premium aesthetic
   ═══════════════════════════════════════════════════════ */

/* ── CSS Custom Properties ─────────────────────────── */
:root {
    --lnn-teal:       #4b7878;
    --lnn-teal-dark:  #3a5f5f;
    --lnn-gold:       #F9C74F;
    --lnn-gold-dark:  #e0a800;
    --lnn-cream:      #fcfcf4;
    --lnn-cream-alt:  #f5f2e8;
    --lnn-purple:     #3a1d6e;
    --lnn-purple-light: #5a3d8e;
    --lnn-rose:       #d4a5a5;
    --lnn-text:       #2c2c2c;
    --lnn-text-muted: #6b6b6b;
    --lnn-border:     rgba(75, 120, 120, .18);
    --lnn-shadow:     0 8px 32px rgba(58, 29, 110, .10);
    --lnn-glass-bg:   rgba(252, 252, 244, .72);
    --lnn-glass-blur: 14px;
    --lnn-radius:     16px;
    --lnn-radius-sm:  10px;
    --lnn-radius-xs:  6px;
    --lnn-font:       'Georgia', 'Palatino Linotype', 'Book Antiqua', serif;
    --lnn-font-sans:  -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    --lnn-transition:  .35s cubic-bezier(.4, 0, .2, 1);
}

/* ── Base wrapper ──────────────────────────────────── */
.lnn-wrap {
    max-width: 680px;
    margin: 2rem auto;
    padding: 2.5rem 2rem;
    background: var(--lnn-cream);
    border-radius: var(--lnn-radius);
    border: 1px solid var(--lnn-border);
    box-shadow: var(--lnn-shadow);
    font-family: var(--lnn-font);
    color: var(--lnn-text);
    position: relative;
    overflow: hidden;
}

/* Subtle gradient overlay at top */
.lnn-wrap::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 220px;
    background: linear-gradient(180deg, rgba(58,29,110,.04) 0%, transparent 100%);
    pointer-events: none;
    border-radius: var(--lnn-radius) var(--lnn-radius) 0 0;
}

/* ── Header ────────────────────────────────────────── */
.lnn-header {
    text-align: center;
    margin-bottom: 2rem;
    position: relative;
}

.lnn-mandala {
    color: var(--lnn-gold);
    margin-bottom: .5rem;
    opacity: .7;
}

.lnn-title {
    font-size: 1.65rem;
    font-weight: 700;
    color: var(--lnn-teal-dark);
    margin: 0 0 .4rem;
    letter-spacing: .02em;
    line-height: 1.25;
}

.lnn-subtitle {
    font-size: .92rem;
    color: var(--lnn-text-muted);
    margin: 0;
    font-style: italic;
}

/* ── Form fields ───────────────────────────────────── */
.lnn-form {
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
}

.lnn-field {
    display: flex;
    flex-direction: column;
    gap: .35rem;
}

.lnn-label {
    font-size: .85rem;
    font-weight: 600;
    color: var(--lnn-teal-dark);
    letter-spacing: .03em;
    text-transform: uppercase;
    font-family: var(--lnn-font-sans);
}

.lnn-req {
    color: var(--lnn-gold-dark);
    font-size: .75rem;
}

.lnn-optional {
    color: var(--lnn-text-muted);
    font-size: .78rem;
    font-weight: 400;
    text-transform: none;
}

.lnn-input {
    padding: .85rem 1.1rem;
    border: 1.5px solid var(--lnn-border);
    border-radius: var(--lnn-radius-sm);
    background: #fff;
    font-family: var(--lnn-font);
    font-size: 1rem;
    color: var(--lnn-text);
    transition: border-color var(--lnn-transition), box-shadow var(--lnn-transition);
    outline: none;
    width: 100%;
    box-sizing: border-box;
}

.lnn-input::placeholder {
    color: #b5b5a8;
    font-style: italic;
}

.lnn-input:focus {
    border-color: var(--lnn-gold);
    box-shadow: 0 0 0 3px rgba(249, 199, 79, .22), inset 0 0 8px rgba(249, 199, 79, .06);
}

/* Date input styling */
.lnn-date {
    cursor: pointer;
}

/* Select wrapper */
.lnn-select-wrap {
    position: relative;
}

.lnn-select {
    appearance: none;
    -webkit-appearance: none;
    padding: .85rem 2.5rem .85rem 1.1rem;
    border: 1.5px solid var(--lnn-border);
    border-radius: var(--lnn-radius-sm);
    background: #fff;
    font-family: var(--lnn-font);
    font-size: 1rem;
    color: var(--lnn-text);
    transition: border-color var(--lnn-transition), box-shadow var(--lnn-transition);
    outline: none;
    width: 100%;
    cursor: pointer;
    box-sizing: border-box;
}

.lnn-select:focus {
    border-color: var(--lnn-gold);
    box-shadow: 0 0 0 3px rgba(249, 199, 79, .22);
}

.lnn-select-arrow {
    position: absolute;
    right: 1rem;
    top: 50%;
    transform: translateY(-50%);
    color: var(--lnn-teal);
    pointer-events: none;
    font-size: .85rem;
}

/* Hint / error */
.lnn-hint {
    font-size: .78rem;
    color: var(--lnn-text-muted);
    font-style: italic;
}

.lnn-error {
    font-size: .8rem;
    color: #c0392b;
    min-height: 1.1em;
}

/* ── Calculate Button ──────────────────────────────── */
.lnn-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: .5rem;
    padding: 1rem 2rem;
    border: none;
    border-radius: var(--lnn-radius-sm);
    background: linear-gradient(135deg, var(--lnn-gold) 0%, var(--lnn-gold-dark) 100%);
    color: #2c2000;
    font-family: var(--lnn-font-sans);
    font-size: 1.05rem;
    font-weight: 700;
    letter-spacing: .04em;
    cursor: pointer;
    transition: transform var(--lnn-transition), box-shadow var(--lnn-transition);
    box-shadow: 0 4px 16px rgba(249, 199, 79, .30);
    margin-top: .5rem;
    width: 100%;
}

.lnn-btn:hover,
.lnn-btn:focus-visible {
    transform: scale(1.025);
    box-shadow: 0 6px 24px rgba(249, 199, 79, .45);
}

.lnn-btn:active {
    transform: scale(.98);
}

.lnn-btn-icon {
    font-size: 1.15rem;
    animation: lnn-twinkle 2.5s ease-in-out infinite;
}

@keyframes lnn-twinkle {
    0%, 100% { opacity: 1; }
    50%      { opacity: .45; }
}

/* ── Results container ─────────────────────────────── */
.lnn-results {
    margin-top: 2.5rem;
    padding: 2rem 1.5rem;
    background: var(--lnn-glass-bg);
    backdrop-filter: blur(var(--lnn-glass-blur));
    -webkit-backdrop-filter: blur(var(--lnn-glass-blur));
    border: 1px solid var(--lnn-border);
    border-radius: var(--lnn-radius);
    box-shadow: 0 4px 24px rgba(58, 29, 110, .07);
    animation: lnn-fadeUp .5s ease-out both;
}

.lnn-results[hidden] {
    display: none;
}

@keyframes lnn-fadeUp {
    from { opacity: 0; transform: translateY(18px); }
    to   { opacity: 1; transform: translateY(0); }
}

/* ── Section title ─────────────────────────────────── */
.lnn-section-title {
    font-size: 1.05rem;
    font-weight: 700;
    color: var(--lnn-teal-dark);
    margin: 0 0 .75rem;
    letter-spacing: .02em;
    text-align: center;
}

/* ── Number cards row ──────────────────────────────── */
.lnn-result-header {
    display: flex;
    gap: 1rem;
    justify-content: center;
    flex-wrap: wrap;
    margin-bottom: 2rem;
}

.lnn-num-card {
    flex: 1 1 120px;
    max-width: 160px;
    text-align: center;
    padding: 1.1rem .8rem;
    border-radius: var(--lnn-radius-sm);
    border: 1px solid var(--lnn-border);
    background: #fff;
    animation: lnn-fadeUp .45s ease-out both;
}

.lnn-num-card:nth-child(2) { animation-delay: .08s; }
.lnn-num-card:nth-child(3) { animation-delay: .16s; }

.lnn-num-card--primary {
    border-color: var(--lnn-gold);
    box-shadow: 0 0 0 2px rgba(249, 199, 79, .18);
}

.lnn-num-label {
    display: block;
    font-family: var(--lnn-font-sans);
    font-size: .72rem;
    text-transform: uppercase;
    letter-spacing: .07em;
    color: var(--lnn-text-muted);
    margin-bottom: .3rem;
}

.lnn-num-value {
    display: block;
    font-size: 2rem;
    font-weight: 700;
    color: var(--lnn-teal-dark);
    line-height: 1.1;
}

.lnn-num-card--primary .lnn-num-value {
    color: var(--lnn-gold-dark);
}

/* ── Letter pill breakdown ─────────────────────────── */
.lnn-breakdown {
    margin-bottom: 2rem;
}

.lnn-pills {
    display: flex;
    flex-wrap: wrap;
    gap: .45rem;
    justify-content: center;
}

.lnn-pill {
    display: inline-flex;
    align-items: center;
    gap: .3rem;
    padding: .35rem .7rem;
    border-radius: 100px;
    background: var(--lnn-cream-alt);
    border: 1px solid var(--lnn-border);
    font-family: var(--lnn-font-sans);
    font-size: .82rem;
    color: var(--lnn-teal-dark);
    animation: lnn-pillPop .3s ease-out both;
}

.lnn-pill-space {
    width: .75rem;
    border: none;
    background: transparent;
    padding: 0;
}

.lnn-pill-letter {
    font-weight: 700;
}

.lnn-pill-arrow {
    color: var(--lnn-rose);
    font-size: .7rem;
}

.lnn-pill-val {
    color: var(--lnn-gold-dark);
    font-weight: 600;
}

@keyframes lnn-pillPop {
    from { opacity: 0; transform: scale(.7); }
    to   { opacity: 1; transform: scale(1); }
}

/* ── Lucky Score ring ──────────────────────────────── */
.lnn-score-section {
    margin-bottom: 2rem;
    text-align: center;
}

.lnn-score-ring-wrap {
    position: relative;
    display: inline-block;
}

.lnn-score-ring {
    display: block;
}

.lnn-score-text {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.6rem;
    font-weight: 700;
    color: var(--lnn-gold-dark);
}

/* ── Lucky attributes ──────────────────────────────── */
.lnn-attrs {
    display: flex;
    gap: 1rem;
    justify-content: center;
    flex-wrap: wrap;
    margin-bottom: 2rem;
}

.lnn-attr {
    flex: 1 1 140px;
    max-width: 180px;
    text-align: center;
    padding: .9rem .7rem;
    background: #fff;
    border-radius: var(--lnn-radius-sm);
    border: 1px solid var(--lnn-border);
}

.lnn-attr-label {
    display: block;
    font-family: var(--lnn-font-sans);
    font-size: .7rem;
    text-transform: uppercase;
    letter-spacing: .06em;
    color: var(--lnn-text-muted);
    margin-bottom: .25rem;
}

.lnn-attr-value {
    display: block;
    font-size: .95rem;
    font-weight: 600;
    color: var(--lnn-teal-dark);
}

.lnn-color-swatch {
    display: inline-block;
    width: 14px;
    height: 14px;
    border-radius: 50%;
    vertical-align: middle;
    margin-left: .3rem;
    border: 1px solid rgba(0,0,0,.1);
}

/* ── Compatibility ─────────────────────────────────── */
.lnn-compat {
    text-align: center;
    margin-bottom: 2rem;
}

.lnn-compat[hidden] { display: none; }

.lnn-compat-badge {
    display: inline-block;
    padding: .4rem 1.1rem;
    border-radius: 100px;
    font-family: var(--lnn-font-sans);
    font-size: .88rem;
    font-weight: 700;
    letter-spacing: .03em;
    margin-bottom: .5rem;
}

.lnn-compat-badge--harmonious {
    background: #d4edda;
    color: #155724;
    border: 1px solid #b1dfbb;
}

.lnn-compat-badge--neutral {
    background: #fff3cd;
    color: #856404;
    border: 1px solid #ffeeba;
}

.lnn-compat-badge--misaligned {
    background: #f8d7da;
    color: #721c24;
    border: 1px solid #f5c6cb;
}

.lnn-compat-text {
    font-size: .88rem;
    color: var(--lnn-text-muted);
    margin: 0;
    font-style: italic;
}

/* ── Interpretation ────────────────────────────────── */
.lnn-interpretation {
    margin-bottom: 2rem;
}

.lnn-meaning-text {
    font-size: .94rem;
    line-height: 1.7;
    color: var(--lnn-text);
}

.lnn-meaning-text h4 {
    font-size: .88rem;
    font-weight: 700;
    color: var(--lnn-teal-dark);
    margin: 1rem 0 .3rem;
    font-family: var(--lnn-font-sans);
    text-transform: uppercase;
    letter-spacing: .04em;
}

.lnn-meaning-text p {
    margin: 0 0 .6rem;
}

/* ── CTA ───────────────────────────────────────────── */
.lnn-cta {
    text-align: center;
    padding: 1.5rem 1rem;
    background: linear-gradient(135deg, rgba(58,29,110,.05), rgba(75,120,120,.06));
    border-radius: var(--lnn-radius-sm);
    border: 1px dashed var(--lnn-border);
}

.lnn-cta-text {
    font-size: .92rem;
    color: var(--lnn-text-muted);
    margin: 0 0 .75rem;
}

.lnn-cta-btn {
    display: inline-block;
    padding: .75rem 1.6rem;
    background: linear-gradient(135deg, var(--lnn-teal) 0%, var(--lnn-teal-dark) 100%);
    color: #fff !important;
    text-decoration: none !important;
    border-radius: var(--lnn-radius-sm);
    font-family: var(--lnn-font-sans);
    font-size: .92rem;
    font-weight: 600;
    letter-spacing: .03em;
    transition: transform var(--lnn-transition), box-shadow var(--lnn-transition);
    box-shadow: 0 4px 14px rgba(75, 120, 120, .25);
}

.lnn-cta-btn:hover,
.lnn-cta-btn:focus-visible {
    transform: scale(1.03);
    box-shadow: 0 6px 20px rgba(75, 120, 120, .35);
    color: #fff !important;
    text-decoration: none !important;
}

/* ═══════════════════════════════════════════════════════
   Responsive
   ═══════════════════════════════════════════════════════ */

/* Tablet */
@media (max-width: 768px) {
    .lnn-wrap {
        margin: 1.5rem 1rem;
        padding: 2rem 1.25rem;
    }

    .lnn-title {
        font-size: 1.4rem;
    }

    .lnn-result-header {
        gap: .75rem;
    }

    .lnn-num-card {
        flex: 1 1 90px;
    }
}

/* Mobile */
@media (max-width: 480px) {
    .lnn-wrap {
        margin: 1rem .5rem;
        padding: 1.5rem 1rem;
        border-radius: var(--lnn-radius-sm);
    }

    .lnn-title {
        font-size: 1.25rem;
    }

    .lnn-subtitle {
        font-size: .84rem;
    }

    .lnn-results {
        padding: 1.5rem 1rem;
    }

    .lnn-attrs {
        flex-direction: column;
        align-items: center;
    }

    .lnn-attr {
        max-width: 100%;
        width: 100%;
    }

    .lnn-result-header {
        flex-direction: column;
        align-items: center;
    }

    .lnn-num-card {
        max-width: 100%;
        width: 100%;
    }

    .lnn-cta-btn {
        display: block;
        text-align: center;
    }
}
