/* ===== ANIMATIONS & COMPONENTS ===== */

/* FAQ */
.faq-item{border-bottom:2px solid var(--color-divider);}
.faq-btn{display:flex;justify-content:space-between;align-items:center;padding:var(--space-5) 0;cursor:pointer;font-size:var(--text-base);font-weight:700;color:var(--color-text);gap:var(--space-4);background:none;border:none;width:100%;text-align:left;}
.faq-icon{flex-shrink:0;width:28px;height:28px;border-radius:50%;background:var(--color-primary-soft);display:flex;align-items:center;justify-content:center;color:var(--color-primary);transition:background var(--ease),transform var(--ease);}
.faq-item.open .faq-icon{background:var(--color-primary);color:#fff;transform:rotate(45deg);}
.faq-body{overflow:hidden;max-height:0;transition:max-height .4s cubic-bezier(0.16,1,0.3,1),padding .3s ease;padding-bottom:0;}
.faq-item.open .faq-body{max-height:400px;padding-bottom:var(--space-5);}
.faq-body p{font-size:var(--text-base);color:var(--color-text-muted);line-height:1.75;}

/* Step circles */
.step-circle{width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary),var(--color-yellow));color:#fff;font-size:var(--text-xl);font-weight:900;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 20px rgba(255,107,53,0.3);flex-shrink:0;}

/* Testimonial */
.testi{background:var(--color-surface);border:2px solid var(--color-border);border-radius:var(--r-xl);padding:var(--space-6);box-shadow:var(--shadow-card);}
.testi__quote{font-size:var(--text-base);color:var(--color-text);line-height:1.75;margin-block:var(--space-4) var(--space-5);font-style:italic;}
.testi__author{display:flex;align-items:center;gap:var(--space-3);}
.testi__avatar{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary),var(--color-yellow));color:#fff;font-weight:900;font-size:var(--text-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.testi__name{font-weight:800;font-size:var(--text-sm);}
.testi__loc{font-size:var(--text-xs);color:var(--color-text-muted);}

/* Service card */
.svc-card{background:var(--color-surface);border:2px solid var(--color-border);border-radius:var(--r-xl);padding:var(--space-6);text-decoration:none;display:block;box-shadow:var(--shadow-card);transition:transform var(--ease),box-shadow var(--ease),border-color var(--ease);}
.svc-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--color-primary);}
.svc-icon{width:52px;height:52px;border-radius:var(--r-lg);display:flex;align-items:center;justify-content:center;margin-bottom:var(--space-4);}
.svc-card h3{font-size:var(--text-lg);font-weight:800;margin-bottom:var(--space-2);color:var(--color-text);}
.svc-card p{font-size:var(--text-sm);color:var(--color-text-muted);line-height:1.65;max-width:28ch;}
.svc-arrow{display:inline-flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);font-weight:800;color:var(--color-primary);margin-top:var(--space-4);}

/* Trust strip */
.trust-strip{display:flex;flex-wrap:wrap;gap:var(--space-5);align-items:center;}
.trust-item{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);font-weight:700;color:var(--color-text-muted);}
.trust-dot{width:8px;height:8px;border-radius:50%;background:var(--color-green);flex-shrink:0;}

/* Stat pill */
.stat-pill{background:var(--color-surface);border:2px solid var(--color-border);border-radius:var(--r-xl);padding:var(--space-5) var(--space-6);text-align:center;box-shadow:var(--shadow-card);}
.stat-num{font-size:var(--text-2xl);font-weight:900;display:block;line-height:1;margin-bottom:var(--space-1);}
.stat-lbl{font-size:var(--text-xs);font-weight:700;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.06em;}

/* Emotion banner (hero top strip) */
.emotion-bar{background:linear-gradient(90deg,var(--color-primary),var(--color-yellow));color:#fff;text-align:center;padding:var(--space-2) var(--space-4);font-size:var(--text-xs);font-weight:800;letter-spacing:.04em;}

/* Pulsing phone icon */
@keyframes ring{0%,100%{transform:rotate(0deg);}10%{transform:rotate(-12deg);}20%{transform:rotate(12deg);}30%{transform:rotate(-8deg);}40%{transform:rotate(8deg);}50%{transform:rotate(0deg);}}
.ring-icon{animation:ring 3s ease-in-out infinite;display:inline-block;}

/* Bounce arrow */
@keyframes bounce-down{0%,100%{transform:translateY(0);}50%{transform:translateY(6px);}}
.bounce{animation:bounce-down 1.6s ease-in-out infinite;}

/* Floating cards */
@keyframes float-y{0%,100%{transform:translateY(0);}50%{transform:translateY(-8px);}}
.float{animation:float-y 4s ease-in-out infinite;}
.float-slow{animation:float-y 6s ease-in-out infinite;}

/* Progress bar */
.prog-bar{height:10px;background:var(--color-surface-2);border-radius:var(--r-full);overflow:hidden;}
.prog-fill{height:100%;background:linear-gradient(90deg,var(--color-primary),var(--color-yellow));border-radius:var(--r-full);width:0;transition:width 1.8s cubic-bezier(0.16,1,0.3,1);}

/* Counter */
[data-count]{display:inline;}

/* Debt type checkboxes */
.debt-opt input{position:absolute;opacity:0;width:0;height:0;}
.debt-opt label{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border:2px solid var(--color-border);border-radius:var(--r-lg);cursor:pointer;font-size:var(--text-sm);font-weight:700;transition:all var(--ease);}
.debt-opt input:checked + label{border-color:var(--color-primary);background:var(--color-primary-soft);color:var(--color-primary);}
.debt-opt label:hover{border-color:var(--color-primary);background:var(--color-primary-soft);}

/* Form card */
.form-card{background:var(--color-surface);border:2px solid var(--color-border);border-radius:var(--r-2xl);padding:clamp(var(--space-8),4vw,var(--space-10));box-shadow:var(--shadow-lg);}
.form-section-title{font-size:var(--text-lg);font-weight:800;margin-bottom:var(--space-6);padding-bottom:var(--space-4);border-bottom:2px solid var(--color-divider);color:var(--color-text);}

/* Success */
.success-box{display:none;text-align:center;padding:var(--space-12) var(--space-8);}
.success-box.show{display:block;}
.success-ring{width:88px;height:88px;border-radius:50%;background:linear-gradient(135deg,var(--color-green),var(--color-accent));display:flex;align-items:center;justify-content:center;margin:0 auto var(--space-6);}
