/* ============================================================
   MI PENSION ALIMENTICIA - Tema Naranja Amigable
   ============================================================ */
:root {
    --orange-50: #fff7ed;
    --orange-100: #ffedd5;
    --orange-200: #fed7aa;
    --orange-300: #fdba74;
    --orange-400: #fb923c;
    --orange-500: #f97316;
    --orange-600: #ea580c;
    --orange-700: #c2410c;
    --orange-800: #9a3412;
    --orange-900: #7c2d12;
    --dark: #1a1a2e;
    --dark-2: #2d2d44;
    --gray-50: #fafafa;
    --gray-100: #f5f5f5;
    --gray-200: #e5e5e5;
    --gray-300: #d4d4d4;
    --gray-400: #a3a3a3;
    --gray-500: #737373;
    --gray-600: #525252;
    --gray-700: #404040;
    --white: #ffffff;
    --green-500: #22c55e;
    --green-600: #16a34a;
    --red-500: #ef4444;
    --font-heading: 'Nunito', sans-serif;
    --font-body: 'Inter', sans-serif;
    --shadow-sm: 0 1px 3px rgba(0,0,0,.08);
    --shadow-md: 0 4px 12px rgba(0,0,0,.1);
    --shadow-lg: 0 8px 30px rgba(0,0,0,.12);
    --shadow-xl: 0 16px 50px rgba(0,0,0,.15);
    --radius: 12px;
    --radius-lg: 20px;
}

* { margin:0; padding:0; box-sizing:border-box; }

html { scroll-behavior:smooth; scroll-padding-top:80px; }

body {
    font-family: var(--font-body);
    color: var(--gray-700);
    line-height: 1.7;
    background: var(--white);
    overflow-x: hidden;
}

.container { max-width:1200px; margin:0 auto; padding:0 24px; }

/* ---- NAVBAR ---- */
.navbar {
    position:fixed; top:0; left:0; right:0; z-index:1000;
    background:rgba(255,255,255,.95); backdrop-filter:blur(10px);
    border-bottom:1px solid var(--gray-200);
    transition: all .3s;
}
.navbar.scrolled { box-shadow: var(--shadow-md); }

.nav-content { display:flex; align-items:center; justify-content:space-between; height:70px; }

.nav-logo {
    display:flex; align-items:center; gap:10px;
    text-decoration:none; color:var(--dark); font-family:var(--font-heading);
    font-weight:800; font-size:.95rem; line-height:1.2;
}
.nav-logo small { font-weight:600; color:var(--orange-600); font-size:.8rem; }
.logo-icon { font-size:1.8rem; color:var(--orange-500); }

.nav-toggle { display:none; background:none; border:none; font-size:1.5rem; cursor:pointer; color:var(--dark); }

.nav-links {
    display:flex; list-style:none; gap:8px; align-items:center;
}
.nav-links a {
    text-decoration:none; color:var(--gray-600); font-size:.9rem; font-weight:500;
    padding:8px 14px; border-radius:8px; transition:all .2s;
}
.nav-links a:hover { background:var(--orange-50); color:var(--orange-600); }

/* ---- HERO ---- */
.hero {
    padding: 120px 0 80px;
    background: linear-gradient(135deg, var(--orange-50) 0%, var(--white) 50%, var(--orange-50) 100%);
    position:relative;
}
.hero::before {
    content:''; position:absolute; top:0; right:0; width:40%; height:100%;
    background:radial-gradient(circle at 70% 30%, rgba(249,115,22,.08) 0%, transparent 60%);
}
.hero-grid { display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:center; }

.hero-badge {
    display:inline-block; background:var(--orange-100); color:var(--orange-700);
    padding:6px 16px; border-radius:50px; font-size:.85rem; font-weight:600;
    margin-bottom:16px;
}
.hero h1 {
    font-family:var(--font-heading); font-size:3rem; font-weight:900;
    color:var(--dark); line-height:1.15; margin-bottom:20px;
}
.hero-sub { font-size:1.1rem; color:var(--gray-600); margin-bottom:28px; max-width:520px; }

