/* ZEROPO LP – Clean & Fast */
@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&display=swap');

:root {
    --bg: #0c0c0f;
    --card: #18181c;
    --border: rgba(255, 255, 255, .06);
    --accent: #E9407A;
    --accent2: #FF6B9D;
    --t1: #F2F2F5;
    --t2: rgba(255, 255, 255, .7);
    --t3: rgba(255, 255, 255, .4);
    --r: 16px;
}

* {
    margin: 0;
    padding: 0;
    box-sizing: border-box
}

html {
    scroll-behavior: smooth
}

body.lp-body {
    font-family: "Plus Jakarta Sans", system-ui, sans-serif;
    background: var(--bg);
    color: var(--t1);
    line-height: 1.7;
    -webkit-font-smoothing: antialiased
}

/* Gradient text util */
.grad {
    background: linear-gradient(135deg, var(--accent), var(--accent2));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text
}

/* ---- Nav ---- */
.lp-nav {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 100;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 14px 24px;
    background: rgba(12, 12, 15, .85);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border-bottom: 1px solid var(--border)
}

.lp-nav-logo {
    display: flex;
    align-items: center;
    gap: 8px;
    text-decoration: none
}

.lp-nav-logo img {
    width: 28px;
    height: 28px;
    border-radius: 7px
}

.lp-nav-logo span {
    font-size: 1.05rem;
    font-weight: 700;
    color: var(--accent)
}

.lp-nav-right {
    display: flex;
    align-items: center;
    gap: 18px
}

.lp-nav-link {
    color: var(--t3);
    font-size: .8rem;
    font-weight: 500;
    text-decoration: none;
    transition: color .2s
}

.lp-nav-link:hover {
    color: var(--t1)
}

.lp-nav-login {
    padding: 8px 20px;
    min-height: 44px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: var(--accent);
    color: #fff;
    font-weight: 600;
    font-size: .82rem;
    border-radius: 8px;
    text-decoration: none;
    transition: opacity .2s, transform .15s;
    -webkit-tap-highlight-color: transparent;
}

.lp-nav-login:hover {
    opacity: .85;
}

.lp-nav-login:active {
    transform: translateY(1px);
    opacity: 0.9;
}

/* ---- Buttons ---- */
.btn-accent {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 14px 28px;
    min-height: 44px;
    background: linear-gradient(135deg, var(--accent), var(--accent2));
    color: #fff;
    font-size: .95rem;
    font-weight: 700;
    border-radius: 12px;
    text-decoration: none;
    transition: transform .25s cubic-bezier(0.34, 1.56, 0.64, 1), box-shadow .2s ease;
    box-shadow: 0 4px 15px rgba(233, 64, 122, .25);
    -webkit-tap-highlight-color: transparent;
    border: none;
    cursor: pointer
}

.btn-accent:hover {
    transform: translateY(-2px) scale(1.02);
    box-shadow: 0 6px 20px rgba(233, 64, 122, .4), inset 0 0 0 1px rgba(255, 255, 255, 0.2);
}

.btn-accent:active {
    transform: translateY(1px) scale(0.98);
    box-shadow: 0 2px 8px rgba(233, 64, 122, .3);
}

.btn-accent.lg {
    padding: 16px 44px;
    min-height: 56px;
    font-size: 1.05rem;
}

.btn-outline {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    padding: 14px 28px;
    min-height: 44px;
    background: transparent;
    border: 1px solid rgba(255, 255, 255, .1);
    color: var(--t2);
    font-size: .9rem;
    font-weight: 500;
    border-radius: 10px;
    text-decoration: none;
    transition: border-color .2s, color .2s, transform .15s, box-shadow .2s;
    -webkit-tap-highlight-color: transparent;
}

.btn-outline:hover {
    border-color: rgba(255, 255, 255, .2);
    color: var(--t1);
    transform: translateY(-2px) scale(1.01);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}

.btn-outline:active {
    transform: translateY(1px) scale(0.99);
    border-color: rgba(255, 255, 255, .15);
    box-shadow: 0 1px 4px rgba(0, 0, 0, 0.05);
}

