/* ============================================================
   Premit Psychometric Assessment — Public Stylesheet
   Theme tokens, then components. Mobile-first.
   ============================================================ */

:root {
    --pp-primary:        #6366f1;
    --pp-primary-dark:   #4f46e5;
    --pp-secondary:      #8b5cf6;
    --pp-success:        #10b981;
    --pp-warning:        #f59e0b;
    --pp-danger:         #ef4444;
    --pp-text:           #1f2937;
    --pp-text-muted:     #6b7280;
    --pp-border:         #e5e7eb;
    --pp-bg:             #ffffff;
    --pp-bg-soft:        #f9fafb;
    --pp-radius:         12px;
    --pp-radius-sm:      8px;
    --pp-shadow:         0 1px 3px rgba(0,0,0,.06), 0 4px 12px rgba(0,0,0,.04);
    --pp-shadow-lg:      0 4px 24px rgba(0,0,0,.08);
}

[x-cloak] { display: none !important; }

.pp-test-player,
.pp-results,
.pp-pricing,
.pp-dashboard {
    max-width: 880px;
    margin: 2rem auto;
    padding: 1rem;
    color: var(--pp-text);
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    line-height: 1.6;
}

/* ----------- Buttons ------------------------------------- */
.pp-btn {
    display: inline-block;
    padding: 0.7rem 1.4rem;
    border: none;
    border-radius: var(--pp-radius-sm);
    background: var(--pp-primary);
    color: #fff;
    font-size: 0.95rem;
    font-weight: 600;
    cursor: pointer;
    text-decoration: none;
    transition: all 0.2s;
    line-height: 1.3;
}
.pp-btn:hover:not(:disabled) {
    background: var(--pp-primary-dark);
    transform: translateY(-1px);
    box-shadow: var(--pp-shadow);
}
.pp-btn:disabled { opacity: 0.5; cursor: not-allowed; }
.pp-btn-primary   { background: var(--pp-primary); }
.pp-btn-secondary { background: #6b7280; }
.pp-btn-secondary:hover:not(:disabled) { background: #4b5563; }
.pp-btn-link {
    background: none;
    color: var(--pp-primary);
    padding: 0.3rem 0.6rem;
    text-decoration: underline;
}
.pp-btn-lg { padding: 1rem 2rem; font-size: 1.05rem; }
.pp-btn-sm { padding: 0.4rem 0.9rem; font-size: 0.85rem; }
.pp-btn-block { display: block; width: 100%; }

/* ----------- Test Header --------------------------------- */
.pp-test-header {
    background: var(--pp-bg);
    border: 1px solid var(--pp-border);
    border-radius: var(--pp-radius);
    padding: 1.2rem 1.5rem;
    margin-bottom: 1.5rem;
    box-shadow: var(--pp-shadow);
    position: sticky; top: 1rem; z-index: 10;
}
.pp-test-title h2 { margin: 0; font-size: 1.4rem; color: var(--pp-primary-dark); }
.pp-test-subtitle { margin: 0.3rem 0 1rem; color: var(--pp-text-muted); font-size: 0.9rem; }

.pp-progress-wrap {
    display: flex; align-items: center; gap: 0.8rem;
}
.pp-progress-bar {
    flex: 1; height: 10px; background: var(--pp-border);
    border-radius: 99px; overflow: hidden;
}
.pp-progress-fill {
    height: 100%;
    background: linear-gradient(90deg, var(--pp-primary), var(--pp-secondary));
    transition: width 0.3s ease-out;
}
.pp-progress-text { font-size: 0.85rem; color: var(--pp-text-muted); white-space: nowrap; }

/* ----------- Banners ------------------------------------- */
.pp-resume-notice {
    background: #ecfdf5; border: 1px solid #6ee7b7;
    color: #065f46; padding: 0.8rem 1rem; border-radius: var(--pp-radius-sm);
    margin-bottom: 1rem; display: flex; justify-content: space-between; align-items: center;
}
.pp-timer-banner {
    background: #fffbeb; border: 1px solid #fcd34d;
    color: #92400e; padding: 0.7rem 1rem; border-radius: var(--pp-radius-sm);
    margin-bottom: 1rem; font-size: 0.9rem;
}
.pp-timer-low { color: var(--pp-danger) !important; animation: pp-pulse 1s infinite; }
@keyframes pp-pulse { 50% { opacity: 0.5; } }

/* ----------- Question Card ------------------------------- */
.pp-question-card {
    display: flex;
    gap: 1rem;
    background: var(--pp-bg);
    border: 1px solid var(--pp-border);
    border-radius: var(--pp-radius);
    padding: 1.5rem;
    margin-bottom: 1rem;
    transition: border-color 0.2s, transform 0.1s;
}
.pp-question-card.pp-current { border-color: var(--pp-primary); }
.pp-question-card.pp-answered {
    background: var(--pp-bg-soft);
    border-color: var(--pp-success);
}
.pp-question-number {
    flex-shrink: 0;
    background: var(--pp-primary);
    color: #fff;
    width: 38px; height: 38px;
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-size: 0.85rem; font-weight: 700;
}
.pp-question-card.pp-answered .pp-question-number { background: var(--pp-success); }
.pp-question-body { flex: 1; }
.pp-question-text {
    margin: 0 0 1rem;
    font-size: 1.05rem;
    font-weight: 500;
    color: var(--pp-text);
}

/* ----------- Options ------------------------------------- */
.pp-options { display: flex; flex-direction: column; gap: 0.5rem; }
.pp-option {
    display: flex; align-items: center; gap: 0.8rem;
    padding: 0.7rem 1rem;
    border: 1px solid var(--pp-border);
    border-radius: var(--pp-radius-sm);
    cursor: pointer;
    transition: all 0.15s;
    background: #fff;
}
.pp-option:hover { border-color: var(--pp-primary); background: #f5f3ff; }
.pp-option input[type="radio"] { accent-color: var(--pp-primary); }
.pp-option-selected {
    background: #eef2ff !important;
    border-color: var(--pp-primary) !important;
    box-shadow: 0 0 0 2px rgba(99,102,241,0.2);
}
.pp-option-key {
    background: var(--pp-bg-soft);
    border: 1px solid var(--pp-border);
    border-radius: 4px;
    padding: 0 0.5rem;
    font-weight: 600;
    font-size: 0.85rem;
    color: var(--pp-text-muted);
}
.pp-option-selected .pp-option-key { background: var(--pp-primary); color: #fff; border-color: var(--pp-primary); }
.pp-option-text { flex: 1; }

/* ----------- Navigation ---------------------------------- */
.pp-nav, .pp-finalize {
    text-align: center;
    padding: 2rem 1rem;
    margin-top: 1rem;
    background: var(--pp-bg);
    border-radius: var(--pp-radius);
    border: 1px solid var(--pp-border);
}
.pp-nav-hint { margin-top: 0.5rem; font-size: 0.85rem; color: var(--pp-text-muted); }
.pp-finalize h3 { color: var(--pp-success); margin-top: 0; }

/* ----------- Loading / Spinner --------------------------- */
.pp-loading { text-align: center; padding: 3rem 1rem; color: var(--pp-text-muted); }
.pp-spinner {
    width: 36px; height: 36px;
    margin: 0 auto 1rem;
    border: 3px solid var(--pp-border);
    border-top-color: var(--pp-primary);
    border-radius: 50%;
    animation: pp-spin 0.8s linear infinite;
}
@keyframes pp-spin { to { transform: rotate(360deg); } }

/* ----------- Errors -------------------------------------- */
.pp-error {
    background: #fef2f2; border: 1px solid #fecaca;
    color: #991b1b; padding: 0.8rem 1rem;
    border-radius: var(--pp-radius-sm);
    margin: 1rem 0;
}

.pp-notice {
    background: #fef3c7;
    border: 1px solid var(--pp-warning);
    color: #78350f;
    padding: 1rem 1.2rem;
    border-radius: var(--pp-radius);
}
.pp-notice a { color: var(--pp-primary-dark); font-weight: 600; }

/* ============================================================
   Results Page
   ============================================================ */

.pp-result-hero {
    background: linear-gradient(135deg, var(--pp-primary), var(--pp-secondary));
    color: #fff;
    padding: 2.5rem 1.5rem;
    border-radius: var(--pp-radius);
    text-align: center;
    margin-bottom: 2rem;
}
.pp-result-hero h1 { margin: 0 0 0.4rem; font-size: 1.8rem; }
.pp-result-meta { opacity: 0.9; margin: 0 0 1.5rem; }
.pp-result-codes {
    display: grid; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
    gap: 1rem; margin-bottom: 1.5rem;
}
.pp-code-card {
    background: rgba(255,255,255,0.15);
    backdrop-filter: blur(8px);
    padding: 1rem;
    border-radius: var(--pp-radius-sm);
}
.pp-code-label { display: block; font-size: 0.8rem; opacity: 0.85; margin-bottom: 0.3rem; }
.pp-code-value { font-size: 1.4rem; font-weight: 700; }
.pp-result-hero-actions { display:flex; gap:.9rem; justify-content:center; flex-wrap:wrap; }
.pp-btn-light { background: rgba(255,255,255,0.16); color:#fff; border:1px solid rgba(255,255,255,0.3); }
.pp-btn-light:hover { background: rgba(255,255,255,0.24); }
.pp-section-headline { display:flex; align-items:center; justify-content:space-between; gap:1rem; flex-wrap:wrap; }
.pp-inline-pdf-link { font-weight:700; color: var(--pp-primary); text-decoration:none; }
.pp-inline-pdf-link:hover { text-decoration:underline; }
.pp-bestfit-grid { display:grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap:1rem; }
.pp-bestfit-card { display:flex; gap:1rem; align-items:flex-start; padding:1rem; border:1px solid var(--pp-border); border-radius: var(--pp-radius); background: linear-gradient(180deg,#ffffff 0%,#f8fbff 100%); }
.pp-bestfit-media { flex:0 0 86px; }
.pp-bestfit-icon-img { width:86px; height:86px; object-fit:cover; border-radius:18px; border:1px solid var(--pp-border); background:#fff; }
.pp-bestfit-topline { display:flex; align-items:center; gap:.6rem; flex-wrap:wrap; margin-bottom:.45rem; }
.pp-bestfit-card h3 { margin:0 0 .35rem; font-size:1.05rem; color:var(--pp-primary-dark); }
.pp-bestfit-desc { margin:0; font-size:.92rem; color:var(--pp-text); }

.pp-result-section {
    background: var(--pp-bg);
    border: 1px solid var(--pp-border);
    border-radius: var(--pp-radius);
    padding: 1.5rem;
    margin-bottom: 1.5rem;
}
.pp-result-section h2 {
    margin-top: 0; color: var(--pp-primary-dark);
    border-bottom: 2px solid var(--pp-bg-soft);
    padding-bottom: 0.6rem;
}
.pp-section-desc { color: var(--pp-text-muted); font-size: 0.95rem; margin-bottom: 1.2rem; }
.pp-grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 1.5rem; align-items: center; }
@media (max-width: 600px) { .pp-grid-2 { grid-template-columns: 1fr; } }
@media (max-width: 767px) {
    .pp-section-headline { align-items:flex-start; }
    .pp-career-card-detailed { grid-template-columns: 1fr; }
    .pp-career-media-col { text-align:left; }
    .pp-career-facts-grid { grid-template-columns: 1fr; }
    .pp-bestfit-card { flex-direction:column; }
}


/* Stream rows */
.pp-stream-list { display: flex; flex-direction: column; gap: 0.6rem; }
.pp-stream-row {
    display: grid;
    grid-template-columns: 1fr 2fr 60px;
    align-items: center; gap: 1rem;
    padding: 0.5rem 0.8rem;
    background: var(--pp-bg-soft);
    border-radius: var(--pp-radius-sm);
}
.pp-stream-name { font-weight: 600; }
.pp-stream-bar {
    height: 12px; background: var(--pp-border);
    border-radius: 99px; overflow: hidden;
}
.pp-stream-bar-fill {
    height: 100%;
    background: linear-gradient(90deg, var(--pp-success), var(--pp-primary));
}
.pp-stream-score { text-align: right; font-weight: 600; color: var(--pp-primary-dark); }

/* Career cards */
.pp-careers-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 1.2rem;
}
.pp-career-card {
    background: #fff;
    border: 1px solid var(--pp-border);
    border-radius: var(--pp-radius);
    padding: 1.2rem;
    transition: transform 0.15s, box-shadow 0.15s;
}
.pp-career-card:hover { transform: translateY(-2px); box-shadow: var(--pp-shadow-lg); }
.pp-career-header { display: flex; align-items: flex-start; gap: 0.6rem; margin-bottom: 0.5rem; }
.pp-career-rank {
    background: var(--pp-primary); color: #fff;
    padding: 0.2rem 0.5rem; border-radius: 4px;
    font-size: 0.8rem; font-weight: 700;
}
.pp-career-card h3 { margin: 0; flex: 1; font-size: 1.1rem; }
.pp-career-fit {
    padding: 0.2rem 0.6rem; border-radius: 99px;
    font-size: 0.8rem; font-weight: 600;
}
.pp-fit-high   { background: #d1fae5; color: #065f46; }
.pp-fit-medium { background: #fef3c7; color: #92400e; }
.pp-fit-low    { background: #fee2e2; color: #991b1b; }
.pp-career-stream { color: var(--pp-text-muted); font-size: 0.85rem; margin: 0 0 0.6rem; }
.pp-career-desc { font-size: 0.9rem; margin: 0 0 0.8rem; }
.pp-career-details summary { cursor: pointer; color: var(--pp-primary); font-size: 0.9rem; }
.pp-career-details dl { margin: 0.6rem 0 0; font-size: 0.85rem; }
.pp-career-details dt { font-weight: 600; margin-top: 0.4rem; color: var(--pp-text-muted); }
.pp-career-details dd { margin: 0.1rem 0 0; }
.pp-careers-grid-detailed { grid-template-columns: 1fr; }
.pp-career-card-detailed { display:grid; grid-template-columns: 110px 1fr; gap:1rem; align-items:start; }
.pp-career-media-col { text-align:center; }
.pp-career-image { width:86px; height:86px; object-fit:cover; border-radius:18px; border:1px solid var(--pp-border); background:#fff; box-shadow: var(--pp-shadow-sm); }
.pp-career-image-caption { margin-top:.4rem; font-size:.75rem; color:var(--pp-text-muted); }
.pp-career-content-col { min-width:0; }
.pp-career-meta-line { display:flex; align-items:center; gap:.6rem; flex-wrap:wrap; margin-bottom:.6rem; }
.pp-career-meta-pill { display:inline-flex; padding:.22rem .55rem; border-radius:999px; background:#fff7d6; color:#9a6a00; font-size:.75rem; font-weight:700; }
.pp-career-facts-grid { display:grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap:.8rem; margin-top:.9rem; }
.pp-career-fact { padding:.75rem .85rem; background: var(--pp-bg-soft); border:1px solid var(--pp-border); border-radius:12px; }
.pp-career-fact strong { display:block; margin-bottom:.25rem; color:var(--pp-primary-dark); font-size:.8rem; }
.pp-career-fact span { display:block; font-size:.9rem; color:var(--pp-text); }
.pp-career-fact-full { grid-column:1 / -1; }

.pp-result-cta {
    background: linear-gradient(135deg, #f0f9ff, #ede9fe);
    border-radius: var(--pp-radius);
    padding: 2rem 1.5rem;
    text-align: center;
}

/* ============================================================
   Pricing & Dashboard
   ============================================================ */
.pp-pricing-header { text-align: center; margin-bottom: 2rem; }
.pp-pricing-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 1.5rem;
}
.pp-plan-card {
    background: #fff;
    border: 1px solid var(--pp-border);
    border-radius: var(--pp-radius);
    padding: 2rem 1.5rem;
    text-align: center;
    position: relative;
    transition: transform 0.2s;
}
.pp-plan-card:hover { transform: translateY(-4px); box-shadow: var(--pp-shadow-lg); }
.pp-plan-featured {
    border-color: var(--pp-primary);
    border-width: 2px;
    transform: scale(1.02);
}
.pp-plan-badge {
    position: absolute; top: -12px; left: 50%; transform: translateX(-50%);
    background: var(--pp-primary); color: #fff;
    padding: 0.25rem 0.9rem;
    border-radius: 99px; font-size: 0.75rem; font-weight: 600;
}
.pp-plan-price { margin: 1rem 0 1.5rem; }
.pp-currency { font-size: 1.2rem; vertical-align: top; }
.pp-amount   { font-size: 2.8rem; font-weight: 700; color: var(--pp-primary-dark); }
.pp-plan-features { list-style: none; padding: 0; margin: 0 0 1.5rem; text-align: left; }
.pp-plan-features li { padding: 0.4rem 0; border-bottom: 1px dashed var(--pp-border); font-size: 0.95rem; }
.pp-plan-features li:last-child { border-bottom: 0; }

/* Dashboard */
.pp-dash-header { margin-bottom: 2rem; }
.pp-dash-section { margin-bottom: 2rem; }
.pp-dash-section h3 { color: var(--pp-primary-dark); }
.pp-dash-table { width: 100%; border-collapse: collapse; background: #fff; border-radius: var(--pp-radius); overflow: hidden; box-shadow: var(--pp-shadow); }
.pp-dash-table th, .pp-dash-table td { padding: 0.8rem 1rem; text-align: left; border-bottom: 1px solid var(--pp-border); }
.pp-dash-table th { background: var(--pp-bg-soft); font-weight: 600; font-size: 0.9rem; }
.pp-dash-table tr:last-child td { border-bottom: 0; }

.pp-status {
    display: inline-block;
    padding: 0.2rem 0.7rem;
    border-radius: 99px;
    font-size: 0.8rem;
    font-weight: 600;
}
.pp-status-completed   { background: #d1fae5; color: #065f46; }
.pp-status-in_progress { background: #fef3c7; color: #92400e; }
.pp-status-abandoned   { background: #fee2e2; color: #991b1b; }
.pp-status-expired     { background: #e5e7eb; color: #374151; }
.pp-status-paid        { background: #d1fae5; color: #065f46; }

.pp-dash-empty {
    background: var(--pp-bg-soft);
    border: 2px dashed var(--pp-border);
    border-radius: var(--pp-radius);
    padding: 3rem 1.5rem;
    text-align: center;
}
.pp-text-muted { color: var(--pp-text-muted); }

/* ----------- Mobile tweaks ------------------------------- */
@media (max-width: 600px) {
    .pp-test-header { position: static; }
    .pp-question-card { padding: 1rem; }
    .pp-question-text { font-size: 1rem; }
    .pp-result-hero { padding: 1.5rem 1rem; }
    .pp-result-hero h1 { font-size: 1.4rem; }
    .pp-code-value { font-size: 1.2rem; }
}

/* ============================================================
   Auth (Register / Login)
   ============================================================ */
.pp-auth-wrap {
    max-width: 480px;
    margin: 2.5rem auto;
    padding: 1rem;
}
.pp-auth-card {
    background: var(--pp-bg);
    border: 1px solid var(--pp-border);
    border-radius: var(--pp-radius);
    padding: 2rem 1.8rem;
    box-shadow: var(--pp-shadow-lg);
}
.pp-auth-header {
    text-align: center;
    margin-bottom: 1.6rem;
}
.pp-auth-header h2 {
    color: var(--pp-primary-dark);
    margin: 0 0 0.4rem;
    font-size: 1.6rem;
}
.pp-auth-header p {
    color: var(--pp-text-muted);
    margin: 0;
    font-size: 0.95rem;
}

.pp-auth-form .pp-field {
    margin-bottom: 1.1rem;
}
.pp-auth-form label {
    display: block;
    font-weight: 600;
    margin-bottom: 0.4rem;
    color: var(--pp-text);
    font-size: 0.9rem;
}
.pp-auth-form input[type="text"],
.pp-auth-form input[type="email"],
.pp-auth-form input[type="tel"],
.pp-auth-form input[type="password"] {
    width: 100%;
    padding: 0.7rem 0.9rem;
    border: 1px solid var(--pp-border);
    border-radius: var(--pp-radius-sm);
    font-size: 1rem;
    background: #fff;
    color: var(--pp-text);
    transition: border-color 0.15s, box-shadow 0.15s;
    box-sizing: border-box;
}
.pp-auth-form input:focus {
    outline: none;
    border-color: var(--pp-primary);
    box-shadow: 0 0 0 3px rgba(99,102,241,0.15);
}

.pp-phone-input {
    display: flex;
    align-items: stretch;
    border: 1px solid var(--pp-border);
    border-radius: var(--pp-radius-sm);
    overflow: hidden;
    background: #fff;
}
.pp-phone-input:focus-within {
    border-color: var(--pp-primary);
    box-shadow: 0 0 0 3px rgba(99,102,241,0.15);
}
.pp-phone-flag {
    background: var(--pp-bg-soft);
    padding: 0 0.9rem;
    display: flex;
    align-items: center;
    border-right: 1px solid var(--pp-border);
    font-weight: 600;
    color: var(--pp-text-muted);
    white-space: nowrap;
}
.pp-phone-input input {
    border: none !important;
    box-shadow: none !important;
    border-radius: 0 !important;
}

.pp-field-hint {
    display: block;
    margin-top: 0.35rem;
    color: var(--pp-text-muted);
    font-size: 0.82rem;
}
.pp-field-hint strong { color: var(--pp-warning); }

.pp-auth-footer {
    text-align: center;
    margin-top: 1.3rem;
    color: var(--pp-text-muted);
    font-size: 0.92rem;
}
.pp-auth-footer a {
    color: var(--pp-primary);
    font-weight: 600;
    text-decoration: none;
}
.pp-auth-footer a:hover { text-decoration: underline; }

@media (max-width: 480px) {
    .pp-auth-wrap { margin: 1rem auto; }
    .pp-auth-card { padding: 1.5rem 1.2rem; }
    .pp-auth-header h2 { font-size: 1.4rem; }
}

/* Wide variant for registration with security questions */
.pp-auth-wide { max-width: 560px; }

.pp-auth-section {
    margin: 1.6rem 0 0.4rem;
    padding-top: 1.2rem;
    border-top: 1px solid var(--pp-border);
    color: var(--pp-primary-dark);
    font-size: 1rem;
}
.pp-auth-section:first-of-type { border-top: 0; padding-top: 0; }

.pp-section-help {
    color: var(--pp-text-muted);
    font-size: 0.88rem;
    margin: 0 0 1rem;
    line-height: 1.5;
}

.pp-field-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0.8rem;
}
@media (max-width: 480px) { .pp-field-row { grid-template-columns: 1fr; gap: 0; } }

.pp-security-slot {
    background: var(--pp-bg-soft);
    padding: 1rem;
    border-radius: var(--pp-radius-sm);
    margin-bottom: 0.8rem;
    border: 1px solid var(--pp-border);
}
.pp-security-slot .pp-field { margin-bottom: 0.7rem; }
.pp-security-slot .pp-field:last-child { margin-bottom: 0; }

.pp-auth-form select {
    width: 100%;
    padding: 0.7rem 0.9rem;
    border: 1px solid var(--pp-border);
    border-radius: var(--pp-radius-sm);
    font-size: 1rem;
    background: #fff;
    color: var(--pp-text);
    box-sizing: border-box;
    cursor: pointer;
}
.pp-auth-form select:focus {
    outline: none;
    border-color: var(--pp-primary);
    box-shadow: 0 0 0 3px rgba(99,102,241,0.15);
}

/* Login mode tabs */
.pp-tabs {
    display: flex;
    gap: 4px;
    background: var(--pp-bg-soft);
    border-radius: var(--pp-radius-sm);
    padding: 4px;
    margin: 0 0 1.2rem;
}
.pp-tab {
    flex: 1;
    padding: 0.55rem 0.9rem;
    border: 0;
    background: transparent;
    color: var(--pp-text-muted);
    font-size: 0.92rem;
    font-weight: 600;
    border-radius: 6px;
    cursor: pointer;
    transition: background 0.15s, color 0.15s;
}
.pp-tab:hover { color: var(--pp-text); }
.pp-tab-active {
    background: #fff;
    color: var(--pp-primary-dark);
    box-shadow: 0 1px 2px rgba(0,0,0,.06);
}

/* Logged-in session confirmation / shared browser safety */
.pp-session-card {
    max-width: 620px;
    margin: 2rem auto;
    padding: 2rem;
    border-radius: 18px;
    background: #ffffff;
    border: 1px solid var(--pp-border, #e5e7eb);
    box-shadow: 0 16px 45px rgba(15, 23, 42, 0.08);
    text-align: center;
    color: var(--pp-text, #1f2937);
}
.pp-session-icon {
    width: 58px;
    height: 58px;
    margin: 0 auto 1rem;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    background: linear-gradient(135deg, rgba(99,102,241,.13), rgba(180,151,52,.16));
    font-size: 1.7rem;
}
.pp-session-card h2 {
    margin: 0 0 .75rem;
    color: var(--pp-primary-dark, #111827);
    font-size: 1.55rem;
}
.pp-session-card p {
    margin: .45rem 0;
    line-height: 1.55;
}
.pp-session-user {
    font-size: 1.05rem;
    color: var(--pp-text, #1f2937);
}
.pp-session-muted {
    color: var(--pp-text-muted, #6b7280);
    font-size: .92rem;
}
.pp-session-actions {
    display: flex;
    gap: .85rem;
    justify-content: center;
    flex-wrap: wrap;
    margin-top: 1.35rem;
}
.pp-test-session-gate {
    margin-top: 1rem;
}
@media (max-width: 560px) {
    .pp-session-card { padding: 1.35rem; margin: 1rem auto; }
    .pp-session-actions { flex-direction: column; }
    .pp-session-actions .pp-btn { width: 100%; }
}

/* ============================================================
   Multi-test dashboard / coupons
   ============================================================ */
.pp-test-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 1rem;
}
.pp-test-card {
    background: #fff;
    border: 1px solid var(--pp-border);
    border-radius: var(--pp-radius);
    padding: 1.2rem;
    box-shadow: var(--pp-shadow);
}
.pp-test-card h3,
.pp-test-card h4 { margin-top: 0; color: var(--pp-primary-dark); }
.pp-test-price { font-weight: 700; color: var(--pp-text); }
.pp-coupon-box {
    max-width: 620px;
    margin: 0 auto 1.5rem;
    background: #fffbeb;
    border: 1px solid #fcd34d;
    border-radius: var(--pp-radius);
    padding: 1rem;
}
.pp-coupon-row { display: flex; gap: 0.6rem; margin-top: 0.5rem; }
.pp-coupon-row input {
    flex: 1;
    border: 1px solid var(--pp-border);
    border-radius: var(--pp-radius-sm);
    padding: 0.7rem 0.9rem;
    font-size: 1rem;
}
.pp-coupon-message { margin: 0.5rem 0 0; font-weight: 600; }
.pp-coupon-ok { color: #065f46; }
.pp-coupon-bad { color: #92400e; }
@media (max-width: 600px) {
    .pp-coupon-row { flex-direction: column; }
}

/* v1.7.2 dashboard category filters and recommendation badges */
.pp-filter-bar{display:flex;gap:.65rem;flex-wrap:wrap;margin:0 0 1.25rem 0;align-items:center}
.pp-filter-btn{border:1px solid #d7dbe3;background:#fff;border-radius:999px;padding:.55rem 1rem;cursor:pointer;font-weight:700;color:#374151;box-shadow:0 2px 8px rgba(15,23,42,.05)}
.pp-filter-btn:hover,.pp-filter-btn.is-active{background:#111827;color:#f6e6c3;border-color:#111827}
.pp-reco-badge{display:inline-block;background:#fff7d6;color:#8a5a00;border:1px solid #f2d477;border-radius:999px;padding:.28rem .65rem;font-size:.78rem;font-weight:800;margin-bottom:.85rem;letter-spacing:.01em}
.pp-test-card[data-category]{position:relative}


.pp-test-card{min-height:430px;display:flex;flex-direction:column;overflow:hidden}
.pp-test-thumb-wrap{margin:-1.2rem -1.2rem .9rem -1.2rem;height:148px;overflow:hidden;border-radius:12px 12px 0 0;background:#f3f4f6}
.pp-test-thumb{width:100%;height:100%;object-fit:cover;display:block}
.pp-test-card h4{font-size:1.1rem;line-height:1.3;min-height:56px;margin-bottom:.7rem}
.pp-test-desc{min-height:96px;position:relative;margin-bottom:.4rem}
.pp-test-desc-text{display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden;margin:0}
.pp-test-desc[data-expanded="1"] .pp-test-desc-text{-webkit-line-clamp:unset;display:block;max-height:none}
.pp-desc-toggle{font-size:.82rem;padding:0;margin-top:.25rem}
.pp-test-card .pp-status{margin-top:auto}
.pp-test-card .pp-btn,.pp-test-card .pp-status + .pp-btn,.pp-test-card .pp-status + a.pp-btn{align-self:flex-start}
.pp-test-thumb-default{display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#fff7d6,#f6e6c3)}
.pp-test-thumb-default span{font-size:3.2rem;line-height:1;filter:drop-shadow(0 6px 12px rgba(0,0,0,.12))}
.pp-career-icon{width:38px;height:38px;object-fit:cover;border-radius:10px;border:1px solid var(--pp-border);background:#fff;margin-right:.5rem}
.pp-career-icon-fallback{display:inline-flex;width:38px;height:38px;align-items:center;justify-content:center;border-radius:10px;background:#fff7d6;border:1px solid #e7c767;margin-right:.5rem;font-size:1.35rem}

/* v1.7.6 Premium dashboard card redesign */
.pp-dashboard{max-width:1120px}
.pp-test-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.35rem;align-items:stretch}
.pp-test-card{min-height:520px;padding:0;border:0;border-radius:18px;overflow:hidden;background:#fff;box-shadow:0 12px 30px rgba(15,23,42,.10);display:flex;flex-direction:column;transition:transform .2s ease,box-shadow .2s ease}
.pp-test-card:hover{transform:translateY(-4px);box-shadow:0 18px 44px rgba(15,23,42,.15)}
.pp-test-thumb-wrap{margin:0;height:190px;border-radius:18px 18px 0 0;background:#07111f;position:relative;overflow:hidden}
.pp-test-thumb{width:100%;height:100%;object-fit:cover;object-position:center center;display:block;transition:transform .35s ease}
.pp-test-card:hover .pp-test-thumb{transform:scale(1.035)}
.pp-test-thumb-default{height:190px;background:radial-gradient(circle at top left,#263c6f,#07111f 52%,#020617);display:flex;align-items:center;justify-content:center}
.pp-test-thumb-default span{font-size:4.5rem;line-height:1;filter:drop-shadow(0 10px 20px rgba(0,0,0,.35))}
.pp-card-content{padding:1.05rem 1.15rem .9rem;display:flex;flex-direction:column;gap:.78rem;flex:1}
.pp-reco-badge{position:absolute;top:12px;left:12px;z-index:2;background:rgba(255,247,214,.96);box-shadow:0 6px 18px rgba(0,0,0,.16);margin:0;max-width:calc(100% - 24px)}
.pp-test-title-strip{background:linear-gradient(135deg,#07111f 0%,#0c2a4f 55%,#123e72 100%);border:1px solid rgba(246,230,195,.20);border-radius:14px;padding:.72rem .85rem;box-shadow:inset 0 1px 0 rgba(255,255,255,.08)}
.pp-test-card h4{font-size:1.05rem;line-height:1.22;min-height:0;margin:0!important;color:#f6e6c3!important;font-weight:800;letter-spacing:.01em;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-shadow:0 1px 2px rgba(0,0,0,.28)}
.pp-test-desc{min-height:88px;margin:0;color:#1f2937}
.pp-test-desc-text{font-size:.94rem;line-height:1.58;-webkit-line-clamp:3;margin:0;color:#263241}
.pp-desc-toggle{display:inline-block;margin-top:.55rem;background:#f2ff3b!important;color:#111827!important;border-radius:999px;padding:.42rem .82rem!important;text-decoration:none!important;font-weight:800;font-size:.82rem;box-shadow:0 4px 12px rgba(17,24,39,.12)}
.pp-card-footer{padding:0 1.15rem 1.12rem;display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin-top:auto;flex-wrap:wrap}
.pp-card-footer .pp-status{margin:0;font-size:.78rem;font-weight:800}
.pp-card-footer .pp-btn{margin:0;min-width:112px;text-align:center;border-radius:10px;font-weight:800;box-shadow:0 6px 16px rgba(79,70,229,.20)}
.pp-card-footer .pp-btn-secondary{background:#111827;color:#f6e6c3}
.pp-card-footer .pp-btn-secondary:hover{background:#0c1220}
@media (max-width:640px){.pp-test-grid{grid-template-columns:1fr}.pp-test-card{min-height:auto}.pp-test-thumb-wrap,.pp-test-thumb-default{height:205px}.pp-card-footer{align-items:flex-start;flex-direction:column}.pp-card-footer .pp-btn{width:100%}}

/* v1.7.7 Dashboard badge placement fix */
.pp-card-footer{display:block!important;padding:0 1.15rem 1.12rem!important;margin-top:auto!important}
.pp-card-reco-row{margin:0 0 .72rem 0;display:block;min-height:0}
.pp-card-action-row{display:flex;align-items:center;justify-content:space-between;gap:.75rem;flex-wrap:wrap}
.pp-card-footer .pp-reco-badge{position:static!important;top:auto!important;left:auto!important;z-index:auto!important;display:inline-flex;align-items:center;max-width:100%;margin:0;background:#fff7d6;color:#8a5a00;border:1px solid #f2d477;box-shadow:none;white-space:normal;line-height:1.25}
.pp-test-thumb-wrap .pp-reco-badge{display:none!important}
@media (max-width:640px){.pp-card-action-row{align-items:flex-start;flex-direction:column}.pp-card-action-row .pp-btn{width:100%}}

/* v1.7.7 Premium landing/pricing page redesign */
.pp-pricing.pp-landing{max-width:1180px;margin:2rem auto;padding:1rem;font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;color:#1f2937}
.pp-landing-hero{display:grid;grid-template-columns:minmax(0,1.05fr) minmax(330px,.95fr);gap:1.4rem;align-items:stretch;background:linear-gradient(135deg,#07111f 0%,#0c2a4f 55%,#123e72 100%);border-radius:28px;padding:1.4rem;box-shadow:0 20px 50px rgba(2,6,23,.18);overflow:hidden;position:relative}
.pp-landing-hero:before{content:"";position:absolute;inset:-40% -20% auto auto;width:420px;height:420px;background:radial-gradient(circle,rgba(246,230,195,.20),transparent 66%);pointer-events:none}
.pp-landing-hero-copy{position:relative;z-index:1;padding:1.4rem 1rem 1.4rem 1.1rem;color:#fff;display:flex;flex-direction:column;justify-content:center}
.pp-landing-kicker{display:inline-flex;align-self:flex-start;background:rgba(246,230,195,.12);border:1px solid rgba(246,230,195,.32);color:#f6e6c3;border-radius:999px;padding:.42rem .78rem;font-weight:800;font-size:.83rem;margin-bottom:1rem;text-transform:uppercase;letter-spacing:.06em}
.pp-landing-hero h1{font-size:clamp(2rem,4vw,4rem);line-height:1.04;margin:0 0 1rem;color:#f6e6c3;font-weight:900;letter-spacing:-.035em}
.pp-landing-lead{font-size:1.08rem;line-height:1.7;color:#e5e7eb;max-width:650px;margin:0 0 1rem}
.pp-landing-meta{display:flex;gap:.6rem;flex-wrap:wrap;margin:1.1rem 0 1.35rem}
.pp-landing-meta span{background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.14);color:#fff;border-radius:999px;padding:.48rem .8rem;font-size:.88rem;font-weight:700}
.pp-landing-actions{display:flex;gap:.75rem;flex-wrap:wrap;margin-top:.25rem}
.pp-landing-visual{position:relative;z-index:1;border-radius:22px;overflow:hidden;background:#020617;min-height:330px;box-shadow:inset 0 0 0 1px rgba(255,255,255,.12)}
.pp-landing-visual img{width:100%;height:100%;object-fit:cover;display:block;min-height:330px}
.pp-landing-icon{height:100%;min-height:330px;display:flex;align-items:center;justify-content:center;font-size:7rem;background:radial-gradient(circle at center,#263c6f,#07111f 55%,#020617);filter:drop-shadow(0 18px 35px rgba(0,0,0,.45))}
.pp-landing-section{background:#fff;border:1px solid #e5e7eb;border-radius:24px;padding:1.5rem;margin:1.4rem 0;box-shadow:0 12px 28px rgba(15,23,42,.08)}
.pp-landing-section h2,.pp-landing-support h2{font-size:clamp(1.55rem,2.2vw,2.25rem);line-height:1.15;margin:0 0 1rem;color:#b39135;font-weight:850;letter-spacing:-.025em}
.pp-landing-about{font-size:1rem;line-height:1.75;color:#334155}
.pp-benefit-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:.85rem}
.pp-benefit-card{display:flex;gap:.75rem;align-items:flex-start;background:#f8fafc;border:1px solid #e5e7eb;border-radius:18px;padding:1rem;min-height:88px}
.pp-benefit-card span{display:inline-flex;width:26px;height:26px;align-items:center;justify-content:center;border-radius:50%;background:#ecfdf5;color:#047857;font-weight:900;flex:0 0 26px}
.pp-benefit-card p{margin:0;font-weight:650;color:#263241;line-height:1.45}
.pp-landing .pp-pricing-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem;align-items:stretch}
.pp-landing .pp-plan-card{border:1px solid #e5e7eb;border-radius:22px;padding:1.4rem;background:#fff;box-shadow:0 12px 28px rgba(15,23,42,.08);position:relative;display:flex;flex-direction:column}
.pp-landing .pp-plan-featured{border-color:#d6b55d;box-shadow:0 16px 38px rgba(179,145,53,.18)}
.pp-landing .pp-plan-badge{position:absolute;top:14px;right:14px;background:#fff7d6;color:#8a5a00;border:1px solid #f2d477;border-radius:999px;padding:.28rem .62rem;font-size:.74rem;font-weight:900}
.pp-landing .pp-plan-card h3{font-size:1.35rem;margin:.25rem 0 .8rem;color:#07111f}
.pp-landing .pp-plan-price{font-size:2.4rem;line-height:1;color:#b39135;font-weight:900;margin:.35rem 0 1rem}
.pp-landing .pp-currency{font-size:1.2rem;vertical-align:super;margin-right:.1rem}
.pp-landing .pp-plan-features{list-style:none;margin:0 0 1.2rem;padding:0;display:grid;gap:.55rem;color:#334155;flex:1}
.pp-landing .pp-plan-features li{line-height:1.45}
.pp-landing-support{margin:1.4rem 0 0;background:linear-gradient(135deg,#fff7d6,#fff);border:1px solid #ead59b;border-radius:24px;padding:1.4rem 1.5rem;box-shadow:0 12px 28px rgba(15,23,42,.06)}
.pp-landing-support p{margin:.25rem 0 1rem;color:#334155;font-size:1rem}
@media (max-width:820px){.pp-landing-hero{grid-template-columns:1fr;padding:1rem}.pp-landing-visual,.pp-landing-visual img,.pp-landing-icon{min-height:240px}.pp-landing-hero-copy{padding:1rem}.pp-landing-actions .pp-btn{width:100%;text-align:center}}

/* v1.7.8 admin-controlled landing sections */
.pp-testimonial-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem}
.pp-testimonial-card{background:#fff;border:1px solid var(--pp-border);border-radius:16px;padding:1rem;box-shadow:var(--pp-shadow)}
.pp-testimonial-card p{margin:0 0 .8rem;color:#374151;font-style:italic}
.pp-testimonial-card strong{color:#0c2a4f}
.pp-faq-list{display:grid;gap:.75rem}
.pp-faq-item{background:#fff;border:1px solid var(--pp-border);border-radius:14px;padding:.85rem 1rem;box-shadow:var(--pp-shadow)}
.pp-faq-item summary{cursor:pointer;font-weight:800;color:#0c2a4f}
.pp-faq-item p{margin:.7rem 0 0;color:#4b5563}
