/* ==========================================================================
   CV4SAP — Landing Page Stylesheet
   Standalone CSS — no dependency on existing stylesheets
   ========================================================================== */

/* --------------------------------------------------------------------------
   CSS Custom Properties (Design Tokens)
   -------------------------------------------------------------------------- */
:root {
    --color-primary: #1e40af;
    --color-primary-light: #3b82f6;
    --color-accent: #06b6d4;
    --color-success: #10b981;
    --color-warning: #f59e0b;
    --color-bg-body: #f8fafc;
    --color-bg-white: #ffffff;
    --color-bg-alt: #f1f5f9;
    --color-bg-dark: #0f172a;
    --color-bg-dark-alt: #1e293b;
    --color-text-heading: #0f172a;
    --color-text-body: #475569;
    --color-text-light: #94a3b8;
    --color-text-white: #ffffff;
    --color-border: #e2e8f0;

    --font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    --container-max-width: 1200px;
    --section-padding: 96px;
    --grid-gap: 24px;
    --card-radius: 16px;
    --card-padding: 32px;
    --btn-height: 48px;
    --btn-radius: 8px;
    --navbar-height: 80px;
    --navbar-sticky-height: 72px;
    --badge-radius: 6px;
    --transition-fast: 0.2s ease;
    --transition-normal: 0.3s ease;
}

/* --------------------------------------------------------------------------
   Reset & Base
   -------------------------------------------------------------------------- */
*,
*::before,
*::after {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

html {
    scroll-behavior: smooth;
    -webkit-text-size-adjust: 100%;
}

body.landing-page {
    font-family: var(--font-family);
    font-size: 16px;
    font-weight: 400;
    line-height: 1.6;
    color: var(--color-text-body);
    background-color: var(--color-bg-body);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

img {
    max-width: 100%;
    height: auto;
    display: block;
}

a {
    color: inherit;
    text-decoration: none;
}

h1, h2, h3, h4, h5, h6 {
    color: var(--color-text-heading);
    line-height: 1.2;
}

/* --------------------------------------------------------------------------
   Container
   -------------------------------------------------------------------------- */
.lp-container {
    width: 100%;
    max-width: var(--container-max-width);
    margin: 0 auto;
    padding: 0 24px;
}

/* --------------------------------------------------------------------------
   Section Base
   -------------------------------------------------------------------------- */
.lp-section {
    padding: var(--section-padding) 0;
}

.lp-section--alt {
    background-color: var(--color-bg-alt);
}

.lp-section--white {
    background-color: var(--color-bg-white);
}

.lp-section--dark {
    background: linear-gradient(135deg, var(--color-bg-dark) 0%, var(--color-bg-dark-alt) 100%);
    color: var(--color-text-white);
}

.lp-section--gradient {
    background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-light) 100%);
    color: var(--color-text-white);
}

.lp-section__title {
    font-size: 36px;
    font-weight: 700;
    text-align: center;
    margin-bottom: 16px;
}

.lp-section__subtitle {
    font-size: 16px;
    color: var(--color-text-body);
    text-align: center;
    max-width: 640px;
    margin: 0 auto 48px;
    line-height: 1.6;
}

.lp-section--dark .lp-section__title,
.lp-section--gradient .lp-section__title {
    color: var(--color-text-white);
}

.lp-section--dark .lp-section__subtitle,
.lp-section--gradient .lp-section__subtitle {
    color: rgba(255, 255, 255, 0.85);
}

/* --------------------------------------------------------------------------
   Buttons
   -------------------------------------------------------------------------- */
.lp-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    height: var(--btn-height);
    padding: 0 32px;
    font-family: var(--font-family);
    font-size: 15px;
    font-weight: 600;
    border-radius: var(--btn-radius);
    border: 2px solid transparent;
    cursor: pointer;
    transition: all var(--transition-fast);
    text-decoration: none;
    line-height: 1;
    white-space: nowrap;
}

.lp-btn:focus-visible {
    outline: 2px solid var(--color-primary-light);
    outline-offset: 2px;
}

.lp-btn--primary {
    background-color: var(--color-primary-light);
    color: var(--color-text-white);
    border-color: var(--color-primary-light);
}

.lp-btn--primary:hover {
    background-color: var(--color-primary);
    border-color: var(--color-primary);
}

.lp-btn--white {
    background-color: var(--color-bg-white);
    color: var(--color-primary);
    border-color: var(--color-bg-white);
}

.lp-btn--white:hover {
    background-color: #f0f4ff;
    border-color: #f0f4ff;
}

.lp-btn--outline {
    background-color: transparent;
    color: var(--color-primary);
    border-color: var(--color-border);
}

.lp-btn--outline:hover {
    border-color: var(--color-primary);
    background-color: rgba(30, 64, 175, 0.04);
}

.lp-btn--outline-white {
    background-color: transparent;
    color: var(--color-text-white);
    border-color: rgba(255, 255, 255, 0.5);
}

.lp-btn--outline-white:hover {
    border-color: rgba(255, 255, 255, 0.9);
    background-color: rgba(255, 255, 255, 0.1);
}

.lp-btn--lg {
    height: 52px;
    padding: 0 36px;
    font-size: 16px;
}

/* --------------------------------------------------------------------------
   Navbar
   -------------------------------------------------------------------------- */
.lp-navbar {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    height: var(--navbar-height);
    z-index: 1000;
    transition: all var(--transition-normal);
    background-color: transparent;
}

.lp-navbar.scrolled {
    height: var(--navbar-sticky-height);
    background-color: var(--color-bg-white);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
}

.lp-navbar__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    height: 100%;
    max-width: var(--container-max-width);
    margin: 0 auto;
    padding: 0 24px;
}

.lp-navbar__logo {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 20px;
    font-weight: 700;
    color: var(--color-text-white);
    text-decoration: none;
    transition: color var(--transition-normal);
}

.lp-navbar__logo i {
    font-size: 24px;
}

.lp-navbar.scrolled .lp-navbar__logo {
    color: var(--color-primary);
}

.lp-navbar__links {
    display: flex;
    align-items: center;
    gap: 32px;
    list-style: none;
}

.lp-navbar__link {
    font-size: 15px;
    font-weight: 500;
    color: rgba(255, 255, 255, 0.85);
    text-decoration: none;
    transition: color var(--transition-fast);
}

.lp-navbar__link:hover {
    color: var(--color-text-white);
}

.lp-navbar.scrolled .lp-navbar__link {
    color: var(--color-text-body);
}

.lp-navbar.scrolled .lp-navbar__link:hover {
    color: var(--color-primary);
}

.lp-navbar__actions {
    display: flex;
    align-items: center;
    gap: 12px;
}

/* Language Switcher */
.lp-lang {
    display: flex;
    align-items: center;
    gap: 4px;
    margin-right: 8px;
}

.lp-lang__item {
    font-size: 13px;
    font-weight: 500;
    color: rgba(255, 255, 255, 0.7);
    padding: 4px 8px;
    border-radius: 4px;
    text-decoration: none;
    transition: all var(--transition-fast);
}

.lp-lang__item:hover,
.lp-lang__item--active {
    color: var(--color-text-white);
    background-color: rgba(255, 255, 255, 0.15);
}

.lp-navbar.scrolled .lp-lang__item {
    color: var(--color-text-light);
}

.lp-navbar.scrolled .lp-lang__item:hover,
.lp-navbar.scrolled .lp-lang__item--active {
    color: var(--color-primary);
    background-color: rgba(30, 64, 175, 0.08);
}

/* Navbar Auth Buttons */
.lp-navbar__btn-login {
    font-size: 14px;
    font-weight: 500;
    color: rgba(255, 255, 255, 0.9);
    background: transparent;
    border: 1px solid rgba(255, 255, 255, 0.4);
    padding: 8px 20px;
    border-radius: var(--btn-radius);
    text-decoration: none;
    transition: all var(--transition-fast);
}

.lp-navbar__btn-login:hover {
    border-color: rgba(255, 255, 255, 0.8);
    background: rgba(255, 255, 255, 0.1);
}

.lp-navbar.scrolled .lp-navbar__btn-login {
    color: var(--color-primary);
    border-color: var(--color-border);
}

.lp-navbar.scrolled .lp-navbar__btn-login:hover {
    border-color: var(--color-primary);
    background: rgba(30, 64, 175, 0.04);
}

.lp-navbar__btn-register {
    font-size: 14px;
    font-weight: 600;
    color: var(--color-primary);
    background: var(--color-bg-white);
    border: none;
    padding: 8px 20px;
    border-radius: var(--btn-radius);
    text-decoration: none;
    transition: all var(--transition-fast);
}

.lp-navbar__btn-register:hover {
    background: #f0f4ff;
}

.lp-navbar.scrolled .lp-navbar__btn-register {
    color: var(--color-text-white);
    background: var(--color-primary-light);
}

.lp-navbar.scrolled .lp-navbar__btn-register:hover {
    background: var(--color-primary);
}

/* Navbar User Menu (logged-in) */
.lp-navbar__user {
    position: relative;
}

.lp-navbar__user-trigger {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    background: rgba(255, 255, 255, 0.12);
    border: 1px solid rgba(255, 255, 255, 0.25);
    color: var(--color-text-white);
    padding: 6px 12px 6px 6px;
    border-radius: 999px;
    font-size: 14px;
    font-weight: 500;
    cursor: pointer;
    transition: all var(--transition-fast);
    max-width: 240px;
}

.lp-navbar__user-trigger:hover {
    background: rgba(255, 255, 255, 0.2);
    border-color: rgba(255, 255, 255, 0.45);
}

.lp-navbar__user-avatar {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 30px;
    height: 30px;
    border-radius: 50%;
    background: var(--color-bg-white);
    color: var(--color-primary);
    font-size: 13px;
    font-weight: 700;
    flex-shrink: 0;
    text-transform: uppercase;
}

.lp-navbar__user-name {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 140px;
}

.lp-navbar__user-caret {
    font-size: 12px;
    opacity: 0.8;
    transition: transform var(--transition-fast);
}

.lp-navbar__user[data-open="true"] .lp-navbar__user-caret {
    transform: rotate(180deg);
}

.lp-navbar.scrolled .lp-navbar__user-trigger {
    color: var(--color-text-heading);
    background: var(--color-bg-alt);
    border-color: var(--color-border);
}

.lp-navbar.scrolled .lp-navbar__user-trigger:hover {
    background: #eef1f6;
    border-color: var(--color-primary);
}

.lp-navbar.scrolled .lp-navbar__user-avatar {
    background: var(--color-primary);
    color: var(--color-text-white);
}

.lp-navbar__user-menu {
    position: absolute;
    top: calc(100% + 10px);
    right: 0;
    min-width: 220px;
    background: var(--color-bg-white);
    border: 1px solid var(--color-border);
    border-radius: 12px;
    box-shadow: 0 12px 32px rgba(15, 23, 42, 0.16);
    padding: 6px;
    display: none;
    z-index: 1001;
}

.lp-navbar__user[data-open="true"] .lp-navbar__user-menu {
    display: block;
}

.lp-navbar__user-menu-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 12px;
    border-radius: 8px;
    font-size: 14px;
    font-weight: 500;
    color: var(--color-text-heading);
    text-decoration: none;
    transition: background var(--transition-fast);
}

.lp-navbar__user-menu-item i {
    font-size: 16px;
    color: var(--color-text-body);
}

.lp-navbar__user-menu-item:hover {
    background: var(--color-bg-alt);
}

.lp-navbar__user-menu-item--danger {
    color: #b91c1c;
}

.lp-navbar__user-menu-item--danger i {
    color: #b91c1c;
}

.lp-navbar__user-menu-item--danger:hover {
    background: rgba(185, 28, 28, 0.08);
}

/* Mobile menu — logged-in user block */
.lp-mobile-menu__user {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 12px 16px;
    margin-bottom: 4px;
    border-radius: 8px;
    background: var(--color-bg-alt);
    color: var(--color-text-heading);
}

.lp-mobile-menu__user-avatar {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: var(--color-primary);
    color: var(--color-text-white);
    font-size: 13px;
    font-weight: 700;
    text-transform: uppercase;
}

.lp-mobile-menu__user-name {
    font-size: 14px;
    font-weight: 600;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* Mobile Toggle */
.lp-navbar__toggle {
    display: none;
    background: none;
    border: none;
    font-size: 24px;
    color: var(--color-text-white);
    cursor: pointer;
    padding: 4px;
}

.lp-navbar.scrolled .lp-navbar__toggle {
    color: var(--color-text-heading);
}

/* Mobile Menu */
.lp-mobile-menu {
    display: none;
    position: fixed;
    top: var(--navbar-sticky-height);
    left: 0;
    right: 0;
    background: var(--color-bg-white);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.12);
    padding: 24px;
    z-index: 999;
    flex-direction: column;
    gap: 8px;
}

.lp-mobile-menu.active {
    display: flex;
}

.lp-mobile-menu__link {
    display: block;
    padding: 12px 16px;
    font-size: 16px;
    font-weight: 500;
    color: var(--color-text-heading);
    text-decoration: none;
    border-radius: 8px;
    transition: background var(--transition-fast);
}

.lp-mobile-menu__link:hover {
    background: var(--color-bg-alt);
}

.lp-mobile-menu__lang {
    display: flex;
    gap: 8px;
    padding: 12px 16px;
}

.lp-mobile-menu__lang a {
    font-size: 14px;
    font-weight: 500;
    color: var(--color-text-body);
    padding: 6px 12px;
    border: 1px solid var(--color-border);
    border-radius: 6px;
    text-decoration: none;
    transition: all var(--transition-fast);
}

.lp-mobile-menu__lang a:hover,
.lp-mobile-menu__lang a.active {
    color: var(--color-primary);
    border-color: var(--color-primary);
    background: rgba(30, 64, 175, 0.04);
}

.lp-mobile-menu__actions {
    display: flex;
    flex-direction: column;
    gap: 8px;
    padding: 12px 16px 0;
    border-top: 1px solid var(--color-border);
    margin-top: 8px;
}

.lp-mobile-menu__actions a {
    display: block;
    text-align: center;
    padding: 12px;
    border-radius: var(--btn-radius);
    font-weight: 600;
    font-size: 15px;
    text-decoration: none;
}

/* --------------------------------------------------------------------------
   Hero
   -------------------------------------------------------------------------- */
.lp-hero {
    background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-light) 100%);
    min-height: 600px;
    padding: 120px 0 80px;
    color: var(--color-text-white);
    overflow: hidden;
}

.lp-hero__inner {
    display: grid;
    grid-template-columns: 1fr 380px;
    gap: 48px;
    align-items: center;
}

.lp-hero__badge {
    display: inline-block;
    background: rgba(255, 255, 255, 0.15);
    color: var(--color-text-white);
    font-size: 12px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    padding: 6px 16px;
    border-radius: var(--badge-radius);
    margin-bottom: 24px;
}

.lp-hero__title {
    font-size: 48px;
    font-weight: 800;
    line-height: 1.15;
    color: var(--color-text-white);
    margin-bottom: 20px;
}

.lp-hero__subtitle {
    font-size: 18px;
    line-height: 1.6;
    color: rgba(255, 255, 255, 0.9);
    max-width: 540px;
    margin-bottom: 32px;
}

.lp-hero__ctas {
    display: flex;
    gap: 16px;
    margin-bottom: 12px;
}

.lp-hero__cta-group {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.lp-hero__cta-sub {
    font-size: 13px;
    color: rgba(255, 255, 255, 0.7);
    padding-left: 4px;
}

/* Hero CV Mockup Card */
.lp-hero__mockup {
    background: var(--color-bg-white);
    border-radius: var(--card-radius);
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);
    padding: 28px;
    max-width: 340px;
    transform: perspective(1000px) rotateY(-5deg);
    color: var(--color-text-heading);
}

.lp-hero__mockup-header {
    display: flex;
    align-items: center;
    gap: 14px;
    margin-bottom: 20px;
}

.lp-hero__mockup-avatar {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    background: var(--color-bg-alt);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-text-light);
    font-size: 20px;
    flex-shrink: 0;
}

.lp-hero__mockup-name {
    font-size: 16px;
    font-weight: 600;
    color: var(--color-text-heading);
    margin-bottom: 2px;
}

.lp-hero__mockup-title {
    font-size: 13px;
    color: var(--color-text-body);
}

.lp-hero__mockup-location {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 13px;
    color: var(--color-text-light);
    margin-bottom: 16px;
}

.lp-hero__mockup-modules {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin-bottom: 16px;
}

.lp-hero__mockup-tag {
    font-size: 11px;
    font-weight: 600;
    color: var(--color-primary);
    background: rgba(30, 64, 175, 0.08);
    padding: 4px 10px;
    border-radius: 4px;
}

.lp-hero__mockup-info {
    display: flex;
    flex-direction: column;
    gap: 10px;
    padding-top: 16px;
    border-top: 1px solid var(--color-border);
}

.lp-hero__mockup-row {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
    color: var(--color-text-body);
}

.lp-hero__mockup-row i {
    color: var(--color-text-light);
    font-size: 14px;
    width: 16px;
    text-align: center;
}

.lp-hero__mockup-progress {
    margin-top: 4px;
}

.lp-hero__mockup-progress-label {
    display: flex;
    justify-content: space-between;
    font-size: 12px;
    color: var(--color-text-light);
    margin-bottom: 6px;
}

.lp-hero__mockup-bar {
    height: 6px;
    background: var(--color-bg-alt);
    border-radius: 3px;
    overflow: hidden;
}

.lp-hero__mockup-bar-fill {
    height: 100%;
    background: var(--color-success);
    border-radius: 3px;
    width: 92%;
}

/* Hero Stats */
.lp-hero__stats {
    display: flex;
    gap: 32px;
    margin-top: 48px;
    padding-top: 32px;
    border-top: 1px solid rgba(255, 255, 255, 0.15);
    grid-column: 1 / -1;
}

.lp-hero__stat {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 14px;
    color: rgba(255, 255, 255, 0.85);
}

.lp-hero__stat i {
    font-size: 18px;
    opacity: 0.7;
}

.lp-hero__stat strong {
    font-weight: 700;
}

.lp-hero__stat-divider {
    width: 1px;
    height: 20px;
    background: rgba(255, 255, 255, 0.2);
}

.lp-section--alt .lp-hero__stat,
.lp-section--white .lp-hero__stat {
    color: var(--color-text-secondary);
}

.lp-section--alt .lp-hero__stat strong,
.lp-section--white .lp-hero__stat strong {
    color: var(--color-text-primary);
}

.lp-section--alt .lp-hero__stat-divider,
.lp-section--white .lp-hero__stat-divider {
    background: var(--color-border);
}

/* --------------------------------------------------------------------------
   Trust Band
   -------------------------------------------------------------------------- */
.lp-trust {
    background: var(--color-bg-white);
    padding: 32px 0;
    border-bottom: 1px solid var(--color-border);
}

.lp-trust__label {
    font-size: 13px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: var(--color-text-light);
    text-align: center;
    margin-bottom: 24px;
}

.lp-trust__logos {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 40px;
    flex-wrap: wrap;
}