.hero-cta { display:flex; gap:14px; flex-wrap:wrap; margin-bottom:36px; }

.hero-stats { display:flex; gap:40px; }
.stat-num { display:block; font-family:var(--font-heading); font-size:1.8rem; font-weight:900; color:var(--orange-600); }
.stat-label { font-size:.82rem; color:var(--gray-500); }

.hero-visual { position:relative; z-index:1; }
.hero-card {
    background:var(--white); border-radius:var(--radius-lg); padding:40px;
    box-shadow:var(--shadow-xl); text-align:center; position:relative;
    border:2px solid var(--orange-100);
}
.hero-card-icon { font-size:3.5rem; margin-bottom:12px; }
.hero-card h3 { font-family:var(--font-heading); font-size:1.5rem; color:var(--dark); margin-bottom:10px; }
.hero-card p { color:var(--gray-600); margin-bottom:24px; font-size:.95rem; }
.hero-card-price { background:var(--orange-50); border-radius:var(--radius); padding:20px; }
.price-old {
    text-decoration:line-through; color:var(--gray-400); font-size:1.1rem;
    display:block; margin-bottom:4px;
}
.price-new {
    font-family:var(--font-heading); font-size:2.8rem; font-weight:900;
    color:var(--orange-600); display:block;
}
.price-label { font-size:.85rem; color:var(--gray-500); display:block; margin-top:4px; }

/* ---- BUTTONS ---- */
.btn {
    display:inline-flex; align-items:center; justify-content:center; gap:8px;
    padding:12px 28px; border-radius:10px; font-size:.95rem; font-weight:600;
    text-decoration:none; border:none; cursor:pointer; transition:all .25s;
    font-family:var(--font-body);
}
.btn-lg { padding:16px 36px; font-size:1.05rem; }
.btn-sm { padding:8px 18px; font-size:.85rem; }
.btn-block { width:100%; }

.btn-primary {
    background:var(--orange-500); color:var(--white);
    box-shadow: 0 4px 12px rgba(249,115,22,.3);
}
.btn-primary:hover { background:var(--orange-600); transform:translateY(-2px); box-shadow: 0 6px 20px rgba(249,115,22,.35); }

.btn-secondary { background:var(--dark); color:var(--white); }
.btn-secondary:hover { background:var(--dark-2); transform:translateY(-2px); }

.btn-outline {
    background:transparent; color:var(--orange-600);
    border:2px solid var(--orange-300);
}
.btn-outline:hover { background:var(--orange-50); border-color:var(--orange-500); }

.btn-white { background:var(--white); color:var(--orange-600); }
.btn-white:hover { background:var(--orange-50); transform:translateY(-2px); }

.btn-outline-white { background:transparent; color:var(--white); border:2px solid rgba(255,255,255,.5); }
.btn-outline-white:hover { background:rgba(255,255,255,.15); border-color:var(--white); }

/* ---- TRUST BAR ---- */
.trust-bar { background:var(--dark); padding:28px 0; }
.trust-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:20px; }
.trust-item {
    display:flex; align-items:center; gap:14px; color:var(--white);
}
.trust-icon { font-size:1.8rem; }
.trust-item strong { font-size:.9rem; display:block; }
.trust-item p { font-size:.78rem; color:var(--gray-400); margin:0; line-height:1.3; }

/* ---- SECTIONS ---- */
.section { padding:80px 0; }
.section-light { background:var(--gray-50); }
.section-white { background:var(--white); }
.section-orange {
    background:linear-gradient(135deg, var(--orange-500) 0%, var(--orange-600) 100%);
    color:var(--white);
}