/* ---- Hero ---- */
.lp-hero {
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    padding: 120px 20px 80px
}

.lp-badge {
    display: inline-block;
    padding: 6px 16px;
    background: rgba(233, 64, 122, .1);
    border: 1px solid rgba(233, 64, 122, .15);
    border-radius: 50px;
    font-size: .75rem;
    font-weight: 600;
    color: var(--accent2);
    margin-bottom: 28px;
    animation: fu .6s .1s ease both
}

.lp-hero-h1 {
    font-size: clamp(1.9rem, 5vw, 3rem);
    font-weight: 800;
    line-height: 1.3;
    margin-bottom: 20px;
    letter-spacing: -.02em;
    animation: fu .6s .2s ease both
}

.lp-hero-p {
    font-size: clamp(.9rem, 2vw, 1.02rem);
    color: var(--t2);
    max-width: 480px;
    margin: 0 auto 36px;
    line-height: 1.9;
    animation: fu .6s .35s ease both
}

.lp-hero-cta {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 12px;
    animation: fu .6s .5s ease both
}

/* Stats */
.lp-stats {
    display: flex;
    align-items: center;
    gap: 0;
    margin-top: 52px;
    padding: 20px 32px;
    background: var(--card);
    border: 1px solid var(--border);
    border-radius: var(--r);
    animation: fu .6s .7s ease both
}

.lp-stat {
    text-align: center;
    flex: 1;
    padding: 0 16px
}

.lp-stat-n {
    display: block;
    font-size: 1.5rem;
    font-weight: 800;
    color: var(--accent);
    white-space: nowrap;
}

.lp-stat-l {
    font-size: .7rem;
    color: var(--t3);
    margin-top: 2px;
    white-space: nowrap;
}

.lp-stat-sep {
    width: 1px;
    height: 32px;
    background: var(--border)
}

/* ---- Section ---- */
.lp-sec {
    padding: 96px 20px;
    max-width: 920px;
    margin: 0 auto
}

.lp-sec-hd {
    text-align: center;
    margin-bottom: 52px
}

.lp-sec-hd h2 {
    font-size: clamp(1.4rem, 3.5vw, 2rem);
    font-weight: 800;
    margin-bottom: 12px;
    letter-spacing: -.02em
}

.lp-sec-sub {
    color: var(--t3);
    font-size: .9rem;
    max-width: 460px;
    margin: 0 auto;
    line-height: 1.7
}

.lp-label {
    display: inline-block;
    padding: 4px 14px;
    background: rgba(233, 64, 122, .1);
    border-radius: 50px;
    font-size: .68rem;
    font-weight: 600;
    color: var(--accent2);
    letter-spacing: .06em;
    text-transform: uppercase;
    margin-bottom: 14px
}

/* ---- Cards (features, testimonials) ---- */
.lp-grid-3 {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 14px
}

.lp-card {
    background: var(--card);
    border: 1px solid var(--border);
    border-radius: var(--r);
    padding: 28px 24px;
    transition: border-color .2s, transform .2s
}

.lp-card:hover {
    border-color: rgba(255, 255, 255, .12);
    transform: translateY(-2px)
}

.lp-card h3 {
    font-size: 1rem;
    font-weight: 700;
    margin-bottom: 8px
}

.lp-card p {
    color: var(--t3);
    font-size: .85rem;
    line-height: 1.7
}

.lp-ic {
    width: 42px;
    height: 42px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 11px;
    background: rgba(233, 64, 122, .1);
    color: var(--accent);
    font-size: 1.2rem;
    margin-bottom: 16px
}

/* ---- Before/After ---- */
.lp-compare {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px;
    max-width: 780px;
    margin: 0 auto
}

.lp-cmp-col {
    background: var(--card);
    border: 1px solid var(--border);
    border-radius: var(--r);
    padding: 26px 22px
}

.lp-cmp-col.bad {
    border-top: 2px solid rgba(255, 80, 80, .45)
}

.lp-cmp-col.good {
    border-top: 2px solid rgba(80, 255, 140, .45)
}