.lp-trust__logo {
    max-height: 40px;
    width: auto;
    object-fit: contain;
    filter: grayscale(1) opacity(0.6);
    transition: filter var(--transition-fast);
}

.lp-trust__logo:hover {
    filter: grayscale(0) opacity(1);
}

/* --------------------------------------------------------------------------
   How It Works — Tabs
   -------------------------------------------------------------------------- */
.lp-how__tabs {
    display: flex;
    justify-content: center;
    gap: 4px;
    margin-bottom: 48px;
}

.lp-how__tab {
    padding: 12px 32px;
    font-size: 15px;
    font-weight: 600;
    color: var(--color-text-light);
    background: none;
    border: none;
    border-bottom: 3px solid transparent;
    cursor: pointer;
    transition: all var(--transition-fast);
    font-family: var(--font-family);
}

.lp-how__tab:hover {
    color: var(--color-text-heading);
}

.lp-how__tab.active {
    color: var(--color-primary);
    border-bottom-color: var(--color-primary);
}

.lp-how__panel {
    display: none;
}

.lp-how__panel.active {
    display: block;
}

.lp-how__steps {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--grid-gap);
}

/* --------------------------------------------------------------------------
   Cards
   -------------------------------------------------------------------------- */
.lp-card {
    background: var(--color-bg-white);
    border: 1px solid var(--color-border);
    border-radius: var(--card-radius);
    padding: var(--card-padding);
    transition: all var(--transition-fast);
}

.lp-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.08);
}

.lp-card__step-number {
    font-size: 48px;
    font-weight: 800;
    color: var(--color-primary);
    opacity: 0.15;
    line-height: 1;
    margin-bottom: 16px;
}

.lp-card__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 52px;
    height: 52px;
    border-radius: 12px;
    font-size: 24px;
    margin-bottom: 20px;
}

.lp-card__icon--primary {
    color: var(--color-primary);
    background: rgba(30, 64, 175, 0.08);
}

.lp-card__icon--accent {
    color: var(--color-accent);
    background: rgba(6, 182, 212, 0.08);
}

.lp-card__title {
    font-size: 20px;
    font-weight: 600;
    margin-bottom: 10px;
}

.lp-card__text {
    font-size: 15px;
    color: var(--color-text-body);
    line-height: 1.6;
}

.lp-card__link {
    display: inline-block;
    margin-top: 16px;
    font-size: 14px;
    font-weight: 500;
    color: var(--color-primary-light);
    text-decoration: none;
    transition: color var(--transition-fast);
}

.lp-card__link:hover {
    color: var(--color-primary);
    text-decoration: underline;
}

/* --------------------------------------------------------------------------
   Feature Grid (3 cols)
   -------------------------------------------------------------------------- */
.lp-features {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--grid-gap);
}

/* --------------------------------------------------------------------------
   Mini Features (4 cols)
   -------------------------------------------------------------------------- */
.lp-mini-features {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 16px;
    margin-top: 32px;
}

.lp-mini-feature {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 14px;
    color: var(--color-text-body);
}

.lp-mini-feature i {
    font-size: 18px;
    color: var(--color-primary);
}

/* --------------------------------------------------------------------------
   SAP Modules — Badge List
   -------------------------------------------------------------------------- */
.lp-modules__seo-text {
    font-size: 16px;
    color: var(--color-text-body);
    max-width: 700px;
    margin: 0 auto 32px;
    text-align: center;
    line-height: 1.6;
}

.lp-modules__badges {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 10px;
    margin-bottom: 24px;
}

.lp-modules__badge {
    display: inline-block;
    font-size: 13px;
    font-weight: 500;
    color: var(--color-primary);
    background: var(--color-bg-white);
    border: 1px solid var(--color-border);
    padding: 8px 16px;
    border-radius: var(--badge-radius);
    text-decoration: none;
    transition: all var(--transition-fast);
}

.lp-modules__badge:hover {
    background: var(--color-primary);
    color: var(--color-text-white);
    border-color: var(--color-primary);
}

.lp-modules__more {
    text-align: center;
    margin-top: 24px;
}

.lp-modules__more a {
    font-size: 14px;
    font-weight: 500;
    color: var(--color-primary-light);
    text-decoration: none;
    transition: color var(--transition-fast);
}

.lp-modules__more a:hover {
    color: var(--color-primary);
    text-decoration: underline;
}

/* --------------------------------------------------------------------------
   Job Cards
   -------------------------------------------------------------------------- */
.lp-jobs {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--grid-gap);
}

.lp-job-card {
    display: block;
    background: var(--color-bg-white);
    border: 1px solid var(--color-border);
    border-radius: var(--card-radius);
    padding: 24px;
    text-decoration: none;
    color: inherit;
    transition: all var(--transition-fast);
}

.lp-job-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.08);
}

.lp-job-card__header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 12px;
}

.lp-job-card__logo {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    object-fit: cover;
    flex-shrink: 0;
}

.lp-job-card__logo-fallback {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: var(--color-bg-alt);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-text-light);
    font-size: 18px;
    flex-shrink: 0;
}

.lp-job-card__work-model {
    font-size: 11px;
    font-weight: 600;
    padding: 4px 10px;
    border-radius: 4px;
    text-transform: uppercase;
    letter-spacing: 0.3px;
}

.lp-job-card__work-model--remote {
    color: #065f46;
    background: #d1fae5;
}

.lp-job-card__work-model--hybrid {
    color: #92400e;
    background: #fef3c7;
}

.lp-job-card__work-model--onsite {
    color: #1e40af;
    background: #dbeafe;
}

.lp-job-card__title {
    font-size: 18px;
    font-weight: 600;
    color: var(--color-text-heading);
    margin-bottom: 4px;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.lp-job-card__company {
    font-size: 14px;
    color: var(--color-text-body);
    margin-bottom: 4px;
}

.lp-job-card__location {
    display: flex;
    align-items: center;
    gap: 4px;
    font-size: 13px;
    color: var(--color-text-light);
    margin-bottom: 12px;
}

.lp-job-card__modules {
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
    margin-bottom: 12px;
}

.lp-job-card__module {
    font-size: 11px;
    background: var(--color-bg-alt);
    color: var(--color-text-body);
    padding: 3px 8px;
    border-radius: 4px;
}

.lp-job-card__date {
    font-size: 12px;
    color: var(--color-text-light);
}

.lp-jobs__empty {
    grid-column: 1 / -1;
    text-align: center;
    font-size: 16px;
    color: var(--color-text-light);
    padding: 48px 0;
}

.lp-jobs__more {
    text-align: center;
    margin-top: 32px;
}

/* --------------------------------------------------------------------------
   Numbers
   -------------------------------------------------------------------------- */
.lp-numbers {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--grid-gap);
    text-align: center;
}

.lp-number__value {
    font-size: 48px;
    font-weight: 800;
    color: var(--color-text-white);
    line-height: 1;
    margin-bottom: 8px;
}

.lp-number__label {
    font-size: 14px;
    color: var(--color-text-light);
    font-weight: 400;
}

/* --------------------------------------------------------------------------
   Why Section (6 advantages)
   -------------------------------------------------------------------------- */
.lp-why {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--grid-gap);
}

.lp-why .lp-card__icon {
    width: 48px;
    height: 48px;
    border-radius: 10px;
    font-size: 22px;
}

.lp-why .lp-card__title {
    font-size: 18px;
}

.lp-why .lp-card__text {
    font-size: 14px;
}

/* --------------------------------------------------------------------------
   FAQ
   -------------------------------------------------------------------------- */
.lp-faq {
    max-width: 760px;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.lp-faq__item {
    background: var(--color-bg-white);
    border: 1px solid var(--color-border);
    border-radius: 12px;
    overflow: hidden;
    transition: box-shadow var(--transition-fast);
}

.lp-faq__item[open] {
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.06);
}

.lp-faq__question {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 20px 24px;
    font-size: 16px;
    font-weight: 600;
    color: var(--color-text-heading);
    cursor: pointer;
    list-style: none;
    gap: 16px;
}

.lp-faq__question::-webkit-details-marker {
    display: none;
}

.lp-faq__chevron {
    font-size: 14px;
    color: var(--color-text-light);
    transition: transform var(--transition-fast);
    flex-shrink: 0;
}

.lp-faq__item[open] .lp-faq__chevron {
    transform: rotate(180deg);
}

.lp-faq__answer {
    padding: 0 24px 20px;
    font-size: 15px;
    color: var(--color-text-body);
    line-height: 1.7;
}

.lp-faq__answer p {
    margin: 0;
}

/* --------------------------------------------------------------------------
   CTA Section
   -------------------------------------------------------------------------- */
.lp-cta__title {
    font-size: 36px;
    font-weight: 700;
    text-align: center;
    margin-bottom: 16px;
    color: var(--color-text-white);
}

.lp-cta__subtitle {
    font-size: 18px;
    color: rgba(255, 255, 255, 0.9);
    text-align: center;
    max-width: 600px;
    margin: 0 auto 32px;
}

.lp-cta__buttons {
    display: flex;
    justify-content: center;
    gap: 16px;
}

/* --------------------------------------------------------------------------
   Footer
   -------------------------------------------------------------------------- */
.lp-footer {
    background: var(--color-bg-dark);
    color: var(--color-text-light);
    padding: 72px 0 0;
}

.lp-footer__grid {
    display: grid;
    grid-template-columns: 1.6fr 1fr 1fr 1.3fr;
    gap: 48px;
    padding-bottom: 56px;
    align-items: start;
}

/* Brand Column */
.lp-footer__brand-col {
    display: flex;
    flex-direction: column;
}

.lp-footer__brand-logo {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    font-size: 22px;
    font-weight: 800;
    color: var(--color-text-white);
    margin-bottom: 14px;
    text-decoration: none;
}

.lp-footer__brand-icon {
    width: 38px;
    height: 38px;
    background: linear-gradient(135deg, var(--color-primary-light), var(--color-primary));
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-text-white);
    font-size: 18px;
    flex-shrink: 0;
}

.lp-footer__brand-desc {
    font-size: 14px;
    color: var(--color-text-light);
    line-height: 1.7;
    max-width: 260px;
    margin-bottom: 20px;
}

/* Trust Indicators (in brand column) */
.lp-footer__trust {
    display: flex;
    flex-direction: column;
    gap: 8px;
    padding: 16px 0;
    border-top: 1px solid rgba(255, 255, 255, 0.07);
    border-bottom: 1px solid rgba(255, 255, 255, 0.07);
    margin-bottom: 20px;
}

.lp-footer__trust-item {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 13px;
    color: var(--color-text-light);
}

.lp-footer__trust-icon--green {
    color: #34d399;
    font-size: 15px;
    flex-shrink: 0;
}

.lp-footer__trust-icon--blue {
    color: #60a5fa;
    font-size: 15px;
    flex-shrink: 0;
}

.lp-footer__trust-icon--purple {
    color: #a78bfa;
    font-size: 15px;
    flex-shrink: 0;
}

/* Social Media */
.lp-footer__social {
    display: flex;
    gap: 10px;
}

.lp-footer__social a {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    border-radius: 8px;
    color: var(--color-text-light);
    background: rgba(255, 255, 255, 0.06);
    font-size: 16px;
    text-decoration: none;
    transition: all var(--transition-fast);
}

.lp-footer__social a:hover {
    color: var(--color-text-white);
    background: rgba(255, 255, 255, 0.14);
    transform: translateY(-2px);
}

/* Column Headings */
.lp-footer__heading {
    font-size: 13px;
    font-weight: 700;
    color: var(--color-text-white);
    text-transform: uppercase;
    letter-spacing: 0.08em;
    margin-bottom: 20px;
}

/* Link Lists */
.lp-footer__links {
    list-style: none;
}

.lp-footer__links li {
    margin-bottom: 0;
}

.lp-footer__links a {
    display: block;
    font-size: 14px;
    color: var(--color-text-light);
    text-decoration: none;
    padding: 5px 0;
    transition: color var(--transition-fast);
}

.lp-footer__links a:hover {
    color: var(--color-text-white);
}

/* Contact Column */
.lp-footer__contact-company {
    font-size: 14px;
    font-weight: 600;
    color: var(--color-text-white);
    margin-bottom: 16px;
}

.lp-footer__contact-list {
    display: flex;
    flex-direction: column;
    gap: 10px;
    margin-bottom: 16px;
}

.lp-footer__contact-item {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    font-size: 13px;
    color: var(--color-text-light);
    line-height: 1.6;
}

.lp-footer__contact-icon {
    color: #60a5fa;
    font-size: 14px;
    margin-top: 2px;
    flex-shrink: 0;
}

.lp-footer__contact-link {
    text-decoration: none;
    transition: color var(--transition-fast);
}

.lp-footer__contact-link:hover {
    color: var(--color-text-white);
}

.lp-footer__corporate {
    margin-top: 16px;
    padding-top: 12px;
    border-top: 1px solid rgba(255, 255, 255, 0.07);
    font-size: 12px;
    color: #475569;
    line-height: 1.8;
}

/* Bottom Bar */
.lp-footer__bottom {
    border-top: 1px solid rgba(255, 255, 255, 0.08);
    padding: 20px 0;
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 12px;
}

.lp-footer__copyright {
    font-size: 13px;
    color: #475569;
}

.lp-footer__bottom-links {
    display: flex;
    gap: 20px;
    flex-wrap: wrap;
}

.lp-footer__bottom-links a {
    font-size: 13px;
    color: #475569;
    text-decoration: none;
    transition: color var(--transition-fast);
}

.lp-footer__bottom-links a:hover {
    color: var(--color-text-light);
}

/* --------------------------------------------------------------------------
   Fade-in Animation
   -------------------------------------------------------------------------- */
.lp-fade-in {
    opacity: 0;
    transform: translateY(20px);
    transition: opacity 0.4s ease, transform 0.4s ease;
}

.lp-fade-in.visible {
    opacity: 1;
    transform: translateY(0);
}

/* ==========================================================================
   DIRECTORY PAGES
   ========================================================================== */

/* --------------------------------------------------------------------------
   Directory — Module Grid (Hub)
   -------------------------------------------------------------------------- */
.lp-dir-module-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 20px;
}

.lp-dir-module-card {
    display: flex;
    align-items: center;
    gap: 16px;
    background: var(--color-bg-white);
    border: 1px solid var(--color-border);
    border-radius: var(--card-radius);
    padding: 20px 24px;
    text-decoration: none;
    color: inherit;
    transition: all var(--transition-fast);
}

.lp-dir-module-card:hover {
    border-color: var(--color-primary-light);
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(0, 0, 0, 0.07);
}

.lp-dir-module-card__code {
    font-size: 14px;
    font-weight: 700;
    color: var(--color-primary);
    background: rgba(30, 64, 175, 0.08);
    padding: 8px 14px;
    border-radius: 8px;
    white-space: nowrap;
    flex-shrink: 0;
}

.lp-dir-module-card__info {
    flex: 1;
    min-width: 0;
}

.lp-dir-module-card__name {
    font-size: 15px;
    font-weight: 600;
    color: var(--color-text-heading);
    margin-bottom: 2px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.lp-dir-module-card__count {
    font-size: 13px;
    color: var(--color-text-light);
}

.lp-dir-module-card__arrow {
    color: var(--color-text-light);
    font-size: 16px;
    flex-shrink: 0;
    transition: transform var(--transition-fast);
}

.lp-dir-module-card:hover .lp-dir-module-card__arrow {
    transform: translateX(4px);
    color: var(--color-primary);
}

/* --------------------------------------------------------------------------
   Directory — Filter Bar
   -------------------------------------------------------------------------- */
.lp-dir-filter-bar {
    background: var(--color-bg-white);
    padding: 16px 0;
    border-bottom: 1px solid var(--color-border);
    position: sticky;
    top: 72px;
    z-index: 50;
}

.lp-dir-filter-bar__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    flex-wrap: nowrap;
    overflow-x: auto;
    scrollbar-width: thin;
}

.lp-dir-filter-bar__filters {
    display: flex;
    gap: 10px;
    align-items: center;
    flex-shrink: 0;
}

.lp-dir-filter-bar__right {
    display: flex;
    gap: 12px;
    align-items: center;
    flex-shrink: 0;
    margin-left: auto;
}

.lp-dir-filter-select {
    font-family: var(--font-family);
    font-size: 14px;
    font-weight: 500;
    color: var(--color-text-heading);
    background: var(--color-bg-white);
    border: 1px solid var(--color-border);
    border-radius: var(--btn-radius);
    padding: 8px 32px 8px 14px;
    cursor: pointer;
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%2394a3b8' viewBox='0 0 16 16'%3E%3Cpath d='M7.247 11.14 2.451 5.658C1.885 5.013 2.345 4 3.204 4h9.592a1 1 0 0 1 .753 1.659l-4.796 5.48a1 1 0 0 1-1.506 0z'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 12px center;
    transition: border-color var(--transition-fast);
}

.lp-dir-filter-select:hover,
.lp-dir-filter-select:focus {
    border-color: var(--color-primary-light);
    outline: none;
}

.lp-dir-filter-bar__count {
    font-size: 14px;
    color: var(--color-text-light);
    white-space: nowrap;
}

/* --------------------------------------------------------------------------
   Directory — Consultant Grid & Cards
   -------------------------------------------------------------------------- */
.lp-dir-consultant-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    gap: var(--grid-gap);
}

.lp-dir-consultant-card {
    position: relative;
    background: var(--color-bg-white);
    border: 1px solid var(--color-border);
    border-radius: var(--card-radius);
    padding: 24px;
    display: flex;
    flex-direction: column;
    transition: all var(--transition-fast);
}

.lp-dir-consultant-card:hover {
    border-color: var(--color-primary-light);
    transform: translateY(-2px);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.08);
}

.lp-dir-consultant-card--locked {
    cursor: pointer;
}

/* Avatar */
.lp-dir-avatar {
    width: 48px;
    height: 48px;
    border-radius: 14px;
    flex-shrink: 0;
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 16px;
    font-weight: 700;
    color: var(--color-text-white);
}

.lp-dir-avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.lp-dir-avatar--blur {
    filter: blur(2px);
    opacity: 0.7;
}

/* Card Header */
.lp-dir-card-header {
    display: flex;
    align-items: center;
    gap: 14px;
    margin-bottom: 14px;
}

.lp-dir-card-name {
    font-size: 16px;
    font-weight: 700;
    color: var(--color-text-heading);
    line-height: 1.3;
}

.lp-dir-card-title {
    font-size: 13px;
    color: var(--color-text-light);
    margin-top: 2px;
}

/* Module Tags */
.lp-dir-modules-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 5px;
    margin-bottom: 12px;
}

.lp-dir-module-tag {
    font-size: 11px;
    font-weight: 600;
    color: var(--color-primary);
    background: rgba(30, 64, 175, 0.07);
    padding: 3px 8px;
    border-radius: 5px;
}

.lp-dir-module-tag--more {
    color: var(--color-text-light);
    background: var(--color-bg-alt);
}

/* Stats Row */
.lp-dir-stats {
    display: flex;
    flex-wrap: wrap;
    gap: 14px;
    margin-bottom: 12px;
    font-size: 13px;
    color: var(--color-text-body);
}

.lp-dir-stats span {
    display: flex;
    align-items: center;
    gap: 5px;
}