.section-header { text-align:center; margin-bottom:50px; }
.section-tag {
    display:inline-block; background:var(--orange-100); color:var(--orange-700);
    padding:4px 14px; border-radius:50px; font-size:.82rem; font-weight:600;
    margin-bottom:12px; text-transform:uppercase; letter-spacing:.5px;
}
.tag-white { background:rgba(255,255,255,.2); color:var(--white); }
.section-header h2 {
    font-family:var(--font-heading); font-size:2.2rem; font-weight:900;
    color:var(--dark); margin-bottom:12px;
}
.section-header-white h2 { color:var(--white); }
.section-header p { color:var(--gray-500); font-size:1.05rem; max-width:600px; margin:0 auto; }
.section-header-white p { color:rgba(255,255,255,.85); }

/* ---- STEPS ---- */
.steps-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:24px; }
.step-card {
    background:var(--white); border-radius:var(--radius); padding:30px 24px;
    text-align:center; position:relative; box-shadow:var(--shadow-sm);
    border:1px solid var(--gray-200); transition:all .3s;
}
.step-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-md); }
.step-num {
    position:absolute; top:-14px; left:20px;
    background:var(--orange-500); color:var(--white);
    width:28px; height:28px; border-radius:50%; display:flex;
    align-items:center; justify-content:center; font-size:.8rem; font-weight:700;
}
.step-icon { font-size:2.4rem; margin-bottom:12px; }
.step-card h4 { font-family:var(--font-heading); font-size:1.05rem; color:var(--dark); margin-bottom:8px; }
.step-card p { font-size:.88rem; color:var(--gray-500); line-height:1.5; }

/* ---- PACKAGES ---- */
.packages-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:28px; }
.package-card {
    background:var(--white); border-radius:var(--radius-lg); padding:36px 28px;
    border:2px solid var(--gray-200); position:relative; transition:all .3s;
    display:flex; flex-direction:column;
}
.package-card:hover { transform:translateY(-6px); box-shadow:var(--shadow-lg); }
.package-popular {
    border-color:var(--orange-400);
    box-shadow: 0 8px 30px rgba(249,115,22,.15);
}
.package-badge {
    position:absolute; top:-12px; left:50%; transform:translateX(-50%);
    background:var(--orange-500); color:var(--white);
    padding:4px 18px; border-radius:50px; font-size:.78rem; font-weight:700;
    white-space:nowrap;
}
.package-icon { font-size:2.5rem; margin-bottom:12px; }
.package-card h3 { font-family:var(--font-heading); font-size:1.3rem; color:var(--dark); margin-bottom:8px; }
.package-desc { font-size:.9rem; color:var(--gray-500); margin-bottom:20px; line-height:1.5; }

.package-price { text-align:center; padding:20px 0; border-top:1px solid var(--gray-200); border-bottom:1px solid var(--gray-200); margin-bottom:20px; }
.package-price .price-old { font-size:1rem; }
.package-price .price-current {
    display:block; font-family:var(--font-heading); font-size:2.5rem; font-weight:900;
    color:var(--orange-600);
}
.package-price .price-consult { font-size:1.8rem; color:var(--dark); }
.package-price .price-period { font-size:.82rem; color:var(--gray-400); display:block; }

.package-features { list-style:none; margin-bottom:24px; flex-grow:1; }
.package-features li {
    padding:6px 0; font-size:.88rem; color:var(--gray-600);
    border-bottom:1px solid var(--gray-100);
}
.package-note { font-size:.78rem; color:var(--gray-400); text-align:center; margin-top:10px; }

/* ---- CALCULATOR ---- */
.calc-card {
    background:var(--white); border-radius:var(--radius-lg); padding:40px;
    box-shadow:var(--shadow-xl); color:var(--gray-700);
}
.calc-grid { display:grid; grid-template-columns:1fr 1fr; gap:40px; }
.calc-inputs h3 { font-family:var(--font-heading); color:var(--dark); margin-bottom:20px; }