.lp-cmp-tag {
    display: inline-block;
    padding: 2px 10px;
    border-radius: 50px;
    font-size: .65rem;
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
    margin-bottom: 14px
}

.lp-cmp-tag.bad {
    background: rgba(255, 80, 80, .1);
    color: #ff6b6b
}

.lp-cmp-tag.good {
    background: rgba(80, 255, 140, .1);
    color: #6bffb0
}

.lp-cmp-col ul {
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 9px
}

.lp-cmp-col li {
    font-size: .84rem;
    color: var(--t2);
    display: flex;
    align-items: flex-start;
    gap: 7px;
    line-height: 1.5
}

.lp-cmp-col.bad li i {
    color: #ff6b6b;
    flex-shrink: 0;
    margin-top: 2px
}

.lp-cmp-col.good li i {
    color: #6bffb0;
    flex-shrink: 0;
    margin-top: 2px
}

/* ---- Steps ---- */
.lp-steps {
    display: flex;
    flex-direction: column;
    gap: 12px;
    max-width: 580px;
    margin: 0 auto
}

.lp-step {
    display: flex;
    align-items: flex-start;
    gap: 16px;
    background: var(--card);
    border: 1px solid var(--border);
    border-radius: var(--r);
    padding: 22px 20px;
    transition: border-color .2s
}

.lp-step:hover {
    border-color: rgba(255, 255, 255, .12)
}

.lp-step-n {
    flex-shrink: 0;
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 10px;
    background: var(--accent);
    color: #fff;
    font-size: .9rem;
    font-weight: 700
}

.lp-step h3 {
    font-size: .95rem;
    font-weight: 700;
    margin-bottom: 4px
}

.lp-step p {
    color: var(--t3);
    font-size: .84rem;
    line-height: 1.6
}

/* Mid CTA */
.lp-mid-cta {
    text-align: center;
    margin-top: 44px;
    padding: 32px 24px;
    background: var(--card);
    border: 1px solid var(--border);
    border-radius: var(--r)
}

.lp-mid-cta p {
    color: var(--t2);
    font-size: .92rem;
    margin-bottom: 18px
}

/* ---- Testimonials ---- */
.lp-stars {
    color: #fbbf24;
    font-size: .82rem;
    margin-bottom: 12px;
    letter-spacing: 2px
}

.lp-quote {
    font-size: .86rem;
    color: var(--t2);
    line-height: 1.8;
    margin-bottom: 16px;
    font-style: italic
}

.lp-author {
    display: flex;
    align-items: center;
    gap: 10px
}

.lp-author strong {
    font-size: .8rem
}

.lp-author small {
    font-size: .7rem;
    color: var(--t3)
}

.lp-avatar {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: rgba(233, 64, 122, .12);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--accent);
    font-size: .85rem
}

.lp-disclaimer {
    text-align: center;
    margin-top: 18px;
    font-size: .72rem;
    color: var(--t3);
    opacity: .7
}

/* ---- Pricing ---- */
.lp-pricing {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(270px, 1fr));
    gap: 16px;
    max-width: 640px;
    margin: 0 auto
}

.lp-plan {
    flex: 1;
    min-width: 280px;
    max-width: 400px;
    background: var(--card);
    border: 1px solid var(--border);
    border-radius: 16px;
    padding: 36px 32px;
    position: relative;
    display: flex;
    flex-direction: column;
    transition: transform .3s cubic-bezier(0.25, 1, 0.5, 1), box-shadow .3s ease, border-color .3s ease;
}

.lp-plan:hover {
    transform: translateY(-6px);
    box-shadow: 0 12px 30px rgba(0, 0, 0, 0.25);
    border-color: rgba(255, 255, 255, 0.1);
}

.lp-plan.popular {
    border-color: var(--accent);
    background: linear-gradient(180deg, rgba(233, 64, 122, .03) 0%, var(--card) 100%);
    box-shadow: 0 8px 30px rgba(233, 64, 122, .12);
    transform: translateY(-8px);
}

