:root {
    --ink: #101423;
    --muted: #667085;
    --line: #dfe3f0;
    --surface: #ffffff;
    --soft: #f6f8ff;
    --soft-blue: #eefbff;
    --brand: #7c5cff;
    --brand-dark: #5f45df;
    --blue: #18a0fb;
    --green: #25c28a;
    --warning: #f5a623;
    --dark: #0c1224;
    --radius: 24px;
    --shadow: 0 24px 70px rgba(16, 20, 35, .12);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
    margin: 0;
    font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Arial, sans-serif;
    color: var(--ink);
    background: linear-gradient(180deg, #fbfcff 0%, #f7f8ff 46%, #ffffff 100%);
    line-height: 1.6;
}
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }

.site-header {
    position: sticky;
    top: 0;
    z-index: 30;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
    padding: 18px clamp(18px, 4vw, 64px);
    background: rgba(255, 255, 255, .86);
    backdrop-filter: blur(16px);
    border-bottom: 1px solid rgba(223, 227, 240, .7);
}
.brand img { width: 224px; height: auto; }
.site-nav { display: flex; align-items: center; gap: 26px; font-weight: 700; color: #343b52; }
.site-nav a:not(.btn):hover { color: var(--brand); }
.nav-toggle { display: none; border: 0; background: var(--soft); border-radius: 12px; padding: 10px 12px; font-size: 20px; }

.container { width: min(1160px, calc(100% - 36px)); margin: 0 auto; }
.section { padding: 86px 0; }
.section-tight { padding: 56px 0; }
.grid-2 { display: grid; grid-template-columns: 1.06fr .94fr; gap: 54px; align-items: center; }
.grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.grid-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }

.eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 9px 14px;
    border: 1px solid #ddd8ff;
    border-radius: 999px;
    color: var(--brand-dark);
    background: #f2f0ff;
    font-size: 14px;
    font-weight: 800;
    letter-spacing: .01em;
}
.eyebrow::before { content: ""; width: 8px; height: 8px; border-radius: 50%; background: var(--green); }