.input-money {
    display:flex; align-items:center; background:var(--gray-50);
    border:2px solid var(--gray-200); border-radius:10px; overflow:hidden;
    transition:border .2s;
}
.input-money:focus-within { border-color:var(--orange-400); }
.input-money span { padding:12px 14px; font-weight:700; color:var(--orange-600); font-size:1.1rem; background:var(--gray-100); }
.input-money input { border:none; background:none; padding:12px; font-size:1rem; width:100%; outline:none; }

.counter-input {
    display:flex; align-items:center; gap:0; border:2px solid var(--gray-200);
    border-radius:10px; overflow:hidden; width:fit-content;
}
.counter-btn {
    width:48px; height:48px; border:none; background:var(--gray-100);
    font-size:1.3rem; cursor:pointer; font-weight:700; color:var(--orange-600);
    transition:all .2s;
}
.counter-btn:hover { background:var(--orange-100); }
.counter-input input {
    width:60px; text-align:center; border:none; font-size:1.1rem;
    font-weight:700; outline:none; background:var(--white);
}

.calc-results {
    display:flex; align-items:center; justify-content:center;
    min-height:300px;
}
.calc-placeholder { text-align:center; color:var(--gray-400); }
.calc-placeholder-icon { font-size:3rem; margin-bottom:12px; }

.calc-result-live {
    width:100%; padding:20px;
}
.result-main {
    text-align:center; padding:24px; background:var(--orange-50);
    border-radius:var(--radius); margin-bottom:20px;
    border:2px solid var(--orange-200);
}
.result-label { font-size:.85rem; color:var(--gray-500); margin-bottom:4px; }
.result-amount {
    font-family:var(--font-heading); font-size:2.8rem; font-weight:900;
    color:var(--orange-600);
}
.result-detail { font-size:.85rem; color:var(--gray-500); margin-top:6px; }