.lp-dir-stats i {
    font-size: 13px;
    color: var(--color-text-light);
}

/* Bio */
.lp-dir-bio {
    font-size: 13px;
    color: var(--color-text-body);
    line-height: 1.6;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    margin-bottom: 14px;
    flex: 1;
}

/* Card Footer */
.lp-dir-card-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding-top: 14px;
    border-top: 1px solid var(--color-border);
    margin-top: auto;
}

.lp-dir-badge-open {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    font-size: 12px;
    font-weight: 600;
    color: #065f46;
    background: #d1fae5;
    padding: 4px 10px;
    border-radius: 5px;
}

.lp-dir-badge-locked {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    font-size: 12px;
    font-weight: 600;
    color: #92400e;
    background: #fef3c7;
    padding: 4px 10px;
    border-radius: 5px;
}

.lp-dir-card-action {
    font-size: 13px;
    font-weight: 600;
    text-decoration: none;
    transition: color var(--transition-fast);
}

.lp-dir-card-action--view {
    color: var(--color-primary-light);
}

.lp-dir-card-action--view:hover {
    color: var(--color-primary);
}

.lp-dir-card-action--unlock {
    color: #d97706;
    background: none;
    border: none;
    cursor: pointer;
    font-family: var(--font-family);
    padding: 0;
}

.lp-dir-card-action--unlock:hover {
    color: #b45309;
}

/* Lock Overlay */
.lp-dir-lock-overlay {
    position: absolute;
    top: 12px;
    right: 12px;
    width: 28px;
    height: 28px;
    background: #fef3c7;
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #d97706;
    font-size: 13px;
}

/* --------------------------------------------------------------------------
   Directory — Pagination
   -------------------------------------------------------------------------- */
.lp-dir-pagination {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 6px;
    margin-top: 40px;
    flex-wrap: wrap;
}

.lp-dir-pagination a,
.lp-dir-pagination span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 40px;
    height: 40px;
    padding: 0 12px;
    font-size: 14px;
    font-weight: 500;
    border-radius: var(--btn-radius);
    border: 1px solid var(--color-border);
    background: var(--color-bg-white);
    color: var(--color-text-body);
    text-decoration: none;
    transition: all var(--transition-fast);
}

.lp-dir-pagination a:hover {
    border-color: var(--color-primary-light);
    color: var(--color-primary);
}

.lp-dir-pagination .active {
    background: var(--color-primary);
    color: var(--color-text-white);
    border-color: var(--color-primary);
}

.lp-dir-pagination .disabled {
    opacity: 0.4;
    pointer-events: none;
}

.lp-dir-pagination .ellipsis {
    border: none;
    background: none;
    color: var(--color-text-light);
    min-width: 24px;
    padding: 0;
}

/* --------------------------------------------------------------------------
   Directory — SEO Content
   -------------------------------------------------------------------------- */
.lp-dir-seo-content {
    border-top: 1px solid var(--color-border);
}

.lp-dir-seo-intro {
    background: #f0f7ff;
    border-left: 4px solid var(--color-primary);
    padding: 20px 24px;
    border-radius: 0 8px 8px 0;
    font-size: 15px;
    color: var(--color-text-body);
    line-height: 1.7;
    margin-bottom: 40px;
}

.lp-dir-seo-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 32px;
}

.lp-dir-seo-grid > *:last-child:nth-child(odd) {
    grid-column: 1 / -1;
}

.lp-dir-seo-section h2 {
    font-size: 20px;
    font-weight: 600;
    margin-bottom: 10px;
}

.lp-dir-seo-section p {
    font-size: 15px;
    color: var(--color-text-body);
    line-height: 1.7;
}

/* --------------------------------------------------------------------------
   Directory — Related Modules
   -------------------------------------------------------------------------- */
.lp-dir-related-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
    gap: 16px;
}

.lp-dir-related-card {
    display: block;
    background: var(--color-bg-white);
    border: 1px solid var(--color-border);
    border-radius: 12px;
    padding: 16px 20px;
    text-decoration: none;
    transition: all var(--transition-fast);
}

.lp-dir-related-card:hover {
    border-color: var(--color-primary-light);
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.06);
}

.lp-dir-related-card__code {
    font-size: 14px;
    font-weight: 700;
    color: var(--color-primary);
    margin-bottom: 4px;
}

.lp-dir-related-card__name {
    font-size: 13px;
    color: var(--color-text-body);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    margin-bottom: 4px;
}

.lp-dir-related-card__count {
    font-size: 12px;
    color: var(--color-text-light);
}

/* --------------------------------------------------------------------------
   Directory — Gate Modal
   -------------------------------------------------------------------------- */
.lp-dir-gate-overlay {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.55);
    backdrop-filter: blur(4px);
    z-index: 2000;
    justify-content: center;
    align-items: center;
}

.lp-dir-gate-overlay.active {
    display: flex;
}

.lp-dir-gate-modal {
    background: var(--color-bg-white);
    border-radius: 20px;
    padding: 40px 32px;
    max-width: 420px;
    width: 90%;
    text-align: center;
    position: relative;
    animation: gateModalIn 0.2s ease;
}

@keyframes gateModalIn {
    from { opacity: 0; transform: scale(0.95); }
    to   { opacity: 1; transform: scale(1); }
}

.lp-dir-gate-close {
    position: absolute;
    top: 16px;
    right: 16px;
    background: none;
    border: none;
    font-size: 18px;
    color: var(--color-text-light);
    cursor: pointer;
    padding: 4px;
    transition: color var(--transition-fast);
}

.lp-dir-gate-close:hover {
    color: var(--color-text-heading);
}

.lp-dir-gate-icon {
    width: 56px;
    height: 56px;
    background: rgba(30, 64, 175, 0.08);
    border-radius: 14px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 24px;
    color: var(--color-primary);
    margin-bottom: 20px;
}

.lp-dir-gate-title {
    font-size: 20px;
    font-weight: 700;
    margin-bottom: 10px;
}

.lp-dir-gate-desc {
    font-size: 15px;
    color: var(--color-text-body);
    line-height: 1.6;
    margin-bottom: 24px;
}

.lp-dir-gate-cta {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 48px;
    background: linear-gradient(135deg, var(--color-primary), var(--color-primary-light));
    color: var(--color-text-white);
    font-size: 15px;
    font-weight: 600;
    border: none;
    border-radius: var(--btn-radius);
    text-decoration: none;
    margin-bottom: 12px;
    transition: opacity var(--transition-fast);
}

.lp-dir-gate-cta:hover {
    opacity: 0.9;
}

.lp-dir-gate-login {
    font-size: 14px;
    color: var(--color-primary-light);
    text-decoration: none;
    font-weight: 500;
}

.lp-dir-gate-login:hover {
    text-decoration: underline;
}

.lp-dir-gate-trust {
    font-size: 12px;
    color: var(--color-text-light);
    margin-top: 16px;
}

/* --------------------------------------------------------------------------
   Directory — Breadcrumb
   -------------------------------------------------------------------------- */
.lp-dir-breadcrumb {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
    color: rgba(255, 255, 255, 0.7);
    margin-bottom: 16px;
    flex-wrap: wrap;
}

.lp-dir-breadcrumb a {
    color: rgba(255, 255, 255, 0.7);
    text-decoration: none;
    transition: color var(--transition-fast);
}

.lp-dir-breadcrumb a:hover {
    color: var(--color-text-white);
}

.lp-dir-breadcrumb__sep {
    font-size: 10px;
    opacity: 0.5;
}

.lp-dir-breadcrumb__current {
    color: var(--color-text-white);
    font-weight: 500;
}

/* --------------------------------------------------------------------------
   Directory — Empty State
   -------------------------------------------------------------------------- */
.lp-dir-empty {
    text-align: center;
    padding: 64px 24px;
    color: var(--color-text-light);
}

.lp-dir-empty i {
    font-size: 48px;
    opacity: 0.3;
    margin-bottom: 16px;
    display: block;
}

.lp-dir-empty p {
    font-size: 16px;
}

/* ==========================================================================
   JOB LISTING PAGES
   ========================================================================== */

/* --------------------------------------------------------------------------
   Job — Search Box (Hero)
   -------------------------------------------------------------------------- */
.lp-job-search {
    max-width: 560px;
    margin: 24px auto 0;
    display: flex;
    gap: 0;
    border-radius: var(--btn-radius);
    overflow: hidden;
    background: rgba(255, 255, 255, 0.12);
    border: 1px solid rgba(255, 255, 255, 0.25);
    transition: border-color var(--transition-fast), background var(--transition-fast);
}

.lp-job-search:focus-within {
    border-color: rgba(255, 255, 255, 0.7);
    background: rgba(255, 255, 255, 0.18);
}

.lp-job-search__input {
    flex: 1;
    background: none;
    border: none;
    padding: 12px 16px 12px 44px;
    font-family: var(--font-family);
    font-size: 15px;
    color: var(--color-text-white);
    outline: none;
}

.lp-job-search__input::placeholder {
    color: rgba(255, 255, 255, 0.5);
}

.lp-job-search__icon {
    position: absolute;
    left: 16px;
    top: 50%;
    transform: translateY(-50%);
    color: rgba(255, 255, 255, 0.5);
    font-size: 16px;
    pointer-events: none;
}

.lp-job-search__wrapper {
    position: relative;
    flex: 1;
}

.lp-job-search__btn {
    background: rgba(255, 255, 255, 0.15);
    border: none;
    border-left: 1px solid rgba(255, 255, 255, 0.15);
    color: var(--color-text-white);
    padding: 0 20px;
    font-family: var(--font-family);
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    transition: background var(--transition-fast);
    white-space: nowrap;
}

.lp-job-search__btn:hover {
    background: rgba(255, 255, 255, 0.25);
}

/* --------------------------------------------------------------------------
   Job — Module Filter Bar
   -------------------------------------------------------------------------- */
.lp-job-filter-modules {
    display: flex;
    gap: 8px;
    overflow-x: auto;
    padding-bottom: 4px;
    scrollbar-width: thin;
    -webkit-overflow-scrolling: touch;
}

.lp-job-filter-modules::-webkit-scrollbar {
    height: 4px;
}

.lp-job-filter-modules::-webkit-scrollbar-thumb {
    background: var(--color-border);
    border-radius: 2px;
}

.lp-job-module-btn {
    display: inline-flex;
    align-items: center;
    padding: 7px 16px;
    font-family: var(--font-family);
    font-size: 13px;
    font-weight: 500;
    color: var(--color-text-body);
    background: var(--color-bg-white);
    border: 1px solid var(--color-border);
    border-radius: 6px;
    text-decoration: none;
    white-space: nowrap;
    cursor: pointer;
    transition: all var(--transition-fast);
}

.lp-job-module-btn:hover {
    border-color: var(--color-primary-light);
    color: var(--color-primary);
}

.lp-job-module-btn.active {
    background: var(--color-primary);
    color: var(--color-text-white);
    border-color: var(--color-primary);
}

/* --------------------------------------------------------------------------
   Job — Listing Grid
   -------------------------------------------------------------------------- */
.lp-job-listing-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(340px, 1fr));
    gap: var(--grid-gap);
}

.lp-job-listing-card {
    display: flex;
    flex-direction: column;
    background: var(--color-bg-white);
    border: 1px solid var(--color-border);
    border-radius: var(--card-radius);
    padding: 24px;
    text-decoration: none;
    color: inherit;
    transition: all var(--transition-fast);
}

.lp-job-listing-card:hover {
    border-color: var(--color-primary-light);
    transform: translateY(-2px);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.08);
}

.lp-job-listing-card__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 12px;
}

.lp-job-listing-card__company {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 14px;
    color: var(--color-text-body);
}

.lp-job-listing-card__logo {
    width: 36px;
    height: 36px;
    border-radius: 8px;
    object-fit: cover;
    flex-shrink: 0;
}

.lp-job-listing-card__logo-fallback {
    width: 36px;
    height: 36px;
    border-radius: 8px;
    background: var(--color-bg-alt);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-text-light);
    font-size: 16px;
    flex-shrink: 0;
}

.lp-job-listing-card__title {
    font-size: 18px;
    font-weight: 600;
    color: var(--color-text-heading);
    margin-bottom: 10px;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.lp-job-listing-card__meta {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    font-size: 13px;
    color: var(--color-text-body);
    margin-bottom: 10px;
}

.lp-job-listing-card__meta span {
    display: flex;
    align-items: center;
    gap: 4px;
}

.lp-job-listing-card__meta i {
    font-size: 13px;
    color: var(--color-text-light);
}

.lp-job-listing-card__rate {
    font-size: 15px;
    font-weight: 600;
    color: var(--color-primary);
    margin-bottom: 10px;
}

.lp-job-listing-card__desc {
    font-size: 13px;
    color: var(--color-text-body);
    line-height: 1.6;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    margin-bottom: 14px;
    flex: 1;
}

.lp-job-listing-card__footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding-top: 14px;
    border-top: 1px solid var(--color-border);
    margin-top: auto;
    font-size: 13px;
}

.lp-job-listing-card__date {
    color: var(--color-text-light);
}

.lp-job-listing-card__link {
    color: var(--color-primary-light);
    font-weight: 600;
    text-decoration: none;
}

/* --------------------------------------------------------------------------
   Job — Detail Page
   -------------------------------------------------------------------------- */

