/* ==========================================================
   Kashoo V2 - Page-specific styles
   ========================================================== */

/* ---------- Hero ---------- */
.hero { background: var(--gradient-soft); padding: var(--sp-8) 0; overflow: hidden; }
.hero .container { display: grid; grid-template-columns: 1.1fr 1fr; gap: var(--sp-6); align-items: center; }
.hero h1 { margin-bottom: var(--sp-4); }
.hero p.lead { font-size: 1.1rem; color: var(--text-muted); margin-bottom: var(--sp-5); }
.hero .cta-row { display: flex; gap: var(--sp-3); flex-wrap: wrap; }
.hero-art { display: flex; justify-content: center; }
.hero-art svg { width: 100%; max-width: 460px; }
.hero-mockup { position: relative; width: 100%; max-width: 460px; }
.hero-mockup > img { display: block; width: 100%; opacity: .9; }
.mock-card {
    position: absolute; top: 6%; left: 50%; transform: translateX(-50%);
    width: 86%; background: #fff; border-radius: var(--radius-lg);
    box-shadow: var(--shadow-lg); padding: var(--sp-5); z-index: 2;
}
.mock-top { display: flex; align-items: center; justify-content: space-between; margin-bottom: var(--sp-3); }
.mock-brand { display: inline-flex; align-items: center; gap: 6px; font-weight: 600; font-size: .9rem; color: var(--text-muted); }
.mock-amount { font-size: 2.4rem; font-weight: 700; background: var(--gradient); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; line-height: 1.1; }
.mock-sub { color: var(--text-faint); font-size: .82rem; margin-top: 2px; }
.mock-stats { display: flex; justify-content: space-between; margin-top: var(--sp-4); gap: var(--sp-2); }
.mock-stats > div { text-align: center; flex: 1; }
.mock-val { display: block; font-weight: 700; color: var(--text); font-size: 1rem; }
.mock-lbl { display: block; font-size: .7rem; color: var(--text-faint); }
@media (max-width: 860px) {
    .hero .container { grid-template-columns: 1fr; text-align: center; }
    .hero .cta-row { justify-content: center; }
    .hero-art { order: -1; }
    .hero-mockup { max-width: 360px; margin: 0 auto; }
}

/* ---------- Sections ---------- */
.section { padding: var(--sp-8) 0; }
.section-head { text-align: center; max-width: 640px; margin: 0 auto var(--sp-6); }
.section-head p { color: var(--text-muted); }

.feature-card { text-align: center; }
.feature-card .ico {
    width: 64px; height: 64px; border-radius: 18px; margin: 0 auto var(--sp-3);
    display: flex; align-items: center; justify-content: center;
    background: var(--gradient-soft); color: var(--lavender-dark);
}
.feature-card .ico .material-symbols-rounded { font-size: 32px; }

.steps { counter-reset: step; }
.step-card { position: relative; padding-top: var(--sp-5); }
.step-card .num {
    width: 40px; height: 40px; border-radius: 50%; background: var(--gradient); color: #fff;
    display: flex; align-items: center; justify-content: center; font-weight: 700; margin-bottom: var(--sp-3);
}