.lp-plan.popular:hover {
    transform: translateY(-12px);
    box-shadow: 0 16px 40px rgba(233, 64, 122, .2);
    border-color: var(--accent2);
}

.lp-popular-tag {
    position: absolute;
    top: -10px;
    right: 18px;
    background: var(--accent);
    color: #fff;
    font-size: .68rem;
    font-weight: 700;
    padding: 3px 14px;
    border-radius: 50px
}

.lp-plan-name {
    font-size: 1.05rem;
    font-weight: 700;
    margin-bottom: 4px
}

.lp-plan-price {
    font-size: 1.7rem;
    font-weight: 800;
    color: var(--accent);
    margin-bottom: 2px
}

.lp-plan-price small {
    font-size: .72rem;
    font-weight: 400;
    color: var(--t3)
}

.lp-plan-daily {
    font-size: .75rem;
    color: var(--t3);
    margin-bottom: 18px
}

.lp-plan ul {
    list-style: none;
    margin-bottom: 22px;
    display: flex;
    flex-direction: column;
    gap: 7px
}

.lp-plan li {
    font-size: .84rem;
    color: var(--t2);
    display: flex;
    align-items: center;
    gap: 7px
}

.lp-plan li i {
    color: var(--accent);
    font-size: .85rem
}

.lp-plan-btn {
    display: block;
    width: 100%;
    text-align: center;
    padding: 13px;
    min-height: 44px;
    border-radius: 10px;
    font-size: .88rem;
    font-weight: 600;
    text-decoration: none;
    background: rgba(255, 255, 255, .05);
    color: var(--t1);
    border: 1px solid var(--border);
    transition: background .2s, transform .15s;
    -webkit-tap-highlight-color: transparent;
}

.lp-plan-btn:hover {
    background: rgba(255, 255, 255, .09);
    transform: translateY(-1px);
}

.lp-plan-btn:active {
    transform: translateY(1px);
    background: rgba(255, 255, 255, .07);
}

.lp-plan-btn.accent {
    background: var(--accent);
    color: #fff;
    border-color: var(--accent);
    box-shadow: 0 4px 12px rgba(233, 64, 122, .2);
    transition: transform .15s, box-shadow .15s, opacity .2s;
}

.lp-plan-btn.accent:hover {
    opacity: .9;
    transform: translateY(-2px);
    box-shadow: 0 6px 16px rgba(233, 64, 122, .3);
}

.lp-plan-btn.accent:active {
    transform: translateY(1px);
    box-shadow: 0 2px 8px rgba(233, 64, 122, .15);
}

/* ---- FAQ ---- */
.lp-faq {
    max-width: 660px;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    gap: 8px
}

.lp-faq details {
    background: var(--card);
    border: 1px solid var(--border);
    border-radius: var(--r);
    overflow: hidden;
    transition: border-color .2s
}

.lp-faq details[open] {
    border-color: rgba(233, 64, 122, .15)
}

.lp-faq summary {
    padding: 16px 20px;
    font-size: .9rem;
    font-weight: 600;
    cursor: pointer;
    list-style: none;
    display: flex;
    align-items: center;
    justify-content: space-between
}

.lp-faq summary::-webkit-details-marker {
    display: none
}

.lp-faq summary::after {
    content: '+';
    font-size: 1.1rem;
    color: var(--accent);
    transition: transform .2s
}

.lp-faq details[open] summary::after {
    transform: rotate(45deg)
}

.lp-faq details p {
    padding: 0 20px 16px;
    font-size: .84rem;
    color: var(--t3);
    line-height: 1.8
}

/* ---- Final CTA ---- */
.lp-final {
    padding: 80px 20px 100px;
    text-align: center
}

.lp-final-card {
    max-width: 520px;
    margin: 0 auto;
    padding: 48px 32px;
    background: var(--card);
    border: 1px solid rgba(233, 64, 122, .12);
    border-radius: 20px
}

.lp-final-card h2 {
    font-size: clamp(1.3rem, 3vw, 1.8rem);
    font-weight: 800;
    margin-bottom: 14px
}