/* Hero — softened gradient on job detail (corporate recruitment feel) */
.lp-hero--job-detail {
    position: relative;
    background: linear-gradient(135deg,
        color-mix(in srgb, var(--color-primary) 85%, #0f172a) 0%,
        color-mix(in srgb, var(--color-primary-light) 85%, #0f172a) 100%);
}
.lp-hero--job-detail::before {
    content: '';
    position: absolute;
    inset: 0;
    background: rgba(15, 23, 42, 0.08);
    pointer-events: none;
}
.lp-hero--job-detail > .lp-container {
    position: relative;
    z-index: 1;
}

/* Breadcrumb — more visible on dark hero */
.lp-hero--job-detail .lp-dir-breadcrumb {
    font-size: 13px;
    gap: 10px;
    color: rgba(255, 255, 255, 0.88);
}
.lp-hero--job-detail .lp-dir-breadcrumb a {
    color: rgba(255, 255, 255, 0.88);
    font-weight: 500;
}
.lp-hero--job-detail .lp-dir-breadcrumb a:hover {
    color: #fff;
    text-decoration: underline;
}
.lp-hero--job-detail .lp-dir-breadcrumb__sep { opacity: 0.7; }
.lp-hero--job-detail .lp-dir-breadcrumb__current {
    color: #fff;
    font-weight: 600;
}

/* Hero — positions badge (premium look) */
.lp-job-hero-position-badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 12px;
    font-weight: 600;
    color: #fff;
    background: rgba(255, 255, 255, 0.18);
    padding: 5px 12px;
    border-radius: 6px;
    line-height: 1.4;
}
.lp-job-hero-position-badge i { font-size: 12px; }
.lp-job-hero-position-badge strong { font-weight: 700; }

.lp-job-hero-grid {
    display: grid;
    grid-template-columns: 1fr 300px;
    gap: 24px;
    align-items: center;
}

.lp-job-hero-card {
    flex-shrink: 0;
}

.lp-job-quick-info {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    gap: 16px;
    padding: 24px 0;
}

.lp-job-quick-card {
    background: var(--color-bg-white);
    border: 1px solid var(--color-border);
    border-radius: 12px;
    padding: 16px;
    text-align: center;
}

.lp-job-quick-card__label {
    font-size: 12px;
    color: var(--color-text-light);
    margin-bottom: 4px;
}

.lp-job-quick-card__value {
    font-size: 15px;
    font-weight: 600;
    color: var(--color-text-heading);
}

.lp-job-detail-layout {
    display: grid;
    grid-template-columns: 1fr 380px;
    gap: 32px;
    align-items: start;
}

.lp-job-detail-main {
    min-width: 0;
}

.lp-job-detail-sidebar {
    position: sticky;
    top: 88px;
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.lp-job-section {
    margin-bottom: 32px;
}

.lp-job-section h2 {
    font-size: 20px;
    font-weight: 600;
    margin-bottom: 16px;
}

.lp-job-section ul {
    list-style: none;
    padding: 0;
}

.lp-job-section ul li {
    position: relative;
    padding-left: 24px;
    margin-bottom: 10px;
    font-size: 15px;
    color: var(--color-text-body);
    line-height: 1.6;
}

.lp-job-section ul li::before {
    content: '\2713';
    position: absolute;
    left: 0;
    color: var(--color-success);
    font-weight: 700;
}

.lp-job-section .rich-content {
    font-size: 15px;
    color: var(--color-text-body);
    line-height: 1.7;
}

.lp-job-section .rich-content p {
    margin-bottom: 12px;
}

.lp-job-section .rich-content li {
    margin-bottom: 6px;
}

.lp-job-skills {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.lp-job-skill-tag {
    font-size: 13px;
    font-weight: 500;
    color: var(--color-primary);
    background: rgba(30, 64, 175, 0.05);
    padding: 8px 16px;
    border-radius: 8px;
    border: 1px solid rgba(30, 64, 175, 0.10);
    line-height: 1.3;
}

/* Skills collapse — desktop max 12, mobile max 8 */
.lp-job-skills--collapsed .lp-job-skill-tag:nth-child(n+13) { display: none; }
.lp-job-skills--expanded  .lp-job-skill-tag { display: inline-flex; }

.lp-job-skills-toggle {
    margin-top: 12px;
    background: transparent;
    border: 1px solid var(--color-border);
    color: var(--color-primary);
    font-size: 13px;
    font-weight: 600;
    padding: 8px 16px;
    border-radius: 8px;
    cursor: pointer;
    transition: background var(--transition-fast), border-color var(--transition-fast);
}
.lp-job-skills-toggle:hover {
    background: rgba(30, 64, 175, 0.06);
    border-color: var(--color-primary-light);
}
.lp-job-skills-toggle:focus-visible {
    outline: 2px solid var(--color-primary-light);
    outline-offset: 2px;
}

/* Apply card — mini metadata badges */
.lp-job-apply-badges {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin-top: 14px;
    padding-top: 14px;
    border-top: 1px solid var(--color-border);
}
.lp-job-apply-badge {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    font-size: 11.5px;
    font-weight: 500;
    color: var(--color-text-body);
    background: var(--color-bg-alt);
    padding: 5px 10px;
    border-radius: 6px;
    line-height: 1.3;
}
.lp-job-apply-badge i {
    font-size: 11px;
    color: var(--color-text-light);
}

/* On-dark variant inside hero apply card */
.lp-job-apply-badges--on-dark {
    border-top-color: rgba(255, 255, 255, 0.15);
}
.lp-job-apply-badges--on-dark .lp-job-apply-badge {
    color: rgba(255, 255, 255, 0.92);
    background: rgba(255, 255, 255, 0.12);
}
.lp-job-apply-badges--on-dark .lp-job-apply-badge i {
    color: rgba(255, 255, 255, 0.7);
}

/* Urgent badge (listing kart üstünde) */
.lp-job-card__urgent-badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 3px 8px;
    background: #f59e0b;
    color: #fff;
    font-size: 11px;
    font-weight: 800;
    letter-spacing: 0.04em;
    border-radius: 6px;
    text-transform: uppercase;
}
.lp-job-card__urgent-badge i { font-size: 11px; }

/* Benefits + Sectors — skill-tag pattern + icon prefix */
.lp-job-benefits,
.lp-job-sectors {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}
.lp-job-benefit-tag,
.lp-job-sector-tag {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 13px;
    font-weight: 500;
    color: var(--color-text-primary, #0f172a);
    background: var(--color-bg-light, #f8fafc);
    padding: 6px 12px;
    border-radius: 6px;
    border: 1px solid var(--color-border, #e2e8f0);
}
.lp-job-benefit-tag i,
.lp-job-sector-tag i {
    color: var(--color-primary);
    font-size: 14px;
}

/* Sidebar Cards */
.lp-job-sidebar-card {
    background: var(--color-bg-white);
    border: 1px solid var(--color-border);
    border-radius: var(--card-radius);
    padding: 24px;
}

.lp-job-sidebar-card__title {
    font-size: 16px;
    font-weight: 600;
    margin-bottom: 8px;
}

.lp-job-sidebar-card__desc {
    font-size: 14px;
    color: var(--color-text-body);
    margin-bottom: 16px;
    line-height: 1.5;
}

.lp-job-sidebar-card .lp-btn {
    width: 100%;
    margin-bottom: 8px;
}

.lp-job-sidebar-card .lp-btn:last-child {
    margin-bottom: 0;
}

.lp-job-trust-signals {
    display: flex;
    flex-direction: column;
    gap: 8px;
    margin-top: 16px;
    padding-top: 16px;
    border-top: 1px solid var(--color-border);
}

.lp-job-trust-signal {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
    color: var(--color-text-body);
}

.lp-job-trust-signal i {
    font-size: 14px;
    color: var(--color-success);
}

.lp-job-key-detail {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    padding: 10px 0;
    border-bottom: 1px solid var(--color-bg-alt);
    font-size: 14px;
}

.lp-job-key-detail:last-child {
    border-bottom: none;
}

.lp-job-key-detail i {
    color: var(--color-text-light);
    font-size: 15px;
    margin-top: 2px;
    flex-shrink: 0;
}

.lp-job-key-detail__label {
    color: var(--color-text-light);
    min-width: 90px;
}

.lp-job-key-detail__value {
    color: var(--color-text-heading);
    font-weight: 500;
}

/* Expired Banner */
.lp-job-expired-banner {
    background: #fef3c7;
    border: 1px solid #fde68a;
    border-radius: 10px;
    padding: 14px 18px;
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 14px;
    color: #92400e;
    margin-bottom: 20px;
}

.lp-job-expired-banner i {
    font-size: 18px;
    flex-shrink: 0;
}

/* Expired Card — corporate notice on detail pages */
.lp-job-expired-card {
    display: flex;
    gap: 18px;
    align-items: flex-start;
    background: rgba(255,255,255,0.10);
    border: 1px solid rgba(255,255,255,0.22);
    backdrop-filter: blur(10px);
    border-radius: 14px;
    padding: 22px 24px;
    margin: 14px 0 24px;
    color: #fff;
}
.lp-job-expired-card__icon {
    flex-shrink: 0;
    width: 48px;
    height: 48px;
    border-radius: 12px;
    background: rgba(254,243,199,0.18);
    color: #fef3c7;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 22px;
}
.lp-job-expired-card__body { flex: 1; min-width: 0; }
.lp-job-expired-card__title {
    font-size: 18px;
    font-weight: 700;
    margin: 0 0 6px;
    color: #fff;
    line-height: 1.3;
}
.lp-job-expired-card__desc {
    font-size: 14px;
    line-height: 1.55;
    color: rgba(255,255,255,0.82);
    margin: 0 0 14px;
}
.lp-job-expired-card__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}
.lp-job-expired-card__actions .lp-btn {
    height: 40px;
    padding: 0 18px;
    font-size: 13px;
}
@media (max-width: 640px) {
    .lp-job-expired-card { padding: 18px; gap: 14px; }
    .lp-job-expired-card__icon { width: 40px; height: 40px; font-size: 18px; }
    .lp-job-expired-card__title { font-size: 16px; }
    .lp-job-expired-card__actions { flex-direction: column; }
    .lp-job-expired-card__actions .lp-btn { width: 100%; }
}

/* Apply card / sidebar — expired pill & block */
.lp-job-hero-card__expired-pill {
    background: rgba(254,243,199,0.18);
    color: #fef3c7;
    border-radius: 8px;
    padding: 10px 14px;
    font-size: 13px;
    font-weight: 600;
    display: flex;
    align-items: center;
    gap: 8px;
}
.lp-job-sidebar-card__expired {
    background: #fef3c7;
    border: 1px solid #fde68a;
    border-radius: 8px;
    padding: 12px 14px;
    font-size: 13px;
    font-weight: 600;
    color: #92400e;
    display: flex;
    align-items: center;
    gap: 8px;
}

/* Solution: expired notice variants */
.lp-sol-hero-card__notice--expired {
    background: rgba(254,243,199,0.18);
    color: #fef3c7;
}
.lp-sol-price-card__expired {
    background: #fef3c7;
    border: 1px solid #fde68a;
    border-radius: 8px;
    padding: 12px 14px;
    font-size: 13px;
    font-weight: 600;
    color: #92400e;
    display: flex;
    align-items: center;
    gap: 8px;
}

/* Match CTA */
.lp-job-cta-match {
    background: linear-gradient(135deg, #eff6ff, #dbeafe);
    border-radius: var(--card-radius);
    padding: 28px;
    text-align: center;
    margin: 32px 0;
}

.lp-job-cta-match__title {
    font-size: 18px;
    font-weight: 600;
    margin-bottom: 8px;
}

.lp-job-cta-match__desc {
    font-size: 14px;
    color: var(--color-text-body);
    margin-bottom: 16px;
}

/* Related Jobs */
.lp-job-related-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--grid-gap);
}

.lp-job-related-card {
    display: block;
    background: var(--color-bg-white);
    border: 1px solid var(--color-border);
    border-radius: var(--card-radius);
    padding: 20px;
    text-decoration: none;
    color: inherit;
    transition: all var(--transition-fast);
}

.lp-job-related-card:hover {
    border-color: var(--color-primary-light);
    transform: translateY(-2px);
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.06);
}

.lp-job-related-card__modules {
    margin-bottom: 8px;
}

.lp-job-related-card__title {
    font-size: 16px;
    font-weight: 600;
    color: var(--color-text-heading);
    margin-bottom: 8px;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.lp-job-related-card__meta {
    font-size: 13px;
    color: var(--color-text-light);
    margin-bottom: 10px;
}

.lp-job-related-card__footer {
    display: flex;
    justify-content: space-between;
    font-size: 12px;
    color: var(--color-text-light);
}

.lp-job-related-card__link {
    color: var(--color-primary-light);
    font-weight: 600;
    font-size: 13px;
}

/* Mobile Sticky Apply Bar */
.lp-job-mobile-bar {
    display: none;
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    background: var(--color-bg-white);
    box-shadow: 0 -4px 12px rgba(0, 0, 0, 0.1);
    padding: 12px 16px;
    z-index: 100;
    gap: 10px;
}

/* ==========================================================================
   SOLUTIONS MARKETPLACE PAGES
   ========================================================================== */

/* --- Solution Listing Grid --- */
.lp-sol-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
    gap: var(--grid-gap);
}

.lp-sol-card {
    display: flex;
    flex-direction: column;
    background: var(--color-bg-white);
    border: 1px solid var(--color-border);
    border-radius: var(--card-radius);
    overflow: hidden;
    text-decoration: none;
    color: inherit;
    transition: all var(--transition-fast);
    position: relative;
}

.lp-sol-card:hover {
    border-color: var(--color-primary-light);
    transform: translateY(-2px);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.08);
}

.lp-sol-card__image {
    width: 100%;
    aspect-ratio: 16/9;
    object-fit: cover;
    background: var(--color-bg-alt);
}

.lp-sol-card__placeholder {
    width: 100%;
    aspect-ratio: 16/9;
    background: linear-gradient(135deg, var(--color-primary), var(--color-primary-light));
    display: flex;
    align-items: center;
    justify-content: center;
    color: rgba(255, 255, 255, 0.9);
    font-size: 18px;
    font-weight: 700;
    letter-spacing: 0.5px;
    text-transform: uppercase;
}

.lp-sol-card__badges {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    padding: 14px 20px 0;
}

.lp-sol-card__badge {
    display: inline-flex;
    align-items: center;
    font-size: 11px;
    font-weight: 600;
    padding: 4px 10px;
    border-radius: 5px;
    letter-spacing: 0.2px;
}

.lp-sol-card__badge--category {
    background: rgba(30, 64, 175, 0.08);
    color: var(--color-primary);
}

.lp-sol-featured-badge {
    background: #fef3c7;
    color: #92400e;
    display: inline-flex;
    align-items: center;
    gap: 3px;
}

.lp-sol-provider-type {
    background: var(--color-bg-alt);
    color: var(--color-text-body);
    font-size: 11px;
    font-weight: 500;
    padding: 3px 8px;
    border-radius: 4px;
    display: inline-flex;
    align-items: center;
    gap: 4px;
}

.lp-sol-card__body {
    padding: 12px 20px 20px;
    flex: 1;
    display: flex;
    flex-direction: column;
}

.lp-sol-card__title {
    font-size: 17px;
    font-weight: 600;
    color: var(--color-text-heading);
    margin-bottom: 8px;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.lp-sol-card__desc {
    font-size: 13px;
    color: var(--color-text-body);
    line-height: 1.5;
    margin-bottom: 12px;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    flex: 1;
}

.lp-sol-card__modules {
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
    margin-bottom: 12px;
}

.lp-sol-card__module {
    font-size: 11px;
    background: var(--color-bg-alt);
    color: var(--color-text-body);
    padding: 3px 8px;
    border-radius: 4px;
}

.lp-sol-card__meta {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 12px;
    color: var(--color-text-light);
    margin-bottom: 12px;
}

.lp-sol-card__footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding-top: 12px;
    border-top: 1px solid var(--color-border);
    font-size: 13px;
}

.lp-sol-price {
    font-weight: 700;
    color: var(--color-primary);
    font-size: 14px;
}

.lp-sol-price--muted {
    color: var(--color-text-light);
    font-weight: 500;
}

.lp-sol-card__link {
    color: var(--color-primary-light);
    font-weight: 600;
    text-decoration: none;
}

/* --- Solution Detail Hero --- */
.lp-sol-detail-hero {
    display: grid;
    grid-template-columns: 1fr 300px;
    gap: 24px;
    align-items: center;
}

.lp-sol-detail-hero-card {
    background: linear-gradient(180deg, rgba(255,255,255,0.18) 0%, rgba(255,255,255,0.08) 100%);
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
    border: 1px solid rgba(255, 255, 255, 0.25);
    border-radius: 18px;
    padding: 24px;
    color: var(--color-text-white);
    position: relative;
    overflow: hidden;
    box-shadow: 0 12px 36px rgba(0, 0, 0, 0.18);
}

.lp-sol-detail-hero-card::before {
    content: '';
    position: absolute;
    top: -40px;
    right: -40px;
    width: 140px;
    height: 140px;
    background: radial-gradient(circle, rgba(255,255,255,0.18) 0%, transparent 70%);
    pointer-events: none;
}

.lp-sol-hero-card__icon {
    width: 38px;
    height: 38px;
    border-radius: 10px;
    background: rgba(255, 255, 255, 0.18);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-size: 18px;
    margin-bottom: 14px;
}

.lp-sol-detail-hero-card__title {
    font-size: 14px;
    font-weight: 500;
    color: rgba(255, 255, 255, 0.75);
    margin-bottom: 4px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.lp-sol-detail-hero-card__price {
    font-size: 28px;
    font-weight: 800;
    margin: 4px 0 2px;
    letter-spacing: -0.5px;
    position: relative;
    z-index: 1;
}

.lp-sol-detail-hero-card__period {
    font-size: 13px;
    color: rgba(255, 255, 255, 0.75);
    margin-bottom: 18px;
}

.lp-sol-hero-card__quote {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 18px;
    font-weight: 700;
    color: #fff;
    margin: 4px 0 18px;
    position: relative;
    z-index: 1;
}

.lp-sol-hero-card__quote i {
    font-size: 20px;
    opacity: 0.85;
}

.lp-sol-hero-card__btn {
    width: 100%;
    height: 46px;
    font-size: 14px;
    font-weight: 600;
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 0 18px !important;
    position: relative;
    z-index: 1;
}

.lp-sol-hero-card__btn i.bi-envelope-paper {
    font-size: 16px;
}

.lp-sol-hero-card__btn i.bi-arrow-right {
    transition: transform var(--transition-fast);
}

.lp-sol-hero-card__btn:hover i.bi-arrow-right {
    transform: translateX(3px);
}

.lp-sol-hero-card__trust {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 14px;
    padding-top: 14px;
    border-top: 1px solid rgba(255, 255, 255, 0.15);
    font-size: 12px;
    color: rgba(255, 255, 255, 0.8);
}

.lp-sol-hero-card__trust span {
    display: inline-flex;
    align-items: center;
    gap: 4px;
}

.lp-sol-hero-card__trust i {
    font-size: 13px;
    color: #86efac;
}

.lp-sol-hero-card__notice {
    background: rgba(255, 255, 255, 0.1);
    border: 1px solid rgba(255, 255, 255, 0.15);
    border-radius: 10px;
    padding: 12px 14px;
    font-size: 13px;
    color: rgba(255, 255, 255, 0.9);
    display: flex;
    align-items: center;
    gap: 8px;
    position: relative;
    z-index: 1;
}

/* --- Solution Gallery (main image + vertical thumb list) --- */
.lp-sol-gallery-wrap {
    margin: 32px 0;
    display: grid;
    grid-template-columns: 1fr 100px;
    gap: 12px;
    max-width: 720px;
}

.lp-sol-gallery-main {
    width: 100%;
    aspect-ratio: 16/10;
    overflow: hidden;
    border-radius: 12px;
    background: var(--color-bg-alt);
    cursor: zoom-in;
    border: 1px solid var(--color-border);
}

.lp-sol-gallery-main img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--transition-fast);
}

.lp-sol-gallery-main:hover img {
    transform: scale(1.02);
}

.lp-sol-gallery-thumbs {
    display: flex;
    flex-direction: column;
    gap: 8px;
    overflow-y: auto;
    max-height: 100%;
    scrollbar-width: thin;
}

.lp-sol-gallery-thumbs::-webkit-scrollbar {
    width: 4px;
}

.lp-sol-gallery-thumbs::-webkit-scrollbar-thumb {
    background: var(--color-border);
    border-radius: 2px;
}

.lp-sol-gallery-thumb {
    flex: 0 0 auto;
    width: 100%;
    aspect-ratio: 16/10;
    border-radius: 6px;
    overflow: hidden;
    border: 2px solid transparent;
    background: var(--color-bg-alt);
    padding: 0;
    cursor: pointer;
    transition: all var(--transition-fast);
}

.lp-sol-gallery-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.lp-sol-gallery-thumb:hover {
    border-color: var(--color-primary-light);
}

.lp-sol-gallery-thumb.active {
    border-color: var(--color-primary);
    box-shadow: 0 0 0 2px rgba(30, 64, 175, 0.2);
}

/* Lightbox arrows */
.lp-sol-lightbox__arrow {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    background: rgba(255, 255, 255, 0.15);
    border: none;
    color: #fff;
    width: 48px;
    height: 48px;
    border-radius: 50%;
    font-size: 22px;
    cursor: pointer;
    transition: background var(--transition-fast);
    display: flex;
    align-items: center;
    justify-content: center;
}

.lp-sol-lightbox__arrow:hover {
    background: rgba(255, 255, 255, 0.3);
}

.lp-sol-lightbox__arrow--prev {
    left: 20px;
}

.lp-sol-lightbox__arrow--next {
    right: 20px;
}

.lp-sol-lightbox__counter {
    position: absolute;
    bottom: 20px;
    left: 50%;
    transform: translateX(-50%);
    background: rgba(0, 0, 0, 0.6);
    color: #fff;
    padding: 6px 14px;
    border-radius: 20px;
    font-size: 13px;
}

.lp-sol-lightbox {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.9);
    z-index: 2000;
    justify-content: center;
    align-items: center;
    padding: 40px;
}

.lp-sol-lightbox.active {
    display: flex;
}

.lp-sol-lightbox img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
    border-radius: 8px;
}

.lp-sol-lightbox__close {
    position: absolute;
    top: 20px;
    right: 20px;
    background: none;
    border: none;
    color: #fff;
    font-size: 32px;
    cursor: pointer;
}

/* --- Solution Detail Content --- */
.lp-sol-detail-layout {
    display: grid;
    grid-template-columns: 1fr 340px;
    gap: 32px;
    align-items: start;
}

.lp-sol-detail-main {
    min-width: 0;
}

.lp-sol-section {
    margin-bottom: 32px;
}

.lp-sol-section h2 {
    font-size: 20px;
    font-weight: 600;
    margin-bottom: 16px;
}

.lp-sol-section .rich-content {
    font-size: 15px;
    color: var(--color-text-body);
    line-height: 1.7;
}

.lp-sol-section .rich-content p {
    margin-bottom: 12px;
}

.lp-sol-section .rich-content ul {
    padding-left: 20px;
    margin-bottom: 12px;
}

.lp-sol-benefits {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 12px;
}

.lp-sol-benefit {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    padding: 14px;
    background: var(--color-bg-alt);
    border-radius: 10px;
    font-size: 14px;
    color: var(--color-text-body);
}

.lp-sol-benefit i {
    color: var(--color-success);
    font-size: 18px;
    flex-shrink: 0;
}

.lp-sol-benefit-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.lp-sol-benefit-list li {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    padding: 12px 14px;
    background: var(--color-bg-alt);
    border-radius: 10px;
    font-size: 14px;
    color: var(--color-text-body);
    line-height: 1.5;
}
.lp-sol-benefit-list li i {
    color: var(--color-success);
    font-size: 17px;
    flex-shrink: 0;
    margin-top: 2px;
}