.result-extras { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.result-box {
    padding:16px; background:var(--gray-50); border-radius:10px;
    text-align:center; border:1px solid var(--gray-200);
}
.result-box-label { font-size:.78rem; color:var(--gray-500); margin-bottom:4px; display:block; }
.result-box-value { font-family:var(--font-heading); font-size:1.3rem; font-weight:800; color:var(--dark); }
.result-box-value.debt { color:var(--red-500); }

.calc-disclaimer { text-align:center; font-size:.78rem; color:rgba(255,255,255,.65); margin-top:20px; }

/* ---- WIZARD FORM ---- */
.wizard-card {
    background:var(--white); border-radius:var(--radius-lg); padding:40px;
    box-shadow:var(--shadow-lg); border:1px solid var(--gray-200);
    max-width:800px; margin:0 auto;
}

.wizard-progress { margin-bottom:36px; position:relative; }
.progress-bar {
    height:4px; background:var(--gray-200); border-radius:4px;
    margin-bottom:16px; position:relative; overflow:hidden;
}
.progress-bar::after {
    content:''; position:absolute; left:0; top:0; height:100%;
    background:var(--orange-500); border-radius:4px;
    width:16.66%; transition:width .4s ease;
}

.progress-steps { display:flex; justify-content:space-between; }
.progress-step { display:flex; flex-direction:column; align-items:center; gap:4px; }
.step-dot {
    width:30px; height:30px; border-radius:50%; display:flex;
    align-items:center; justify-content:center; font-size:.75rem; font-weight:700;
    background:var(--gray-200); color:var(--gray-500); transition:all .3s;
}
.progress-step.active .step-dot { background:var(--orange-500); color:var(--white); }
.progress-step.done .step-dot { background:var(--green-500); color:var(--white); }
.step-name { font-size:.7rem; color:var(--gray-400); font-weight:600; }
.progress-step.active .step-name { color:var(--orange-600); }

.wizard-step { display:none; }
.wizard-step.active { display:block; animation:fadeIn .3s ease; }

@keyframes fadeIn { from { opacity:0; transform:translateY(10px); } to { opacity:1; transform:translateY(0); } }

.step-header { margin-bottom:28px; }
.step-header h3 { font-family:var(--font-heading); font-size:1.4rem; color:var(--dark); margin-bottom:6px; }
.step-header p { color:var(--gray-500); font-size:.95rem; }

.form-grid { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.form-grid .full { grid-column:1/-1; }

.form-group { margin-bottom:18px; }
.form-group label { display:block; font-weight:600; color:var(--dark); margin-bottom:6px; font-size:.9rem; }
.form-group small { display:block; margin-top:4px; font-size:.78rem; color:var(--gray-400); }

.form-group input[type="text"],
.form-group input[type="email"],
.form-group input[type="tel"],
.form-group input[type="number"],
.form-group input[type="date"],
.form-group select,
.form-group textarea {
    width:100%; padding:12px 14px; border:2px solid var(--gray-200);
    border-radius:10px; font-size:.95rem; font-family:var(--font-body);
    transition:border .2s; background:var(--white); color:var(--dark);
}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus { outline:none; border-color:var(--orange-400); }

.question-label { font-size:1rem !important; margin-bottom:12px !important; }

/* Radio Cards */
.radio-cards { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.radio-cards-sm { grid-template-columns:1fr 1fr 1fr; }

.radio-card { cursor:pointer; }
.radio-card input { display:none; }
.radio-card-content {
    padding:16px; border:2px solid var(--gray-200); border-radius:var(--radius);
    transition:all .2s; text-align:center;
}
.radio-card-content strong { display:block; color:var(--dark); font-size:.9rem; margin-bottom:2px; }
.radio-card-content small { color:var(--gray-500); font-size:.78rem; }
.radio-icon { font-size:1.5rem; display:block; margin-bottom:6px; }

.radio-card input:checked + .radio-card-content {
    border-color:var(--orange-500); background:var(--orange-50);
    box-shadow: 0 0 0 3px rgba(249,115,22,.15);
}

/* Chip Options */
.time-options { display:flex; flex-wrap:wrap; gap:8px; }
.chip-option { cursor:pointer; }
.chip-option input { display:none; }
.chip-option span {
    display:inline-block; padding:8px 18px; border:2px solid var(--gray-200);
    border-radius:50px; font-size:.85rem; color:var(--gray-600);
    transition:all .2s;
}
.chip-option input:checked + span {
    border-color:var(--orange-500); background:var(--orange-500); color:var(--white);
}
.chip-option:hover span { border-color:var(--orange-300); }

/* Menores */
.menor-entry {
    background:var(--gray-50); border-radius:var(--radius); padding:20px;
    margin-bottom:14px; border:1px solid var(--gray-200); position:relative;
}
.menor-header {
    font-weight:700; font-size:.9rem; color:var(--orange-600);
    margin-bottom:12px; display:flex; justify-content:space-between; align-items:center;
}
.btn-remove-menor {
    background:none; border:none; color:var(--red-500); cursor:pointer;
    font-size:.85rem; font-weight:600;
}

/* Checkbox */
.checkbox-label {
    display:flex; gap:10px; cursor:pointer; font-size:.9rem;
    color:var(--gray-600); align-items:flex-start;
}
.checkbox-label input[type="checkbox"] { margin-top:4px; width:18px; height:18px; accent-color:var(--orange-500); }

/* Wizard Nav */
.wizard-nav {
    display:flex; justify-content:space-between; align-items:center;
    margin-top:30px; padding-top:20px; border-top:1px solid var(--gray-200);
}

/* Summary */
.summary-card {
    background:var(--gray-50); border-radius:var(--radius); padding:24px;
    margin-bottom:20px;
}
.summary-row {
    display:flex; justify-content:space-between; padding:8px 0;
    border-bottom:1px solid var(--gray-200); font-size:.9rem;
}
.summary-row:last-child { border:none; }
.summary-label { color:var(--gray-500); }
.summary-value { color:var(--dark); font-weight:600; }

.summary-calc {
    background:var(--orange-50); border:2px solid var(--orange-200);
    border-radius:var(--radius); padding:24px; margin-bottom:20px;
}
.summary-calc h4 { font-family:var(--font-heading); color:var(--orange-700); margin-bottom:14px; }
.summary-calc-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:12px; }
.summary-calc-item { text-align:center; }
.summary-calc-item .label { font-size:.78rem; color:var(--gray-500); display:block; }
.summary-calc-item .value { font-family:var(--font-heading); font-size:1.3rem; font-weight:800; color:var(--orange-600); }
.summary-calc-item .value.debt-val { color:var(--red-500); }

.package-selected {
    display:flex; justify-content:space-between; align-items:center;
    background:var(--white); border:2px solid var(--orange-400);
    border-radius:var(--radius); padding:20px; margin-bottom:20px;
}
.package-selected h4 { font-family:var(--font-heading); color:var(--dark); margin-bottom:4px; }
.package-selected p { font-size:.85rem; color:var(--gray-500); margin:0; }
.package-selected-price { text-align:right; }
.package-selected-price .price-old { font-size:.9rem; }
.package-selected-price .price-new {
    font-family:var(--font-heading); font-size:2rem; font-weight:900; color:var(--orange-600);
}

/* ---- GUIA / PANFLETO ---- */
.guia-intro {
    display:flex; gap:28px; background:var(--white); border-radius:var(--radius-lg);
    padding:36px; box-shadow:var(--shadow-md); margin-bottom:40px;
    border-left:5px solid var(--orange-500);
}
.guia-intro-icon { font-size:3rem; flex-shrink:0; }
.guia-intro-text h3 { font-family:var(--font-heading); color:var(--dark); margin-bottom:10px; font-size:1.2rem; }
.guia-intro-text p { color:var(--gray-600); margin-bottom:14px; }

.guia-resumen {
    list-style:none; counter-reset:guia; padding:0;
}
.guia-resumen li {
    counter-increment:guia; padding:10px 0 10px 40px; position:relative;
    font-size:.92rem; color:var(--gray-600); border-bottom:1px solid var(--gray-100);
    line-height:1.6;
}
.guia-resumen li:last-child { border:none; }
.guia-resumen li::before {
    content:counter(guia); position:absolute; left:0; top:10px;
    width:26px; height:26px; border-radius:50%; background:var(--orange-500);
    color:var(--white); font-size:.75rem; font-weight:700;
    display:flex; align-items:center; justify-content:center;
}
.guia-resumen li em { color:var(--orange-600); font-style:normal; font-weight:600; }

.guia-steps-grid {
    display:grid; grid-template-columns:1fr 1fr; gap:24px; margin-bottom:40px;
}
.guia-step {
    background:var(--white); border-radius:var(--radius); padding:28px;
    box-shadow:var(--shadow-sm); border:1px solid var(--gray-200);
    transition:all .3s; position:relative;
}
.guia-step:hover { transform:translateY(-4px); box-shadow:var(--shadow-md); }
.guia-step-num {
    display:inline-block; background:var(--orange-500); color:var(--white);
    padding:3px 12px; border-radius:50px; font-size:.75rem; font-weight:700;
    margin-bottom:12px; text-transform:uppercase; letter-spacing:.5px;
}
.guia-step-icon { font-size:2.2rem; margin-bottom:10px; }
.guia-step h4 { font-family:var(--font-heading); color:var(--dark); margin-bottom:8px; font-size:1.05rem; }
.guia-step p { font-size:.88rem; color:var(--gray-600); line-height:1.6; margin-bottom:10px; }

.guia-tip {
    background:var(--orange-50); border-radius:8px; padding:12px 14px;
    font-size:.82rem; color:var(--orange-800); line-height:1.5;
    border-left:3px solid var(--orange-400);
}

.guia-follow-list { list-style:none; padding:0; margin:0 0 10px; }
.guia-follow-list li {
    padding:4px 0 4px 20px; position:relative; font-size:.85rem;
    color:var(--gray-600); line-height:1.5;
}
.guia-follow-list li::before {
    content:''; position:absolute; left:0; top:10px;
    width:8px; height:8px; border-radius:50%; background:var(--orange-400);
}

.guia-paquete-box {
    background:var(--white); border:2px solid var(--orange-300);
    border-radius:var(--radius-lg); padding:36px; text-align:center;
}
.guia-paquete-box h3 {
    font-family:var(--font-heading); color:var(--dark); margin-bottom:24px; font-size:1.3rem;
}
.guia-includes-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:20px; }
.guia-include {
    padding:20px; background:var(--orange-50); border-radius:var(--radius);
    text-align:center;
}
.include-icon { font-size:2rem; display:block; margin-bottom:8px; }
.guia-include strong { display:block; color:var(--dark); font-size:.9rem; margin-bottom:4px; }
.guia-include p { font-size:.78rem; color:var(--gray-500); line-height:1.4; margin:0; }

@media (max-width:968px) {
    .guia-intro { flex-direction:column; gap:16px; }
    .guia-steps-grid { grid-template-columns:1fr; }
    .guia-includes-grid { grid-template-columns:1fr 1fr; }
}
@media (max-width:640px) {
    .guia-intro { padding:20px; }
    .guia-includes-grid { grid-template-columns:1fr; }
    .guia-paquete-box { padding:20px; }
}

/* ---- FAQ ---- */
.faq-grid { max-width:720px; margin:0 auto; }
.faq-item { border-bottom:1px solid var(--gray-200); }
.faq-question {
    width:100%; background:none; border:none; padding:18px 0;
    display:flex; justify-content:space-between; align-items:center;
    cursor:pointer; text-align:left; font-size:1rem; font-weight:600;
    color:var(--dark); font-family:var(--font-body);
}
.faq-icon { font-size:1.3rem; color:var(--orange-500); transition:transform .3s; }
.faq-item.open .faq-icon { transform:rotate(45deg); }
.faq-answer {
    max-height:0; overflow:hidden; transition:max-height .3s ease;
}
.faq-item.open .faq-answer { max-height:300px; }
.faq-answer p { padding-bottom:18px; font-size:.92rem; color:var(--gray-600); line-height:1.7; }

/* ---- CTA ---- */
.section-cta {
    background:linear-gradient(135deg, var(--dark) 0%, var(--dark-2) 100%);
    padding:80px 0; text-align:center; color:var(--white);
}
.section-cta h2 { font-family:var(--font-heading); font-size:2.2rem; font-weight:900; margin-bottom:12px; }
.section-cta p { color:var(--gray-400); font-size:1.05rem; margin-bottom:28px; }
.cta-buttons { display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }

/* ---- FOOTER ---- */
.footer { background:var(--dark); color:var(--gray-400); padding:60px 0 30px; }
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr; gap:40px; margin-bottom:40px; }
.footer-logo {
    display:flex; align-items:center; gap:10px; color:var(--white);
    font-family:var(--font-heading); font-weight:800; font-size:.95rem;
    line-height:1.2; margin-bottom:14px;
}
.footer-logo small { color:var(--orange-400); }
.footer-logo .logo-icon { color:var(--orange-400); }
.footer-brand p { font-size:.88rem; line-height:1.6; }
.footer-links h4 { color:var(--white); font-family:var(--font-heading); margin-bottom:16px; font-size:1rem; }
.footer-links a { display:block; color:var(--gray-400); text-decoration:none; font-size:.88rem; margin-bottom:8px; transition:color .2s; }
.footer-links a:hover { color:var(--orange-400); }
.footer-bottom {
    display:flex; justify-content:space-between; padding-top:20px;
    border-top:1px solid var(--dark-2); font-size:.82rem;
}
.footer-bottom a { color:var(--orange-400); text-decoration:none; }

