/* ============================================================
   SavingsEasy — main.css
   Global tokens, reset, components, public page styles
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap');

/* ── Tokens ─────────────────────────────────────────────────── */
:root {
  --primary:       #1a7f5a;
  --primary-dark:  #14664a;
  --primary-light: #e8f5f0;
  --primary-mid:   #2da870;
  --accent:        #2563eb;
  --accent-light:  #eff6ff;
  --surface:       #ffffff;
  --bg:            #f0f4f8;
  --bg-alt:        #f8fafc;
  --text:          #0f172a;
  --text-light:    #1e293b;
  --muted:         #64748b;
  --border:        #e2e8f0;
  --danger:        #ef4444;
  --danger-light:  #fef2f2;
  --success:       #22c55e;
  --success-light: #f0fdf4;
  --warning:       #f59e0b;
  --warning-light: #fffbeb;
  --radius-sm:     6px;
  --radius:        12px;
  --radius-lg:     16px;
  --radius-xl:     24px;
  --shadow-sm:     0 1px 4px rgba(0,0,0,.06);
  --shadow:        0 2px 12px rgba(0,0,0,.08);
  --shadow-lg:     0 8px 32px rgba(0,0,0,.12);
  --shadow-xl:     0 20px 60px rgba(0,0,0,.16);
  --font:          'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --transition:    .18s ease;
  --sidebar-w:     260px;
}

/* ── Reset ──────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;max-width:100%;overflow-x:hidden}
body{font-family:var(--font);font-size:16px;line-height:1.6;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;max-width:100%;overflow-x:hidden}
img,svg{display:block;max-width:100%}
a{color:var(--primary);text-decoration:none}
a:hover{color:var(--primary-dark)}
ul{list-style:none}
button,input,select,textarea{font-family:inherit;font-size:inherit}
button{cursor:pointer;border:none;background:none}

/* ── Type ───────────────────────────────────────────────────── */
h1,h2,h3,h4,h5,h6{font-weight:700;line-height:1.25;color:var(--text)}
h1{font-size:clamp(2rem,5vw,3.25rem)}
h2{font-size:clamp(1.5rem,3vw,2.25rem)}
h3{font-size:1.35rem}
h4{font-size:1.1rem}
p{color:var(--muted);line-height:1.7}

/* ── Layout ─────────────────────────────────────────────────── */
.container{width:100%;max-width:1200px;margin:0 auto;padding:0 24px;min-width:0}
.container-sm{max-width:760px}
.flex{display:flex}
.flex-center{display:flex;align-items:center}
.flex-between{display:flex;align-items:center;justify-content:space-between}
.flex-col{display:flex;flex-direction:column}
.gap-8{gap:8px}.gap-12{gap:12px}.gap-16{gap:16px}.gap-24{gap:24px}
.mt-8{margin-top:8px}.mt-16{margin-top:16px}.mt-24{margin-top:24px}.mt-32{margin-top:32px}
.mb-8{margin-bottom:8px}.mb-16{margin-bottom:16px}.mb-24{margin-bottom:24px}
.text-center{text-align:center}
.text-muted{color:var(--muted);font-size:.9rem}
.fw-600{font-weight:600}.fw-700{font-weight:700}

/* ── Card ───────────────────────────────────────────────────── */
.card{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow);border:1px solid var(--border);padding:28px;transition:box-shadow var(--transition),transform var(--transition)}
.card:hover{box-shadow:var(--shadow-lg)}
.card-sm{padding:20px;border-radius:var(--radius)}