.lp-sol-steps {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.lp-sol-step {
    display: flex;
    align-items: flex-start;
    gap: 14px;
    padding: 16px;
    background: var(--color-bg-white);
    border: 1px solid var(--color-border);
    border-radius: 10px;
}

.lp-sol-step__number {
    width: 32px;
    height: 32px;
    border-radius: 8px;
    background: var(--color-primary);
    color: var(--color-text-white);
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    flex-shrink: 0;
}

.lp-sol-step__content {
    flex: 1;
    min-width: 0;
}

.lp-sol-step__title {
    font-size: 15px;
    font-weight: 600;
    color: var(--color-text-heading);
    margin-bottom: 2px;
}

.lp-sol-step__text {
    font-size: 14px;
    color: var(--color-text-body);
    line-height: 1.6;
}

/* --- Solution Detail Sidebar --- */
.lp-sol-sidebar {
    position: sticky;
    top: 88px;
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.lp-sol-price-card,
.lp-sol-info-card {
    background: var(--color-bg-white);
    border: 1px solid var(--color-border);
    border-radius: var(--card-radius);
    padding: 24px;
}

.lp-sol-price-card__label {
    font-size: 12px;
    color: var(--color-text-light);
    margin-bottom: 4px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.lp-sol-price-card__amount {
    font-size: 28px;
    font-weight: 800;
    color: var(--color-text-heading);
    margin-bottom: 4px;
}

.lp-sol-price-card__period {
    font-size: 13px;
    color: var(--color-text-light);
    margin-bottom: 6px;
}

.lp-sol-price-card__tax-note {
    font-size: 11.5px;
    color: var(--color-text-light);
    display: inline-flex;
    align-items: center;
    gap: 5px;
    margin-bottom: 14px;
    letter-spacing: 0.2px;
}
.lp-sol-price-card__tax-note i { font-size: 12px; opacity: 0.7; }

.lp-sol-price-card__maintenance {
    padding: 12px 14px;
    background: linear-gradient(135deg, rgba(37, 99, 235, 0.05), rgba(37, 99, 235, 0.08));
    border: 1px solid rgba(37, 99, 235, 0.15);
    border-radius: 10px;
    margin-bottom: 16px;
}
.lp-sol-price-card__maintenance-head {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 12px;
    font-weight: 600;
    color: var(--color-text-body);
    text-transform: uppercase;
    letter-spacing: 0.3px;
    margin-bottom: 4px;
}
.lp-sol-price-card__maintenance-head i {
    color: var(--color-primary, #2563eb);
    font-size: 14px;
}
.lp-sol-price-card__maintenance-pct {
    margin-left: auto;
    background: var(--color-primary, #2563eb);
    color: #fff;
    font-size: 11px;
    padding: 2px 8px;
    border-radius: 12px;
    font-weight: 700;
}
.lp-sol-price-card__maintenance-amount {
    font-size: 18px;
    font-weight: 700;
    color: var(--color-text-heading);
}
.lp-sol-price-card__maintenance-period {
    font-size: 12px;
    font-weight: 500;
    color: var(--color-text-light);
    margin-left: 2px;
}

/* Hero card (summary) */
.lp-sol-detail-hero-card__tax {
    font-size: 11.5px;
    color: rgba(255, 255, 255, 0.65);
    letter-spacing: 0.2px;
    margin-top: 2px;
    margin-bottom: 12px;
}
.lp-sol-detail-hero-card__maintenance {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 12px;
    color: rgba(255, 255, 255, 0.85);
    background: rgba(255, 255, 255, 0.12);
    border: 1px solid rgba(255, 255, 255, 0.18);
    padding: 6px 10px;
    border-radius: 8px;
    margin-bottom: 14px;
}
.lp-sol-detail-hero-card__maintenance i { font-size: 12px; }

.lp-sol-price-card .lp-btn {
    width: 100%;
    margin-bottom: 12px;
}

.lp-sol-trust-list {
    display: flex;
    flex-direction: column;
    gap: 8px;
    padding-top: 12px;
    border-top: 1px solid var(--color-border);
    font-size: 13px;
    color: var(--color-text-body);
}

.lp-sol-trust-list span {
    display: flex;
    align-items: center;
    gap: 8px;
}

.lp-sol-trust-list i {
    color: var(--color-success);
    font-size: 14px;
}

.lp-sol-info-card h4 {
    font-size: 16px;
    font-weight: 600;
    margin-bottom: 14px;
}

.lp-sol-info-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 10px 0;
    border-bottom: 1px solid var(--color-bg-alt);
    font-size: 14px;
}

.lp-sol-info-row:last-child {
    border-bottom: none;
}

.lp-sol-info-row__label {
    color: var(--color-text-light);
}

.lp-sol-info-row__value {
    color: var(--color-text-heading);
    font-weight: 500;
    text-align: right;
}

.lp-sol-info-row--stack {
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
}
.lp-sol-info-row--stack .lp-sol-info-row__label {
    font-size: 12px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.3px;
}

.lp-sol-cat-chips {
    display: flex;
    flex-direction: column;
    gap: 6px;
    width: 100%;
}
.lp-sol-cat-chip {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 7px 10px;
    background: var(--color-bg-alt);
    border: 1px solid var(--color-card-border, #e2e8f0);
    border-radius: 8px;
    font-size: 12.5px;
    line-height: 1.3;
    color: var(--color-text-body);
    flex-wrap: wrap;
}
.lp-sol-cat-chip > i {
    color: var(--color-primary, #2563eb);
    font-size: 13px;
    flex-shrink: 0;
}
.lp-sol-cat-chip__cat {
    font-weight: 600;
    color: var(--color-text-heading);
}
.lp-sol-cat-chip__sep {
    color: var(--color-text-light);
    font-weight: 700;
}
.lp-sol-cat-chip__sub {
    color: var(--color-text-body);
}

/* --- Related Solutions --- */
.lp-sol-related-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--grid-gap);
}

/* --- Mobile sticky bar --- */
.lp-sol-mobile-bar {
    display: none;
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    background: var(--color-bg-white);
    box-shadow: 0 -4px 12px rgba(0, 0, 0, 0.1);
    padding: 12px 16px;
    z-index: 100;
    gap: 10px;
    align-items: center;
}

.lp-sol-mobile-bar__price {
    flex: 0 0 auto;
    font-weight: 700;
    color: var(--color-primary);
    font-size: 14px;
}

.lp-sol-mobile-bar .lp-btn {
    flex: 1;
}

/* --- SEO text block --- */
.lp-sol-seo-text {
    max-width: 840px;
    margin: 0 auto;
    color: var(--color-text-body);
    font-size: 15px;
    line-height: 1.7;
}

.lp-sol-seo-text h2 {
    font-size: 22px;
    font-weight: 600;
    margin-bottom: 16px;
    color: var(--color-text-heading);
}

.lp-sol-seo-text p {
    margin-bottom: 14px;
}

.lp-sol-seo-links {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 20px;
}

.lp-sol-seo-links a {
    font-size: 13px;
    padding: 6px 14px;
    background: var(--color-bg-white);
    border: 1px solid var(--color-border);
    border-radius: 6px;
    color: var(--color-primary);
    text-decoration: none;
    transition: all var(--transition-fast);
}

.lp-sol-seo-links a:hover {
    background: var(--color-primary);
    color: var(--color-text-white);
    border-color: var(--color-primary);
}

/* ==========================================================================
   LEGAL / STATIC PAGES (about, privacy, terms, delivery, distance, refund, faq)
   ========================================================================== */

.lp-legal-page {
    background: var(--color-bg-body);
}

/* Legal Hero */
.lp-legal-hero {
    background: var(--color-bg-body);
    padding: 100px 0 32px;
}

.lp-legal-hero__inner {
    max-width: 840px;
    margin: 0 auto;
}

.lp-legal-hero h1 {
    font-size: 36px;
    font-weight: 700;
    color: var(--color-text-heading);
    margin-bottom: 8px;
}

.lp-legal-updated {
    font-size: 13px;
    color: var(--color-text-light);
    margin-top: 12px;
}

/* Legal Content Box */
.lp-legal-content {
    max-width: 840px;
    margin: -16px auto 0;
    background: var(--color-bg-white);
    border: 1px solid var(--color-border);
    border-radius: 16px;
    padding: 48px;
    position: relative;
    z-index: 1;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.03);
}

.lp-legal-content h2 {
    font-size: 22px;
    font-weight: 600;
    color: var(--color-text-heading);
    margin-top: 32px;
    margin-bottom: 12px;
}

.lp-legal-content h2:first-child {
    margin-top: 0;
}

.lp-legal-content h3 {
    font-size: 17px;
    font-weight: 600;
    color: var(--color-text-heading);
    margin-top: 20px;
    margin-bottom: 8px;
}

.lp-legal-content p {
    font-size: 15px;
    line-height: 1.8;
    color: var(--color-text-body);
    margin-bottom: 14px;
}

.lp-legal-content ul,
.lp-legal-content ol {
    padding-left: 24px;
    margin-bottom: 16px;
}

.lp-legal-content li {
    font-size: 15px;
    line-height: 1.8;
    color: var(--color-text-body);
    margin-bottom: 8px;
}

.lp-legal-content a {
    color: var(--color-primary-light);
    text-decoration: none;
}

.lp-legal-content a:hover {
    text-decoration: underline;
}

.lp-legal-content table {
    width: 100%;
    border-collapse: collapse;
    margin-bottom: 16px;
    font-size: 14px;
}

.lp-legal-content th,
.lp-legal-content td {
    padding: 12px 14px;
    border-bottom: 1px solid var(--color-border);
    text-align: left;
    vertical-align: top;
}

.lp-legal-content th {
    background: var(--color-bg-alt);
    font-weight: 600;
    color: var(--color-text-heading);
}

.lp-legal-section {
    margin-bottom: 8px;
}

/* Contact info block inside legal (seller info etc) */
.lp-legal-seller-info {
    background: var(--color-bg-alt);
    border-left: 4px solid var(--color-primary);
    padding: 20px 24px;
    border-radius: 0 10px 10px 0;
    margin-bottom: 24px;
}

.lp-legal-seller-info h3 {
    margin-top: 0;
    color: var(--color-primary);
}

.lp-legal-seller-info p {
    margin-bottom: 6px;
    font-size: 14px;
}

/* ==========================================================================
   FAQ PAGE
   ========================================================================== */

.lp-faq-page {
    max-width: 840px;
    margin: 0 auto;
}

.lp-faq-category {
    margin-bottom: 32px;
}

.lp-faq-category h2 {
    font-size: 20px;
    font-weight: 600;
    color: var(--color-text-heading);
    margin-bottom: 14px;
    display: flex;
    align-items: center;
    gap: 10px;
}

.lp-faq-category h2 i {
    color: var(--color-primary);
    font-size: 22px;
}

.lp-faq-list {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.lp-faq-item {
    background: var(--color-bg-white);
    border: 1px solid var(--color-border);
    border-radius: 10px;
    overflow: hidden;
    transition: box-shadow var(--transition-fast);
}

.lp-faq-item[open] {
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.05);
    border-color: var(--color-primary-light);
}

.lp-faq-item summary {
    padding: 16px 20px;
    font-size: 15px;
    font-weight: 600;
    color: var(--color-text-heading);
    cursor: pointer;
    list-style: none;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}

.lp-faq-item summary::-webkit-details-marker {
    display: none;
}

.lp-faq-item summary::after {
    content: '\F282';
    font-family: 'bootstrap-icons';
    font-size: 14px;
    color: var(--color-text-light);
    transition: transform var(--transition-fast);
    flex-shrink: 0;
}

.lp-faq-item[open] summary::after {
    transform: rotate(180deg);
}

.lp-faq-answer {
    padding: 0 20px 18px;
    font-size: 14px;
    line-height: 1.7;
    color: var(--color-text-body);
}

.lp-faq-empty {
    text-align: center;
    padding: 48px 24px;
    color: var(--color-text-light);
}

.lp-faq-empty i {
    font-size: 48px;
    opacity: 0.3;
    margin-bottom: 12px;
    display: block;
}

/* ==========================================================================
   ABOUT PAGE
   ========================================================================== */

.lp-about-intro {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 24px;
    margin-bottom: 64px;
}

.lp-about-card {
    background: var(--color-bg-white);
    border: 1px solid var(--color-border);
    border-radius: 16px;
    padding: 32px;
}

.lp-about-card__icon {
    width: 48px;
    height: 48px;
    border-radius: 12px;
    background: rgba(30, 64, 175, 0.08);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-primary);
    font-size: 24px;
    margin-bottom: 16px;
}

.lp-about-card h3 {
    font-size: 20px;
    font-weight: 600;
    margin-bottom: 10px;
}

.lp-about-card p {
    font-size: 15px;
    line-height: 1.7;
    color: var(--color-text-body);
}

.lp-about-values {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 20px;
    margin-bottom: 48px;
}

.lp-about-value {
    text-align: center;
    padding: 24px 16px;
    background: var(--color-bg-white);
    border: 1px solid var(--color-border);
    border-radius: 12px;
}

.lp-about-value i {
    font-size: 32px;
    color: var(--color-primary);
    margin-bottom: 10px;
    display: block;
}

.lp-about-value h4 {
    font-size: 15px;
    font-weight: 600;
    margin-bottom: 6px;
}

.lp-about-value p {
    font-size: 13px;
    color: var(--color-text-light);
    line-height: 1.5;
}

.lp-about-stats {
    display: flex;
    justify-content: center;
    gap: 48px;
    padding: 48px 0;
    background: linear-gradient(135deg, #0f172a 0%, #1e293b 100%);
    color: var(--color-text-white);
    border-radius: 16px;
    flex-wrap: wrap;
}

.lp-about-stat {
    text-align: center;
}

.lp-about-stat__value {
    font-size: 36px;
    font-weight: 800;
    color: var(--color-text-white);
    margin-bottom: 4px;
}

.lp-about-stat__label {
    font-size: 14px;
    color: var(--color-text-light);
}

/* ==========================================================================
   CONTACT PAGE
   ========================================================================== */

.lp-contact-grid {
    display: grid;
    grid-template-columns: 1.4fr 1fr;
    gap: 32px;
    max-width: 1100px;
    margin: 0 auto;
    align-items: start;
}

.lp-contact-form-card {
    background: var(--color-bg-white);
    border: 1px solid var(--color-border);
    border-radius: 16px;
    padding: 32px;
}

.lp-contact-form-card h2 {
    font-size: 20px;
    font-weight: 600;
    margin-bottom: 6px;
}

.lp-contact-form-card__sub {
    font-size: 14px;
    color: var(--color-text-body);
    margin-bottom: 24px;
}

.lp-contact-form .form-group {
    margin-bottom: 16px;
}

.lp-contact-form .form-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
}

.lp-contact-form label {
    display: block;
    font-size: 13px;
    font-weight: 500;
    color: var(--color-text-heading);
    margin-bottom: 6px;
}

.lp-contact-form input,
.lp-contact-form select,
.lp-contact-form textarea {
    width: 100%;
    padding: 10px 14px;
    font-family: var(--font-family);
    font-size: 14px;
    color: var(--color-text-heading);
    background: var(--color-bg-white);
    border: 1px solid var(--color-border);
    border-radius: 8px;
    transition: border-color var(--transition-fast);
}

.lp-contact-form input:focus,
.lp-contact-form select:focus,
.lp-contact-form textarea:focus {
    outline: none;
    border-color: var(--color-primary-light);
}

.lp-contact-form textarea {
    min-height: 120px;
    resize: vertical;
}

.lp-contact-form .form-error {
    font-size: 12px;
    color: #dc2626;
    margin-top: 4px;
}

.lp-contact-info-card {
    background: var(--color-bg-white);
    border: 1px solid var(--color-border);
    border-radius: 16px;
    padding: 28px;
    position: sticky;
    top: 88px;
}

.lp-contact-info-card h3 {
    font-size: 17px;
    font-weight: 600;
    margin-bottom: 4px;
}

.lp-contact-info-card .lp-contact-info-company {
    font-size: 14px;
    font-weight: 600;
    color: var(--color-primary);
    margin-bottom: 16px;
}

.lp-contact-info-row {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    padding: 10px 0;
    font-size: 13px;
    color: var(--color-text-body);
    line-height: 1.6;
    border-bottom: 1px solid var(--color-bg-alt);
}

.lp-contact-info-row:last-child {
    border-bottom: none;
}

.lp-contact-info-row i {
    color: var(--color-primary-light);
    font-size: 14px;
    margin-top: 3px;
    flex-shrink: 0;
}

.lp-contact-info-row a {
    color: var(--color-text-body);
    text-decoration: none;
}

.lp-contact-info-row a:hover {
    color: var(--color-primary);
}

.lp-contact-info-corporate {
    margin-top: 16px;
    padding-top: 14px;
    border-top: 1px solid var(--color-border);
    font-size: 11px;
    color: var(--color-text-light);
    line-height: 1.7;
}

.lp-contact-flash {
    background: #d1fae5;
    border: 1px solid #6ee7b7;
    color: #065f46;
    padding: 14px 18px;
    border-radius: 10px;
    margin-bottom: 20px;
    font-size: 14px;
    display: flex;
    align-items: center;
    gap: 8px;
}

.lp-contact-flash--error {
    background: #fee2e2;
    border-color: #fca5a5;
    color: #991b1b;
}

/* ==========================================================================
   AUTH PAGES (login, register, firm application)
   ========================================================================== */

.lp-auth-page {
    background: var(--color-bg-body);
    min-height: calc(100vh - 80px);
}

/* --- Split screen layout (login + consultant register) --- */
.lp-auth-split {
    display: grid;
    grid-template-columns: 1fr 480px;
    min-height: calc(100vh - 80px);
    padding-top: 80px;
}

/* --- Fullscreen mode (no navbar/footer) --- */
body.is-auth-fullscreen { overflow-x: hidden; }
body.is-auth-fullscreen .lp-auth-page { min-height: 100vh; }
body.is-auth-fullscreen .lp-auth-split { min-height: 100vh; padding-top: 0; }
body.is-auth-fullscreen .lp-auth-form-side {
    max-height: 100vh;
    overflow-y: auto;
    align-items: flex-start;
    padding-top: 80px;
    padding-bottom: 40px;
}
body.is-auth-fullscreen .lp-auth-form-inner { margin: auto 0; }

/* Floating topbar for fullscreen auth pages */
.lp-auth-topbar {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    height: 60px;
    padding: 0 24px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    z-index: 50;
    pointer-events: none;
}
.lp-auth-topbar > * { pointer-events: auto; }

.lp-auth-topbar__brand {
    text-decoration: none;
}
.lp-auth-topbar__logo {
    font-size: 18px;
    font-weight: 800;
    letter-spacing: 0.5px;
    color: var(--color-text-white);
    text-shadow: 0 1px 2px rgba(0,0,0,0.15);
}

.lp-auth-topbar__actions {
    display: flex;
    align-items: center;
    gap: 12px;
}

.lp-auth-topbar__lang {
    display: flex;
    gap: 2px;
    background: rgba(255,255,255,0.9);
    backdrop-filter: blur(8px);
    border: 1px solid rgba(255,255,255,0.4);
    border-radius: 999px;
    padding: 4px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.08);
}
.lp-auth-topbar__lang-link {
    font-size: 12px;
    font-weight: 600;
    color: var(--color-text-body);
    text-decoration: none;
    padding: 5px 10px;
    border-radius: 999px;
    transition: all 0.15s;
    letter-spacing: 0.5px;
}
.lp-auth-topbar__lang-link:hover { color: var(--color-primary); }
.lp-auth-topbar__lang-link.is-active {
    background: var(--color-primary);
    color: var(--color-text-white);
}

.lp-auth-topbar__close {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: rgba(255,255,255,0.9);
    backdrop-filter: blur(8px);
    border: 1px solid rgba(255,255,255,0.4);
    color: var(--color-text-heading);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 16px;
    text-decoration: none;
    transition: all 0.15s;
    box-shadow: 0 2px 8px rgba(0,0,0,0.08);
}
.lp-auth-topbar__close:hover {
    background: var(--color-bg-white);
    color: var(--color-primary);
    transform: scale(1.05);
}

/* On pages WITHOUT the side panel (register role, firm pending, firm register),
   the topbar sits on light background — dark logo text + subtle bar background
   for visibility against white page content */
body.is-auth-fullscreen.auth-light-top .lp-auth-topbar {
    background: rgba(255,255,255,0.85);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    border-bottom: 1px solid rgba(15, 23, 42, 0.06);
    box-shadow: 0 1px 3px rgba(15, 23, 42, 0.03);
    pointer-events: auto;
}
body.is-auth-fullscreen.auth-light-top .lp-auth-topbar__logo {
    color: var(--color-primary);
    text-shadow: none;
}

.lp-auth-side-panel {
    background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-light) 100%);
    padding: 64px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    color: var(--color-text-white);
    position: relative;
    overflow: hidden;
}