.lp-final-card p {
    color: var(--t3);
    margin-bottom: 24px;
    font-size: .9rem;
    line-height: 1.7
}

.lp-final-card small {
    display: block;
    margin-top: 14px;
    font-size: .76rem;
    color: var(--t3)
}

/* ---- Footer ---- */
.lp-foot {
    text-align: center;
    padding: 28px 20px 120px 20px;
    border-top: 1px solid var(--border);
    color: var(--t3);
    font-size: .72rem
}

/* ---- Animations (lightweight) ---- */
@keyframes fu {
    from {
        opacity: 0;
        transform: translateY(18px)
    }

    to {
        opacity: 1;
        transform: translateY(0)
    }
}

.lp-r {
    opacity: 0;
    transform: translateY(18px);
    transition: opacity .5s ease, transform .5s ease
}

.lp-r.vis {
    opacity: 1;
    transform: translateY(0)
}

/* ---- Responsive ---- */
@media(max-width:768px) {
    .lp-compare {
        grid-template-columns: 1fr
    }

    .lp-pricing {
        grid-template-columns: 1fr;
        max-width: 360px
    }

    .lp-nav-link {
        display: none
    }
}

/* ---- Trust Bar ---- */
.lp-trust-bar {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 20px;
    flex-wrap: wrap;
    margin-top: 40px;
    padding: 16px 24px;
    background: var(--card);
    border: 1px solid var(--border);
    border-radius: var(--r)
}

.lp-trust-bar span {
    font-size: .75rem;
    color: var(--t3);
    display: flex;
    align-items: center;
    gap: 5px;
    white-space: nowrap
}

.lp-trust-bar i {
    color: var(--accent);
    font-size: .85rem
}

/* ---- Pain List ---- */
.lp-pain-list {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 10px;
    max-width: 700px;
    margin: 0 auto
}

.lp-pain {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 16px 18px;
    background: var(--card);
    border: 1px solid var(--border);
    border-radius: var(--r)
}

.lp-pain i {
    font-size: 1.1rem;
    color: var(--accent);
    flex-shrink: 0
}

.lp-pain p {
    font-size: .88rem;
    color: var(--t2);
    line-height: 1.5
}

.lp-pain-cta {
    text-align: center;
    margin-top: 36px;
    font-size: .95rem;
    color: var(--t2);
    line-height: 1.8
}

/* ---- Pricing Notes ---- */
.lp-plan-notes {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 20px;
    flex-wrap: wrap;
    margin-top: 20px
}

.lp-plan-notes span {
    font-size: .75rem;
    color: var(--t3);
    display: flex;
    align-items: center;
    gap: 5px
}

.lp-plan-notes i {
    color: var(--accent);
    font-size: .8rem
}

/* ---- Responsive ---- */
@media(max-width:768px) {
    .lp-compare {
        grid-template-columns: 1fr
    }

    .lp-pricing {
        grid-template-columns: 1fr;
        max-width: 360px
    }

    .lp-nav-link {
        display: none
    }

    .lp-trust-bar {
        gap: 12px;
        padding: 14px 18px
    }
}

@media(max-width:640px) {
    .lp-nav {
        padding: 12px 16px
    }

    .lp-hero {
        padding: 100px 16px 60px
    }

    .lp-sec {
        padding: 72px 16px
    }

    .lp-final-card {
        padding: 36px 20px
    }

    .lp-trust-bar {
        flex-direction: column;
        gap: 8px
    }

    .lp-plan-notes {
        flex-direction: column;
        gap: 6px
    }
}

/* ---- Hero Note ---- */
.lp-hero-note {
    font-size: .78rem;
    color: var(--t3);
    margin-top: 4px;
    display: block;
    text-align: center
}

/* ---- Bridge ---- */
.lp-bridge {
    text-align: center;
    margin-top: 40px;
    font-size: .95rem;
    color: var(--t2);
    line-height: 1.8
}

.lp-bridge-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    margin-top: 10px;
    color: var(--accent);
    font-size: 1rem;
    text-decoration: none;
    border: 1px solid var(--border);
    border-radius: 50%;
    transition: border-color .2s, transform .2s
}