.cta-band { background: var(--gradient); color: #fff; border-radius: var(--radius-lg); padding: var(--sp-7); text-align: center; margin: var(--sp-6) 0; }
.cta-band h2 { color: #fff; }
.cta-band .btn-primary { background: #fff; color: var(--mint-dark); }

/* ---------- Auth pages ---------- */
.auth-wrap { min-height: 100vh; display: flex; align-items: center; justify-content: center; padding: var(--sp-5); background: var(--gradient-soft); }
.auth-card { background: var(--surface); border-radius: var(--radius-lg); box-shadow: var(--shadow-lg); padding: var(--sp-6); width: 100%; max-width: 440px; }
.auth-card.wide { max-width: 520px; }
.auth-head { text-align: center; margin-bottom: var(--sp-5); }
.auth-head .brand { justify-content: center; margin-bottom: var(--sp-3); }
.auth-head p { color: var(--text-muted); font-size: .92rem; }
.auth-foot { text-align: center; margin-top: var(--sp-4); font-size: .9rem; color: var(--text-muted); }
.auth-row { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: var(--sp-2); }

/* ---------- FAQ accordion ---------- */
.faq-item { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius); margin-bottom: var(--sp-3); overflow: hidden; }
.faq-q { padding: 18px 20px; font-weight: 500; cursor: pointer; display: flex; justify-content: space-between; align-items: center; gap: var(--sp-3); }
.faq-q .chev { transition: transform .25s; color: var(--lavender-dark); }
.faq-item.open .faq-q .chev { transform: rotate(180deg); }
.faq-a { max-height: 0; overflow: hidden; transition: max-height .3s; color: var(--text-muted); }
.faq-item.open .faq-a { max-height: 400px; }
.faq-a div { padding: 0 20px 18px; }

/* ---------- Earn / task engine ---------- */
.task-stage { max-width: 560px; margin: 0 auto; text-align: center; }
.timer-ring { position: relative; width: 130px; height: 130px; margin: 0 auto var(--sp-4); }
.timer-ring svg { transform: rotate(-90deg); }
.timer-ring .track { fill: none; stroke: var(--surface-2); stroke-width: 10; }
.timer-ring .prog { fill: none; stroke: url(#tg); stroke-width: 10; stroke-linecap: round; transition: stroke-dashoffset 1s linear; }
.timer-ring .count { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; font-size: 2.2rem; font-weight: 700; }
.prompt-box {
    background: var(--gradient-soft); border-radius: var(--radius); padding: var(--sp-5);
    font-size: 1.8rem; font-weight: 600; letter-spacing: .02em; margin-bottom: var(--sp-4);
    word-break: break-word;
}
.task-input { text-align: center; font-size: 1.2rem !important; }
.feedback { font-weight: 600; min-height: 28px; margin: var(--sp-3) 0; }
.feedback.correct { color: var(--success); }
.feedback.incorrect { color: var(--error); }

.task-card-link { text-decoration: none; color: inherit; }
.task-card-link .feature-card .ico { transition: transform .2s; }
.task-card-link:hover .feature-card .ico { transform: scale(1.08) rotate(-4deg); }

/* ---------- Dashboard ---------- */
.welcome-bar { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: var(--sp-3); margin-bottom: var(--sp-5); }
.quick-actions { display: flex; gap: var(--sp-3); flex-wrap: wrap; }
.quick-actions a { flex: 1; min-width: 140px; }

/* ---------- Referral ---------- */
.ref-link-box { display: flex; gap: var(--sp-2); }
.ref-link-box input { flex: 1; }

/* ---------- Maintenance ---------- */
.maintenance { min-height: 100vh; display: flex; align-items: center; justify-content: center; text-align: center; padding: var(--sp-5); background: var(--gradient-soft); }
.maintenance .material-symbols-rounded { font-size: 80px; color: var(--lavender-dark); }

/* ---------- Legal documents ---------- */
.legal-doc { line-height: 1.75; }
.legal-doc h3 { margin: var(--sp-5) 0 var(--sp-2); font-size: 1.15rem; color: var(--text); }
.legal-doc p { margin-bottom: var(--sp-3); color: var(--text-muted); }
.legal-doc p:first-child { margin-top: 0; }
.legal-doc ul { margin: 0 0 var(--sp-3) var(--sp-5); color: var(--text-muted); }
.legal-doc a { font-weight: 500; }

/* ---------- Cookie consent ---------- */
.cookie-bar {
    position: fixed; left: 50%; bottom: 20px; transform: translateX(-50%);
    width: min(720px, calc(100% - 32px)); z-index: 1500;
    background: var(--surface); border: 1px solid var(--border);
    border-radius: var(--radius-lg); box-shadow: var(--shadow-lg);
    padding: var(--sp-4) var(--sp-5);
    display: flex; align-items: center; gap: var(--sp-4); flex-wrap: wrap;
    animation: cookieUp .4s ease;
}
@keyframes cookieUp { from { transform: translate(-50%, 120%); opacity: 0; } to { transform: translate(-50%, 0); opacity: 1; } }
.cookie-bar .cookie-ico { width: 44px; height: 44px; border-radius: 14px; flex-shrink: 0; display: flex; align-items: center; justify-content: center; background: var(--gradient-soft); color: var(--lavender-dark); }
.cookie-bar .cookie-text { flex: 1; min-width: 220px; font-size: .9rem; color: var(--text-muted); }
.cookie-bar .cookie-text strong { color: var(--text); }
.cookie-bar .cookie-actions { display: flex; gap: var(--sp-2); flex-wrap: wrap; }
@media (max-width: 520px) {
    .cookie-bar { bottom: 0; width: 100%; border-radius: 18px 18px 0 0; }
    .cookie-bar .cookie-actions { width: 100%; }
    .cookie-bar .cookie-actions .btn { flex: 1; }
}

/* ---------- Powered by ---------- */
.powered-by { display: inline-flex; align-items: center; gap: 5px; }
.powered-by a { color: var(--mint); font-weight: 600; }

/* ---------- Payment methods (centered, any count) ---------- */
.pm-grid { display: flex; flex-wrap: wrap; justify-content: center; gap: var(--sp-5); }
.pm-grid .pm-card { flex: 0 1 280px; max-width: 320px; }
.pm-logo { background: transparent !important; overflow: hidden; }
.pm-logo img { width: 64px; height: 64px; object-fit: contain; border-radius: 16px; }
@media (max-width: 560px) {
    .pm-grid .pm-card { flex: 1 1 100%; max-width: none; }
}