.lp-auth-side-panel::before {
    content: '';
    position: absolute;
    top: -80px;
    right: -80px;
    width: 280px;
    height: 280px;
    background: radial-gradient(circle, rgba(255,255,255,0.15) 0%, transparent 70%);
    pointer-events: none;
}

.lp-auth-side-panel__badge {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: rgba(255, 255, 255, 0.15);
    padding: 8px 16px;
    border-radius: 24px;
    font-size: 13px;
    font-weight: 500;
    margin-bottom: 24px;
    align-self: flex-start;
}

.lp-auth-side-panel__title {
    font-size: 36px;
    font-weight: 800;
    line-height: 1.2;
    margin-bottom: 16px;
    color: var(--color-text-white);
    position: relative;
}

.lp-auth-side-panel__desc {
    font-size: 16px;
    line-height: 1.6;
    color: rgba(255, 255, 255, 0.9);
    margin-bottom: 32px;
    max-width: 420px;
}

.lp-auth-side-panel__list {
    list-style: none;
    padding: 0;
    margin: 0 0 32px;
    display: flex;
    flex-direction: column;
    gap: 14px;
}

.lp-auth-side-panel__list li {
    display: flex;
    align-items: center;
    gap: 12px;
    font-size: 15px;
    color: rgba(255, 255, 255, 0.95);
}

.lp-auth-side-panel__list i {
    color: #86efac;
    font-size: 18px;
    flex-shrink: 0;
}

.lp-auth-side-panel__stat {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    background: rgba(255, 255, 255, 0.12);
    border: 1px solid rgba(255, 255, 255, 0.2);
    padding: 12px 18px;
    border-radius: 12px;
    font-size: 14px;
    align-self: flex-start;
}

.lp-auth-side-panel__stat strong {
    font-size: 18px;
    font-weight: 700;
}

/* Form side */
.lp-auth-form-side {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 48px 40px;
    background: var(--color-bg-white);
}

.lp-auth-form-inner {
    width: 100%;
    max-width: 400px;
}

.lp-auth-header {
    margin-bottom: 28px;
}

.lp-auth-header h1 {
    font-size: 26px;
    font-weight: 700;
    color: var(--color-text-heading);
    margin-bottom: 6px;
}

.lp-auth-header p {
    font-size: 14px;
    color: var(--color-text-body);
}

/* Social login button */
.lp-auth-social-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    width: 100%;
    height: 44px;
    padding: 0 16px;
    background: var(--color-bg-white);
    color: var(--color-text-heading);
    border: 1px solid var(--color-border);
    border-radius: 8px;
    font-family: var(--font-family);
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    transition: all var(--transition-fast);
    position: relative;
}

.lp-auth-social-btn:hover {
    border-color: var(--color-primary-light);
    background: #f8fafc;
}

.lp-auth-social-btn i {
    font-size: 18px;
    color: #0a66c2;
}

.lp-auth-social-btn[disabled],
.lp-auth-social-btn.disabled {
    opacity: 0.6;
    cursor: not-allowed;
}

/* Divider */
.lp-auth-divider {
    display: flex;
    align-items: center;
    gap: 14px;
    margin: 18px 0;
    color: var(--color-text-light);
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: 1px;
}

.lp-auth-divider::before,
.lp-auth-divider::after {
    content: '';
    flex: 1;
    height: 1px;
    background: var(--color-border);
}

/* Form */
.lp-auth-form {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.lp-auth-form__group {
    display: flex;
    flex-direction: column;
}

.lp-auth-form__row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
}

.lp-auth-form__label {
    font-size: 13px;
    font-weight: 500;
    color: var(--color-text-heading);
    margin-bottom: 6px;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.lp-auth-form__label a {
    font-size: 12px;
    color: var(--color-primary-light);
    text-decoration: none;
    font-weight: 500;
}

.lp-auth-form__label a:hover {
    text-decoration: underline;
}

.lp-auth-form__label--required::after {
    content: '*';
    color: #dc2626;
    margin-left: 3px;
}

.lp-auth-form__input {
    width: 100%;
    height: 42px;
    padding: 0 14px;
    font-family: var(--font-family);
    font-size: 14px;
    color: var(--color-text-heading);
    background: var(--color-bg-white);
    border: 1px solid var(--color-border);
    border-radius: 8px;
    transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}

.lp-auth-form__input:focus {
    outline: none;
    border-color: var(--color-primary-light);
    box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);
}

.lp-auth-form__input--error {
    border-color: #dc2626;
}

.lp-auth-form textarea.lp-auth-form__input {
    height: auto;
    padding: 10px 14px;
    min-height: 80px;
    resize: vertical;
}

.lp-auth-form__input-wrapper {
    position: relative;
}

.lp-auth-form__password-toggle {
    position: absolute;
    right: 4px;
    top: 50%;
    transform: translateY(-50%);
    background: none;
    border: none;
    color: var(--color-text-light);
    cursor: pointer;
    padding: 8px 12px;
    font-size: 16px;
    transition: color var(--transition-fast);
}

.lp-auth-form__password-toggle:hover {
    color: var(--color-text-heading);
}

.lp-auth-form__hint {
    font-size: 12px;
    color: var(--color-text-light);
    margin-top: 6px;
}

.lp-auth-form__error {
    font-size: 12px;
    color: #dc2626;
    margin-top: 6px;
}

.lp-auth-form__success {
    font-size: 12px;
    color: #059669;
    margin-top: 6px;
}

/* Password strength bar */
.lp-auth-strength {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-top: 8px;
}

.lp-auth-strength__bars {
    display: flex;
    gap: 3px;
    flex: 1;
}

.lp-auth-strength__bar {
    flex: 1;
    height: 4px;
    background: var(--color-border);
    border-radius: 2px;
    transition: background var(--transition-fast);
}