.lp-bridge-link:hover {
    border-color: var(--accent);
    transform: translateY(2px)
}

/* ---- Small Button ---- */
.btn-accent.sm {
    padding: 12px 28px;
    font-size: .88rem
}

/* ---- Cost Comparison Table ---- */
.lp-cost-compare {
    max-width: 660px;
    margin: 0 auto 36px;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch
}

.lp-cost-compare table {
    width: 100%;
    border-collapse: collapse;
    font-size: .84rem
}

.lp-cost-compare th,
.lp-cost-compare td {
    padding: 12px 14px;
    text-align: center;
    border-bottom: 1px solid var(--border)
}

.lp-foot {
    background: var(--bg);
    padding: 60px 20px 80px;
    text-align: center;
    border-top: 1px solid var(--border)
}

.lp-cost-compare thead th {
    font-weight: 600;
    color: var(--t3);
    font-size: .75rem;
    text-transform: uppercase;
    letter-spacing: .05em
}

.lp-cost-compare td:first-child {
    text-align: left;
    color: var(--t2);
    font-weight: 500
}

.lp-cost-compare td {
    color: var(--t3)
}

.lp-cost-compare .hl {
    color: var(--accent);
    font-weight: 700
}

.lp-cost-compare thead .hl {
    color: var(--accent);
    font-weight: 700
}

/* ---- Risk Reversal ---- */
.lp-risk {
    display: flex;
    align-items: flex-start;
    gap: 14px;
    max-width: 560px;
    margin: 28px auto 0;
    padding: 20px 22px;
    background: rgba(40, 167, 69, .06);
    border: 1px solid rgba(40, 167, 69, .15);
    border-radius: var(--r)
}

.lp-risk>i {
    font-size: 1.3rem;
    color: #5cb85c;
    flex-shrink: 0;
    margin-top: 2px
}

.lp-risk strong {
    font-size: .9rem;
    display: block;
    margin-bottom: 4px
}

.lp-risk p {
    font-size: .8rem;
    color: var(--t3);
    line-height: 1.6;
    margin: 0
}

/* ---- Initial Avatar ---- */
.lp-avatar {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: rgba(233, 64, 122, .12);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--accent);
    font-size: .78rem;
    font-weight: 700
}

/* ---- Sticky Mobile CTA ---- */
.lp-sticky-cta {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 99;
    padding: 10px 16px;
    background: rgba(12, 12, 15, .95);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border-top: 1px solid var(--border);
    transform: translateY(100%);
    transition: transform .3s ease;
    display: none
}

.lp-sticky-cta.show {
    transform: translateY(0)
}

.lp-sticky-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    max-width: 640px;
    margin: 0 auto;
}

.lp-sticky-price {
    font-size: 1.15rem;
    font-weight: 800;
    color: var(--accent);
    white-space: nowrap;
    letter-spacing: 0.5px;
}

.lp-sticky-price small {
    font-size: .75rem;
    font-weight: 500;
    color: var(--t2);
    margin-left: 2px;
}

.lp-sticky-cta .sticky-btn {
    flex: 1;
    max-width: 250px;
    text-align: center;
    padding: 13px 20px;
    border-radius: 12px;
    font-size: .95rem;
    font-weight: 700;
    box-shadow: 0 4px 15px rgba(233, 64, 122, 0.3);
}

@media(max-width:640px) {
    .lp-sticky-cta {
        display: block
    }

    .lp-nav {
        padding: 12px 16px
    }

    .lp-hero {
        padding: 90px 16px 50px
    }

    .lp-sec {
        padding: 60px 16px
    }

    .lp-final-card {
        padding: 36px 16px
    }

    /* スマホ特化: ヒーローCTA */
    .lp-hero-cta {
        width: 100%;
        max-width: 320px;
        margin-left: -5px
    }

    .lp-hero-cta .btn-accent {
        width: 100%;
        justify-content: center
    }

    /* スマホ特化: カウンター改行防止 */
    .lp-stats {
        padding: 16px 8px;
        margin-top: 36px;
        width: 100%;
        max-width: 360px
    }

    .lp-stat {
        padding: 0 4px
    }

    .lp-stat-n {
        font-size: 1.3rem;
        white-space: nowrap
    }

    .lp-stat-l {
        font-size: .62rem;
        white-space: nowrap;
        letter-spacing: -.03em
    }
}