h1, h2, h3 { line-height: 1.08; margin: 0 0 18px; letter-spacing: -0.035em; }
h1 { font-size: clamp(42px, 6vw, 76px); }
h2 { font-size: clamp(32px, 4vw, 50px); }
h3 { font-size: 24px; }
p { margin: 0 0 20px; color: var(--muted); }
.lead { font-size: clamp(18px, 2vw, 22px); color: #475066; }
.center { text-align: center; }
.max-760 { max-width: 760px; }
.center.max-760 { margin-left: auto; margin-right: auto; }

.hero { padding: 92px 0 54px; overflow: hidden; }
.hero-copy { position: relative; }
.hero-copy::before {
    content: "";
    position: absolute;
    width: 260px; height: 260px;
    left: -120px; top: -90px;
    background: radial-gradient(circle, rgba(124, 92, 255, .16), transparent 68%);
    pointer-events: none;
}
.hero-actions, .cta-row { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 28px; }
.hero-card {
    position: relative;
    padding: 18px;
    border-radius: 36px;
    background: rgba(255, 255, 255, .8);
    box-shadow: var(--shadow);
    border: 1px solid rgba(223, 227, 240, .85);
}
.hero-card::after {
    content: "Policy fit first";
    position: absolute;
    right: 28px;
    bottom: 30px;
    padding: 10px 14px;
    border-radius: 999px;
    background: #101423;
    color: white;
    font-size: 13px;
    font-weight: 800;
    box-shadow: 0 14px 36px rgba(16,20,35,.22);
}

.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    border-radius: 999px;
    padding: 15px 22px;
    border: 1px solid transparent;
    cursor: pointer;
    font-weight: 850;
    transition: transform .18s ease, box-shadow .18s ease, background .18s ease;
    font-size: 16px;
}
.btn:hover { transform: translateY(-2px); }
.btn-primary { color: #fff; background: linear-gradient(135deg, var(--brand), var(--blue)); box-shadow: 0 16px 34px rgba(124, 92, 255, .28); }
.btn-secondary { color: var(--ink); background: #fff; border-color: var(--line); box-shadow: 0 12px 28px rgba(16,20,35,.08); }
.btn-small { padding: 10px 16px; font-size: 14px; }
.btn-muted { color: #667085; background: #eef1f7; border-color: #e1e5ee; cursor: not-allowed; }

.trust-strip { padding: 20px 0 70px; }
.trust-card, .feature-card, .package-card, .faq-item, .contact-card, .process-card, .policy-card {
    background: var(--surface);
    border: 1px solid rgba(223, 227, 240, .9);
    border-radius: var(--radius);
    box-shadow: 0 16px 40px rgba(16,20,35,.06);
}
.trust-card { padding: 22px; display: flex; gap: 14px; align-items: flex-start; }
.icon {
    width: 42px;
    height: 42px;
    flex: 0 0 42px;
    display: grid;
    place-items: center;
    border-radius: 14px;
    background: #f1efff;
    color: var(--brand);
    font-weight: 900;
}
.trust-card h3 { font-size: 17px; margin-bottom: 4px; letter-spacing: -.02em; }
.trust-card p { margin: 0; font-size: 14px; }

.band { background: #0c1224; color: #fff; border-radius: 44px; padding: 72px clamp(22px, 5vw, 72px); box-shadow: var(--shadow); }
.band p { color: #c8d0e6; }
.band .eyebrow { background: rgba(124,92,255,.18); color: #fff; border-color: rgba(255,255,255,.18); }
.band .feature-card { background: rgba(255,255,255,.06); border-color: rgba(255,255,255,.12); box-shadow: none; }
.band .feature-card h3 { color: #fff; }

.feature-card, .process-card, .policy-card { padding: 28px; }
.feature-card h3, .process-card h3, .policy-card h3 { font-size: 22px; }
.feature-card p, .process-card p, .policy-card p { margin-bottom: 0; }

.process-list { counter-reset: step; display: grid; gap: 16px; }
.process-card { position: relative; padding-left: 84px; }
.process-card::before {
    counter-increment: step;
    content: counter(step);
    position: absolute;
    left: 26px;
    top: 26px;
    width: 38px;
    height: 38px;
    display: grid;
    place-items: center;
    border-radius: 12px;
    background: var(--ink);
    color: #fff;
    font-weight: 900;
}

.package-card { padding: 30px; display: flex; flex-direction: column; min-height: 100%; position: relative; overflow: hidden; }
.package-card.featured { border-color: #c9c1ff; box-shadow: 0 24px 70px rgba(124, 92, 255, .16); }
.package-card.featured::before { content: "Popular"; position: absolute; right: 22px; top: 22px; background: #f1efff; color: var(--brand); border-radius: 999px; padding: 7px 12px; font-weight: 850; font-size: 13px; }
.package-price { display: flex; align-items: flex-end; gap: 6px; margin: 12px 0 18px; }
.package-price strong { font-size: 44px; line-height: 1; letter-spacing: -.05em; }
.package-card ul { margin: 18px 0 24px; padding: 0; list-style: none; display: grid; gap: 10px; }
.package-card li { color: #475066; display: flex; gap: 10px; }
.package-card li::before { content: "✓"; color: var(--green); font-weight: 900; }
.package-actions { margin-top: auto; display: grid; gap: 12px; }
.package-actions form { display: block; }
.package-actions .btn { width: 100%; }

.faq-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.faq-item { padding: 24px; }
.faq-item h3 { font-size: 19px; margin-bottom: 9px; }
.faq-item p { margin: 0; }

.cta-panel {
    display: grid;
    grid-template-columns: 1.2fr .8fr;
    gap: 30px;
    align-items: center;
    padding: 42px;
    border-radius: 36px;
    background: linear-gradient(135deg, #161b3d 0%, #2d246a 54%, #136aa6 100%);
    color: #fff;
    box-shadow: var(--shadow);
}
.cta-panel p { color: #e3e9ff; }
.cta-panel .btn-secondary { color: var(--ink); }

.page-hero { padding: 78px 0 44px; }
.page-hero .container { display: grid; grid-template-columns: 1.1fr .9fr; align-items: center; gap: 54px; }

.form-shell { display: grid; grid-template-columns: .85fr 1.15fr; gap: 30px; align-items: start; }
.contact-card { padding: 30px; }
.form-card { padding: 30px; background: #fff; border: 1px solid var(--line); border-radius: 30px; box-shadow: var(--shadow); }
label { display: block; font-weight: 800; color: #1b2235; margin-bottom: 7px; }
input, textarea, select {
    width: 100%;
    border: 1px solid #d8deea;
    border-radius: 14px;
    padding: 13px 14px;
    font: inherit;
    background: #fff;
    color: var(--ink);
    outline: none;
}
textarea { min-height: 150px; resize: vertical; }
input:focus, textarea:focus, select:focus { border-color: var(--brand); box-shadow: 0 0 0 4px rgba(124,92,255,.12); }
.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.form-row { margin-bottom: 18px; }
.notice { padding: 15px 16px; border-radius: 16px; margin-bottom: 18px; font-weight: 700; }
.notice.success { background: #edfff7; color: #126949; border: 1px solid #baf0d6; }
.notice.error { background: #fff2f2; color: #8a1d1d; border: 1px solid #f2c2c2; }
.honeypot { position: absolute; left: -9999px; opacity: 0; }

.order-summary { background: #fff; border: 1px solid var(--line); border-radius: 30px; box-shadow: var(--shadow); padding: 30px; }
.order-summary .package-price strong { font-size: 38px; }

.site-footer {
    width: min(1160px, calc(100% - 36px));
    margin: 54px auto 28px;
    padding: 30px 0 0;
    border-top: 1px solid var(--line);
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 20px;
    color: #667085;
}
.footer-links { display: flex; gap: 20px; font-weight: 800; }
.footer-links a:hover { color: var(--brand); }
.legal { grid-column: 1 / -1; font-size: 13px; color: #7b8498; }

@media (max-width: 920px) {
    .grid-2, .grid-3, .grid-4, .page-hero .container, .form-shell, .cta-panel { grid-template-columns: 1fr; }
    .faq-grid { grid-template-columns: 1fr; }
    .site-nav { display: none; position: absolute; top: 76px; left: 18px; right: 18px; padding: 18px; background: #fff; border: 1px solid var(--line); border-radius: 22px; box-shadow: var(--shadow); flex-direction: column; align-items: stretch; }
    .site-nav.open { display: flex; }
    .nav-toggle { display: inline-flex; }
    .brand img { width: 200px; }
}
@media (max-width: 620px) {
    .hero { padding-top: 58px; }
    .section { padding: 60px 0; }
    .form-grid { grid-template-columns: 1fr; }
    .site-footer { grid-template-columns: 1fr; }
    .footer-links { flex-wrap: wrap; }
    .band, .cta-panel { border-radius: 28px; padding: 36px 22px; }
}