.lp-auth-strength--weak .lp-auth-strength__bar:nth-child(-n+1) { background: #dc2626; }
.lp-auth-strength--fair .lp-auth-strength__bar:nth-child(-n+2) { background: #f59e0b; }
.lp-auth-strength--good .lp-auth-strength__bar:nth-child(-n+3) { background: #3b82f6; }
.lp-auth-strength--strong .lp-auth-strength__bar { background: #10b981; }

.lp-auth-strength__label {
    font-size: 11px;
    font-weight: 600;
    color: var(--color-text-light);
    white-space: nowrap;
    min-width: 80px;
    text-align: right;
}

/* Checkbox */
.lp-auth-form__check {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    font-size: 13px;
    line-height: 1.5;
    color: var(--color-text-body);
    cursor: pointer;
}

.lp-auth-form__check input[type="checkbox"] {
    margin-top: 3px;
    cursor: pointer;
    accent-color: var(--color-primary);
    flex-shrink: 0;
}

.lp-auth-form__check a {
    color: var(--color-primary-light);
    text-decoration: none;
    font-weight: 500;
}

.lp-auth-form__check a:hover {
    text-decoration: underline;
}

/* Submit button */
.lp-auth-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    width: 100%;
    height: 48px;
    padding: 0 24px;
    background: linear-gradient(135deg, var(--color-primary), var(--color-primary-light));
    color: var(--color-text-white);
    border: none;
    border-radius: 8px;
    font-family: var(--font-family);
    font-size: 15px;
    font-weight: 600;
    cursor: pointer;
    transition: all var(--transition-fast);
}

.lp-auth-btn:hover {
    filter: brightness(1.08);
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(30, 64, 175, 0.25);
}

.lp-auth-btn:disabled {
    opacity: 0.6;
    cursor: not-allowed;
    transform: none;
}

/* Footer links */
.lp-auth-footer {
    text-align: center;
    margin-top: 24px;
    font-size: 13px;
    color: var(--color-text-body);
}

.lp-auth-footer a {
    color: var(--color-primary-light);
    text-decoration: none;
    font-weight: 600;
    margin-left: 4px;
}

.lp-auth-footer a:hover {
    text-decoration: underline;
}

/* --- Role selection cards --- */
.lp-auth-role-cards {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 20px;
    max-width: 880px;
    margin: 0 auto;
}

.lp-auth-role-card {
    background: var(--color-bg-white);
    border: 1px solid var(--color-border);
    border-radius: 20px;
    padding: 36px 32px;
    text-align: left;
    cursor: pointer;
    transition: all var(--transition-fast);
    display: flex;
    flex-direction: column;
}

.lp-auth-role-card:hover {
    border-color: var(--color-primary-light);
    transform: translateY(-4px);
    box-shadow: 0 12px 32px rgba(0, 0, 0, 0.08);
}

.lp-auth-role-card__icon {
    width: 56px;
    height: 56px;
    border-radius: 14px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--color-text-white);
    font-size: 26px;
    margin-bottom: 18px;
}

.lp-auth-role-card__icon--consultant {
    background: linear-gradient(135deg, #3b82f6, #06b6d4);
}

.lp-auth-role-card__icon--firm {
    background: linear-gradient(135deg, #8b5cf6, #ec4899);
}

.lp-auth-role-card h3 {
    font-size: 20px;
    font-weight: 700;
    color: var(--color-text-heading);
    margin-bottom: 8px;
}

.lp-auth-role-card__desc {
    font-size: 14px;
    color: var(--color-text-body);
    line-height: 1.6;
    margin-bottom: 18px;
}

.lp-auth-role-card__features {
    list-style: none;
    padding: 0;
    margin: 0 0 20px;
    display: flex;
    flex-direction: column;
    gap: 8px;
    flex: 1;
}

.lp-auth-role-card__features li {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
    color: var(--color-text-body);
}

.lp-auth-role-card__features i {
    color: var(--color-success);
    font-size: 15px;
    flex-shrink: 0;
}

.lp-auth-role-card__meta {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 12px;
    color: var(--color-text-light);
    margin-bottom: 16px;
    padding-top: 14px;
    border-top: 1px solid var(--color-bg-alt);
}

.lp-auth-role-card__badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    background: #fef3c7;
    color: #92400e;
    padding: 4px 10px;
    border-radius: 5px;
    font-size: 11px;
    font-weight: 600;
}

.lp-auth-role-card__cta {
    display: inline-flex;
    align-items: center;
    justify-content: space-between;
    height: 44px;
    padding: 0 18px;
    background: linear-gradient(135deg, var(--color-primary), var(--color-primary-light));
    color: var(--color-text-white);
    border-radius: 8px;
    font-size: 14px;
    font-weight: 600;
    text-decoration: none;
    transition: all var(--transition-fast);
}

.lp-auth-role-card__cta:hover {
    filter: brightness(1.08);
}

/* --- Firm application form --- */
.lp-auth-firm-form {
    max-width: 860px;
    margin: 0 auto;
    background: var(--color-bg-white);
    border: 1px solid var(--color-border);
    border-radius: 20px;
    padding: 40px;
}

.lp-auth-firm-form__section {
    margin-bottom: 32px;
    padding-bottom: 24px;
    border-bottom: 1px solid var(--color-bg-alt);
}

.lp-auth-firm-form__section:last-child {
    border-bottom: none;
    margin-bottom: 0;
}

.lp-auth-firm-form__section-title {
    font-size: 17px;
    font-weight: 600;
    color: var(--color-text-heading);
    margin-bottom: 18px;
    display: flex;
    align-items: center;
    gap: 10px;
}

.lp-auth-firm-form__section-title i {
    color: var(--color-primary);
    font-size: 18px;
}

.lp-auth-firm-form__section-desc {
    font-size: 13px;
    color: var(--color-text-light);
    margin-bottom: 14px;
    margin-top: -8px;
}

/* Sticky progress bar */
.lp-auth-progress {
    position: sticky;
    top: 72px;
    background: var(--color-bg-white);
    border-bottom: 1px solid var(--color-border);
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.03);
    z-index: 40;
    padding: 14px 0;
}
body.is-auth-fullscreen .lp-auth-progress { top: 60px; }

.lp-auth-progress__inner {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    max-width: 820px;
    margin: 0 auto;
    flex-wrap: wrap;
}

.lp-auth-progress__step {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
    font-weight: 500;
    color: var(--color-text-light);
    transition: color var(--transition-fast);
}

.lp-auth-progress__step-num {
    width: 28px;
    height: 28px;
    border-radius: 50%;
    background: var(--color-bg-alt);
    color: var(--color-text-light);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 12px;
    font-weight: 700;
    transition: all var(--transition-fast);
}

.lp-auth-progress__step--active {
    color: var(--color-primary);
}

.lp-auth-progress__step--active .lp-auth-progress__step-num {
    background: var(--color-primary);
    color: var(--color-text-white);
}

.lp-auth-progress__step--done {
    color: var(--color-success);
}

.lp-auth-progress__step--done .lp-auth-progress__step-num {
    background: var(--color-success);
    color: var(--color-text-white);
}

.lp-auth-progress__connector {
    width: 32px;
    height: 2px;
    background: var(--color-bg-alt);
}

/* Module selection grid */
.lp-auth-module-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 12px;
}

.lp-auth-module-check {
    position: relative;
    background: var(--color-bg-white);
    border: 2px solid var(--color-border);
    border-radius: 12px;
    padding: 16px;
    cursor: pointer;
    transition: all var(--transition-fast);
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.lp-auth-module-check:hover {
    border-color: var(--color-primary-light);
}

.lp-auth-module-check--active {
    border-color: var(--color-primary);
    background: rgba(30, 64, 175, 0.04);
}

.lp-auth-module-check input[type="checkbox"] {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.lp-auth-module-check__header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 8px;
}

.lp-auth-module-check__icon {
    width: 36px;
    height: 36px;
    border-radius: 10px;
    background: rgba(30, 64, 175, 0.08);
    color: var(--color-primary);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 18px;
    flex-shrink: 0;
}

.lp-auth-module-check--active .lp-auth-module-check__icon {
    background: var(--color-primary);
    color: var(--color-text-white);
}

.lp-auth-module-check__check {
    width: 20px;
    height: 20px;
    border-radius: 50%;
    border: 2px solid var(--color-border);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-text-white);
    font-size: 12px;
    flex-shrink: 0;
    transition: all var(--transition-fast);
}

.lp-auth-module-check--active .lp-auth-module-check__check {
    background: var(--color-primary);
    border-color: var(--color-primary);
}

.lp-auth-module-check__recommended {
    position: absolute;
    top: -9px;
    left: 12px;
    right: auto;
    background: #f59e0b;
    color: #fff;
    font-size: 10px;
    font-weight: 700;
    padding: 3px 8px;
    border-radius: 4px;
    text-transform: uppercase;
    letter-spacing: 0.3px;
    box-shadow: 0 2px 4px rgba(245, 158, 11, 0.25);
    display: none;
    z-index: 1;
}

.lp-auth-module-check.show-recommended .lp-auth-module-check__recommended {
    display: inline-block;
}

.lp-auth-module-check__title {
    font-size: 14px;
    font-weight: 600;
    color: var(--color-text-heading);
    margin-top: 4px;
}

.lp-auth-module-check__desc {
    font-size: 12px;
    color: var(--color-text-body);
    line-height: 1.4;
}

.lp-auth-module-counter {
    font-size: 13px;
    color: var(--color-text-light);
    margin-top: 14px;
    text-align: center;
}

/* Firm pending page */
.lp-auth-pending-card {
    background: var(--color-bg-white);
    border: 1px solid var(--color-border);
    border-radius: 20px;
    padding: 48px 40px;
    max-width: 600px;
    margin: 0 auto;
    text-align: center;
}

.lp-auth-pending-icon {
    width: 80px;
    height: 80px;
    border-radius: 50%;
    background: linear-gradient(135deg, rgba(30, 64, 175, 0.1), rgba(59, 130, 246, 0.1));
    color: var(--color-primary);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 36px;
    margin-bottom: 20px;
}

.lp-auth-pending-steps {
    display: flex;
    justify-content: space-between;
    gap: 16px;
    margin: 32px 0;
    padding: 24px 0;
    border-top: 1px solid var(--color-border);
    border-bottom: 1px solid var(--color-border);
}

.lp-auth-pending-step {
    flex: 1;
    text-align: center;
}

.lp-auth-pending-step__icon {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: var(--color-bg-alt);
    color: var(--color-text-light);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 18px;
    margin-bottom: 8px;
}

.lp-auth-pending-step--done .lp-auth-pending-step__icon {
    background: var(--color-success);
    color: var(--color-text-white);
}

.lp-auth-pending-step--pending .lp-auth-pending-step__icon {
    background: #fef3c7;
    color: #92400e;
}

.lp-auth-pending-step__title {
    font-size: 13px;
    font-weight: 600;
    color: var(--color-text-heading);
    margin-bottom: 4px;
}

.lp-auth-pending-step__desc {
    font-size: 12px;
    color: var(--color-text-light);
}

/* --------------------------------------------------------------------------
   Responsive — Tablet (768px — 1023px)
   -------------------------------------------------------------------------- */
@media (max-width: 1023px) {
    :root {
        --section-padding: 72px;
    }

    .lp-hero__inner {
        grid-template-columns: 1fr;
    }

    .lp-hero__mockup {
        display: none;
    }

    .lp-hero__title {
        font-size: 38px;
    }

    .lp-how__steps {
        grid-template-columns: repeat(3, 1fr);
    }

    .lp-features {
        grid-template-columns: repeat(2, 1fr);
    }

    .lp-mini-features {
        grid-template-columns: repeat(2, 1fr);
    }

    .lp-jobs {
        grid-template-columns: repeat(2, 1fr);
    }

    .lp-numbers {
        grid-template-columns: repeat(2, 1fr);
        gap: 32px;
    }

    .lp-why {
        grid-template-columns: repeat(2, 1fr);
    }

    .lp-footer__grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .lp-section__title {
        font-size: 30px;
    }

    /* Directory — Tablet */
    .lp-dir-seo-grid {
        grid-template-columns: 1fr;
    }

    /* Jobs — Tablet */
    .lp-job-hero-grid {
        grid-template-columns: 1fr;
    }

    .lp-job-hero-card {
        display: none;
    }

    .lp-job-detail-layout {
        grid-template-columns: 1fr;
    }

    .lp-job-detail-sidebar {
        position: static;
    }

    .lp-job-related-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .lp-job-mobile-bar {
        display: flex;
    }

    /* Solutions — Tablet */
    .lp-sol-detail-hero {
        grid-template-columns: 1fr;
    }

    .lp-sol-detail-hero-card {
        display: none;
    }

    .lp-sol-detail-layout {
        grid-template-columns: 1fr;
    }

    .lp-sol-sidebar {
        position: static;
    }

    .lp-sol-related-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .lp-sol-mobile-bar {
        display: flex;
    }

    .lp-sol-benefits {
        grid-template-columns: 1fr;
    }

    /* Legal + About + Contact — Tablet */
    .lp-about-intro {
        grid-template-columns: 1fr;
    }

    .lp-about-values {
        grid-template-columns: repeat(2, 1fr);
    }

    .lp-contact-grid {
        grid-template-columns: 1fr;
    }

    .lp-contact-info-card {
        position: static;
    }

    /* Auth — Tablet */
    .lp-auth-split {
        grid-template-columns: 1fr;
    }

    .lp-auth-side-panel {
        display: none;
    }

    .lp-auth-form-side {
        padding: 40px 24px;
    }

    .lp-auth-role-cards {
        grid-template-columns: 1fr;
    }

    .lp-auth-module-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

/* --------------------------------------------------------------------------
   Responsive — Mobile (< 768px)
   -------------------------------------------------------------------------- */
@media (max-width: 767px) {
    :root {
        --section-padding: 56px;
        --card-padding: 24px;
    }

    /* Navbar Mobile */
    .lp-navbar__links,
    .lp-navbar__actions {
        display: none;
    }

    .lp-navbar__toggle {
        display: block;
    }

    /* Hero Mobile */
    .lp-hero {
        padding: 100px 0 56px;
        min-height: auto;
    }

    .lp-hero__inner {
        grid-template-columns: 1fr;
        gap: 0;
    }

    .lp-hero__mockup {
        display: none;
    }

    .lp-hero__title {
        font-size: 32px;
    }

    .lp-hero__subtitle {
        font-size: 16px;
    }

    .lp-hero__ctas {
        flex-direction: column;
    }

    .lp-hero__ctas .lp-btn {
        width: 100%;
    }

    .lp-hero__stats {
        flex-direction: column;
        gap: 16px;
    }

    .lp-hero__stat-divider {
        display: none;
    }

    /* Trust */
    .lp-trust__logos {
        gap: 24px;
    }

    .lp-trust__logo {
        max-height: 32px;
    }

    /* How */
    .lp-how__tabs {
        gap: 0;
    }

    .lp-how__tab {
        padding: 10px 20px;
        font-size: 14px;
    }

    .lp-how__steps {
        grid-template-columns: 1fr;
    }

    /* Features */
    .lp-features {
        grid-template-columns: 1fr;
    }

    .lp-mini-features {
        grid-template-columns: repeat(2, 1fr);
    }

    /* Jobs */
    .lp-jobs {
        grid-template-columns: 1fr;
    }

    /* Numbers */
    .lp-numbers {
        grid-template-columns: repeat(2, 1fr);
        gap: 24px;
    }

    .lp-number__value {
        font-size: 36px;
    }

    /* Why */
    .lp-why {
        grid-template-columns: 1fr;
    }

    /* CTA */
    .lp-cta__title {
        font-size: 26px;
    }

    .lp-cta__buttons {
        flex-direction: column;
        align-items: center;
    }

    .lp-cta__buttons .lp-btn {
        width: 100%;
        max-width: 320px;
    }

    /* Footer */
    .lp-footer__grid {
        grid-template-columns: 1fr;
        gap: 36px;
    }

    .lp-footer__brand-desc {
        max-width: 100%;
    }

    .lp-footer__bottom {
        flex-direction: column;
        gap: 16px;
        text-align: center;
    }

    .lp-footer__bottom-links {
        justify-content: center;
    }

    .lp-section__title {
        font-size: 26px;
    }

    .lp-section__subtitle {
        font-size: 15px;
    }

    /* Directory — Mobile */
    .lp-dir-module-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 12px;
    }

    .lp-dir-module-card {
        padding: 14px 16px;
        gap: 10px;
    }

    .lp-dir-module-card__code {
        font-size: 12px;
        padding: 6px 10px;
    }

    .lp-dir-module-card__arrow {
        display: none;
    }

    .lp-dir-consultant-grid {
        grid-template-columns: 1fr;
    }

    .lp-dir-filter-bar__inner {
        flex-direction: column;
        align-items: stretch;
    }

    .lp-dir-filter-bar__filters {
        flex-direction: column;
    }

    .lp-dir-filter-select {
        width: 100%;
    }

    .lp-dir-filter-bar__count {
        text-align: center;
    }

    .lp-dir-seo-grid {
        grid-template-columns: 1fr;
    }

    .lp-dir-related-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .lp-dir-gate-modal {
        padding: 32px 24px;
    }

    /* Jobs — Mobile */
    .lp-job-listing-grid {
        grid-template-columns: 1fr;
    }

    .lp-job-search {
        flex-direction: column;
    }

    .lp-job-search__btn {
        border-left: none;
        border-top: 1px solid rgba(255, 255, 255, 0.15);
        padding: 12px;
    }

    .lp-job-hero-grid {
        grid-template-columns: 1fr;
    }

    .lp-job-hero-card {
        display: none;
    }

    .lp-job-detail-layout {
        grid-template-columns: 1fr;
    }

    .lp-job-detail-sidebar {
        position: static;
    }

    .lp-job-quick-info {
        grid-template-columns: repeat(2, 1fr);
        gap: 10px;
        padding: 16px 0;
    }

    .lp-job-quick-card { padding: 12px; }

    .lp-job-related-grid {
        grid-template-columns: 1fr;
    }

    /* Mobile skill cap = 8 (desktop is 12 via .lp-job-skills--collapsed) */
    .lp-job-skills--collapsed .lp-job-skill-tag:nth-child(n+9) { display: none; }
    .lp-job-skills--expanded  .lp-job-skill-tag                { display: inline-flex; }

    /* Tighter spacing on mobile job detail */
    .lp-job-section { margin-bottom: 24px; }
    .lp-job-sidebar-card { padding: 18px; }
    .lp-job-detail-layout { gap: 20px; }

    .lp-job-mobile-bar {
        display: flex;
        padding-bottom: calc(12px + env(safe-area-inset-bottom, 0px));
    }

    /* Solutions — Mobile */
    .lp-sol-grid {
        grid-template-columns: 1fr;
    }

    .lp-sol-detail-hero {
        grid-template-columns: 1fr;
    }

    .lp-sol-detail-hero-card {
        display: none;
    }

    .lp-sol-detail-layout {
        grid-template-columns: 1fr;
    }

    .lp-sol-sidebar {
        position: static;
    }

    .lp-sol-gallery-wrap {
        grid-template-columns: 1fr;
    }

    .lp-sol-gallery-thumbs {
        flex-direction: row;
        max-height: none;
        overflow-x: auto;
    }

    .lp-sol-gallery-thumb {
        flex: 0 0 auto;
        width: 80px;
    }

    .lp-sol-related-grid {
        grid-template-columns: 1fr;
    }

    .lp-sol-benefits {
        grid-template-columns: 1fr;
    }

    .lp-sol-mobile-bar {
        display: flex;
    }

    /* Legal + About + Contact — Mobile */
    .lp-legal-content {
        padding: 24px;
    }

    .lp-legal-hero h1 {
        font-size: 28px;
    }

    .lp-about-intro {
        grid-template-columns: 1fr;
        gap: 16px;
    }

    .lp-about-values {
        grid-template-columns: 1fr;
    }

    .lp-about-stats {
        gap: 24px;
        padding: 32px 16px;
    }

    .lp-about-stat__value {
        font-size: 28px;
    }

    .lp-contact-grid {
        grid-template-columns: 1fr;
    }

    .lp-contact-form-card,
    .lp-contact-info-card {
        padding: 20px;
    }

    .lp-contact-form .form-row {
        grid-template-columns: 1fr;
    }

    .lp-contact-info-card {
        position: static;
    }

    /* Auth — Mobile */
    .lp-auth-split {
        grid-template-columns: 1fr;
    }

    .lp-auth-side-panel {
        display: none;
    }

    .lp-auth-form-side {
        padding: 32px 20px;
    }

    .lp-auth-header h1 {
        font-size: 22px;
    }

    .lp-auth-role-cards {
        grid-template-columns: 1fr;
    }

    .lp-auth-firm-form {
        padding: 24px;
    }

    .lp-auth-form__row {
        grid-template-columns: 1fr;
    }

    .lp-auth-module-grid {
        grid-template-columns: 1fr;
    }

    .lp-auth-progress__inner {
        gap: 4px;
    }

    .lp-auth-progress__step span {
        display: none;
    }

    .lp-auth-progress__connector {
        width: 16px;
    }

    .lp-auth-pending-steps {
        flex-direction: column;
        gap: 20px;
    }
}

/* =========================================================================
   MODULE LANDING PAGES (/modules, /modules/{slug})
   ========================================================================= */

/* --- Index: Module card --- */
.lp-mod-card { position: relative; transition: all var(--transition-fast); }
.lp-mod-card__link { display: block; text-decoration: none; color: inherit; height: 100%; }
.lp-mod-card__link:hover { color: inherit; }
.lp-mod-card__badges { display: flex; gap: 4px; margin: 8px 0; }
.lp-mod-card__badge {
    display: inline-block;
    padding: 2px 10px;
    border-radius: 50px;
    font-size: 0.6875rem;
    font-weight: 700;
    background: var(--color-warning-light, #fef3c7);
    color: #92400e;
}

/* --- Detail: Feature zigzag --- */
.lp-mod-features { display: flex; flex-direction: column; gap: 20px; max-width: 800px; margin: 0 auto; }
.lp-mod-feature {
    display: flex;
    align-items: flex-start;
    gap: 20px;
    padding: 24px;
    background: var(--color-bg-white);
    border: 1px solid var(--color-border);
    border-radius: var(--card-radius);
    transition: all var(--transition-fast);
}
.lp-mod-feature:hover { box-shadow: 0 4px 16px rgba(0,0,0,0.06); transform: translateY(-2px); }
.lp-mod-feature--reverse { flex-direction: row-reverse; text-align: right; }
.lp-mod-feature__icon {
    width: 48px; height: 48px; border-radius: 12px;
    display: flex; align-items: center; justify-content: center;
    font-size: 1.25rem; flex-shrink: 0;
}
.lp-mod-feature__content h3 { font-size: 1rem; font-weight: 700; color: var(--color-text-primary); margin: 0 0 4px; }
.lp-mod-feature__content p { font-size: 0.9375rem; color: var(--color-text-secondary); margin: 0; line-height: 1.6; }

/* --- Detail: Timeline stepper --- */
.lp-mod-timeline {
    display: flex;
    justify-content: center;
    gap: 0;
    max-width: 960px;
    margin: 0 auto;
    position: relative;
}
.lp-mod-timeline::before {
    content: '';
    position: absolute;
    top: 24px;
    left: 15%;
    right: 15%;
    height: 2px;
    background: var(--color-border);
    z-index: 0;
}
.lp-mod-timeline__step {
    flex: 1;
    text-align: center;
    position: relative;
    z-index: 1;
    padding: 0 12px;
}
.lp-mod-timeline__num {
    width: 48px; height: 48px; border-radius: 50%;
    display: inline-flex; align-items: center; justify-content: center;
    font-size: 1.25rem; font-weight: 800; color: #fff;
    margin-bottom: 14px;
    position: relative;
    box-shadow: 0 0 0 4px var(--color-bg-white, #fff);
}
.lp-mod-timeline__title { font-size: 1rem; font-weight: 700; color: var(--color-text-primary); margin: 0 0 6px; }
.lp-mod-timeline__text { font-size: 0.875rem; color: var(--color-text-secondary); line-height: 1.5; margin: 0; }

/* --- Detail: Scenario cards (use cases) --- */
.lp-mod-scenario { display: flex; overflow: hidden; padding: 0; }
.lp-mod-scenario__bar { width: 4px; flex-shrink: 0; border-radius: 4px 0 0 4px; }
.lp-mod-scenario__body { padding: 24px; flex: 1; }

/* --- Detail: FAQ numbering --- */
.lp-mod-faq__num {
    font-weight: 800;
    font-size: 0.875rem;
    min-width: 24px;
    flex-shrink: 0;
}

/* --- Detail: Other modules grid --- */
.lp-mod-others {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    gap: 16px;
}
.lp-mod-others__card {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 16px 20px;
    background: var(--color-bg-white);
    border: 1px solid var(--color-border);
    border-radius: var(--card-radius);
    text-decoration: none;
    transition: all var(--transition-fast);
}
.lp-mod-others__card:hover { box-shadow: 0 4px 12px rgba(0,0,0,0.06); transform: translateY(-2px); }
.lp-mod-others__icon {
    width: 40px; height: 40px; border-radius: 10px;
    display: flex; align-items: center; justify-content: center;
    font-size: 1.1rem; flex-shrink: 0;
}
.lp-mod-others__info { flex: 1; min-width: 0; }
.lp-mod-others__info strong { display: block; font-size: 0.9375rem; color: var(--color-text-primary); margin-bottom: 2px; }
.lp-mod-others__info span { font-size: 0.8125rem; color: var(--color-text-secondary); display: block; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.lp-mod-others__arrow { color: var(--color-text-muted); font-size: 1rem; flex-shrink: 0; }

/* --- Module landing responsive --- */
@media (max-width: 768px) {
    .lp-mod-feature,
    .lp-mod-feature--reverse { flex-direction: column; text-align: left; }
    .lp-mod-timeline { flex-direction: column; align-items: center; gap: 24px; }
    .lp-mod-timeline::before { display: none; }
    .lp-mod-timeline__step { max-width: 300px; }
    .lp-mod-others { grid-template-columns: 1fr; }
    .lp-mini-features { grid-template-columns: repeat(2, 1fr); }
}

/* =========================================================================
   CONTACT PAGE
   ========================================================================= */

.lp-contact-layout {
    display: grid;
    grid-template-columns: 1.2fr 0.8fr;
    gap: 32px;
    align-items: start;
}
.lp-contact-form__grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
}
.lp-contact-info-list { display: flex; flex-direction: column; gap: 0; }
.lp-contact-info-row {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    padding: 10px 0;
    border-bottom: 1px solid var(--color-border);
    gap: 12px;
}
.lp-contact-info-row:last-child { border-bottom: none; }
.lp-contact-info-label {
    font-size: 0.8125rem;
    color: var(--color-text-muted);
    flex-shrink: 0;
    min-width: 100px;
}
.lp-contact-info-value {
    font-size: 0.8125rem;
    color: var(--color-text-primary);
    text-align: right;
    word-break: break-word;
}

@media (max-width: 768px) {
    .lp-contact-layout { grid-template-columns: 1fr; }
    .lp-contact-form__grid { grid-template-columns: 1fr; }
}

/* =========================================================================
   SOLUTIONS FILTER — More Filters Button + Modal + Active Chips + Pills
   ========================================================================= */

/* More Filters button */
.lp-dir-filter-more {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-family: var(--font-family);
    font-size: 14px;
    font-weight: 600;
    color: var(--color-primary);
    background: var(--color-bg-white);
    border: 1px solid var(--color-primary);
    border-radius: var(--btn-radius);
    padding: 8px 14px;
    cursor: pointer;
    white-space: nowrap;
    transition: all var(--transition-fast);
}
.lp-dir-filter-more:hover {
    background: var(--color-primary);
    color: #fff;
}
.lp-dir-filter-more__badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 20px;
    height: 20px;
    padding: 0 6px;
    border-radius: 10px;
    background: var(--color-primary);
    color: #fff;
    font-size: 11px;
    font-weight: 700;
}
.lp-dir-filter-more:hover .lp-dir-filter-more__badge {
    background: #fff;
    color: var(--color-primary);
}

/* Sort select (no arrow) */
.lp-dir-filter-select--sort {
    background-color: transparent;
    border-color: transparent;
}
.lp-dir-filter-select--sort:hover,
.lp-dir-filter-select--sort:focus {
    background-color: var(--color-bg-white);
    border-color: var(--color-border);
}

/* Active Chips Bar */
.lp-dir-active-chips {
    background: var(--color-bg-alt);
    border-bottom: 1px solid var(--color-border);
    padding: 12px 0;
    position: sticky;
    top: 135px; /* navbar + filter bar */
    z-index: 49;
}
.lp-dir-active-chips__inner {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    align-items: center;
}

/* Generic Chip */
.lp-chip {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 10px 6px 12px;
    background: var(--color-bg-white);
    border: 1px solid var(--color-border);
    border-radius: 20px;
    font-size: 13px;
    font-weight: 500;
    color: var(--color-text-heading);
    transition: all var(--transition-fast);
}
.lp-chip__remove {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 18px;
    height: 18px;
    border-radius: 50%;
    background: var(--color-bg-alt);
    border: none;
    color: var(--color-text-muted);
    cursor: pointer;
    font-size: 10px;
    transition: all var(--transition-fast);
}
.lp-chip__remove:hover {
    background: #ef4444;
    color: #fff;
}

/* Chip outline variant (for tags) */
.lp-chip--outline {
    background: transparent;
    cursor: pointer;
    user-select: none;
}
.lp-chip--outline:hover {
    background: var(--color-bg-alt);
    border-color: var(--color-primary-light);
}
.lp-chip--outline.is-active {
    background: var(--color-primary);
    border-color: var(--color-primary);
    color: #fff;
}
.lp-chip--outline.is-active em {
    color: rgba(255,255,255,0.7);
}

.lp-dir-clear-all {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 12px;
    background: transparent;
    border: none;
    color: var(--color-primary);
    font-size: 13px;
    font-weight: 600;
    cursor: pointer;
    border-radius: 20px;
    transition: background var(--transition-fast);
}
.lp-dir-clear-all:hover {
    background: var(--color-bg-white);
}

/* Modal */
.lp-dir-modal {
    position: fixed;
    inset: 0;
    z-index: 1000;
    display: flex;
    align-items: center;
    justify-content: center;
}
.lp-dir-modal[hidden] { display: none; }
.lp-dir-modal__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(15, 23, 42, 0.6);
    animation: lpModalFade 200ms ease;
}
@keyframes lpModalFade {
    from { opacity: 0; }
    to { opacity: 1; }
}
.lp-dir-modal__content {
    position: relative;
    background: var(--color-bg-white);
    border-radius: 16px;
    width: 92%;
    max-width: 640px;
    max-height: 85vh;
    display: flex;
    flex-direction: column;
    box-shadow: 0 20px 60px rgba(0,0,0,0.2);
    animation: lpModalSlide 250ms cubic-bezier(0.2, 0.9, 0.3, 1);
}
@keyframes lpModalSlide {
    from { opacity: 0; transform: translateY(20px) scale(0.98); }
    to { opacity: 1; transform: translateY(0) scale(1); }
}
.lp-dir-modal__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 20px 24px;
    border-bottom: 1px solid var(--color-border);
}
.lp-dir-modal__header h2 {
    font-size: 18px;
    font-weight: 700;
    margin: 0;
    color: var(--color-text-primary);
}
.lp-dir-modal__close {
    background: transparent;
    border: none;
    color: var(--color-text-muted);
    font-size: 20px;
    cursor: pointer;
    padding: 4px;
    border-radius: 8px;
    transition: all var(--transition-fast);
}
.lp-dir-modal__close:hover {
    background: var(--color-bg-alt);
    color: var(--color-text-primary);
}
.lp-dir-modal__body {
    padding: 20px 24px;
    overflow-y: auto;
    flex: 1;
}
.lp-dir-modal__footer {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    padding: 16px 24px;
    border-top: 1px solid var(--color-border);
    background: var(--color-bg-alt);
    border-radius: 0 0 16px 16px;
}

