/* ============================================
   Landing / SEO Pages — standalone stylesheet
   Only Bootstrap is loaded before this file.
   ============================================ */

/* --- Tokens --- */
.seo-landing-page {
    --lp-primary: #7209b7;
    --lp-primary-dark: #5a0891;
    --lp-primary-light: #9d4edd;
    --lp-accent: #4cc9f0;
    --lp-dark: #0f172a;
    --lp-dark-soft: #1e293b;
    --lp-gray-700: #374151;
    --lp-gray-500: #6b7280;
    --lp-gray-400: #9ca3af;
    --lp-gray-200: #e5e7eb;
    --lp-gray-100: #f3f4f6;
    --lp-gray-50: #f9fafb;
    --lp-white: #ffffff;
    --lp-surface: #f8f9fc;
    --lp-success: #059669;
    --lp-warning: #d97706;
    --lp-danger: #dc2626;
    --lp-info: #0891b2;
    --lp-radius: 16px;
    --lp-radius-sm: 10px;
    --lp-radius-lg: 24px;
    --lp-shadow: 0 4px 20px rgba(0,0,0,0.06);
    --lp-shadow-lg: 0 12px 40px rgba(0,0,0,0.1);
}

/* --- Base --- */
.seo-landing-page {
    font-family: 'Outfit', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    color: var(--lp-gray-700);
    line-height: 1.7;
}
.seo-landing-page h1, .seo-landing-page h2, .seo-landing-page h3,
.seo-landing-page h4, .seo-landing-page h5 {
    color: var(--lp-dark);
    line-height: 1.2;
    letter-spacing: -0.02em;
}
.seo-landing-page p      { color: var(--lp-gray-500); }
.seo-landing-page .lead  { color: var(--lp-gray-500); font-weight: 400; }