/* ---- EMAIL FLOAT ---- */
.email-float {
    position:fixed; bottom:24px; right:24px; z-index:900;
    width:60px; height:60px; border-radius:50%;
    background:linear-gradient(135deg, #f97316, #ea580c); display:flex; align-items:center; justify-content:center;
    box-shadow: 0 4px 15px rgba(249,115,22,.4);
    transition:transform .3s;
    text-decoration:none; font-size:28px; color:#fff;
}
.email-float:hover { transform:scale(1.1); }

/* ---- MODAL ---- */
.modal-overlay {
    position:fixed; inset:0; background:rgba(0,0,0,.6);
    display:flex; align-items:center; justify-content:center; z-index:2000;
    backdrop-filter:blur(4px);
}
.modal-card {
    background:var(--white); border-radius:var(--radius-lg); padding:48px;
    max-width:480px; width:90%; text-align:center;
}
.modal-icon { font-size:3rem; margin-bottom:12px; }
.modal-card h2 { font-family:var(--font-heading); color:var(--dark); margin-bottom:12px; }
.modal-card p { color:var(--gray-600); font-size:.95rem; margin-bottom:14px; }
.modal-price {
    background:var(--orange-50); padding:14px; border-radius:10px;
    margin-bottom:14px; font-size:1.1rem;
}
.modal-price strong { color:var(--orange-600); font-size:1.4rem; }
.modal-note { font-size:.82rem; color:var(--gray-400); margin-bottom:20px; }

/* ---- SCROLL ANIM ---- */
[data-anim] { opacity:0; transform:translateY(24px); transition:all .6s ease; }
[data-anim].visible { opacity:1; transform:translateY(0); }

/* ---- RESPONSIVE ---- */
@media (max-width:968px) {
    .hero-grid { grid-template-columns:1fr; gap:40px; }
    .hero h1 { font-size:2.2rem; }
    .hero-visual { max-width:400px; margin:0 auto; }
    .trust-grid { grid-template-columns:1fr 1fr; gap:16px; }
    .steps-grid { grid-template-columns:1fr 1fr; }
    .packages-grid { grid-template-columns:1fr; max-width:420px; margin:0 auto; }
    .calc-grid { grid-template-columns:1fr; }
    .footer-grid { grid-template-columns:1fr; }
    .footer-bottom { flex-direction:column; text-align:center; gap:4px; }
    .form-grid { grid-template-columns:1fr; }
    .radio-cards-sm { grid-template-columns:1fr 1fr; }
    .summary-calc-grid { grid-template-columns:1fr; gap:8px; }
    .package-selected { flex-direction:column; text-align:center; gap:12px; }
}

@media (max-width:640px) {
    .nav-toggle { display:block; }
    .nav-links {
        display:none; position:absolute; top:70px; left:0; right:0;
        background:var(--white); flex-direction:column; padding:20px;
        box-shadow:var(--shadow-md); border-top:1px solid var(--gray-200);
    }
    .nav-links.open { display:flex; }
    .hero { padding:100px 0 60px; }
    .hero h1 { font-size:1.8rem; }
    .hero-stats { gap:20px; }
    .stat-num { font-size:1.4rem; }
    .section { padding:50px 0; }
    .section-header h2 { font-size:1.6rem; }
    .steps-grid { grid-template-columns:1fr; }
    .trust-grid { grid-template-columns:1fr; }
    .wizard-card { padding:24px 18px; }
    .progress-steps { gap:4px; }
    .step-name { display:none; }
    .step-dot { width:26px; height:26px; font-size:.7rem; }
    .radio-cards { grid-template-columns:1fr; }
    .radio-cards-sm { grid-template-columns:1fr; }
    .time-options { gap:6px; }
    .chip-option span { padding:6px 12px; font-size:.8rem; }
    .calc-card { padding:24px 18px; }
    .section-cta h2 { font-size:1.6rem; }
    .result-extras { grid-template-columns:1fr; }
}