@media(min-width:641px) {
    .lp-sticky-cta {
        display: none !important
    }
}

/* ---- High-Conversion Elements ---- */

/* Hero Campaign Badge */
.lp-campaign-badge {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 6px 18px;
    background: rgba(255, 215, 0, 0.1);
    border: 1px solid rgba(255, 215, 0, 0.3);
    border-radius: 50px;
    font-size: 0.8rem;
    font-weight: 700;
    color: #FFD700;
    margin-bottom: 24px;
    animation: fu .6s .1s ease both;
}

.pulse-dot {
    width: 8px;
    height: 8px;
    background-color: #FFD700;
    border-radius: 50%;
    box-shadow: 0 0 0 0 rgba(255, 215, 0, 0.7);
    animation: pulse-dot 1.5s infinite;
}

@keyframes pulse-dot {
    0% {
        transform: scale(0.95);
        box-shadow: 0 0 0 0 rgba(255, 215, 0, 0.7);
    }

    70% {
        transform: scale(1);
        box-shadow: 0 0 0 6px rgba(255, 215, 0, 0);
    }

    100% {
        transform: scale(0.95);
        box-shadow: 0 0 0 0 rgba(255, 215, 0, 0);
    }
}

/* Hero CTA Texts */
.lp-hero-campaign-text {
    font-size: 0.95rem;
    font-weight: 700;
    color: var(--t1);
    margin-bottom: 4px;
}

.hl-yellow {
    color: #FFD700;
    text-shadow: 0 0 10px rgba(255, 215, 0, 0.3);
}

.lp-hero-sub-links {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    margin-top: 8px;
}

.lp-hero-login-link {
    font-size: 0.82rem;
    color: var(--t3);
    text-decoration: underline;
    transition: color 0.2s;
}

.lp-hero-login-link:hover {
    color: var(--t1);
}

/* Pricing Campaign Banner */
.lp-pricing-campaign-banner {
    display: flex;
    align-items: center;
    gap: 20px;
    background: linear-gradient(135deg, rgba(233, 64, 122, 0.15) 0%, rgba(255, 107, 157, 0.05) 100%);
    border: 1px solid rgba(233, 64, 122, 0.4);
    border-radius: 16px;
    padding: 24px;
    max-width: 640px;
    margin: 0 auto 32px;
}

.lp-pricing-campaign-banner .banner-icon {
    font-size: 2rem;
    color: var(--accent);
    flex-shrink: 0;
}

.lp-pricing-campaign-banner .banner-text h3 {
    font-size: 1.05rem;
    font-weight: 800;
    color: #fff;
    margin-bottom: 4px;
}

.lp-pricing-campaign-banner .banner-text p {
    font-size: 0.85rem;
    color: var(--t2);
    line-height: 1.6;
}

@media(max-width: 640px) {
    .lp-pricing-campaign-banner {
        flex-direction: column;
        text-align: center;
        gap: 12px;
        padding: 20px;
    }
}

/* Final CTA Setup */
.lp-final-campaign-text {
    font-size: 1.05rem;
    font-weight: 800;
    color: #FFD700;
    margin-bottom: 20px;
}

.lp-final-cta-btns {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 14px;
    flex-wrap: wrap;
    margin-bottom: 8px;
}

.btn-ghost-accent {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 14px 28px;
    background: transparent;
    border: 1px solid var(--accent);
    color: var(--accent);
    font-size: 0.95rem;
    font-weight: 700;
    border-radius: 10px;
    text-decoration: none;
    transition: background 0.15s, color 0.15s, box-shadow 0.15s;
}

.btn-ghost-accent:hover {
    background: rgba(233, 64, 122, 0.1);
    color: var(--accent2);
    box-shadow: inset 0 0 0 1px var(--accent);
}