/* ── Buttons ────────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 24px;border-radius:var(--radius);font-weight:600;font-size:.95rem;cursor:pointer;border:none;transition:background var(--transition),transform var(--transition),box-shadow var(--transition);white-space:nowrap;text-decoration:none}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--primary);color:#fff}
.btn-primary:hover{background:var(--primary-dark);color:#fff;box-shadow:0 4px 16px rgba(26,127,90,.3)}
.btn-accent{background:var(--accent);color:#fff}
.btn-accent:hover{background:#1d4ed8;color:#fff}
.btn-outline{background:transparent;color:var(--primary);border:2px solid var(--primary)}
.btn-outline:hover{background:var(--primary-light)}
.btn-ghost{background:transparent;color:var(--muted)}
.btn-ghost:hover{background:var(--bg);color:var(--text)}
.btn-danger{background:var(--danger);color:#fff}
.btn-danger:hover{background:#dc2626;color:#fff}
.btn-white{background:#fff;color:var(--primary);font-weight:700}
.btn-white:hover{background:#f0fdf4;color:var(--primary-dark)}
.btn-sm{padding:8px 16px;font-size:.85rem;border-radius:var(--radius-sm)}
.btn-lg{padding:15px 32px;font-size:1.05rem;border-radius:var(--radius-lg)}
.btn-block{width:100%}
.btn[disabled],.btn:disabled{opacity:.6;cursor:not-allowed;pointer-events:none}

/* ── Forms ──────────────────────────────────────────────────── */
.form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:18px}
.form-label{font-size:.88rem;font-weight:600;color:var(--text-light)}
.form-control{width:100%;padding:12px 16px;border:1.5px solid var(--border);border-radius:var(--radius);background:#fff;color:var(--text);transition:border-color var(--transition),box-shadow var(--transition);outline:none}
.form-control:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(26,127,90,.12)}
.form-control::placeholder{color:#9ca3af}
.form-control.is-invalid{border-color:var(--danger)}
.form-hint{font-size:.8rem;color:var(--muted)}
.form-error{font-size:.82rem;color:var(--danger)}
select.form-control{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:40px}
textarea.form-control{resize:vertical;min-height:100px}

/* ── Alerts ─────────────────────────────────────────────────── */
.alert{padding:14px 18px;border-radius:var(--radius);font-size:.9rem;font-weight:500;margin-bottom:16px}
.alert-success{background:var(--success-light);color:#15803d;border:1px solid #bbf7d0}
.alert-danger{background:var(--danger-light);color:#b91c1c;border:1px solid #fecaca}
.alert-warning{background:var(--warning-light);color:#92400e;border:1px solid #fde68a}
.alert-info{background:var(--accent-light);color:#1d4ed8;border:1px solid #bfdbfe}

/* ── Badges ─────────────────────────────────────────────────── */
.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:99px;font-size:.78rem;font-weight:600}
.badge-green{background:#dcfce7;color:#15803d}
.badge-blue{background:#dbeafe;color:#1d4ed8}
.badge-purple{background:#ede9fe;color:#7c3aed}
.badge-pink{background:#fce7f3;color:#be185d}
.badge-yellow{background:#fef9c3;color:#92400e}
.badge-red{background:#fee2e2;color:#b91c1c}
.badge-teal{background:#ccfbf1;color:#0f766e}
.badge-indigo{background:#e0e7ff;color:#4338ca}
.badge-gray{background:#f1f5f9;color:#475569}

/* ── Table ──────────────────────────────────────────────────── */
.table-wrap{overflow-x:auto;border-radius:var(--radius-lg);border:1px solid var(--border)}
table{width:100%;border-collapse:collapse}
th,td{padding:14px 18px;text-align:left;font-size:.9rem}
th{font-weight:600;color:var(--muted);background:var(--bg-alt);border-bottom:1px solid var(--border);white-space:nowrap}
th a{color:inherit;font-weight:inherit;text-decoration:none}
th a:hover{color:var(--text)}
td{border-bottom:1px solid var(--border);color:var(--text-light)}
tr:last-child td{border-bottom:none}
tbody tr:hover{background:var(--bg-alt)}

/* ── Modal ──────────────────────────────────────────────────── */
.modal-overlay{position:fixed;inset:0;background:rgba(15,23,42,.5);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:24px;opacity:0;pointer-events:none;transition:opacity var(--transition)}
.modal-overlay.open{opacity:1;pointer-events:auto}
.modal{background:var(--surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);width:100%;max-width:540px;max-height:90vh;overflow-y:auto;transform:translateY(20px);transition:transform var(--transition)}
.modal-overlay.open .modal{transform:translateY(0)}
.modal-header{display:flex;align-items:center;justify-content:space-between;padding:24px 28px 0}
.modal-body{padding:24px 28px 28px}
.modal-close{width:36px;height:36px;border-radius:50%;background:var(--bg);display:flex;align-items:center;justify-content:center;border:none;cursor:pointer;color:var(--muted);transition:background var(--transition)}
.modal-close:hover{background:var(--border)}

/* ── Navbar ─────────────────────────────────────────────────── */
.navbar{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.92);backdrop-filter:blur(12px);border-bottom:1px solid var(--border)}
.navbar-inner{display:flex;align-items:center;justify-content:space-between;padding:16px 0}
.navbar-brand{display:flex;align-items:center;gap:10px;font-weight:800;font-size:1.2rem;color:var(--text)}
.navbar-brand span{color:var(--primary)}
.logo-mark{
  width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;
  background-image:url('../images/brand-mark.svg');
  background-size:cover;background-position:center;background-repeat:no-repeat;
  color:transparent;font-size:0;line-height:0;overflow:hidden;flex-shrink:0
}
.navbar-links{display:flex;align-items:center;gap:8px}
.navbar-links a{padding:8px 16px;border-radius:var(--radius-sm);color:var(--muted);font-weight:500;font-size:.92rem;transition:color var(--transition),background var(--transition)}
.navbar-links a:hover{color:var(--text);background:var(--bg)}
.nav-cta{display:flex;align-items:center;gap:10px}

/* ── Utilities ──────────────────────────────────────────────── */
.card-flat{box-shadow:none;border:1px solid var(--border)}
.text-small{font-size:.85rem}
.empty-state{text-align:center;padding:60px 24px}
.empty-state-icon{font-size:3rem;margin-bottom:16px}
.empty-state h3{margin-bottom:8px;font-size:1.1rem}
.empty-state p{font-size:.9rem}
.form-control.is-invalid:focus{box-shadow:0 0 0 3px rgba(239,68,68,.12)}

/* ── Footer ─────────────────────────────────────────────────── */
.footer{background:var(--text);color:#94a3b8;padding:60px 0 32px;margin-top:80px}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:40px;margin-bottom:48px}
.footer-brand p{color:#64748b;font-size:.9rem;margin-top:12px;line-height:1.7}
.footer h4{color:#fff;font-size:.9rem;font-weight:600;margin-bottom:16px}
.footer ul li{margin-bottom:10px}
.footer ul li a{color:#64748b;font-size:.88rem;transition:color var(--transition)}
.footer ul li a:hover{color:#94a3b8}
.footer-link-btn{color:#64748b;font-size:.88rem;line-height:1.5;padding:0;background:none;border:none;transition:color var(--transition);text-align:left}
.footer-link-btn:hover{color:#94a3b8}
.footer-bottom{border-top:1px solid #1e293b;padding-top:28px;display:flex;align-items:center;justify-content:space-between;font-size:.85rem}
.footer-brand-mark{display:flex;align-items:center;gap:8px;font-weight:800;color:#fff}

/* Cookie consent */
.cookie-consent{position:fixed;left:24px;right:24px;bottom:24px;z-index:1200;display:none}
.cookie-consent.visible{display:block;animation:fadeUp .28s ease both}
.cookie-card{max-width:960px;margin:0 auto;background:linear-gradient(140deg,#0f172a,#1f2937);color:#e2e8f0;border:1px solid rgba(148,163,184,.24);border-radius:20px;box-shadow:var(--shadow-xl);padding:22px 24px;display:flex;align-items:flex-start;gap:18px}
.cookie-icon{width:44px;height:44px;border-radius:50%;background:rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;font-size:1.2rem;flex-shrink:0}
.cookie-copy h3{font-size:1.05rem;color:#f8fafc;margin-bottom:4px}
.cookie-copy p{font-size:.9rem;color:#cbd5e1;line-height:1.55}
.cookie-copy a{color:#93c5fd;text-decoration:underline}
.cookie-actions{display:flex;align-items:center;gap:10px;flex-shrink:0;margin-left:auto}
.cookie-btn{border:none;border-radius:999px;padding:10px 16px;font-size:.85rem;font-weight:700;line-height:1;transition:transform var(--transition),background var(--transition),color var(--transition);cursor:pointer}
.cookie-btn:active{transform:translateY(1px)}
.cookie-btn-manage{background:transparent;color:#cbd5e1;border:1px solid rgba(203,213,225,.35)}
.cookie-btn-manage:hover{background:rgba(255,255,255,.1)}
.cookie-btn-reject{background:#334155;color:#f1f5f9}
.cookie-btn-reject:hover{background:#475569}
.cookie-btn-accept{background:#10b981;color:#052e16}
.cookie-btn-accept:hover{background:#34d399}

.cookie-modal{position:fixed;inset:0;z-index:1300;background:rgba(2,6,23,.62);backdrop-filter:blur(6px);display:none;align-items:center;justify-content:center;padding:24px}
.cookie-modal.open{display:flex}
.cookie-modal-card{width:100%;max-width:620px;background:#fff;border:1px solid #e2e8f0;border-radius:24px;box-shadow:var(--shadow-xl);overflow:hidden}
.cookie-modal-head{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid #e2e8f0}
.cookie-modal-head h3{font-size:1.15rem}
.cookie-modal-close{width:34px;height:34px;border-radius:999px;border:1px solid #e2e8f0;background:#f8fafc;color:#475569;font-size:1.05rem;line-height:1;cursor:pointer}
.cookie-modal-body{padding:20px 24px 24px}
.cookie-modal-body > p{font-size:.92rem;color:#64748b;margin-bottom:18px}
.cookie-list{display:flex;flex-direction:column;gap:12px}
.cookie-item{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:12px 14px;border:1px solid #e2e8f0;border-radius:14px;background:#f8fafc}
.cookie-item strong{display:block;font-size:.92rem;color:#0f172a;margin-bottom:3px}
.cookie-item span{display:block;font-size:.82rem;color:#64748b;line-height:1.45}
.cookie-switch{display:inline-flex;align-items:center;gap:8px;font-size:.82rem;font-weight:600;color:#334155;flex-shrink:0}
.cookie-switch input{accent-color:#10b981}
.cookie-required{background:#ecfeff;border-color:#bae6fd}
.cookie-required .cookie-switch{color:#0f766e}
.cookie-modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:18px}
.cookie-save-btn,.cookie-cancel-btn{border:none;border-radius:999px;padding:10px 16px;font-size:.84rem;font-weight:700;cursor:pointer}
.cookie-cancel-btn{background:#e2e8f0;color:#1e293b}
.cookie-cancel-btn:hover{background:#cbd5e1}
.cookie-save-btn{background:#0ea5e9;color:#082f49}
.cookie-save-btn:hover{background:#38bdf8}

/* ── Sections ───────────────────────────────────────────────── */
.section{padding:80px 0}
.section-sm{padding:56px 0}
.section-header{text-align:center;max-width:620px;margin:0 auto 56px}
.section-header .eyebrow{display:inline-block;background:var(--primary-light);color:var(--primary);font-size:.8rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:4px 14px;border-radius:99px;margin-bottom:16px}
.section-header h2{color:var(--text);margin-bottom:14px}
.section-header p{font-size:1.05rem}

/* Content pages */
.content-page{background:var(--bg-alt)}
.content-page + .footer{margin-top:0}
.content-hero{background:linear-gradient(135deg,#0a3d27,#1a7f5a);padding:46px 0 42px;color:#fff}
.content-hero-inner{max-width:820px}
.content-hero h1{color:#fff;margin:10px 0 12px;font-size:clamp(2rem,4vw,3rem)}
.content-hero p{color:rgba(255,255,255,.82);font-size:1.02rem;max-width:720px}
.content-kicker{display:inline-flex;align-items:center;border-radius:999px;background:rgba(255,255,255,.13);color:#fff;font-size:.76rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;padding:6px 13px}
.content-meta{font-size:.88rem!important;margin-top:14px;color:rgba(255,255,255,.68)!important}
.content-section{padding:42px 0 52px}
.container-readable{max-width:880px}
.legal-page .container-readable{max-width:1180px;padding-left:16px;padding-right:16px}
.content-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:18px;margin-bottom:20px}
.content-card{background:#fff;border:1px solid var(--border);border-radius:18px;box-shadow:var(--shadow-sm);padding:24px}
.content-card-large{grid-row:span 2}
.content-card h2,.content-card h3{margin-bottom:10px}
.content-card p + p{margin-top:12px}
.content-split{display:grid;grid-template-columns:1fr 1fr;gap:24px;align-items:center;margin:28px 0}
.content-split h2{margin:12px 0}
.content-list-card{background:#fff;border:1px solid var(--border);border-radius:18px;padding:24px;box-shadow:var(--shadow-sm)}
.content-check-list,.legal-copy ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.content-check-list li,.legal-copy li{position:relative;padding-left:24px;color:var(--text-light);line-height:1.65}
.content-check-list li::before,.legal-copy li::before{content:"";position:absolute;left:0;top:.62em;width:8px;height:8px;border-radius:50%;background:var(--primary)}
.content-feature-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:12px}
.content-feature-grid h3{font-size:1rem;margin-bottom:6px}
.content-feature-grid p{font-size:.9rem}
.content-cta-card{margin-top:24px;background:linear-gradient(135deg,#ecfdf5,#f8fafc);border:1px solid #bbf7d0;border-radius:22px;padding:24px;display:flex;align-items:center;justify-content:space-between;gap:18px}
.content-actions{display:flex;gap:12px;flex-wrap:wrap}
.legal-copy{padding:30px}
.legal-copy h2{font-size:1.22rem;margin:28px 0 8px}
.legal-copy h2:first-child{margin-top:0}
.legal-copy p{margin-bottom:12px;color:var(--text-light)}
.legal-page .content-hero{padding:18px 0 16px}
.legal-page .content-hero h1{font-size:clamp(1.65rem,2.6vw,2.15rem);margin:6px 0}
.legal-page .content-hero p{font-size:.92rem;line-height:1.55}
.legal-page .content-kicker{font-size:.7rem;padding:4px 10px}
.legal-page .content-meta{margin-top:6px}
.legal-page .content-section{padding:14px 0 22px}
.legal-page .legal-copy{padding:34px 42px;border-radius:18px}
.legal-page .legal-copy h2{font-size:1.08rem;margin:26px 0 10px}
.legal-page .legal-copy p{margin-bottom:14px;line-height:1.82}
.legal-page .legal-copy ul{gap:10px;margin:8px 0 16px}
.legal-page .legal-copy li{line-height:1.72}
main.legal-page + .footer{padding-top:30px}

/* Contact page */
.contact-page{background:var(--bg-alt)}
.contact-page + .footer{margin-top:0}
.contact-hero{background:radial-gradient(circle at 85% 10%,rgba(45,168,112,.38),transparent 34%),linear-gradient(135deg,#0a3d27,#1a7f5a);padding:48px 0;color:#fff;overflow:hidden}
.contact-hero-grid{display:grid;grid-template-columns:1.3fr .7fr;gap:32px;align-items:center}
.contact-hero h1{color:#fff;margin:12px 0 14px;font-size:clamp(2rem,4vw,3rem)}
.contact-hero p{color:rgba(255,255,255,.82);font-size:1.03rem;max-width:700px}
.contact-quick-card{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.18);border-radius:22px;padding:24px;backdrop-filter:blur(12px)}
.contact-quick-card h2{color:#fff;font-size:1.15rem;margin-bottom:12px}
.contact-quick-card ul{display:flex;flex-direction:column;gap:10px}
.contact-quick-card li{position:relative;color:rgba(255,255,255,.84);padding-left:22px;font-size:.92rem;line-height:1.55}
.contact-quick-card li::before{content:"";position:absolute;left:0;top:.62em;width:8px;height:8px;border-radius:50%;background:#86efac}
.contact-section{padding:38px 0 52px}
.contact-layout{display:grid;grid-template-columns:340px 1fr;gap:24px;align-items:start}
.contact-info-panel{display:flex;flex-direction:column;gap:14px}
.contact-info-card,.contact-form-card{background:#fff;border:1px solid var(--border);border-radius:22px;box-shadow:var(--shadow-sm)}
.contact-info-card{padding:22px}
.contact-icon{width:38px;height:38px;border-radius:12px;background:var(--primary-light);color:var(--primary);display:flex;align-items:center;justify-content:center;font-weight:800;margin-bottom:14px}
.contact-info-card h3{font-size:1.02rem;margin-bottom:8px}
.contact-info-card p{font-size:.92rem;margin:0}
.contact-form-card{padding:30px 34px}
.contact-form-head{display:flex;justify-content:space-between;gap:16px;margin-bottom:22px}
.contact-form-head h2{margin-bottom:6px}
.contact-form-head p{font-size:.94rem}
.contact-alert:empty{display:none}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.contact-topic-grid{grid-template-columns:.8fr 1.2fr}
.contact-form textarea.form-control{min-height:170px;line-height:1.65}
.contact-submit-row{display:flex;align-items:center;justify-content:space-between;gap:20px;margin-top:8px}
.contact-submit-row p{font-size:.86rem;max-width:440px;margin:0}

/* ── Grid helpers ───────────────────────────────────────────── */
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}

/* ── FAQ ────────────────────────────────────────────────────── */
.faq-item{border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;margin-bottom:12px}
.faq-q{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;cursor:pointer;font-weight:600;font-size:.95rem;color:var(--primary-dark);background:#fff;transition:background var(--transition)}
.faq-q:hover{background:var(--bg-alt)}
.faq-icon{font-size:1.2rem;color:var(--primary);transition:transform var(--transition)}
.faq-a{padding:0 22px;max-height:0;overflow:hidden;background:#fff;transition:max-height .3s ease,padding .2s}
.faq-item.open .faq-a{max-height:300px;padding:0 22px 18px}
.faq-item.open .faq-icon{transform:rotate(45deg)}
.faq-a p{font-size:.93rem;color:var(--text);line-height:1.7}

/* ── Insight cards ──────────────────────────────────────────── */
.insight-card{display:flex;align-items:flex-start;gap:14px;padding:16px;background:var(--bg-alt);border-radius:var(--radius);border-left:3px solid var(--primary);margin-bottom:12px}
.insight-icon{font-size:1.4rem;flex-shrink:0;margin-top:2px}
.insight-text{font-size:.88rem;color:var(--text-light);line-height:1.5}
.insight-text strong{color:var(--text)}

/* ── Misc ───────────────────────────────────────────────────── */
.spinner{width:20px;height:20px;border:2.5px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:spin .65s linear infinite;display:inline-block}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes fadeUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
.fade-up{animation:fadeUp .5s ease both}
.fade-up-1{animation-delay:.1s}.fade-up-2{animation-delay:.2s}.fade-up-3{animation-delay:.3s}.fade-up-4{animation-delay:.4s}

/* ── Tabs ───────────────────────────────────────────────────── */
.tabs{display:flex;gap:4px;background:var(--bg);border-radius:var(--radius);padding:4px}
.tab-btn{flex:1;padding:9px 18px;border-radius:var(--radius-sm);font-size:.88rem;font-weight:600;color:var(--muted);border:none;background:none;cursor:pointer;transition:background var(--transition),color var(--transition)}
.tab-btn.active{background:#fff;color:var(--text);box-shadow:var(--shadow-sm)}

/* ── Pagination ─────────────────────────────────────────────── */
.pagination{display:flex;align-items:center;gap:4px}
.page-btn{width:36px;height:36px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:.88rem;font-weight:600;color:var(--muted);border:1px solid var(--border);background:#fff;cursor:pointer;transition:background var(--transition),color var(--transition)}
.page-btn.active,.page-btn:hover{background:var(--primary);color:#fff;border-color:var(--primary)}

/* ── Responsive ─────────────────────────────────────────────── */
@media(max-width:1024px){.grid-4{grid-template-columns:repeat(2,1fr)}.footer-grid{grid-template-columns:1fr 1fr}}
@media(max-width:768px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}.section{padding:56px 0}.footer-grid{grid-template-columns:1fr;gap:28px}.footer-bottom{flex-direction:column;gap:12px;text-align:center}.navbar-links{display:none}.cookie-consent{left:14px;right:14px;bottom:14px}.cookie-card{flex-direction:column;gap:14px;padding:18px}.cookie-actions{width:100%;margin-left:0;flex-wrap:wrap}.cookie-btn{flex:1;min-width:130px}.cookie-modal{padding:14px}.cookie-modal-head,.cookie-modal-body{padding-left:16px;padding-right:16px}.cookie-modal-actions{flex-wrap:wrap}.cookie-save-btn,.cookie-cancel-btn{flex:1;min-width:130px}}
@media(max-width:900px){.content-grid,.content-split{grid-template-columns:1fr}.content-card-large{grid-row:auto}.content-feature-grid{grid-template-columns:repeat(2,1fr)}.content-cta-card{align-items:flex-start;flex-direction:column}}
@media(max-width:900px){.contact-hero-grid,.contact-layout{grid-template-columns:1fr}.contact-info-panel{display:grid;grid-template-columns:repeat(3,1fr)}}
@media(max-width:640px){.content-hero{padding:34px 0 32px}.content-section{padding:28px 0 40px}.content-card,.content-list-card,.legal-copy,.content-cta-card{padding:20px}.content-feature-grid{grid-template-columns:1fr}.legal-page .content-hero{padding:14px 0 12px}.legal-page .content-section{padding:10px 0 18px}.legal-page .container-readable{padding-left:10px;padding-right:10px}.legal-page .legal-copy{padding:22px}.legal-page .legal-copy h2{margin-top:20px}.legal-page .legal-copy p{line-height:1.72}.legal-page .legal-copy li{line-height:1.62}.contact-hero{padding:34px 0}.contact-section{padding:24px 0 38px}.contact-info-panel,.contact-grid,.contact-topic-grid{grid-template-columns:1fr}.contact-form-card{padding:22px}.contact-submit-row{align-items:stretch;flex-direction:column}.contact-submit-row .btn{width:100%}}

@media(max-width:900px){
  .home-hero-grid,
  .home-privacy-grid{grid-template-columns:1fr!important;gap:36px!important}
  .hero-section{padding:70px 0 56px!important}
  .hero-preview-wrap{max-width:620px;width:100%;margin:0 auto}
}
@media(max-width:640px){
  .container{padding-left:16px;padding-right:16px}
  .home-hero-grid,
  .home-privacy-grid{gap:26px!important}
  .hero-section{padding:52px 0 42px!important}
  .home-hero-actions{display:grid!important;grid-template-columns:1fr;gap:12px!important}
  .home-hero-actions .btn{width:100%}
  .home-trust-points{flex-wrap:wrap!important;gap:8px 14px!important}
  .hero-preview-window{padding:14px!important;border-radius:20px!important}
  .hero-preview-bar{margin-bottom:14px!important}
  .hero-preview-address{min-width:0}
  .hero-preview-address span{display:block;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:.7rem!important}
  .hero-preview-stats{grid-template-columns:1fr!important}
  .hero-preview-card{min-height:auto}
  .hero-preview-label{font-size:.66rem!important}
  .hero-preview-value{font-size:1rem!important}
  .hero-preview-sub{font-size:.68rem!important}
  .home-proof-row{gap:20px!important;justify-content:space-between!important}
  .home-proof-row>div:not(.home-proof-divider){flex:1 1 130px}
  .home-proof-divider{display:none}
}

/* Homepage dashboard preview animation */
.hero-home-advanced::after{content:"";position:absolute;inset:0;pointer-events:none;background:linear-gradient(115deg,transparent 0 35%,rgba(255,255,255,.055) 43%,transparent 52%),repeating-linear-gradient(90deg,rgba(255,255,255,.025) 0 1px,transparent 1px 112px);opacity:.56;animation:homePreviewField 18s linear infinite}
.hero-home-advanced>.container{position:relative;z-index:1}
.hero-preview-wrap{perspective:1200px}
.hero-preview-window{position:relative;overflow:hidden;box-shadow:0 28px 76px rgba(2,40,26,.3),inset 0 1px 0 rgba(255,255,255,.2);transform:rotateX(var(--hero-tilt-y,0deg)) rotateY(var(--hero-tilt-x,0deg)) translateY(0);transition:transform .45s cubic-bezier(.2,.8,.2,1),box-shadow .45s ease;animation:homePreviewFloat 7s ease-in-out infinite}
.hero-preview-window::before{content:"";position:absolute;inset:-2px;border-radius:inherit;pointer-events:none;background:linear-gradient(115deg,transparent 8%,rgba(255,255,255,.25) 18%,transparent 31%);transform:translateX(-120%);animation:homePreviewSweep 6.5s ease-in-out infinite}
.hero-preview-window::after{content:"";position:absolute;inset:0;pointer-events:none;background:radial-gradient(680px 320px at 82% 2%,rgba(255,255,255,.12),transparent 58%);animation:homePreviewGlow 9s ease-in-out infinite alternate}
.hero-preview-window>*{position:relative;z-index:1}
.hero-preview-dot{box-shadow:0 0 18px currentColor;animation:homeDotPulse 2.8s ease-in-out infinite}
.hero-preview-dot.red{color:rgba(239,68,68,.45)}
.hero-preview-dot.amber{color:rgba(245,158,11,.45);animation-delay:.25s}
.hero-preview-dot.green{color:rgba(34,197,94,.45);animation-delay:.5s}
.hero-preview-address{box-shadow:inset 0 1px 0 rgba(255,255,255,.08);transition:background-color .25s ease}
.hero-preview-window:hover .hero-preview-address{background:rgba(255,255,255,.12)!important}
.hero-preview-card{position:relative;overflow:hidden;min-height:116px;border:1px solid rgba(255,255,255,.08);box-shadow:inset 0 1px 0 rgba(255,255,255,.12);animation:homeCardRise .7s cubic-bezier(.2,.8,.2,1) both,homeCardFloat 5.8s ease-in-out infinite;animation-delay:calc(var(--card-index) * .12s),calc(var(--card-index) * .32s)}
.hero-preview-card::after{content:"";position:absolute;inset:0;pointer-events:none;background:linear-gradient(115deg,transparent 20%,rgba(255,255,255,.12),transparent 46%);transform:translateX(-130%);animation:homeCardSweep 5.5s ease-in-out infinite;animation-delay:calc(var(--card-index) * .4s)}
.hero-preview-label,.hero-preview-value,.hero-preview-sub{position:relative;z-index:1}
.hero-preview-chart{position:relative;overflow:hidden;border:1px solid rgba(255,255,255,.08)}
.hero-preview-bar-col{position:relative;overflow:hidden;transform-origin:bottom;animation:homeBarGrow .95s cubic-bezier(.2,.8,.2,1) both,homeBarPulse 4.8s ease-in-out infinite;animation-delay:calc(.28s + var(--bar-index) * .08s),calc(var(--bar-index) * .22s)}
.hero-preview-bar-col::before{content:"";position:absolute;inset:0 0 auto;height:34%;border-radius:inherit;background:linear-gradient(180deg,rgba(255,255,255,.18),transparent)}
@keyframes homePreviewField{0%{background-position:0 0,0 0}100%{background-position:280px 0,220px 0}}
@keyframes homePreviewFloat{0%,100%{transform:rotateX(var(--hero-tilt-y,0deg)) rotateY(var(--hero-tilt-x,0deg)) translateY(0)}50%{transform:rotateX(var(--hero-tilt-y,0deg)) rotateY(var(--hero-tilt-x,0deg)) translateY(-10px)}}
@keyframes homePreviewSweep{0%,42%{transform:translateX(-120%)}62%,100%{transform:translateX(120%)}}
@keyframes homePreviewGlow{0%{opacity:.55;transform:translateX(0)}100%{opacity:.9;transform:translateX(-7%)}}
@keyframes homeDotPulse{0%,100%{transform:scale(1);opacity:.95}50%{transform:scale(1.14);opacity:1}}
@keyframes homeCardRise{from{opacity:0;transform:translateY(14px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}
@keyframes homeCardFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-4px)}}
@keyframes homeCardSweep{0%,48%{transform:translateX(-130%)}68%,100%{transform:translateX(130%)}}
@keyframes homeBarGrow{from{transform:scaleY(.05);opacity:.35}to{transform:scaleY(1);opacity:1}}
@keyframes homeBarPulse{0%,100%{filter:saturate(1);opacity:.86}50%{filter:saturate(1.3);opacity:1}}
@media(prefers-reduced-motion:reduce){.hero-home-advanced::after,.hero-preview-window,.hero-preview-window::before,.hero-preview-window::after,.hero-preview-dot,.hero-preview-card,.hero-preview-card::after,.hero-preview-bar-col{animation:none!important}}
