/* Personality quizzes — hub, play, result */
.page-personality {
 --pz-accent: #7c3aed;
 --pz-accent-soft: rgba(124, 58, 237, 0.12);
 --pz-teal: #0d9488;
 --pz-card-bg: var(--bs-body-bg, #fff);
 --pz-border: rgba(15, 23, 42, 0.08);
}

body.page-personality {
 padding-top: 60px;
}
@media (min-width: 992px) {
 body.page-personality { padding-top: 56px; }
}

.pz-wrap {
 max-width: 960px;
 margin: 0 auto;
 padding: 1.25rem 1rem 3rem;
}

.pz-bc {
 display: flex;
 flex-wrap: wrap;
 align-items: center;
 gap: 0.35rem;
 font-size: 0.85rem;
 color: var(--bs-secondary-color);
 margin-bottom: 1rem;
}
.pz-bc a { color: inherit; text-decoration: none; }
.pz-bc a:hover { color: var(--pz-accent); }
.pz-bc--compact { margin-bottom: 0.75rem; }

.pz-hero,
.pz-landing-hero {
 text-align: center;
 margin-bottom: 1.75rem;
}
.pz-hero-eyebrow {
 font-size: 0.8rem;
 font-weight: 600;
 letter-spacing: 0.04em;
 text-transform: uppercase;
 color: var(--pz-accent);
 margin-bottom: 0.5rem;
}
.pz-hero h1,
.pz-landing-hero h1 {
 font-size: clamp(1.75rem, 4vw, 2.35rem);
 font-weight: 800;
 line-height: 1.15;
 margin-bottom: 0.75rem;
}
.pz-hero-lead {
 font-size: 1.05rem;
 color: var(--bs-secondary-color);
 max-width: 42rem;
 margin: 0 auto 1rem;
}

.pz-landing-meta {
 display: flex;
 flex-wrap: wrap;
 justify-content: center;
 gap: 0.75rem 1.25rem;
 list-style: none;
 padding: 0;
 margin: 0;
 font-size: 0.9rem;
 color: var(--bs-secondary-color);
}
.pz-landing-meta i { color: var(--pz-accent); margin-right: 0.25rem; }

.pz-outcome-preview {
 text-align: center;
 margin-bottom: 1.5rem;
}
.pz-outcome-preview-label {
 font-size: 0.85rem;
 color: var(--bs-secondary-color);
 margin-bottom: 0.6rem;
}
.pz-outcome-chips {
 display: flex;
 flex-wrap: wrap;
 justify-content: center;
 gap: 0.5rem;
}
.pz-outcome-chip {
 display: inline-flex;
 align-items: center;
 gap: 0.35rem;
 padding: 0.35rem 0.75rem;
 border-radius: 999px;
 background: var(--pz-accent-soft);
 font-size: 0.85rem;
 font-weight: 600;
}

.pz-start-form { text-align: center; }

.pz-btn {
 display: inline-flex;
 align-items: center;
 justify-content: center;
 gap: 0.4rem;
 padding: 0.65rem 1.25rem;
 border-radius: 0.65rem;
 font-weight: 600;
 text-decoration: none;
 border: 2px solid transparent;
 cursor: pointer;
 transition: transform 0.15s ease, box-shadow 0.15s ease;
}
.pz-btn--primary {
 background: linear-gradient(135deg, #7c3aed, #6d28d9);
 color: #fff;
 border: none;
 box-shadow: 0 8px 24px rgba(124, 58, 237, 0.28);
}
.pz-btn--primary:hover {
 color: #fff;
 transform: translateY(-1px);
 box-shadow: 0 12px 28px rgba(124, 58, 237, 0.35);
}
.pz-btn--lg { padding: 0.85rem 1.75rem; font-size: 1.05rem; }
.pz-btn--outline {
 background: transparent;
 border-color: var(--pz-border);
 color: inherit;
}
.pz-btn--link {
 background: transparent;
 color: var(--pz-accent);
 padding-left: 0.5rem;
 padding-right: 0.5rem;
}

.pz-carousel { margin-bottom: 2rem; }

.pz-about { margin-top: 2rem; }
.pz-about-title {
 font-size: 1.25rem;
 font-weight: 700;
 margin-bottom: 1rem;
 text-align: center;
}
.pz-about-grid {
 display: grid;
 grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
 gap: 1rem;
}
.pz-about-card {
 padding: 1.1rem;
 border-radius: 0.85rem;
 border: 1px solid var(--pz-border);
 background: var(--pz-card-bg);
 text-align: center;
}
.pz-about-card i {
 font-size: 1.5rem;
 color: var(--pz-accent);
 display: block;
 margin-bottom: 0.5rem;
}
.pz-about-card h3 {
 font-size: 1rem;
 font-weight: 700;
 margin-bottom: 0.35rem;
}
.pz-about-card p {
 font-size: 0.88rem;
 color: var(--bs-secondary-color);
 margin: 0;
}

/* Play step */
.pz-wrap--play { max-width: 640px; }
.pz-play-top {
 display: flex;
 flex-direction: column;
 gap: 0.75rem;
 margin-bottom: 1.25rem;
}
.pz-play-top .pz-bc--compact { margin-bottom: 0; }
.pz-progress {
 height: 8px;
 border-radius: 999px;
 background: var(--pz-accent-soft);
 overflow: hidden;
 margin-top: 0.15rem;
 margin-bottom: 0;
}
.pz-progress-fill {
 height: 100%;
 border-radius: inherit;
 background: linear-gradient(90deg, var(--pz-teal), var(--pz-accent));
 transition: width 0.25s ease;
}
.pz-progress-label {
 font-size: 0.82rem;
 color: var(--bs-secondary-color);
 margin: 0;
 text-align: center;
}

.pz-card {
 padding: 1.5rem 1.25rem;
 border-radius: 1rem;
 border: 1px solid var(--pz-border);
 background: var(--pz-card-bg);
 box-shadow: 0 12px 40px rgba(15, 23, 42, 0.06);
}
.pz-question {
 font-size: clamp(1.25rem, 3.5vw, 1.6rem);
 font-weight: 800;
 line-height: 1.25;
 margin-bottom: 0.5rem;
}
.pz-question-hint {
 font-size: 0.88rem;
 color: var(--bs-secondary-color);
 margin-bottom: 1.25rem;
}

.pz-options {
 display: flex;
 flex-direction: column;
 gap: 0.65rem;
}
.pz-option {
 display: flex;
 align-items: center;
 gap: 0.75rem;
 width: 100%;
 padding: 0.9rem 1rem;
 border: 2px solid var(--pz-border);
 border-radius: 0.75rem;
 background: var(--pz-card-bg);
 text-align: left;
 cursor: pointer;
 transition: border-color 0.15s, background 0.15s, transform 0.12s;
}
.pz-option:hover {
 border-color: var(--pz-accent);
 background: var(--pz-accent-soft);
 transform: translateX(2px);
}
.pz-option-letter {
 flex-shrink: 0;
 width: 2rem;
 height: 2rem;
 display: flex;
 align-items: center;
 justify-content: center;
 border-radius: 0.5rem;
 background: var(--pz-accent-soft);
 color: var(--pz-accent);
 font-weight: 800;
 font-size: 0.9rem;
}
.pz-option-text {
 flex: 1;
 font-weight: 600;
 line-height: 1.35;
}
.pz-option-arrow {
 color: var(--bs-secondary-color);
 opacity: 0.5;
}

/* Chosen-answer reveal (image loads here only) */
.pz-reveal {
 text-align: center;
}
.pz-reveal-kicker {
 font-size: 0.8rem;
 font-weight: 700;
 text-transform: uppercase;
 letter-spacing: 0.05em;
 color: var(--pz-teal);
 margin-bottom: 0.75rem;
}
.pz-reveal-choice {
 display: flex;
 align-items: center;
 justify-content: center;
 gap: 0.75rem;
 margin-bottom: 1.25rem;
 padding: 0.85rem 1rem;
 border-radius: 0.75rem;
 background: var(--pz-accent-soft);
 border: 2px solid rgba(124, 58, 237, 0.2);
}
.pz-option-letter--lg {
 width: 2.5rem;
 height: 2.5rem;
 font-size: 1.1rem;
}
.pz-reveal-text {
 font-size: 1.1rem;
 font-weight: 700;
 line-height: 1.35;
 text-align: left;
}
.pz-reveal-figure {
 margin: 0 0 1.25rem;
}
.pz-reveal-image {
 width: 100%;
 max-width: 420px;
 height: auto;
 max-height: 280px;
 object-fit: cover;
 border-radius: 0.85rem;
 box-shadow: 0 12px 32px rgba(15, 23, 42, 0.12);
}
.pz-reveal-caption {
 margin-top: 0.5rem;
 font-size: 0.88rem;
 color: var(--bs-secondary-color);
}
.pz-reveal-next {
 margin-top: 0.5rem;
}

/* Result */
.pz-wrap--result {
 max-width: 520px;
 padding-top: 2rem;
}
.pz-result-card {
 text-align: center;
 padding: 2rem 1.5rem;
 border-radius: 1.25rem;
 border: 1px solid var(--pz-border);
 background: linear-gradient(180deg, var(--pz-accent-soft) 0%, var(--pz-card-bg) 45%);
 box-shadow: 0 16px 48px rgba(124, 58, 237, 0.12);
}
.pz-result-kicker {
 font-size: 0.8rem;
 text-transform: uppercase;
 letter-spacing: 0.06em;
 font-weight: 700;
 color: var(--pz-accent);
 margin-bottom: 0.5rem;
}
.pz-result-figure {
 margin: 0 0 1rem;
}
.pz-result-image {
 width: 100%;
 max-width: 320px;
 height: auto;
 max-height: 280px;
 object-fit: cover;
 border-radius: 1rem;
 box-shadow: 0 12px 32px rgba(15, 23, 42, 0.12);
}
.pz-result-emoji {
 font-size: 4rem;
 line-height: 1;
 margin-bottom: 0.5rem;
}
.pz-result-title {
 font-size: clamp(1.6rem, 4vw, 2rem);
 font-weight: 800;
 margin-bottom: 0.35rem;
}
.pz-result-subtitle {
 font-size: 1.05rem;
 font-weight: 600;
 color: var(--pz-teal);
 margin-bottom: 0.75rem;
}
.pz-result-desc {
 color: var(--bs-secondary-color);
 margin-bottom: 1.5rem;
 line-height: 1.55;
}
.pz-result-actions {
 display: flex;
 flex-direction: column;
 gap: 0.65rem;
 align-items: center;
 margin-bottom: 1rem;
}
.pz-result-share-links {
 display: flex;
 justify-content: center;
 gap: 0.75rem;
}
.pz-share-icon {
 width: 2.5rem;
 height: 2.5rem;
 display: flex;
 align-items: center;
 justify-content: center;
 border-radius: 999px;
 border: 1px solid var(--pz-border);
 color: inherit;
 text-decoration: none;
 transition: background 0.15s;
}
.pz-share-icon:hover {
 background: var(--pz-accent-soft);
 color: var(--pz-accent);
}

[data-theme="dark"] .page-personality {
 --pz-border: rgba(255, 255, 255, 0.1);
 --pz-card-bg: var(--bs-body-bg);
}