/* --- Navbar dropdown --- */
@media (min-width: 992px) {
    .seo-dropdown {
        border: none; box-shadow: 0 10px 40px rgba(0,0,0,0.1);
        border-radius: 14px; padding: 0.5rem; margin-top: 10px;
    }
    .seo-dropdown::before {
        content: ''; position: absolute; top: -16px; left: 0; width: 100%; height: 16px;
    }
    .seo-dropdown::after {
        content: ''; position: absolute; top: -7px; left: 24px;
        border-bottom: 7px solid #fff; border-left: 7px solid transparent; border-right: 7px solid transparent;
    }
    .nav-item.dropdown:hover > .seo-dropdown {
        display: block; animation: lpFadeUp .2s ease-out;
    }
}
@keyframes lpFadeUp {
    from { opacity: 0; transform: translateY(8px); }
    to   { opacity: 1; transform: translateY(0); }
}
.seo-dropdown .dropdown-item { border-radius: 10px; transition: background .15s, transform .15s; }
.seo-dropdown .dropdown-item:hover { background: #f3f4f6; transform: translateX(3px); }
.seo-drop-icon {
    width: 32px; height: 32px; display: inline-flex; align-items: center;
    justify-content: center; border-radius: 8px; font-size: 0.9rem; flex-shrink: 0;
}

/* --- Buttons --- */
.seo-landing-page .btn {
    display: inline-block;
    border-radius: 10px;
    font-weight: 600;
    line-height: 1.5;
    transition: background-color .2s ease, box-shadow .2s ease, transform .2s ease;
}
.seo-landing-page .btn-lg {
    padding: 0.7rem 1.75rem;
    font-size: 1.05rem;
}

.seo-landing-page .btn-primary {
    background: var(--lp-primary); border: 2px solid var(--lp-primary); color: #fff;
    box-shadow: 0 2px 8px rgba(114,9,183,.25);
}
.seo-landing-page .btn-primary:hover {
    background: var(--lp-primary-dark); border-color: var(--lp-primary-dark);
    transform: translateY(-1px); box-shadow: 0 4px 16px rgba(114,9,183,.35);
}

.seo-landing-page .btn-outline-primary {
    background: transparent; border: 2px solid var(--lp-primary); color: var(--lp-primary);
}
.seo-landing-page .btn-outline-primary:hover {
    background: var(--lp-primary); color: #fff;
    transform: translateY(-1px); box-shadow: 0 2px 8px rgba(114,9,183,.25);
}

.seo-landing-page .btn-outline-light {
    background: transparent; border: 2px solid rgba(255,255,255,.5); color: #fff;
}
.seo-landing-page .btn-outline-light:hover {
    background: rgba(255,255,255,.15); border-color: rgba(255,255,255,.8);
    transform: translateY(-1px);
}

.seo-landing-page .btn-light {
    background: #fff; border: 2px solid #fff; color: var(--lp-primary);
    box-shadow: 0 2px 8px rgba(0,0,0,.08);
}
.seo-landing-page .btn-light:hover {
    background: #f3f4f6; border-color: #f3f4f6; transform: translateY(-1px);
}

.seo-landing-page .btn-dark {
    background: var(--lp-dark); border: 2px solid var(--lp-dark); color: #fff;
}
.seo-landing-page .btn-dark:hover {
    background: var(--lp-dark-soft); border-color: var(--lp-dark-soft); transform: translateY(-1px);
}

.seo-landing-page .btn-warning {
    background: #f59e0b; border: 2px solid #f59e0b; color: var(--lp-dark);
}
.seo-landing-page .btn-warning:hover {
    background: #d97706; border-color: #d97706; transform: translateY(-1px);
}

/* --- Hero --- */
.seo-landing-page .lp-hero {
    padding: 5.5rem 0 4.5rem;
    position: relative; overflow: hidden;
}
.seo-landing-page .lp-hero::before {
    content: ''; position: absolute; inset: 0;
    background: radial-gradient(ellipse at 20% 50%, rgba(114,9,183,.06) 0%, transparent 60%),
                radial-gradient(ellipse at 80% 20%, rgba(76,201,240,.06) 0%, transparent 60%);
    pointer-events: none;
}
.seo-landing-page .lp-hero-gradient {
    background: linear-gradient(135deg, #7209b7 0%, #560bad 40%, #480ca8 100%);
    color: #fff;
}
.seo-landing-page .lp-hero-gradient::before {
    background: radial-gradient(ellipse at 30% 0%, rgba(76,201,240,.2) 0%, transparent 60%),
                radial-gradient(ellipse at 80% 100%, rgba(157,78,221,.3) 0%, transparent 60%);
}
.seo-landing-page .lp-hero-gradient .lp-hero-dot-pattern {
    position: absolute; inset: 0;
    background-image: radial-gradient(rgba(255,255,255,.12) 1px, transparent 1px);
    background-size: 24px 24px; pointer-events: none;
}
.seo-landing-page .lp-hero h1 {
    font-size: clamp(2.2rem, 5vw, 3.5rem); font-weight: 800;
    letter-spacing: -0.03em; line-height: 1.1; margin-bottom: 1.5rem;
}
.seo-landing-page .lp-hero-gradient h1 { color: #fff; }
.seo-landing-page .lp-hero .lead {
    font-size: clamp(1.05rem, 2vw, 1.25rem); max-width: 640px; margin: 0 auto;
}
.seo-landing-page .lp-hero-gradient .lead { color: rgba(255,255,255,.85); }

/* --- Badges --- */
.seo-landing-page .lp-badge {
    display: inline-flex; align-items: center; gap: .4rem;
    padding: .4rem 1rem; border-radius: 50rem; font-size: .8rem;
    font-weight: 600; margin-bottom: 1.25rem; border: 1px solid transparent;
}
.seo-landing-page .lp-badge-primary { background: rgba(114,9,183,.1); color: var(--lp-primary); border-color: rgba(114,9,183,.15); }
.seo-landing-page .lp-badge-light   { background: rgba(255,255,255,.2); color: #fff; border-color: rgba(255,255,255,.25); }
.seo-landing-page .lp-badge-success { background: rgba(5,150,105,.1); color: var(--lp-success); border-color: rgba(5,150,105,.15); }
.seo-landing-page .lp-badge-warning { background: rgba(217,119,6,.1); color: var(--lp-warning); border-color: rgba(217,119,6,.15); }
.seo-landing-page .lp-badge-info    { background: rgba(8,145,178,.1); color: var(--lp-info); border-color: rgba(8,145,178,.15); }

/* --- Sections --- */
.seo-landing-page .lp-section         { padding: 5rem 0; }
.seo-landing-page .lp-section-alt      { background: var(--lp-surface); }
.seo-landing-page .lp-section-heading  { margin-bottom: 3.5rem; }
.seo-landing-page .lp-section-heading h2 {
    font-size: clamp(1.75rem, 3.5vw, 2.5rem); font-weight: 800; letter-spacing: -0.03em; margin-bottom: .75rem;
}
.seo-landing-page .lp-section-heading p { font-size: 1.1rem; max-width: 580px; margin: 0 auto; }
.seo-landing-page .lp-overline {
    font-size: .75rem; font-weight: 700; text-transform: uppercase;
    letter-spacing: .1em; color: var(--lp-primary); display: block; margin-bottom: .5rem;
}

/* --- Cards --- */
.seo-landing-page .lp-card {
    background: #fff; border: 1px solid var(--lp-gray-200); border-radius: var(--lp-radius);
    padding: 2rem; transition: border-color .25s, box-shadow .25s, transform .25s; height: 100%;
}
.seo-landing-page .lp-card:hover {
    border-color: rgba(114,9,183,.2); box-shadow: var(--lp-shadow); transform: translateY(-4px);
}
.seo-landing-page .lp-card-flat {
    background: #fff; border: 1px solid var(--lp-gray-200); border-radius: var(--lp-radius); padding: 2rem; height: 100%;
}
.seo-landing-page .lp-card-icon {
    width: 52px; height: 52px; display: inline-flex; align-items: center; justify-content: center;
    border-radius: 14px; font-size: 1.35rem; margin-bottom: 1.25rem; flex-shrink: 0;
}
.seo-landing-page .lp-card h3 { font-size: 1.15rem; font-weight: 700; margin-bottom: .6rem; }
.seo-landing-page .lp-card p,
.seo-landing-page .lp-card-flat p { font-size: .93rem; line-height: 1.65; margin-bottom: 0; }

/* Icon colours */
.seo-landing-page .lp-icon-primary { background: rgba(114,9,183,.1);  color: var(--lp-primary); }
.seo-landing-page .lp-icon-accent  { background: rgba(76,201,240,.12); color: #3ab5db; }
.seo-landing-page .lp-icon-success { background: rgba(5,150,105,.1);  color: var(--lp-success); }
.seo-landing-page .lp-icon-warning { background: rgba(245,158,11,.1); color: var(--lp-warning); }
.seo-landing-page .lp-icon-danger  { background: rgba(220,38,38,.1);  color: var(--lp-danger); }
.seo-landing-page .lp-icon-info    { background: rgba(8,145,178,.1);  color: var(--lp-info); }
.seo-landing-page .lp-icon-dark    { background: rgba(15,23,42,.08);  color: var(--lp-dark); }

/* --- Steps --- */
.seo-landing-page .lp-step-num {
    width: 56px; height: 56px; display: inline-flex; align-items: center; justify-content: center;
    border-radius: 50%; font-size: 1.25rem; font-weight: 800; margin-bottom: 1.25rem;
    background: var(--lp-primary); color: #fff; box-shadow: 0 4px 12px rgba(114,9,183,.25);
}

/* --- Check lists --- */
.seo-landing-page .lp-check-list { list-style: none; padding: 0; margin: 0; }
.seo-landing-page .lp-check-list li {
    display: flex; align-items: flex-start; gap: .75rem;
    padding: .65rem 0; font-size: .95rem; color: var(--lp-gray-700);
}
.seo-landing-page .lp-check-list li i {
    color: var(--lp-success); font-size: 1.15rem; margin-top: 2px; flex-shrink: 0;
}
.seo-landing-page .lp-check-list li strong { color: var(--lp-dark); }

/* --- Stats --- */
.seo-landing-page .lp-stat       { text-align: center; padding: 1.5rem; }
.seo-landing-page .lp-stat-value {
    font-size: 2.75rem; font-weight: 800; letter-spacing: -0.03em; line-height: 1; margin-bottom: .25rem;
    background: linear-gradient(135deg, var(--lp-primary), var(--lp-accent));
    -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}
.seo-landing-page .lp-stat-label { font-size: .85rem; color: var(--lp-gray-500); font-weight: 500; }

/* --- Mock panel --- */
.seo-landing-page .lp-mock-panel {
    background: #fff; border: 1px solid var(--lp-gray-200);
    border-radius: var(--lp-radius-lg); overflow: hidden; box-shadow: var(--lp-shadow-lg);
}
.seo-landing-page .lp-mock-panel-header {
    padding: 1rem 1.5rem; border-bottom: 1px solid var(--lp-gray-200); background: var(--lp-gray-50);
    display: flex; align-items: center; justify-content: space-between;
}
.seo-landing-page .lp-mock-panel-body { padding: 1.5rem; }
.seo-landing-page .lp-mock-row {
    display: flex; align-items: center; justify-content: space-between;
    padding: .75rem 0; border-bottom: 1px solid var(--lp-gray-100);
}
.seo-landing-page .lp-mock-row:last-child { border-bottom: none; }
.seo-landing-page .lp-mock-bar     { height: 6px; border-radius: 3px; background: var(--lp-gray-200); overflow: hidden; }
.seo-landing-page .lp-mock-bar-fill { height: 100%; border-radius: 3px; }

/* --- Quote --- */
.seo-landing-page .lp-quote-section {
    background: linear-gradient(135deg, var(--lp-primary), #560bad); color: #fff;
    position: relative; overflow: hidden;
}
.seo-landing-page .lp-quote-section::before {
    content: ''; position: absolute; inset: 0;
    background: radial-gradient(ellipse at 20% 80%, rgba(76,201,240,.15) 0%, transparent 60%);
    pointer-events: none;
}
.seo-landing-page .lp-quote {
    font-size: clamp(1.25rem, 3vw, 1.75rem); font-weight: 600; line-height: 1.4; margin-bottom: 1.5rem;
}
.seo-landing-page .lp-quote-cite { font-size: 1rem; opacity: .75; font-style: normal; }

/* --- CTA --- */
.seo-landing-page .lp-cta { padding: 5rem 0; text-align: center; position: relative; overflow: hidden; }
.seo-landing-page .lp-cta-dark {
    background: linear-gradient(135deg, #0f172a, #1e293b 50%, #0f172a); color: #fff;
}
.seo-landing-page .lp-cta-dark::before {
    content: ''; position: absolute; inset: 0;
    background: radial-gradient(ellipse at 30% 50%, rgba(114,9,183,.15) 0%, transparent 60%),
                radial-gradient(ellipse at 70% 50%, rgba(76,201,240,.1)  0%, transparent 60%);
    pointer-events: none;
}
.seo-landing-page .lp-cta h2 {
    font-size: clamp(1.75rem, 3.5vw, 2.75rem); font-weight: 800; letter-spacing: -0.03em; margin-bottom: 1rem;
}
.seo-landing-page .lp-cta-dark h2 { color: #fff; }
.seo-landing-page .lp-cta p       { font-size: 1.1rem; margin-bottom: 2rem; }
.seo-landing-page .lp-cta-dark p  { color: rgba(255,255,255,.65); }
.seo-landing-page .lp-cta-subtle  { font-size: .85rem; opacity: .55; margin-top: 1rem; }

/* --- FAQ --- */
.seo-landing-page .lp-faq .accordion-item { background: transparent; border: none; margin-bottom: .75rem; }
.seo-landing-page .lp-faq .accordion-button {
    background: #fff; border: 1px solid var(--lp-gray-200); border-radius: var(--lp-radius-sm) !important;
    font-weight: 600; color: var(--lp-dark); padding: 1.1rem 1.5rem; box-shadow: none; font-size: .95rem;
}
.seo-landing-page .lp-faq .accordion-button:not(.collapsed) {
    color: var(--lp-primary); border-color: rgba(114,9,183,.2); box-shadow: 0 2px 8px rgba(114,9,183,.08);
}
.seo-landing-page .lp-faq .accordion-body {
    padding: .75rem 1.5rem 1.25rem; font-size: .93rem; color: var(--lp-gray-500); line-height: 1.7;
}

/* --- Table preview --- */
.seo-landing-page .lp-table-preview {
    border-radius: var(--lp-radius-lg); overflow: hidden;
    border: 1px solid var(--lp-gray-200); box-shadow: var(--lp-shadow-lg);
}
.seo-landing-page .lp-table-preview .table { margin-bottom: 0; font-size: .88rem; }
.seo-landing-page .lp-table-preview thead th {
    background: var(--lp-gray-50); border-bottom: 2px solid var(--lp-gray-200);
    font-weight: 700; color: var(--lp-dark); padding: .85rem 1rem;
    font-size: .82rem; text-transform: uppercase; letter-spacing: .04em;
}
.seo-landing-page .lp-table-preview td { padding: .85rem 1rem; vertical-align: top; color: var(--lp-gray-500); }

/* --- Footer --- */
.lp-footer {
    background: #0f172a; color: rgba(255,255,255,.65); padding: 4rem 0 2rem;
}
.lp-footer a { color: rgba(255,255,255,.65); text-decoration: none; font-size: .9rem; transition: color .2s; }
.lp-footer a:hover { color: #fff; }
.lp-footer-heading {
    color: #fff; font-size: .8rem; font-weight: 700;
    text-transform: uppercase; letter-spacing: .08em; margin-bottom: 1.25rem;
}
.lp-footer-links { list-style: none; padding: 0; margin: 0; }
.lp-footer-links li { margin-bottom: .65rem; }
.lp-footer-bottom {
    border-top: 1px solid rgba(255,255,255,.08); margin-top: 3rem;
    padding-top: 1.5rem; font-size: .82rem; color: rgba(255,255,255,.4);
}

/* --- Responsive --- */
@media (max-width: 991.98px) {
    .seo-landing-page .lp-hero    { padding: 4rem 0 3rem; }
    .seo-landing-page .lp-section { padding: 3.5rem 0; }
    .seo-landing-page .lp-cta     { padding: 3.5rem 0; }
    .seo-landing-page .lp-section-heading { margin-bottom: 2.5rem; }
}
@media (max-width: 767.98px) {
    .seo-landing-page .lp-hero    { padding: 3rem 0 2.5rem; }
    .seo-landing-page .lp-section { padding: 2.5rem 0; }
    .seo-landing-page .lp-card    { padding: 1.5rem; }
}