/* Modal groups */
.lp-dir-modal__group {
    border: none;
    padding: 0;
    margin: 0 0 24px;
}
.lp-dir-modal__group legend {
    font-size: 13px;
    font-weight: 700;
    color: var(--color-text-heading);
    text-transform: uppercase;
    letter-spacing: 0.03em;
    margin-bottom: 10px;
    padding: 0;
}

.lp-dir-modal__row {
    display: flex;
    align-items: center;
    gap: 8px;
}
.lp-dir-modal__input,
.lp-dir-modal__select {
    flex: 1;
    font-family: var(--font-family);
    font-size: 14px;
    padding: 8px 12px;
    border: 1px solid var(--color-border);
    border-radius: var(--btn-radius);
    background: var(--color-bg-white);
    color: var(--color-text-heading);
}
.lp-dir-modal__input:focus,
.lp-dir-modal__select:focus {
    outline: none;
    border-color: var(--color-primary);
}
.lp-dir-modal__dash {
    color: var(--color-text-muted);
    font-weight: 600;
}

/* Checkbox list */
.lp-dir-modal__checks {
    display: flex;
    flex-direction: column;
    gap: 8px;
}
.lp-dir-modal__checks--scroll {
    max-height: 200px;
    overflow-y: auto;
    border: 1px solid var(--color-border);
    border-radius: 8px;
    padding: 8px 12px;
}
.lp-dir-check {
    display: flex;
    align-items: center;
    gap: 10px;
    cursor: pointer;
    font-size: 14px;
    color: var(--color-text-heading);
    user-select: none;
}
.lp-dir-check input[type="checkbox"] {
    appearance: none;
    width: 18px;
    height: 18px;
    border: 1.5px solid var(--color-border);
    border-radius: 4px;
    background: var(--color-bg-white);
    cursor: pointer;
    position: relative;
    flex-shrink: 0;
}
.lp-dir-check input[type="checkbox"]:checked {
    background: var(--color-primary);
    border-color: var(--color-primary);
}
.lp-dir-check input[type="checkbox"]:checked::after {
    content: '';
    position: absolute;
    top: 2px;
    left: 5px;
    width: 5px;
    height: 9px;
    border: solid #fff;
    border-width: 0 2px 2px 0;
    transform: rotate(45deg);
}
.lp-dir-check em {
    color: var(--color-text-muted);
    font-style: normal;
    font-size: 12px;
}

/* Pills group */
.lp-dir-modal__pills {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}
.lp-dir-pill {
    display: inline-flex;
    align-items: center;
    padding: 7px 14px;
    background: var(--color-bg-white);
    border: 1px solid var(--color-border);
    border-radius: 20px;
    font-size: 13px;
    font-weight: 500;
    color: var(--color-text-heading);
    cursor: pointer;
    transition: all var(--transition-fast);
    user-select: none;
}
.lp-dir-pill:hover {
    border-color: var(--color-primary-light);
    color: var(--color-primary);
}
.lp-dir-pill.is-active {
    background: var(--color-primary);
    border-color: var(--color-primary);
    color: #fff;
}
.lp-dir-pill input {
    display: none;
}

/* Toggle switch */
.lp-dir-toggle {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    cursor: pointer;
    font-size: 14px;
    color: var(--color-text-heading);
    user-select: none;
}
.lp-dir-toggle input {
    display: none;
}
.lp-dir-toggle__track {
    display: inline-block;
    width: 40px;
    height: 22px;
    border-radius: 12px;
    background: var(--color-border);
    position: relative;
    transition: background var(--transition-fast);
    flex-shrink: 0;
}
.lp-dir-toggle__track::after {
    content: '';
    position: absolute;
    top: 2px;
    left: 2px;
    width: 18px;
    height: 18px;
    border-radius: 50%;
    background: #fff;
    transition: transform var(--transition-fast);
    box-shadow: 0 1px 3px rgba(0,0,0,0.2);
}
.lp-dir-toggle input:checked ~ .lp-dir-toggle__track {
    background: var(--color-primary);
}
.lp-dir-toggle input:checked ~ .lp-dir-toggle__track::after {
    transform: translateX(18px);
}

/* Tags group */
.lp-dir-modal__tags {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}
.lp-dir-modal__tags .lp-chip--outline {
    cursor: pointer;
    padding: 5px 10px;
    font-size: 12px;
}
.lp-dir-modal__tags .lp-chip--outline em {
    color: var(--color-text-muted);
    font-style: normal;
    margin-left: 4px;
}

/* SEO internal links */
.lp-sol-seo-links {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}
.lp-sol-seo-links a {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 6px 12px;
    background: var(--color-bg-white);
    border: 1px solid var(--color-border);
    border-radius: 20px;
    font-size: 13px;
    color: var(--color-text-heading);
    text-decoration: none;
    transition: all var(--transition-fast);
}
.lp-sol-seo-links a:hover {
    border-color: var(--color-primary);
    color: var(--color-primary);
}
.lp-sol-seo-links a span {
    color: var(--color-text-muted);
    font-size: 12px;
}

/* Mobile adjustments */
@media (max-width: 768px) {
    .lp-dir-filter-bar__inner { flex-wrap: wrap; }
    .lp-dir-filter-bar__filters { flex-wrap: wrap; gap: 8px; }
    .lp-dir-filter-bar__right { width: 100%; justify-content: space-between; margin-left: 0; }
    .lp-dir-active-chips { top: auto; position: relative; }
    .lp-dir-modal__content { width: 95%; max-height: 90vh; }
    .lp-dir-modal__row { flex-wrap: wrap; }
}

/* ==========================================================================
   Auth Pages — verify, forgot, reset (mirror login structure)
   ========================================================================== */

/* Hero icon (large circular icon at top of card) */
.lp-auth-icon-hero {
    width: 80px;
    height: 80px;
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 20px;
    font-size: 36px;
    color: var(--color-text-white);
    box-shadow: 0 8px 24px rgba(15, 23, 42, 0.08);
}
.lp-auth-icon-hero--primary {
    background: linear-gradient(135deg, var(--color-primary), var(--color-primary-light));
}
.lp-auth-icon-hero--success {
    background: linear-gradient(135deg, var(--color-success), #34d399);
    width: 96px;
    height: 96px;
    font-size: 44px;
}
.lp-auth-icon-hero--warning {
    background: linear-gradient(135deg, var(--color-warning), #fbbf24);
}
.lp-auth-icon-hero--soft-primary {
    background: #eff6ff;
    color: var(--color-primary);
    box-shadow: none;
}
.lp-auth-icon-hero--pulse {
    animation: lpAuthIconPulse 2s ease-in-out infinite;
}
@keyframes lpAuthIconPulse {
    0%, 100% { transform: scale(1); box-shadow: 0 8px 24px rgba(30, 64, 175, 0.18); }
    50% { transform: scale(1.04); box-shadow: 0 12px 32px rgba(30, 64, 175, 0.32); }
}

.lp-auth-card-center {
    text-align: center;
}
.lp-auth-card-center .lp-auth-header {
    text-align: center;
    margin-bottom: 24px;
}

/* Email pill (shows user's email) */
.lp-auth-email-pill {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 14px 18px;
    background: var(--color-bg-alt);
    border: 1px solid var(--color-border);
    border-radius: 12px;
    margin-bottom: 18px;
    text-align: left;
}
.lp-auth-email-pill__content {
    display: flex;
    flex-direction: column;
    min-width: 0;
}
.lp-auth-email-pill__label {
    font-size: 11px;
    font-weight: 600;
    color: var(--color-text-light);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: 2px;
}
.lp-auth-email-pill__value {
    font-size: 14px;
    font-weight: 600;
    color: var(--color-text-heading);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.lp-auth-email-pill__copy {
    background: transparent;
    border: 1px solid var(--color-border);
    border-radius: 8px;
    width: 36px;
    height: 36px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--color-text-body);
    cursor: pointer;
    transition: all var(--transition-fast);
    flex-shrink: 0;
}
.lp-auth-email-pill__copy:hover {
    background: var(--color-bg-white);
    color: var(--color-primary);
    border-color: var(--color-primary-light);
}
.lp-auth-email-pill__copy.is-copied {
    background: var(--color-success);
    border-color: var(--color-success);
    color: var(--color-text-white);
}

/* Warning strip (spam reminder) */
.lp-auth-warning-strip {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    padding: 12px 14px;
    background: #fffbeb;
    border: 1px solid #fde68a;
    border-left-width: 3px;
    border-radius: 10px;
    margin-bottom: 20px;
    font-size: 13px;
    line-height: 1.5;
    color: #92400e;
    text-align: left;
}
.lp-auth-warning-strip i {
    font-size: 16px;
    margin-top: 1px;
    flex-shrink: 0;
}

/* Status alert (success/warning/danger/info) — slide-down */
.lp-auth-alert {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    padding: 12px 14px;
    border-radius: 10px;
    margin-bottom: 16px;
    font-size: 13px;
    font-weight: 500;
    line-height: 1.5;
    text-align: left;
    animation: lpAuthAlertSlideDown 0.2s ease-out;
}
.lp-auth-alert i {
    font-size: 16px;
    margin-top: 1px;
    flex-shrink: 0;
}
.lp-auth-alert--success {
    background: #f0fdf4;
    border: 1px solid #bbf7d0;
    color: #166534;
}
.lp-auth-alert--warning {
    background: #fffbeb;
    border: 1px solid #fde68a;
    color: #92400e;
}
.lp-auth-alert--danger {
    background: #fef2f2;
    border: 1px solid #fecaca;
    color: #b91c1c;
}
.lp-auth-alert--info {
    background: #eff6ff;
    border: 1px solid #bfdbfe;
    color: #1d4ed8;
}
@keyframes lpAuthAlertSlideDown {
    from { opacity: 0; transform: translateY(-6px); }
    to { opacity: 1; transform: translateY(0); }
}

/* Cooldown text below CTA */
.lp-auth-cooldown {
    font-size: 12px;
    color: var(--color-text-light);
    text-align: center;
    margin-top: 10px;
    min-height: 18px;
    font-weight: 500;
}
.lp-auth-cooldown--active {
    color: var(--color-warning);
}

/* CTA spinner (inline SVG, replaces icon while submitting) */
.lp-auth-spinner {
    display: inline-block;
    width: 16px;
    height: 16px;
    border: 2px solid currentColor;
    border-right-color: transparent;
    border-radius: 50%;
    animation: lpAuthSpin 0.7s linear infinite;
    vertical-align: middle;
}
@keyframes lpAuthSpin {
    to { transform: rotate(360deg); }
}

/* Provider quick-access buttons (Gmail/Outlook/Yahoo) */
.lp-auth-providers {
    margin-bottom: 20px;
}
.lp-auth-providers__label {
    font-size: 12px;
    color: var(--color-text-light);
    margin-bottom: 8px;
    text-align: center;
}
.lp-auth-provider-grid {
    display: flex;
    gap: 8px;
    justify-content: center;
    flex-wrap: wrap;
}
.lp-auth-provider-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 14px;
    background: var(--color-bg-white);
    border: 1px solid var(--color-border);
    border-radius: 999px;
    font-size: 13px;
    font-weight: 500;
    color: var(--color-text-body);
    text-decoration: none;
    transition: all var(--transition-fast);
}
.lp-auth-provider-btn:hover {
    border-color: var(--color-primary-light);
    color: var(--color-primary);
    transform: translateY(-1px);
    box-shadow: 0 2px 8px rgba(15, 23, 42, 0.06);
}
.lp-auth-provider-btn img {
    width: 14px;
    height: 14px;
    border-radius: 2px;
}

/* Password rules checklist (live) */
.lp-auth-rules {
    list-style: none;
    margin: 10px 0 0;
    padding: 0;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 4px 12px;
}
.lp-auth-rules__item {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 12px;
    color: var(--color-text-light);
    transition: color var(--transition-fast);
}
.lp-auth-rules__item::before {
    content: '○';
    font-size: 14px;
    line-height: 1;
    color: var(--color-text-light);
    transition: all var(--transition-fast);
}
.lp-auth-rules__item--ok {
    color: var(--color-success);
}
.lp-auth-rules__item--ok::before {
    content: '✓';
    color: var(--color-success);
    font-weight: 700;
}

/* Empty state (token expired) */
.lp-auth-empty-state {
    text-align: center;
}
.lp-auth-empty-state .lp-auth-icon-hero {
    margin-bottom: 20px;
}
.lp-auth-empty-state__title {
    font-size: 22px;
    font-weight: 700;
    color: var(--color-text-heading);
    margin-bottom: 8px;
}
.lp-auth-empty-state__desc {
    font-size: 14px;
    color: var(--color-text-body);
    line-height: 1.6;
    margin-bottom: 24px;
    max-width: 360px;
    margin-left: auto;
    margin-right: auto;
}

/* Footer link variant for back-to-login */
.lp-auth-back-link {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 13px;
    color: var(--color-text-body);
    text-decoration: none;
    font-weight: 500;
    transition: color var(--transition-fast);
}
.lp-auth-back-link:hover {
    color: var(--color-primary);
}

/* Reduced motion — kill animations */
@media (prefers-reduced-motion: reduce) {
    .lp-auth-icon-hero--pulse,
    .lp-auth-alert,
    .lp-auth-spinner,
    .lp-auth-provider-btn {
        animation: none !important;
        transition: none !important;
    }
}

/* Mobile tweaks for new auth elements */
@media (max-width: 480px) {
    .lp-auth-rules {
        grid-template-columns: 1fr;
    }
    .lp-auth-provider-grid {
        flex-direction: column;
    }
    .lp-auth-provider-btn {
        justify-content: center;
    }
    .lp-auth-icon-hero {
        width: 72px;
        height: 72px;
        font-size: 32px;
    }
    .lp-auth-icon-hero--success {
        width: 84px;
        height: 84px;
        font-size: 38px;
    }
}


/* ═══════════════════════════════════════════════════════════════════════
   AUDIENCE SEGMENTS — conversion-focused 3-card section
   Asymmetric grid: firm card weighted (revenue source)
   ═══════════════════════════════════════════════════════════════════════ */
.lp-audiences {
    padding: 96px 0 64px;
    background: linear-gradient(180deg, #f8fafc 0%, #ffffff 100%);
}
.lp-audiences__title {
    font-size: clamp(1.5rem, 2.4vw + 1rem, 2.25rem);
    font-weight: 800;
    color: #0f172a;
    text-align: center;
    margin: 0 0 48px;
    letter-spacing: -0.02em;
}
.lp-audiences__grid {
    display: grid;
    grid-template-columns: 1fr 1.4fr 1fr;
    gap: 24px;
    align-items: stretch;
}
.lp-aud-card {
    position: relative;
    display: flex;
    flex-direction: column;
    background: #ffffff;
    border: 1px solid #e2e8f0;
    border-radius: 18px;
    padding: 32px 28px;
    text-decoration: none;
    color: inherit;
    transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.04);
}
.lp-aud-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 10px 30px rgba(15, 23, 42, 0.10);
    border-color: #cbd5e1;
}
.lp-aud-card__icon {
    width: 52px;
    height: 52px;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(59, 130, 246, 0.08);
    color: #2563eb;
    font-size: 24px;
    margin-bottom: 18px;
}
.lp-aud-card__title {
    font-size: 1.35rem;
    font-weight: 700;
    color: #0f172a;
    margin: 0 0 16px;
    letter-spacing: -0.01em;
}
.lp-aud-card__list {
    list-style: none;
    padding: 0;
    margin: 0 0 24px;
    flex: 1 1 auto;
}
.lp-aud-card__list li {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    padding: 6px 0;
    color: #475569;
    font-size: 14.5px;
    line-height: 1.5;
}
.lp-aud-card__list li i {
    color: #10b981;
    font-size: 16px;
    margin-top: 2px;
    flex-shrink: 0;
}
.lp-aud-card__extra {
    margin: -8px 0 20px;
    padding: 10px 14px;
    background: rgba(59, 130, 246, 0.06);
    border-left: 3px solid #3b82f6;
    border-radius: 6px;
    color: #1e40af;
    font-size: 13.5px;
    font-weight: 600;
}
.lp-aud-card__cta {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 12px 20px;
    border-radius: 10px;
    font-weight: 600;
    font-size: 14.5px;
    transition: all 0.2s ease;
    align-self: flex-start;
    margin-top: auto;
}
.lp-aud-card__cta--primary {
    background: linear-gradient(135deg, #1e40af, #3b82f6);
    color: #ffffff;
}
.lp-aud-card__cta--secondary {
    background: #f1f5f9;
    color: #1e40af;
}
.lp-aud-card__cta--ghost {
    background: transparent;
    color: #64748b;
    border: 1px solid #e2e8f0;
}
.lp-aud-card:hover .lp-aud-card__cta--primary {
    filter: brightness(1.08);
    transform: translateX(2px);
}
.lp-aud-card:hover .lp-aud-card__cta--secondary {
    background: #e2e8f0;
}
.lp-aud-card:hover .lp-aud-card__cta--ghost {
    background: #f8fafc;
    color: #0f172a;
}
/* Featured (firm) — visually heavier */
.lp-aud-card--featured {
    background: linear-gradient(180deg, #ffffff 0%, #f0f7ff 100%);
    border: 2px solid #3b82f6;
    box-shadow: 0 8px 24px rgba(59, 130, 246, 0.12);
    transform: translateY(-8px);
}
.lp-aud-card--featured:hover {
    transform: translateY(-12px);
    box-shadow: 0 16px 40px rgba(59, 130, 246, 0.18);
    border-color: #2563eb;
}
.lp-aud-card--featured .lp-aud-card__icon {
    background: linear-gradient(135deg, #1e40af, #3b82f6);
    color: #ffffff;
    width: 60px;
    height: 60px;
    font-size: 28px;
}
.lp-aud-card--featured .lp-aud-card__title {
    font-size: 1.5rem;
}
.lp-aud-card__badge {
    position: absolute;
    top: -12px;
    right: 20px;
    background: linear-gradient(135deg, #10b981, #059669);
    color: #ffffff;
    font-size: 11px;
    font-weight: 700;
    padding: 5px 12px;
    border-radius: 20px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    box-shadow: 0 2px 8px rgba(16, 185, 129, 0.25);
}
@media (max-width: 920px) {
    .lp-audiences__grid {
        grid-template-columns: 1fr;
        gap: 18px;
    }
    .lp-aud-card--featured {
        transform: none;
        order: -1;  /* firm card first on mobile */
    }
    .lp-aud-card--featured:hover {
        transform: translateY(-4px);
    }
    .lp-audiences {
        padding: 64px 0 40px;
    }
}
