/* ======================================================
   BANCUIP — Landing Page Styles
   ====================================================== */

/* --- Reset --- */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'DM Sans',system-ui,-apple-system,sans-serif;line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{text-decoration:none;color:inherit}
ul{list-style:none}
img{max-width:100%;display:block}
button{font-family:inherit;cursor:pointer}

/* --- Light theme tokens --- */
:root{
  --bg-body:#dcdce1;
  --bg-page:#ffffff;
  --bg-card:#f8f8fb;
  --bg-card-hover:#f0f0f5;
  --bg-input:#f3f3f6;
  --bg-purple:linear-gradient(145deg,#f3f0ff 0%,#ebe6fd 100%);
  --bg-green:linear-gradient(135deg,#eff7ec,#e6f2dc 40%,#f6fbf0 100%);
  --bg-green-section:linear-gradient(180deg,#f6faf2,#eff7e8 50%,#f4f9ef 100%);
  --bg-hero:linear-gradient(180deg,#ffffff 0%,#f0edfa 55%,#ffffff 100%);
  --text:#1a1a2e;
  --text2:#555;
  --text3:#888;
  --text4:#aaa;
  --border:#ebebee;
  --purple:#4F46E5;
  --accent:#10b981;
  --accent-light:#ecfdf5;
  --accent-up-bg:#dcfce7;--accent-up:#16a34a;
  --accent-dn-bg:#fee2e2;--accent-dn:#ef4444;
  --card-shadow:0 8px 40px rgba(80,70,130,.10),0 2px 12px rgba(0,0,0,.04);
  --navbar-bg:rgba(255,255,255,.88);
  --footer-bg:#1a1a2e;
  --footer-text:#fff;
  --green-panel-border:rgba(200,220,190,.3);
  --stat-green-bg:rgba(220,240,205,.45);
  --stat-glass:rgba(255,255,255,.6);
  --visa-card-bg:linear-gradient(145deg,#1a1a2e,#28283c,#1a1a2e);
  --visa-text:#fff;
  --card-vis-bg:linear-gradient(140deg,#f0e8fa 0%,#f5e0ec 40%,#fce8ee 70%,#fff0f0 100%);
  --dot-grid:rgba(180,170,200,.25);
  --speed-active-bg:#eeeaff;
  --speed-active-text:#4F46E5;
}

/* --- Dark theme tokens --- */
[data-theme="dark"]{
  --bg-body:#0c0c12;
  --bg-page:#141419;
  --bg-card:#1b1b24;
  --bg-card-hover:#222230;
  --bg-input:#1e1e28;
  --bg-purple:linear-gradient(145deg,#1c1830 0%,#201a38 100%);
  --bg-green:linear-gradient(135deg,#161e14,#1a2418 40%,#171e15 100%);
  --bg-green-section:linear-gradient(180deg,#151c13,#1a2316 50%,#161d14 100%);
  --bg-hero:linear-gradient(180deg,#141419 0%,#1a1630 55%,#141419 100%);
  --text:#e2e2ea;
  --text2:#a0a0ad;
  --text3:#6a6a78;
  --text4:#4a4a58;
  --border:#28283a;
  --purple:#8b7ff5;
  --accent:#34d399;
  --accent-light:rgba(16,185,129,.08);
  --accent-up-bg:#0d2615;--accent-up:#4ade80;
  --accent-dn-bg:#2a1015;--accent-dn:#f87171;
  --card-shadow:0 8px 40px rgba(0,0,0,.3),0 2px 12px rgba(0,0,0,.2);
  --navbar-bg:rgba(20,20,25,.88);
  --footer-bg:#0a0a10;
  --footer-text:#e2e2ea;
  --green-panel-border:rgba(60,80,50,.25);
  --stat-green-bg:rgba(30,50,25,.5);
  --stat-glass:rgba(30,30,40,.6);
  --visa-card-bg:linear-gradient(145deg,#ddd,#eee,#ddd);
  --visa-text:#111;
  --card-vis-bg:linear-gradient(140deg,#1e1a30 0%,#28203a 40%,#2a2035 70%,#221a2e 100%);
  --dot-grid:rgba(140,120,180,.12);
  --speed-active-bg:#1e1a35;
  --speed-active-text:#a78bfa;
}

/* --- Shared --- */
body{background:var(--bg-page);color:var(--text)}
.container{max-width:1200px;margin:0 auto;padding:0 48px}

/* --- Page wrapper (fills viewport) --- */
.page-wrapper{
  width:100%;min-height:100vh;
  background:var(--bg-page);
  overflow:hidden;
}

/* ======================================================
   NAVBAR
   ====================================================== */
.navbar{
  position:sticky;top:0;z-index:100;
  background:var(--navbar-bg);backdrop-filter:blur(16px);
  border-bottom:1px solid transparent;transition:border-color .3s;
}
.navbar.scrolled{border-bottom-color:var(--border)}
.nav-inner{
  max-width:1200px;margin:0 auto;padding:16px 48px;
  display:flex;align-items:center;justify-content:space-between;
}
.logo{font-weight:700;font-size:1.15rem;letter-spacing:-.5px}
.nav-links{display:flex;gap:28px}
.nav-links a{font-size:.88rem;color:var(--text2);font-weight:500;display:flex;align-items:center;gap:5px;transition:color .15s}
.nav-links a:hover{color:var(--text)}
.nav-right{display:flex;align-items:center;gap:10px}
.nav-signin{
  font-size:.88rem;font-weight:500;color:var(--text2);
  padding:9px 20px;border-radius:28px;border:1px solid var(--border);transition:all .15s;
}
.nav-signin:hover{border-color:var(--text3);background:var(--bg-card)}
.nav-cta{
  font-size:.88rem;font-weight:500;color:var(--bg-page);
  background:var(--text);padding:9px 22px;border-radius:28px;transition:background .15s;
}
.nav-cta:hover{opacity:.88}

/* ======================================================
   THEME TOGGLE
   ====================================================== */
.theme-toggle{
  background:none;border:1px solid var(--border);border-radius:50%;
  width:36px;height:36px;display:flex;align-items:center;justify-content:center;
  cursor:pointer;color:var(--text3);transition:all .2s;flex-shrink:0;
}
.theme-toggle:hover{border-color:var(--text3);color:var(--text)}
.icon-moon{display:none}
[data-theme="dark"] .icon-sun{display:none}
[data-theme="dark"] .icon-moon{display:block}

/* ======================================================
   HERO
   ====================================================== */
.hero{padding:72px 0 0;text-align:center;background:var(--bg-hero)}
.hero h1{font-size:3.4rem;font-weight:700;line-height:1.12;letter-spacing:-1.8px;margin-bottom:18px}
.hero-sub{font-size:.95rem;color:var(--text3);max-width:480px;margin:0 auto 30px;line-height:1.65}
.btn-primary{
  display:inline-block;background:var(--text);color:var(--bg-page);
  padding:14px 34px;border-radius:32px;font-size:.92rem;font-weight:500;
  transition:opacity .15s,transform .15s;
}
.btn-primary:hover{opacity:.88;transform:translateY(-1px)}
.hero-dashboard{position:relative;margin-top:44px;padding:0 16px}
.hero-img{
  width:100%;max-width:900px;margin:0 auto;border-radius:14px;
  box-shadow:var(--card-shadow);
}
img.hero-img-dark{display:none}
[data-theme="dark"] img.hero-img-light{display:none}
[data-theme="dark"] img.hero-img-dark{display:block}
.hero-dashboard-fade{
  position:absolute;bottom:0;left:0;right:0;height:100px;
  background:linear-gradient(to top,var(--bg-page) 20%,transparent);
  pointer-events:none;
}

/* ======================================================
   PARTNERS
   ====================================================== */
.partners{padding:40px 0;text-align:center}
.partners-label{font-size:.78rem;font-weight:600;color:var(--text4);text-transform:uppercase;letter-spacing:1.5px;margin-bottom:20px}
.partners-logos{display:flex;justify-content:center;gap:48px;align-items:center;flex-wrap:wrap}
.partner-item{display:flex;align-items:center;gap:10px;color:var(--text3);font-weight:600;font-size:.88rem}
.partner-logo{transition:.2s}
img.logo-dark{display:none}
[data-theme="dark"] img.logo-light{display:none}
[data-theme="dark"] img.logo-dark{display:block}

/* ======================================================
   SHARED SECTION STYLES
   ====================================================== */
.sec-heading{font-size:2.6rem;font-weight:700;line-height:1.18;letter-spacing:-1.2px;margin-bottom:20px}
.sec-heading.center{text-align:center}
.sec-sub{font-size:.95rem;color:var(--text3);line-height:1.65;max-width:560px;margin-bottom:48px}
.sec-sub.center{text-align:center;margin-left:auto;margin-right:auto}
.btn-outline{
  display:inline-block;padding:12px 26px;border:1.5px solid var(--border);border-radius:26px;
  font-size:.88rem;font-weight:500;color:var(--text);transition:all .15s;
}
.btn-outline:hover{border-color:var(--text3);background:var(--bg-card)}
.btn-outline-hero{
  display:inline-flex;align-items:center;padding:14px 34px;border:1.5px solid var(--border);
  border-radius:32px;font-size:.92rem;font-weight:500;color:var(--text);transition:all .15s;
}
.btn-outline-hero:hover{border-color:var(--text3);background:var(--bg-card)}

/* ======================================================
   FEATURES (12 cards grid)
   ====================================================== */
.features{padding:80px 0}
.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.feat-card{
  background:var(--bg-card);border:1px solid var(--border);
  border-radius:20px;padding:28px 24px;transition:all .2s;
}
.feat-card:hover{box-shadow:0 8px 24px rgba(0,0,0,.06);transform:translateY(-2px)}
.feat-card .feat-icon{
  width:46px;height:46px;display:flex;align-items:center;justify-content:center;
  background:var(--accent-light,#ecfdf5);color:var(--accent,#10b981);
  border-radius:12px;margin-bottom:16px;font-size:1.1rem;
}
[data-theme="dark"] .feat-card .feat-icon{background:rgba(16,185,129,.1);color:#34d399}
.feat-card h3{font-size:.95rem;font-weight:600;margin-bottom:8px}
.feat-card p{font-size:.84rem;color:var(--text3);line-height:1.6}

/* ======================================================
   PRICING
   ====================================================== */
.pricing{padding:80px 0;background:linear-gradient(180deg,var(--bg-page) 0%,var(--bg-card) 100%)}
.pricing-cards{display:grid;grid-template-columns:1fr 1fr;gap:24px;max-width:720px;margin:0 auto}
.pcard{
  background:var(--bg-page);border:1px solid var(--border);
  border-radius:20px;padding:36px 28px;text-align:center;
  transition:all .2s;
}
.pcard:hover{box-shadow:0 8px 32px rgba(0,0,0,.08);transform:translateY(-2px)}
.pcard-icon{margin-bottom:16px;display:flex;justify-content:center}
.pcard h3{font-size:1.1rem;font-weight:700;margin-bottom:8px}
.pcard-price{font-size:2.2rem;font-weight:800;letter-spacing:-.5px;margin-bottom:4px;color:var(--accent,#10b981)}
.pcard-price span{font-size:.85rem;font-weight:500;color:var(--text3)}
.pcard>p{font-size:.85rem;color:var(--text3);margin-bottom:24px}
.pcard-features{margin-bottom:28px;text-align:left}
.pcard-features li{display:flex;align-items:center;gap:10px;padding:6px 0;font-size:.88rem;color:var(--text2)}
.pcard-features li i{color:var(--accent,#10b981);font-size:.78rem}

/* ======================================================
   FAQ
   ====================================================== */
.faq{padding:72px 0}
.faq-list{max-width:720px;margin:0 auto 32px}
.faq-item{border-bottom:1px solid var(--border)}
.faq-item summary{
  display:flex;align-items:center;justify-content:space-between;
  padding:20px 0;font-size:.95rem;color:var(--text);cursor:pointer;
  list-style:none;transition:color .15s;
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary:hover{color:var(--accent)}
.faq-item summary span{font-size:1.3rem;color:var(--text3);transition:transform .3s}
.faq-item[open] summary span{transform:rotate(45deg)}
.faq-item p{padding:0 0 20px;font-size:.88rem;color:var(--text2);line-height:1.7}

/* ======================================================
   CTA SECTION
   ====================================================== */
.cta-section{padding:80px 0;background:linear-gradient(135deg,var(--accent-light,#ecfdf5),var(--bg-card))}
[data-theme="dark"] .cta-section{background:linear-gradient(135deg,rgba(16,185,129,.06),var(--bg-card))}

/* ======================================================
   FOOTER
   ====================================================== */
.footer{background:var(--footer-bg);color:var(--footer-text);padding:56px 0 28px}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.2fr;gap:40px;margin-bottom:40px}
.footer-brand{}
.footer-logo{color:var(--footer-text);font-size:1.2rem;display:inline-block;margin-bottom:14px}
.footer-desc{font-size:.82rem;color:rgba(255,255,255,.5);line-height:1.7;margin-bottom:20px}
.footer-social{display:flex;gap:12px}
.footer-social a{
  width:34px;height:34px;border-radius:8px;
  border:1px solid rgba(255,255,255,.12);
  display:flex;align-items:center;justify-content:center;
  color:rgba(255,255,255,.5);font-size:.82rem;transition:all .15s;
}
.footer-social a:hover{border-color:rgba(255,255,255,.3);color:#fff;background:rgba(255,255,255,.05)}
.footer-col h4{font-size:.82rem;font-weight:600;margin-bottom:16px;text-transform:uppercase;letter-spacing:.8px;color:rgba(255,255,255,.7)}
.footer-col a{display:block;font-size:.85rem;color:rgba(255,255,255,.45);padding:4px 0;transition:color .15s}
.footer-col a:hover{color:#fff}
.footer-address{font-size:.82rem;color:rgba(255,255,255,.4);line-height:1.6;margin-top:4px}
.footer-bottom{padding-top:24px;border-top:1px solid rgba(255,255,255,.08);text-align:center}
.footer-bottom p{font-size:.78rem;color:rgba(255,255,255,.35)}

/* ======================================================
   ANIMATIONS
   ====================================================== */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .55s ease,transform .55s ease}
.reveal.visible{opacity:1;transform:translateY(0)}

/* ======================================================
   RESPONSIVE
   ====================================================== */

/* Tablet landscape */
@media(max-width:1024px){
  .container{padding:0 36px}
  .nav-inner{padding:16px 36px}
  .hero h1{font-size:2.6rem}
  .sec-heading{font-size:2rem}
  .features-grid{grid-template-columns:repeat(2,1fr)}
}

/* Tablet portrait */
@media(max-width:768px){
  .container{padding:0 24px}
  .nav-inner{padding:14px 24px}
  .nav-links{display:none}
  .nav-signin{padding:8px 16px;font-size:.82rem}
  .nav-cta{padding:8px 18px;font-size:.82rem}

  .hero{padding:48px 0 0}
  .hero h1{font-size:2rem;letter-spacing:-1px}
  .hero-sub{font-size:.88rem}
  .btn-primary{padding:12px 28px;font-size:.88rem}
  .btn-outline-hero{padding:12px 28px;font-size:.88rem}
  .sec-heading{font-size:1.6rem;letter-spacing:-.8px;margin-bottom:16px}
  .sec-sub{font-size:.88rem;margin-bottom:36px}

  .features{padding:56px 0}
  .features-grid{grid-template-columns:repeat(2,1fr);gap:14px}
  .feat-card{padding:22px 20px}

  .pricing-cards{grid-template-columns:1fr;max-width:380px}
  .pcard{padding:28px 24px}

  .faq{padding:56px 0}
  .faq-item summary{font-size:.88rem;padding:16px 0}

  .footer{padding:40px 0 24px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px}

  .cta-section{padding:56px 0}
  .partners-logos{gap:32px}
}

/* Mobile */
@media(max-width:480px){
  .container{padding:0 16px}
  .nav-inner{padding:12px 16px}
  .logo{font-size:1rem}
  .nav-signin{display:none}
  .nav-cta{padding:8px 16px;font-size:.78rem}
  .theme-toggle{width:32px;height:32px}

  .hero{padding:36px 0 0}
  .hero h1{font-size:1.55rem;letter-spacing:-.7px}
  .hero-sub{font-size:.82rem;margin-bottom:24px}
  .btn-primary{padding:11px 24px;font-size:.84rem}
  .btn-outline-hero{padding:11px 24px;font-size:.84rem}
  .hero-dashboard{margin-top:32px;padding:0 8px}
  .sec-heading{font-size:1.35rem;letter-spacing:-.6px;margin-bottom:14px}
  .sec-sub{font-size:.82rem;margin-bottom:28px}

  .features{padding:40px 0}
  .features-grid{grid-template-columns:1fr;gap:12px}
  .feat-card{padding:20px 18px;border-radius:16px}
  .feat-card .feat-icon{width:40px;height:40px;border-radius:10px;font-size:1rem}
  .feat-card h3{font-size:.88rem}
  .feat-card p{font-size:.8rem}

  .pricing{padding:40px 0}
  .pcard-price{font-size:1.8rem}

  .faq{padding:40px 0}
  .faq .sec-heading{font-size:1.25rem}
  .faq-item summary{font-size:.84rem;padding:14px 0}
  .faq-item p{font-size:.82rem;padding-bottom:14px}

  .cta-section{padding:40px 0}

  .footer{padding:32px 0 20px}
  .footer-grid{grid-template-columns:1fr;gap:28px}
  .footer-desc{font-size:.78rem}
  .footer-col h4{font-size:.75rem}
  .footer-col a{font-size:.82rem}
  .footer-address{font-size:.78rem}

  .partners-logos{gap:24px}
  .partner-item{font-size:.78rem}
  .partner-item img{height:24px!important}
}
