* { font-family: 'Inter', sans-serif; }
pre { border-radius: var(--ce-radius); overflow: hidden; }

.navbar {
    backdrop-filter: blur(8px);
    background: rgba(255,255,255,.9) !important;
    padding: 0.75rem 0;
}
.navbar-brand { font-weight: 800; font-size: 1.5rem; letter-spacing: -0.025em; }
.nav-link { color: var(--ce-neutral) !important; font-weight: 500; font-size: 0.925rem; padding: 0.5rem 1rem !important; transition: color .2s; }
.nav-link:hover { color: var(--bs-primary) !important; }
.nav-link.active { color: var(--bs-secondary) !important; }
.sidebar-card { background: #fff; border: 1px solid #f1f5f9; border-radius: var(--ce-radius); padding: 1.25rem; box-shadow: var(--ce-card-shadow); }
.sidebar-card h6 { font-weight: 700; font-size: 0.9rem; margin-bottom: 1rem; text-transform: uppercase; letter-spacing: 0.05em; color: var(--bs-primary); }
.sidebar-card ul { list-style: none; padding: 0; margin: 0; }
.sidebar-card ul li { margin-bottom: 0.5rem; }
.sidebar-card ul li a { color: var(--ce-neutral); text-decoration: none; font-size: 0.9rem; }
.sidebar-card ul li a:hover { color: var(--bs-secondary); }
.footer { background: var(--bs-primary); padding: 4rem 0 2rem; }
.footer h5 { color: #fff; font-weight: 700; font-size: 1.05rem; margin-bottom: 1.25rem; }
.footer p, .footer a { color: rgba(255,255,255,.5); font-size: 0.9rem; }
.footer a { text-decoration: none; }
.footer a:hover { color: #fff; }
.footer-links { list-style: none; padding: 0; }
.footer-links li { margin-bottom: 0.6rem; }
.footer-bottom { border-top: 1px solid rgba(255,255,255,.1); padding-top: 1.5rem; margin-top: 3rem; }
.footer-bottom p { color: rgba(255,255,255,.35); margin: 0; }
.sosmed-icon { display: inline-flex; align-items: center; justify-content: center; width: 44px; height: 44px; border-radius: 50%; border: 1px solid rgba(255,255,255,.15); color: rgba(255,255,255,.6); font-size: 1.2rem; transition: all .2s; text-decoration: none; }
.sosmed-icon:hover { background: rgba(255,255,255,.1); border-color: var(--ce-accent); color: var(--ce-accent); transform: translateY(-2px); }
.hero {
    background:
        linear-gradient(to right, rgba(40,40,40,.95) 0%, rgba(51,51,51,.7) 50%, rgba(255,255,255,0) 70%, transparent 100%),
        url(../img/bg-baru.png) center / cover no-repeat;
    padding: 6rem 0 5rem;
    position: relative;
    overflow: hidden;
}
.hero h1 { color: #fff; font-weight: 900; font-size: 3.25rem; line-height: 1.1; letter-spacing: -0.03em; }
.hero p.lead { font-size: 1.15rem; color: rgba(255,255,255,.7); font-weight: 400; }
.section-title { font-weight: 800; font-size: 2rem; letter-spacing: -0.025em; margin-bottom: 0.5rem; }
.section-subtitle { color: var(--ce-neutral); font-size: 1.05rem; margin-bottom: 3rem; }
.post-card { background: #fff; border: 1px solid #f1f5f9; border-radius: var(--ce-radius); overflow: hidden; transition: all .25s; box-shadow: var(--ce-card-shadow); height: 100%; }
.post-card:hover { box-shadow: var(--ce-card-shadow-hover); transform: translateY(-4px); }
.post-body { padding: 1.25rem; }
.post-body h6 { font-weight: 600; font-size: 1rem; margin-bottom: 0.5rem; }
.post-body p { color: var(--ce-neutral); font-size: 0.875rem; }
.post-meta { color: var(--ce-neutral); font-size: 0.8rem; }
.stats-section { background: var(--bs-primary); padding: 4rem 0; }
.stat-item h2 { font-weight: 800; font-size: 2.75rem; color: #fff; letter-spacing: -0.03em; }
.stat-item p { color: rgba(255,255,255,.6); font-weight: 500; margin: 0; }
.feature-card { border: none; border-radius: var(--ce-radius); padding: 1.5rem; background: #fff; box-shadow: var(--ce-card-shadow); height: 100%; }
.feature-card:hover { box-shadow: var(--ce-card-shadow-hover); transform: translateY(-4px); }
.feature-icon { width: 48px; height: 48px; border-radius: var(--ce-radius); background: var(--bs-secondary); display: inline-flex; align-items: center; justify-content: center; color: #fff; font-size: 1.25rem; margin-bottom: 1rem; }
.feature-card h6 { font-weight: 700; }
.feature-card p { color: var(--ce-neutral); font-size: 0.9rem; margin-bottom: 0; }
.testimonial-card { background: #fff; border: 1px solid #f1f5f9; border-radius: var(--ce-radius); padding: 2rem; box-shadow: var(--ce-card-shadow); }
.testimonial-card p { color: var(--bs-body-color); font-size: 1rem; line-height: 1.7; font-style: italic; }
.testimonial-avatar { width: 48px; height: 48px; border-radius: 50%; background: var(--bs-secondary); display: flex; align-items: center; justify-content: center; font-weight: 700; color: #fff; }
.cta-section { background: #f8fafc; padding: 5rem 0; }
.cta-section h2 { font-weight: 800; font-size: 2.25rem; letter-spacing: -0.025em; }
.cta-section p { color: var(--ce-neutral); font-size: 1.1rem; }
.btn-cta { background: var(--bs-primary); border: none; padding: 0.85rem 2.25rem; font-weight: 600; border-radius: var(--ce-radius); color: #fff; transition: all .2s; }
.btn-cta:hover { opacity: .9; color: #fff; transform: translateY(-1px); }
.btn-hero { background: var(--bs-secondary); border: none; padding: 0.8rem 2rem; font-weight: 600; border-radius: var(--ce-radius); font-size: 1rem; color: #fff; transition: all .2s; }
.btn-hero:hover { opacity: .85; transform: translateY(-1px); color: #fff; }
.btn-hero-outline { background: transparent; border: 2px solid rgba(255,255,255,.3); padding: 0.75rem 2rem; font-weight: 600; border-radius: var(--ce-radius); font-size: 1rem; color: #fff; transition: all .2s; }
.btn-hero-outline:hover { background: rgba(255,255,255,.1); border-color: rgba(255,255,255,.6); color: #fff; }
.form-control:focus, .form-select:focus, .form-check-input:focus, .btn:focus { box-shadow: none !important; border-color: var(--bs-primary) !important; }
.card-hover { transition: all .25s; }
.card-hover:hover { box-shadow: var(--ce-card-shadow-hover); transform: translateY(-4px); }

.timeline {
    position: relative;
    padding: 20px 0;
}

.timeline-item {
    position: relative;
    width: 50%;
    padding: 20px 40px;
    box-sizing: border-box;
}

.timeline-item::before {
    content: '';
    position: absolute;
    top: 0;
    bottom: 0;
    width: 3px;
    background: var(--ce-accent);
    z-index: 0;
}

.timeline-item:nth-child(odd)::before {
    right: 0;
    transform: translateX(50%);
}

.timeline-item:nth-child(even)::before {
    left: 0;
    transform: translateX(-50%);
}

.timeline-item:last-child::before {
    display: block;
    bottom: auto;
    height: 30px;
}

.timeline-item:nth-child(odd) {
    left: 0;
    text-align: right;
}

.timeline-item:nth-child(even) {
    left: 50%;
    text-align: left;
}

.timeline-dot {
    position: absolute;
    width: 16px;
    height: 16px;
    background: var(--ce-accent);
    border: 3px solid #fff;
    border-radius: 50%;
    top: 30px;
    z-index: 1;
    box-shadow: 0 0 0 3px var(--ce-accent);
}

.timeline-item:nth-child(odd) .timeline-dot {
    right: -8px;
}

.timeline-item:nth-child(even) .timeline-dot {
    left: -8px;
}

.timeline-content {
    background: #fff;
    padding: 20px;
    border-radius: var(--ce-radius);
    box-shadow: var(--ce-card-shadow);
    transition: box-shadow 0.2s;
}

.timeline-content:hover {
    box-shadow: var(--ce-card-shadow-hover);
}

.timeline-content h5 {
    margin-bottom: 6px;
    color: var(--bs-primary);
}

.timeline-content p {
    margin: 0;
    color: var(--ce-neutral);
    font-size: 0.9rem;
}

.timeline-badge {
    display: inline-block;
    background: var(--ce-accent);
    color: #fff;
    padding: 3px 12px;
    border-radius: 20px;
    font-size: 0.8rem;
    font-weight: 600;
    margin-bottom: 8px;
}

@media (max-width: 767px) {
    .timeline-item {
        width: 100%;
        padding: 20px 20px 20px 50px;
        left: 0 !important;
        text-align: left !important;
    }

    .timeline-item::before,
    .timeline-item:nth-child(odd)::before,
    .timeline-item:nth-child(even)::before {
        left: 20px;
        right: auto;
        transform: translateX(-50%);
    }

    .timeline-item:nth-child(odd) .timeline-dot,
    .timeline-item:nth-child(even) .timeline-dot {
        left: 12px;
        right: auto;
    }
}

.page-hero {
    height: 320px;
    background-size: cover;
    background-position: center;
}

@media (max-width: 767px) {
    .page-hero {
        height: 220px;
    }
}

.w-20 { width: 20% !important; }
.w-40 { width: 40% !important; }
.w-60 { width: 60% !important; }
.w-80 { width: 80% !important; }
.selectable-plan { cursor: pointer; }
.duration-option { min-width: 120px; }
.tld-select { max-width: 130px; }
.form-check-lg { width: 20px; height: 20px; }
.text-accent { color: var(--ce-accent); }
.text-emerald { color: #10b981; }
.container-narrow { max-width: 600px; }
.img-qris { max-width: 200px; }
.checkmark-circle { width: 80px; height: 80px; background: #ecfdf5; font-size: 2.5rem; }
.bg-coupon { background: #f0fdf4; }
.bg-subtle { background: #f8fafc; }
.order-progress { height: 4px; }
