/* ============================================
   MobileBank UI Kit — COMPLETE DESIGN SYSTEM
   Light mobile app feel + coral accent
   Accent: Coral #F43F5E + soft pastels
   Font: Plus Jakarta Sans
   Material Icons + Swiper.js
   ============================================ */

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

/* ============================================
   CSS VARIABLES
   ============================================ */
:root {
  --primary: #F43F5E;
  --primary-dark: #E11D48;
  --primary-light: #FB7185;
  --primary-glow: rgba(244,63,94,0.15);
  --primary-bg: rgba(244,63,94,0.08);
  --accent: #F43F5E;

  --success: #22C55E;
  --success-bg: rgba(34,197,94,0.1);
  --warning: #F59E0B;
  --warning-bg: rgba(245,158,11,0.1);
  --info: #3B82F6;
  --info-bg: rgba(59,130,246,0.1);
  --purple: #8B5CF6;
  --purple-bg: rgba(139,92,246,0.1);
  --teal: #14B8A6;

  --bg-page: #F0F2F5;
  --bg-surface: #FFFFFF;
  --bg-elevated: #FFFFFF;
  --bg-input: #F5F6F8;
  --bg-hover: rgba(0,0,0,0.03);
  --text-primary: #0F172A;
  --text-secondary: #64748B;
  --text-dim: #94A3B8;
  --border: rgba(0,0,0,0.06);
  --border-strong: rgba(0,0,0,0.1);
  --shadow-sm: 0 1px 3px rgba(0,0,0,0.06);
  --shadow-md: 0 4px 12px rgba(0,0,0,0.08);
  --shadow-lg: 0 8px 32px rgba(0,0,0,0.1);
  --shadow-xl: 0 16px 48px rgba(0,0,0,0.12);
  --shadow-phone: 0 25px 80px rgba(0,0,0,0.2), 0 0 0 1px rgba(0,0,0,0.06);

  --radius-sm: 8px;
  --radius-md: 12px;
  --radius-lg: 16px;
  --radius-xl: 24px;
  --radius-phone: 48px;

  --pastel-coral: #FFF1F2;
  --pastel-blue: #EFF6FF;
  --pastel-green: #F0FDF4;
  --pastel-purple: #F5F3FF;
  --pastel-orange: #FFF7ED;
  --pastel-yellow: #FEFCE8;
}

/* ============================================
   RESET
   ============================================ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{
  font-family:'Plus Jakarta Sans',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  background:var(--bg-page);color:var(--text-primary);line-height:1.5;
  overflow-x:hidden;transition:background .3s,color .3s;
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;
}
h1,h2,h3,h4,h5,h6{font-family:'Plus Jakarta Sans',sans-serif;font-weight:700;line-height:1.2;color:var(--text-primary)}
a{color:var(--primary);text-decoration:none;transition:color .2s}
a:hover{color:var(--primary-dark)}
img{max-width:100%;display:block}
ul{list-style:none}
button,input,select,textarea{font-family:'Plus Jakarta Sans',sans-serif;font-size:.9rem;border:none;outline:none;background:none;cursor:pointer}

/* ============================================
   DEMO BANNER
   ============================================ */
.demo-banner{
  background:linear-gradient(90deg,var(--primary-dark),var(--primary),#FF6B81);
  color:#fff;text-align:center;padding:10px 16px;font-size:.82rem;font-weight:600;
  letter-spacing:.02em;position:relative;z-index:1001;
}
.demo-banner a{color:#fff;text-decoration:underline;font-weight:700}

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

/* ============================================
   BUTTONS
   ============================================ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-weight:600;border-radius:var(--radius-md);cursor:pointer;
  transition:all .25s ease;white-space:nowrap;font-family:'Plus Jakarta Sans',sans-serif;
  text-decoration:none;
}
.btn-primary{
  background:var(--primary);color:#fff;
  box-shadow:0 4px 14px rgba(244,63,94,0.3);
}
.btn-primary:hover{background:var(--primary-dark);color:#fff;transform:translateY(-2px);box-shadow:0 6px 20px rgba(244,63,94,0.4)}
.btn-outline{
  background:transparent;color:var(--primary);
  border:2px solid var(--primary);
}
.btn-outline:hover{background:var(--primary);color:#fff}
.btn-ghost{background:transparent;color:var(--text-secondary)}
.btn-ghost:hover{background:var(--bg-hover);color:var(--text-primary)}
.btn-sm{padding:8px 16px;font-size:.82rem}
.btn-md{padding:10px 24px;font-size:.85rem}
.btn-lg{padding:14px 32px;font-size:.95rem}
.btn-xl{padding:16px 40px;font-size:1rem;border-radius:var(--radius-lg)}
.btn-block{width:100%;justify-content:center}

/* ============================================
   TOP NAV (Landing page desktop)
   ============================================ */
.topnav{
  position:sticky;top:0;z-index:1000;
  background:rgba(255,255,255,0.92);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid var(--border);
  height:68px;padding:0 32px;
  display:flex;align-items:center;gap:0;
  transition:background .3s;
}
.topnav-brand{
  display:flex;align-items:center;gap:10px;
  font-weight:800;font-size:1.25rem;
  color:var(--primary);margin-right:48px;white-space:nowrap;
  text-decoration:none;
}
.topnav-brand svg{width:34px;height:34px}
.topnav-links{display:flex;align-items:center;gap:0;flex:1}
.topnav-links a{
  padding:22px 20px;font-weight:600;font-size:.88rem;
  color:var(--text-secondary);border-bottom:2px solid transparent;
  transition:color .2s,border-color .2s;white-space:nowrap;text-decoration:none;
}
.topnav-links a:hover,.topnav-links a.active{
  color:var(--primary);border-bottom-color:var(--primary);
}
.topnav-right{display:flex;align-items:center;gap:12px;margin-left:auto}
.hamburger{
  display:none;flex-direction:column;gap:5px;cursor:pointer;
  padding:8px;background:none;
}
.hamburger span{width:22px;height:2px;background:var(--text-primary);border-radius:2px;transition:all .3s}
.hamburger.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.hamburger.active span:nth-child(2){opacity:0}
.hamburger.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

@media(max-width:768px){
  .topnav{padding:0 16px}
  .topnav-links{
    display:none;position:absolute;top:68px;left:0;right:0;
    flex-direction:column;background:var(--bg-surface);
    border-bottom:1px solid var(--border);
    box-shadow:var(--shadow-lg);padding:8px 0;
  }
  .topnav-links.open{display:flex}
  .topnav-links a{padding:14px 24px;border-bottom:none}
  .hamburger{display:flex}
}

/* ============================================
   SECTIONS (Landing page)
   ============================================ */
.section{padding:80px 0}
.section-center{text-align:center}
.section-label{
  display:inline-block;font-size:.82rem;font-weight:700;
  color:var(--primary);text-transform:uppercase;letter-spacing:.08em;
  margin-bottom:10px;
}
.section-title{
  font-size:2.6rem;font-weight:900;letter-spacing:-0.02em;
  margin-bottom:16px;line-height:1.15;
}
.section-sub{
  font-size:1.1rem;color:var(--text-secondary);line-height:1.7;
  max-width:600px;margin:0 auto 48px;
}

/* ============================================
   HERO SECTION
   ============================================ */
.hero{
  padding:80px 0 80px;
  background:linear-gradient(180deg,#FFFFFF 0%,#FFF1F2 50%,#F0F2F5 100%);
  position:relative;overflow:hidden;
}
.hero::before{
  content:'';position:absolute;top:-200px;right:-200px;
  width:700px;height:700px;border-radius:50%;
  background:radial-gradient(circle,rgba(244,63,94,0.06) 0%,transparent 70%);
  pointer-events:none;
}
.hero::after{
  content:'';position:absolute;bottom:-100px;left:-100px;
  width:400px;height:400px;border-radius:50%;
  background:radial-gradient(circle,rgba(59,130,246,0.04) 0%,transparent 70%);
  pointer-events:none;
}
.hero-split{
  display:flex;align-items:center;gap:80px;
}
.hero-content{flex:1;max-width:560px}
.hero-badge{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--pastel-coral);color:var(--primary);
  font-weight:600;font-size:.82rem;padding:8px 16px;
  border-radius:24px;margin-bottom:24px;
}
.hero-headline{
  font-size:3.4rem;font-weight:900;line-height:1.08;
  margin-bottom:24px;letter-spacing:-0.03em;
}
.hero-headline .accent{
  color:var(--primary);
  background:linear-gradient(135deg,var(--primary),#FF6B81);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;
}
.hero-sub{
  font-size:1.15rem;color:var(--text-secondary);line-height:1.7;
  margin-bottom:36px;max-width:480px;
}

/* App Store Buttons in Hero */
.hero-store-buttons{display:flex;gap:14px;margin-bottom:32px;flex-wrap:wrap}
.store-btn{
  display:flex;align-items:center;gap:10px;
  background:#0F172A;color:#fff;
  padding:12px 24px;border-radius:var(--radius-md);
  cursor:pointer;transition:all .25s;border:none;
  text-decoration:none;
}
.store-btn:hover{background:#1E293B;transform:translateY(-2px);color:#fff;box-shadow:0 8px 24px rgba(0,0,0,0.15)}
.store-btn .store-icon{font-size:1.6rem;line-height:1}
.store-btn .store-icon svg{width:24px;height:24px;fill:#fff}
.store-btn-text{text-align:left}
.store-btn-text small{display:block;font-size:.65rem;opacity:.8;font-weight:400;letter-spacing:.02em}
.store-btn-text strong{display:block;font-size:.95rem;font-weight:700;letter-spacing:-.01em}

.hero-proof{display:flex;gap:24px;flex-wrap:wrap}
.hero-proof span{
  display:flex;align-items:center;gap:6px;
  font-size:.85rem;color:var(--text-secondary);font-weight:500;
}
.hero-proof .dot{
  width:7px;height:7px;border-radius:50%;background:var(--success);
}

/* Hero Phone Mockup (tilted) */
.hero-phone-wrap{
  flex:0 0 340px;display:flex;justify-content:center;
  perspective:1000px;
}
.hero-phone{
  width:280px;
  background:#1A1A2E;
  border-radius:44px;
  box-shadow:var(--shadow-phone);
  overflow:hidden;position:relative;
  border:4px solid #1A1A2E;
  transform:rotate(-6deg) rotateY(8deg);
  transition:transform .5s ease;
}
.hero-phone:hover{transform:rotate(-3deg) rotateY(4deg)}
.hero-phone .phone-notch{
  width:100px;height:28px;background:#1A1A2E;
  border-radius:0 0 18px 18px;
  position:absolute;top:0;left:50%;transform:translateX(-50%);
  z-index:10;
}
.hero-phone .phone-screen{
  background:#fff;margin:10px;border-radius:36px;
  padding:42px 16px 16px;overflow:hidden;
}
.phone-greeting{font-size:.75rem;color:var(--text-secondary);margin-bottom:2px}
.phone-balance-label{font-size:.6rem;color:var(--text-dim);margin-top:8px}
.phone-balance{font-size:1.5rem;font-weight:800;margin-bottom:10px;letter-spacing:-.02em}
.phone-actions{display:flex;gap:8px;margin-bottom:12px;justify-content:space-between;padding:0 4px}
.phone-action{display:flex;flex-direction:column;align-items:center;gap:3px}
.phone-action-icon{
  width:32px;height:32px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:.7rem;font-weight:700;
}
.phone-action span{font-size:.5rem;color:var(--text-dim);font-weight:500}
.phone-card-mini{
  background:linear-gradient(135deg,var(--primary),#FF6B81);
  border-radius:10px;padding:10px 12px;color:#fff;margin-bottom:10px;
}
.phone-card-mini .card-bal{font-size:.5rem;opacity:.8}
.phone-card-mini .card-num{font-size:.65rem;letter-spacing:1.5px;margin-top:4px;font-weight:600}
.phone-tx-mini{display:flex;flex-direction:column;gap:6px}
.phone-tx-item{display:flex;align-items:center;gap:8px;padding:4px 0}
.phone-tx-icon{
  width:28px;height:28px;border-radius:8px;
  display:flex;align-items:center;justify-content:center;font-size:.65rem;
}
.phone-tx-info{flex:1}
.phone-tx-name{font-size:.6rem;font-weight:600}
.phone-tx-cat{font-size:.45rem;color:var(--text-dim)}
.phone-tx-amt{font-size:.6rem;font-weight:700}
.phone-tx-amt.neg{color:var(--text-primary)}
.phone-tx-amt.pos{color:var(--success)}

@media(max-width:900px){
  .hero-split{flex-direction:column;text-align:center;gap:48px}
  .hero-content{max-width:100%}
  .hero-sub{margin-left:auto;margin-right:auto}
  .hero-store-buttons{justify-content:center}
  .hero-proof{justify-content:center}
  .hero-phone-wrap{flex:none}
  .hero-headline{font-size:2.4rem}
}

/* ============================================
   STATS STRIP
   ============================================ */
.stats-strip{
  display:grid;grid-template-columns:repeat(4,1fr);gap:24px;
  padding:40px 0;margin:0 auto;
}
.stat-item{text-align:center;padding:24px 16px}
.stat-value{font-size:2.2rem;font-weight:900;color:var(--primary);letter-spacing:-.02em}
.stat-label{font-size:.88rem;color:var(--text-secondary);font-weight:500;margin-top:4px}

@media(max-width:600px){
  .stats-strip{grid-template-columns:repeat(2,1fr);gap:16px}
  .stat-value{font-size:1.6rem}
}

/* ============================================
   FEATURES GRID
   ============================================ */
.features-grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:24px;
  max-width:800px;margin:0 auto;
}
.feature-card{
  background:var(--bg-surface);border-radius:var(--radius-xl);
  padding:36px 28px;text-align:left;
  border:1px solid var(--border);
  transition:all .3s ease;
}
.feature-card:hover{
  transform:translateY(-4px);
  box-shadow:var(--shadow-lg);
  border-color:transparent;
}
.feature-card h3{font-size:1.15rem;font-weight:700;margin-bottom:8px}
.feature-card p{font-size:.92rem;color:var(--text-secondary);line-height:1.6}
.feature-icon{
  width:56px;height:56px;border-radius:var(--radius-lg);
  display:flex;align-items:center;justify-content:center;
  font-size:1.5rem;margin-bottom:20px;
}
.feature-icon .material-icons-outlined,
.feature-icon .material-symbols-rounded{font-size:28px}
.feature-icon.coral{background:var(--pastel-coral);color:var(--primary)}
.feature-icon.blue{background:var(--pastel-blue);color:var(--info)}
.feature-icon.green{background:var(--pastel-green);color:var(--success)}
.feature-icon.purple{background:var(--pastel-purple);color:var(--purple)}

@media(max-width:600px){
  .features-grid{grid-template-columns:1fr}
  .section-title{font-size:1.8rem}
}

/* ============================================
   SCREEN PREVIEWS (Swiper on landing page)
   ============================================ */
.previews-section{
  background:linear-gradient(180deg,#F0F2F5 0%,#FFF1F2 50%,#F0F2F5 100%);
}
.screen-preview-swiper{
  max-width:900px;margin:0 auto;padding:20px 0 60px;
  overflow:visible;
}
.screen-preview-swiper .swiper-slide{
  display:flex;justify-content:center;
  transition:transform .4s ease,opacity .4s ease;
}
.screen-preview-swiper .swiper-slide-active{transform:scale(1)}
.screen-preview-swiper .swiper-slide:not(.swiper-slide-active){transform:scale(0.85);opacity:0.6}

.preview-phone{
  width:220px;
  background:#1A1A2E;border-radius:32px;
  overflow:hidden;position:relative;
  border:3px solid #1A1A2E;
  box-shadow:0 16px 48px rgba(0,0,0,0.15);
}
.preview-notch{
  width:80px;height:22px;background:#1A1A2E;
  border-radius:0 0 14px 14px;
  position:absolute;top:0;left:50%;transform:translateX(-50%);z-index:10;
}
.preview-screen{
  background:#fff;margin:8px;border-radius:26px;
  padding:34px 12px 14px;min-height:380px;
  overflow:hidden;
}
/* Preview screen inner elements */
.ps-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.ps-title{font-size:.7rem;font-weight:800}
.ps-card{
  border-radius:10px;padding:10px 12px;color:#fff;margin-bottom:6px;
}
.ps-bar{height:5px;background:var(--bg-input);border-radius:3px;margin-bottom:0;overflow:hidden}
.ps-bar-fill{height:100%;border-radius:3px;transition:width .8s ease}
.ps-item{display:flex;align-items:center;gap:6px;padding:5px 0}
.ps-dot{
  width:24px;height:24px;border-radius:6px;
  display:flex;align-items:center;justify-content:center;font-size:.55rem;
}
.ps-item-info{flex:1}
.ps-item-name{font-size:.55rem;font-weight:600}
.ps-item-sub{font-size:.42rem;color:var(--text-dim)}
.ps-item-val{font-size:.55rem;font-weight:700}

/* Swiper pagination */
.screen-preview-swiper .swiper-pagination{position:relative;margin-top:20px}
.screen-preview-swiper .swiper-pagination-bullet{
  width:10px;height:10px;background:var(--text-dim);opacity:.3;
  transition:all .3s;
}
.screen-preview-swiper .swiper-pagination-bullet-active{
  background:var(--primary);opacity:1;width:28px;border-radius:5px;
}

/* ============================================
   TESTIMONIALS
   ============================================ */
.testimonials-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;
  max-width:1000px;margin:0 auto;
}
.testimonial-card{
  background:var(--bg-surface);border-radius:var(--radius-xl);
  padding:32px 28px;text-align:left;
  border:1px solid var(--border);
  transition:all .3s ease;
}
.testimonial-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:transparent}
.testimonial-stars{color:#FBBF24;font-size:1rem;margin-bottom:14px;letter-spacing:2px}
.testimonial-text{
  font-size:.92rem;color:var(--text-secondary);line-height:1.7;
  margin-bottom:20px;font-style:italic;
}
.testimonial-author{display:flex;align-items:center;gap:12px}
.testimonial-avatar{
  width:44px;height:44px;border-radius:50%;
  background:var(--pastel-coral);color:var(--primary);
  display:flex;align-items:center;justify-content:center;
  font-weight:700;font-size:.85rem;overflow:hidden;
  object-fit:cover;flex-shrink:0;
}
.testimonial-avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%}
.testimonial-name{font-weight:700;font-size:.9rem}
.testimonial-role{font-size:.78rem;color:var(--text-dim)}

@media(max-width:768px){
  .testimonials-grid{grid-template-columns:1fr;max-width:480px}
}

/* ============================================
   DOWNLOAD / CTA SECTION
   ============================================ */
.cta-section{
  padding:80px 0;
  background:linear-gradient(135deg,#FFF1F2 0%,#EFF6FF 50%,#F5F3FF 100%);
  text-align:center;position:relative;overflow:hidden;
}
.cta-section::before{
  content:'';position:absolute;top:-100px;right:-100px;
  width:400px;height:400px;border-radius:50%;
  background:radial-gradient(circle,rgba(244,63,94,0.08),transparent 70%);
}
.cta-phone-wrap{
  display:flex;justify-content:center;margin-top:40px;
}
.cta-phone{
  width:200px;background:#1A1A2E;border-radius:32px;
  overflow:hidden;position:relative;border:3px solid #1A1A2E;
  box-shadow:var(--shadow-phone);
}
.cta-phone .cta-phone-screen{
  background:linear-gradient(180deg,var(--primary),#FF6B81);
  margin:6px;border-radius:26px;
  padding:60px 20px;text-align:center;color:#fff;
}
.cta-phone .cta-phone-screen .cta-phone-icon{font-size:2rem;margin-bottom:8px}
.cta-phone .cta-phone-screen .cta-phone-text{font-size:.7rem;font-weight:600}

.cta-store-buttons{display:flex;gap:14px;justify-content:center;margin-top:32px;flex-wrap:wrap}

/* ============================================
   FOOTER
   ============================================ */
.footer{
  background:#0F172A;color:#94A3B8;padding:64px 0 32px;
}
.footer-grid{
  display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:40px;
  margin-bottom:48px;
}
.footer-brand{
  display:flex;align-items:center;gap:10px;
  font-weight:800;font-size:1.2rem;color:#fff;margin-bottom:14px;
}
.footer-brand svg{width:30px;height:30px}
.footer-desc{font-size:.88rem;line-height:1.7;color:#94A3B8;max-width:300px}
.footer-social{display:flex;gap:12px;margin-top:20px}
.footer-social a{
  width:36px;height:36px;border-radius:50%;
  background:rgba(255,255,255,0.08);color:#94A3B8;
  display:flex;align-items:center;justify-content:center;
  transition:all .2s;font-size:.9rem;
}
.footer-social a:hover{background:var(--primary);color:#fff}
.footer h4{color:#fff;font-size:.92rem;margin-bottom:16px;font-weight:700}
.footer ul li{margin-bottom:10px}
.footer ul a{color:#94A3B8;font-size:.88rem;text-decoration:none;transition:color .2s}
.footer ul a:hover{color:#fff}
.footer-bottom{
  display:flex;justify-content:space-between;align-items:center;
  padding-top:32px;border-top:1px solid rgba(255,255,255,0.08);
  font-size:.82rem;flex-wrap:wrap;gap:12px;
}

@media(max-width:768px){
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px}
}
@media(max-width:480px){
  .footer-grid{grid-template-columns:1fr}
}

/* ============================================
   PHONE PAGE BACKGROUNDS
   ============================================ */
.phone-page-bg{
  min-height:100vh;
  display:flex;flex-direction:column;align-items:center;
  padding:40px 20px 60px;
  position:relative;
}
.phone-page-bg.bg-coral{
  background:linear-gradient(160deg,#FFF1F2 0%,#FFE4E6 30%,#FECDD3 60%,#FFF1F2 100%);
}
.phone-page-bg.bg-blue{
  background:linear-gradient(160deg,#EFF6FF 0%,#DBEAFE 30%,#BFDBFE 60%,#EFF6FF 100%);
}
.phone-page-bg.bg-green{
  background:linear-gradient(160deg,#F0FDF4 0%,#DCFCE7 30%,#BBF7D0 60%,#F0FDF4 100%);
}
.phone-page-bg.bg-purple{
  background:linear-gradient(160deg,#F5F3FF 0%,#EDE9FE 30%,#DDD6FE 60%,#F5F3FF 100%);
}
.phone-page-bg.bg-warm{
  background:linear-gradient(160deg,#FFF7ED 0%,#FFEDD5 30%,#FED7AA 60%,#FFF7ED 100%);
}
.phone-page-title{
  font-size:1.6rem;font-weight:800;color:var(--text-primary);
  margin-bottom:6px;text-align:center;letter-spacing:-.02em;
}
.phone-page-sub{
  font-size:.95rem;color:var(--text-secondary);margin-bottom:32px;
  text-align:center;
}

/* ============================================
   REALISTIC PHONE FRAME
   ============================================ */
.phone-frame{
  width:390px;
  background:#1A1A2E;
  border-radius:var(--radius-phone);
  position:relative;
  box-shadow:
    var(--shadow-phone),
    inset 0 0 0 1px rgba(255,255,255,0.08),
    0 0 0 1px rgba(0,0,0,0.3);
  overflow:hidden;
}

/* Dynamic Island */
.dynamic-island{
  width:120px;height:32px;
  background:#000;
  border-radius:20px;
  position:absolute;top:12px;left:50%;transform:translateX(-50%);
  z-index:20;
  box-shadow:inset 0 0 4px rgba(0,0,0,0.5);
}
.dynamic-island::before{
  content:'';position:absolute;
  width:10px;height:10px;border-radius:50%;
  background:radial-gradient(circle at 30% 30%,#1a1a3e,#000);
  right:24px;top:50%;transform:translateY(-50%);
}

/* Status Bar */
.status-bar{
  display:flex;justify-content:space-between;align-items:center;
  padding:14px 28px 0;
  position:relative;z-index:15;
  height:52px;
}
.status-time{
  font-size:.88rem;font-weight:700;color:#0F172A;
  min-width:40px;
}
.status-icons{
  display:flex;align-items:center;gap:6px;
}
.status-icons svg{display:block}

/* Phone Screen Content */
.phone-screen-content{
  margin:0 8px 8px;
  border-radius:0 0 calc(var(--radius-phone) - 8px) calc(var(--radius-phone) - 8px);
  padding:8px 16px 0;
  overflow-y:auto;
  max-height:calc(100vh - 240px);
  min-height:680px;
  scrollbar-width:none;
  -ms-overflow-style:none;
}
.phone-screen-content::-webkit-scrollbar{display:none}
.phone-screen-content.white-bg{background:#fff}
.phone-screen-content.gray-bg{background:#F8F9FB}

/* ============================================
   APP HEADER (inside phone)
   ============================================ */
.app-header{
  display:flex;justify-content:space-between;align-items:center;
  padding:8px 0 16px;
}
.app-header-greeting{font-size:.82rem;color:var(--text-dim);font-weight:500}
.app-header-name{font-size:1.35rem;font-weight:800;letter-spacing:-.02em}
.app-header-title{font-size:1.35rem;font-weight:800;letter-spacing:-.02em}
.app-header-btn{
  width:40px;height:40px;border-radius:50%;
  background:var(--bg-surface);
  border:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;
  font-size:1.1rem;cursor:pointer;
  transition:all .2s;position:relative;
  box-shadow:var(--shadow-sm);
}
.app-header-btn:hover{background:var(--bg-input)}
.app-header-btn .material-icons-outlined,
.app-header-btn .material-symbols-rounded{font-size:22px;color:var(--text-secondary)}
.notif-badge::after{
  content:'';position:absolute;top:8px;right:8px;
  width:8px;height:8px;border-radius:50%;
  background:var(--primary);
  border:2px solid var(--bg-surface);
}

/* ============================================
   BALANCE CARD (Home)
   ============================================ */
.balance-card{
  background:linear-gradient(135deg,#F43F5E 0%,#FB7185 50%,#FF8FA3 100%);
  border-radius:var(--radius-xl);
  padding:24px;color:#fff;margin-bottom:20px;
  position:relative;overflow:hidden;
}
.balance-card::before{
  content:'';position:absolute;top:-40px;right:-40px;
  width:140px;height:140px;border-radius:50%;
  background:rgba(255,255,255,0.1);
}
.balance-card::after{
  content:'';position:absolute;bottom:-30px;left:-30px;
  width:100px;height:100px;border-radius:50%;
  background:rgba(255,255,255,0.06);
}
.balance-card-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px;position:relative;z-index:1}
.balance-card-label{font-size:.82rem;opacity:.85;font-weight:500}
.balance-card-eye{
  width:32px;height:32px;border-radius:50%;
  background:rgba(255,255,255,0.15);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;transition:background .2s;
}
.balance-card-eye:hover{background:rgba(255,255,255,0.25)}
.balance-card-eye .material-icons-outlined,
.balance-card-eye .material-symbols-rounded{font-size:18px;color:#fff}
.balance-amount{
  font-size:2.2rem;font-weight:900;letter-spacing:-.03em;
  margin-bottom:4px;position:relative;z-index:1;
}
.balance-change{
  font-size:.82rem;font-weight:600;
  display:inline-flex;align-items:center;gap:4px;
  position:relative;z-index:1;
}
.balance-change.up{color:#D1FAE5}

/* ============================================
   QUICK ACTIONS
   ============================================ */
.quick-actions{
  display:flex;justify-content:space-between;
  padding:0 8px;margin-bottom:20px;
}
.quick-action{
  display:flex;flex-direction:column;align-items:center;gap:8px;
  cursor:pointer;
}
.quick-action-icon{
  width:52px;height:52px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:1.2rem;transition:all .25s;
  box-shadow:var(--shadow-sm);
}
.quick-action-icon .material-icons-outlined,
.quick-action-icon .material-symbols-rounded{font-size:24px}
.quick-action-icon.coral{background:var(--pastel-coral);color:var(--primary)}
.quick-action-icon.blue{background:var(--pastel-blue);color:var(--info)}
.quick-action-icon.green{background:var(--pastel-green);color:var(--success)}
.quick-action-icon.purple{background:var(--pastel-purple);color:var(--purple)}
.quick-action:hover .quick-action-icon{transform:scale(1.08)}
.quick-action span{font-size:.72rem;color:var(--text-secondary);font-weight:600}

/* ============================================
   CREDIT CARD WIDGET
   ============================================ */
.card-widget{
  border-radius:var(--radius-lg);
  padding:20px;color:#fff;
  position:relative;overflow:hidden;
  cursor:pointer;
  transition:transform .3s ease;
}
.card-widget:hover{transform:scale(1.02)}
.card-widget::before{
  content:'';position:absolute;top:-30px;right:-30px;
  width:120px;height:120px;border-radius:50%;
  background:rgba(255,255,255,0.08);
}
.card-widget::after{
  content:'';position:absolute;bottom:-20px;left:30%;
  width:80px;height:80px;border-radius:50%;
  background:rgba(255,255,255,0.05);
}
.coral-gradient{background:linear-gradient(135deg,#F43F5E,#FF6B81,#FF8FA3)}
.blue-gradient{background:linear-gradient(135deg,#3B82F6,#818CF8)}
.dark-gradient{background:linear-gradient(135deg,#1E293B,#334155,#475569)}
.card-brand{
  font-size:.88rem;font-weight:800;letter-spacing:.08em;
  text-align:right;position:relative;z-index:1;
  opacity:.9;
}
.card-chip{
  width:36px;height:26px;background:linear-gradient(135deg,#D4AF37,#F5D061,#D4AF37);
  border-radius:5px;margin:10px 0;position:relative;z-index:1;
}
.card-chip::before{
  content:'';position:absolute;top:4px;left:4px;right:4px;bottom:4px;
  border:1px solid rgba(0,0,0,0.15);border-radius:3px;
}
.card-number{
  font-size:1.05rem;letter-spacing:2.5px;font-weight:600;
  margin-bottom:12px;position:relative;z-index:1;
}
.card-details{
  display:flex;justify-content:space-between;align-items:flex-end;
  position:relative;z-index:1;
}
.card-holder,.card-expiry{font-size:.55rem;opacity:.6;text-transform:uppercase;letter-spacing:.06em;margin-bottom:2px}
.card-holder-name,.card-expiry-date{font-size:.78rem;font-weight:700;letter-spacing:.03em}

/* ============================================
   TRANSACTIONS LIST
   ============================================ */
.screen-section{margin-bottom:20px}
.screen-section-header,.tx-section-title{
  display:flex;justify-content:space-between;align-items:center;
  margin-bottom:12px;
}
.screen-section-header h3,.tx-section-title h3{font-size:.95rem;font-weight:700}
.screen-section-header a,.tx-section-title a{font-size:.78rem;color:var(--primary);font-weight:600}
.screen-section-title{font-size:.95rem;font-weight:700;margin-bottom:12px}

.tx-list{
  display:flex;flex-direction:column;gap:2px;
}
.tx-item{
  display:flex;align-items:center;gap:12px;
  padding:12px 14px;
  background:var(--bg-surface);
  border-radius:var(--radius-lg);
  transition:all .2s;
  cursor:pointer;
}
.tx-item:hover{background:var(--bg-input)}
.tx-icon{
  width:42px;height:42px;border-radius:var(--radius-md);
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
}
.tx-icon .material-icons-outlined,
.tx-icon .material-symbols-rounded{font-size:20px}
.tx-icon.food{background:var(--pastel-orange);color:#F97316}
.tx-icon.shopping{background:var(--pastel-coral);color:var(--primary)}
.tx-icon.transport{background:var(--pastel-blue);color:var(--info)}
.tx-icon.entertainment{background:var(--pastel-purple);color:var(--purple)}
.tx-icon.income{background:var(--pastel-green);color:var(--success)}
.tx-icon.bills{background:var(--pastel-yellow);color:var(--warning)}
.tx-icon.transfer{background:var(--pastel-blue);color:var(--info)}
.tx-info{flex:1;min-width:0}
.tx-name{font-size:.88rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tx-category{font-size:.72rem;color:var(--text-dim);margin-top:1px}
.tx-right{text-align:right;flex-shrink:0}
.tx-amount{font-size:.88rem;font-weight:700}
.tx-amount.neg{color:var(--text-primary)}
.tx-amount.pos{color:var(--success)}
.tx-date{font-size:.68rem;color:var(--text-dim);margin-top:1px}

/* ============================================
   BOTTOM TAB BAR
   ============================================ */
.bottom-tabs{
  display:flex;justify-content:space-around;align-items:center;
  padding:8px 0 24px;
  background:var(--bg-surface);
  border-top:1px solid var(--border);
  position:sticky;bottom:0;
  border-radius:0 0 calc(var(--radius-phone) - 8px) calc(var(--radius-phone) - 8px);
}
.bottom-tab{
  display:flex;flex-direction:column;align-items:center;gap:3px;
  padding:6px 12px;text-decoration:none;
  transition:all .2s;cursor:pointer;
  position:relative;
}
.bottom-tab-icon{font-size:1.3rem;color:var(--text-dim);transition:color .2s}
.bottom-tab-icon .material-icons-outlined,
.bottom-tab-icon .material-symbols-rounded{font-size:24px}
.bottom-tab-label{font-size:.62rem;color:var(--text-dim);font-weight:600;transition:color .2s}
.bottom-tab.active .bottom-tab-icon{color:var(--primary)}
.bottom-tab.active .bottom-tab-icon .material-icons-outlined,
.bottom-tab.active .bottom-tab-icon .material-symbols-rounded{color:var(--primary);font-variation-settings:'FILL' 1}
.bottom-tab.active .bottom-tab-label{color:var(--primary)}
.bottom-tab.active::before{
  content:'';position:absolute;top:-1px;
  width:24px;height:3px;border-radius:0 0 3px 3px;
  background:var(--primary);
}

/* ============================================
   CARDS PAGE — Swiper Card Carousel
   ============================================ */
.cards-swiper{
  width:100%;padding:4px 0 16px;
  overflow:visible;
}
.cards-swiper .swiper-slide{
  display:flex;justify-content:center;
}
.cards-swiper .swiper-pagination{
  position:relative;margin-top:12px;
}
.cards-swiper .swiper-pagination-bullet{
  width:8px;height:8px;background:var(--text-dim);opacity:.3;
  transition:all .3s;
}
.cards-swiper .swiper-pagination-bullet-active{
  background:var(--primary);opacity:1;width:24px;border-radius:4px;
}

/* Card Actions Row */
.card-actions{
  display:flex;justify-content:space-around;
  padding:8px 0 16px;
}
.card-action-btn{
  display:flex;flex-direction:column;align-items:center;gap:6px;
  cursor:pointer;
}
.card-action-icon{
  width:48px;height:48px;border-radius:50%;
  border:1.5px solid var(--border-strong);
  display:flex;align-items:center;justify-content:center;
  background:var(--bg-surface);
  transition:all .25s;
  box-shadow:var(--shadow-sm);
}
.card-action-icon .material-icons-outlined,
.card-action-icon .material-symbols-rounded{font-size:22px;color:var(--text-secondary)}
.card-action-btn:hover .card-action-icon{
  background:var(--primary);border-color:var(--primary);
}
.card-action-btn:hover .card-action-icon .material-icons-outlined,
.card-action-btn:hover .card-action-icon .material-symbols-rounded{color:#fff}
.card-action-label{font-size:.72rem;color:var(--text-secondary);font-weight:600}

/* Spending Donut Chart */
.spending-section{margin-bottom:20px}
.spending-header{
  display:flex;justify-content:space-between;align-items:center;
  margin-bottom:16px;
}
.spending-header h3{font-size:.95rem;font-weight:700}
.spending-header .spending-total{font-size:.88rem;color:var(--text-dim);font-weight:600}
.donut-chart-container{
  display:flex;align-items:center;gap:20px;
  background:var(--bg-surface);border-radius:var(--radius-lg);
  padding:16px;
}
.donut-chart{
  width:100px;height:100px;border-radius:50%;
  position:relative;flex-shrink:0;
}
.donut-spending{
  background:conic-gradient(
    #F97316 0% 35%,
    var(--primary) 35% 60%,
    var(--info) 60% 75%,
    var(--purple) 75% 85%,
    var(--success) 85% 100%
  );
}
.donut-chart::before{
  content:'';position:absolute;inset:22px;
  background:var(--bg-surface);border-radius:50%;
}
.donut-center{
  position:absolute;inset:0;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  z-index:1;
}
.donut-center strong{font-size:.92rem;font-weight:800}
.donut-center small{font-size:.6rem;color:var(--text-dim)}
.donut-legend{display:flex;flex-direction:column;gap:6px}
.donut-legend-item{display:flex;align-items:center;gap:6px;font-size:.72rem;color:var(--text-secondary)}
.donut-legend-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}

/* ============================================
   PAYMENTS PAGE
   ============================================ */
/* Send To Contacts */
.pay-contacts{
  display:flex;gap:14px;overflow-x:auto;
  padding:4px 0 8px;
  scrollbar-width:none;
}
.pay-contacts::-webkit-scrollbar{display:none}
.pay-contact{
  display:flex;flex-direction:column;align-items:center;gap:6px;
  flex-shrink:0;cursor:pointer;
}
.pay-contact-avatar{
  width:52px;height:52px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-weight:700;font-size:.78rem;color:#fff;
  overflow:hidden;
  box-shadow:var(--shadow-sm);
  transition:transform .2s;
}
.pay-contact:hover .pay-contact-avatar{transform:scale(1.08)}
.pay-contact-avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%}
.pay-contact-avatar.add-contact{
  background:var(--bg-input);color:var(--text-dim);
  border:2px dashed var(--border-strong);
  font-size:1.2rem;
}
.pay-contact-name{font-size:.68rem;color:var(--text-secondary);font-weight:600;text-align:center}

/* QR Pay Button */
.qr-pay-btn{
  display:flex;align-items:center;justify-content:center;gap:10px;
  width:100%;padding:14px;
  background:linear-gradient(135deg,var(--primary),#FF6B81);
  color:#fff;font-weight:700;font-size:.92rem;
  border-radius:var(--radius-lg);
  border:none;cursor:pointer;
  margin-bottom:20px;
  box-shadow:0 4px 14px rgba(244,63,94,0.25);
  transition:all .25s;
}
.qr-pay-btn:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(244,63,94,0.3)}
.qr-pay-btn .material-icons-outlined,
.qr-pay-btn .material-symbols-rounded{font-size:24px}

/* Bill Cards */
.bill-card{
  display:flex;align-items:center;gap:12px;
  padding:14px;background:var(--bg-surface);
  border-radius:var(--radius-lg);
  margin-bottom:8px;
  transition:all .2s;
}
.bill-card:hover{background:var(--bg-input)}
.bill-icon{
  width:42px;height:42px;border-radius:var(--radius-md);
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
}
.bill-icon .material-icons-outlined,
.bill-icon .material-symbols-rounded{font-size:20px}
.bill-icon.electricity{background:var(--pastel-yellow);color:var(--warning)}
.bill-icon.internet{background:var(--pastel-blue);color:var(--info)}
.bill-icon.phone-bill{background:var(--pastel-purple);color:var(--purple)}
.bill-info{flex:1;min-width:0}
.bill-name{font-size:.88rem;font-weight:600}
.bill-due{font-size:.72rem;color:var(--text-dim);margin-top:1px}
.bill-amount{font-size:.92rem;font-weight:700;margin-right:8px}
.bill-pay-btn{
  padding:6px 16px;background:var(--primary);color:#fff;
  border-radius:var(--radius-sm);font-weight:700;font-size:.78rem;
  border:none;cursor:pointer;transition:all .2s;
  flex-shrink:0;
}
.bill-pay-btn:hover{background:var(--primary-dark)}

/* Scheduled Payments */
.schedule-item{
  display:flex;align-items:center;gap:12px;
  padding:12px 14px;background:var(--bg-surface);
  border-radius:var(--radius-lg);margin-bottom:6px;
}
.schedule-dot{
  width:10px;height:10px;border-radius:50%;flex-shrink:0;
}
.schedule-dot.coral{background:var(--primary)}
.schedule-dot.blue{background:var(--info)}
.schedule-dot.green{background:var(--success)}
.schedule-info{flex:1}
.schedule-name{font-size:.88rem;font-weight:600}
.schedule-date{font-size:.72rem;color:var(--text-dim);margin-top:1px}
.schedule-amount{font-size:.88rem;font-weight:700;flex-shrink:0}

/* ============================================
   BUDGET PAGE
   ============================================ */
/* Month Selector */
.month-selector{
  display:flex;align-items:center;justify-content:center;gap:16px;
  margin-bottom:20px;
}
.month-prev,.month-next{
  width:32px;height:32px;border-radius:50%;
  background:var(--bg-surface);border:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;font-size:.8rem;color:var(--text-secondary);
  transition:all .2s;box-shadow:var(--shadow-sm);
}
.month-prev:hover,.month-next:hover{background:var(--bg-input);color:var(--text-primary)}
.month-label{font-size:1rem;font-weight:700}

/* Budget Progress Ring */
.budget-ring-container{
  text-align:center;margin-bottom:24px;
}
.budget-ring{
  width:180px;height:180px;margin:0 auto;position:relative;
}
.budget-ring svg{width:100%;height:100%;transform:rotate(-90deg)}
.ring-bg{
  fill:none;stroke:var(--bg-input);stroke-width:12;
}
.ring-fill{
  fill:none;stroke:var(--primary);stroke-width:12;
  stroke-linecap:round;
  stroke-dasharray:502.65;
  stroke-dashoffset:502.65;
  transition:stroke-dashoffset 1.5s cubic-bezier(0.4,0,0.2,1);
}
.budget-ring-center{
  position:absolute;inset:0;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
}
.budget-ring-amount{font-size:1.8rem;font-weight:900;letter-spacing:-.03em}
.budget-ring-total{font-size:.78rem;color:var(--text-dim);font-weight:500}
.budget-ring-pct{
  font-size:.72rem;color:var(--primary);font-weight:700;
  margin-top:2px;
}
.budget-ring-label{
  font-size:.78rem;color:var(--text-dim);margin-top:8px;
}

/* Category Budgets */
.category-budget{margin-bottom:14px}
.category-budget-header{
  display:flex;justify-content:space-between;align-items:center;
  margin-bottom:6px;
}
.category-budget-name{
  display:flex;align-items:center;gap:8px;
  font-size:.82rem;font-weight:600;
}
.category-budget-name .material-icons-outlined,
.category-budget-name .material-symbols-rounded{font-size:18px}
.cat-dot{width:8px;height:8px;border-radius:50%}
.category-budget-values{font-size:.75rem;color:var(--text-dim);font-weight:500}
.category-budget-bar{
  height:8px;background:var(--bg-input);border-radius:4px;
  overflow:hidden;
}
.category-budget-fill{
  height:100%;border-radius:4px;width:0;
  transition:width 1s cubic-bezier(0.4,0,0.2,1);
}
.category-budget-fill.orange{background:var(--warning)}
.category-budget-fill.blue{background:var(--info)}
.category-budget-fill.coral{background:var(--primary)}
.category-budget-fill.purple{background:var(--purple)}
.category-budget-fill.green{background:var(--success)}

/* Insight Card */
.insight-card{
  display:flex;gap:12px;align-items:flex-start;
  background:var(--pastel-yellow);
  border-radius:var(--radius-lg);
  padding:14px 16px;margin-bottom:20px;
}
.insight-icon{font-size:1.2rem;flex-shrink:0;margin-top:2px}
.insight-icon .material-icons-outlined,
.insight-icon .material-symbols-rounded{font-size:22px;color:var(--warning)}
.insight-text{font-size:.82rem;color:var(--text-secondary);line-height:1.5}
.insight-text strong{color:var(--text-primary)}

/* Mini Bar Chart (Spending Trend) */
.spending-trend{
  background:var(--bg-surface);border-radius:var(--radius-lg);
  padding:16px;margin-bottom:20px;
}
.spending-trend h4{font-size:.88rem;font-weight:700;margin-bottom:14px}
.mini-bars{
  display:flex;align-items:flex-end;justify-content:space-between;
  height:100px;gap:8px;padding:0 4px;
}
.mini-bar-item{
  display:flex;flex-direction:column;align-items:center;gap:4px;
  flex:1;
}
.mini-bar{
  width:100%;border-radius:4px 4px 0 0;
  background:var(--bg-input);position:relative;
  min-height:8px;transition:height .8s cubic-bezier(0.4,0,0.2,1);
}
.mini-bar-inner{
  position:absolute;bottom:0;left:0;right:0;
  border-radius:4px 4px 0 0;
  transition:height .8s cubic-bezier(0.4,0,0.2,1);
}
.mini-bar-label{font-size:.6rem;color:var(--text-dim);font-weight:600}
.mini-bar-val{font-size:.55rem;color:var(--text-dim);font-weight:500}

/* ============================================
   PROFILE PAGE
   ============================================ */
.profile-avatar-section{
  text-align:center;padding:8px 0 20px;
}
.profile-avatar{
  width:80px;height:80px;border-radius:50%;
  margin:0 auto 12px;
  display:flex;align-items:center;justify-content:center;
  font-weight:800;font-size:1.6rem;color:#fff;
  background:linear-gradient(135deg,var(--primary),#FF6B81);
  box-shadow:0 4px 14px rgba(244,63,94,0.3);
  overflow:hidden;
}
.profile-avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%}
.profile-name{font-size:1.2rem;font-weight:800;margin-bottom:2px}
.profile-account{font-size:.78rem;color:var(--text-dim)}
.profile-member{font-size:.72rem;color:var(--text-dim);margin-top:4px}

/* Settings List */
.settings-list{
  display:flex;flex-direction:column;gap:3px;
  margin-bottom:16px;
}
.settings-item{
  display:flex;align-items:center;gap:12px;
  padding:13px 14px;background:var(--bg-surface);
  border-radius:var(--radius-md);
  cursor:pointer;transition:background .2s;
}
.settings-item:hover{background:var(--bg-input)}
.settings-icon{
  width:38px;height:38px;border-radius:var(--radius-sm);
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
}
.settings-icon .material-icons-outlined,
.settings-icon .material-symbols-rounded{font-size:20px}
.settings-icon.coral{background:var(--pastel-coral);color:var(--primary)}
.settings-icon.blue{background:var(--pastel-blue);color:var(--info)}
.settings-icon.purple{background:var(--pastel-purple);color:var(--purple)}
.settings-icon.green{background:var(--pastel-green);color:var(--success)}
.settings-icon.orange{background:var(--pastel-orange);color:#F97316}
.settings-icon.gray{background:var(--bg-input);color:var(--text-secondary)}
.settings-label{flex:1;font-size:.88rem;font-weight:600}
.settings-chevron{
  color:var(--text-dim);font-size:.8rem;
}
.settings-chevron .material-icons-outlined,
.settings-chevron .material-symbols-rounded{font-size:18px;color:var(--text-dim)}

/* Theme Toggle */
.theme-toggle-row{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px;background:var(--bg-surface);
  border-radius:var(--radius-md);margin-bottom:16px;
}
.theme-toggle-label{
  display:flex;align-items:center;gap:8px;
  font-size:.88rem;font-weight:600;
}
.theme-toggle-label .material-icons-outlined,
.theme-toggle-label .material-symbols-rounded{font-size:20px;color:var(--warning)}
.theme-toggle{
  width:48px;height:26px;border-radius:13px;
  background:var(--bg-input);cursor:pointer;
  position:relative;transition:background .3s;
  border:1px solid var(--border);
}
.theme-toggle::before{
  content:'';position:absolute;top:2px;left:2px;
  width:20px;height:20px;border-radius:50%;
  background:#fff;box-shadow:var(--shadow-sm);
  transition:transform .3s;
}
.theme-toggle.on{background:var(--primary);border-color:var(--primary)}
.theme-toggle.on::before{transform:translateX(22px)}

/* App Version */
.app-version{
  text-align:center;font-size:.72rem;color:var(--text-dim);
  margin-bottom:14px;
}

/* Logout Button */
.logout-btn{
  display:flex;align-items:center;justify-content:center;gap:8px;
  width:100%;padding:14px;
  background:transparent;
  color:var(--primary);font-weight:700;font-size:.92rem;
  border:2px solid var(--primary);
  border-radius:var(--radius-lg);
  cursor:pointer;transition:all .2s;
}
.logout-btn:hover{background:var(--primary);color:#fff}
.logout-btn .material-icons-outlined,
.logout-btn .material-symbols-rounded{font-size:20px}

/* ============================================
   SCROLL ANIMATIONS
   ============================================ */
.anim{
  opacity:0;transform:translateY(24px);
  transition:opacity .7s cubic-bezier(0.4,0,0.2,1),
             transform .7s cubic-bezier(0.4,0,0.2,1);
}
.anim.visible{opacity:1;transform:translateY(0)}

/* Staggered delays */
.features-grid .feature-card:nth-child(1).anim{transition-delay:.05s}
.features-grid .feature-card:nth-child(2).anim{transition-delay:.15s}
.features-grid .feature-card:nth-child(3).anim{transition-delay:.25s}
.features-grid .feature-card:nth-child(4).anim{transition-delay:.35s}

.testimonials-grid .testimonial-card:nth-child(1).anim{transition-delay:.05s}
.testimonials-grid .testimonial-card:nth-child(2).anim{transition-delay:.15s}
.testimonials-grid .testimonial-card:nth-child(3).anim{transition-delay:.25s}

/* ============================================
   RESPONSIVE — PHONE FRAME
   ============================================ */
@media(max-width:430px){
  .phone-frame{width:100%;border-radius:0;box-shadow:none}
  .dynamic-island{display:none}
  .phone-screen-content{margin:0;border-radius:0;min-height:auto}
  .bottom-tabs{border-radius:0}
  .phone-page-bg{padding:0}
  .phone-page-title,.phone-page-sub{display:none}
  .status-bar{display:none}
}

/* ============================================
   UTILITY CLASSES
   ============================================ */
.text-center{text-align:center}
.mt-8{margin-top:8px}
.mt-16{margin-top:16px}
.mt-20{margin-top:20px}
.mt-24{margin-top:24px}
.mb-8{margin-bottom:8px}
.mb-16{margin-bottom:16px}
.mb-20{margin-bottom:20px}
.mb-24{margin-bottom:24px}
.gap-8{gap:8px}
.gap-16{gap:16px}

/* ============================================
   LANDING PAGE — PREVIEWS ROW (fallback)
   ============================================ */
.previews-row{
  display:flex;justify-content:center;gap:24px;
  flex-wrap:wrap;padding:20px 0;
}
.previews-row .preview-phone:nth-child(2){
  transform:scale(1.05);z-index:2;
}

/* ============================================
   MISC ANIMATIONS
   ============================================ */
@keyframes fadeInUp{
  from{opacity:0;transform:translateY(20px)}
  to{opacity:1;transform:translateY(0)}
}
@keyframes pulse{
  0%,100%{transform:scale(1)}
  50%{transform:scale(1.05)}
}
@keyframes shimmer{
  0%{background-position:-200% 0}
  100%{background-position:200% 0}
}

/* Card hover shimmer effect */
.card-widget:hover::before{
  animation:pulse 2s infinite;
}

/* ============================================
   ENHANCED PHONE FRAME DETAILS
   ============================================ */

/* Side buttons on phone frame */
.phone-frame::before{
  content:'';
  position:absolute;
  right:-3px;top:140px;
  width:4px;height:40px;
  background:#2D2D44;
  border-radius:0 3px 3px 0;
  z-index:5;
}
.phone-frame::after{
  content:'';
  position:absolute;
  right:-3px;top:200px;
  width:4px;height:40px;
  background:#2D2D44;
  border-radius:0 3px 3px 0;
  z-index:5;
}

/* Volume buttons (left side) */
.dynamic-island::after{
  content:'';
  position:absolute;
  left:-135px;top:90px;
  width:4px;height:28px;
  background:#2D2D44;
  border-radius:3px 0 0 3px;
  box-shadow:0 40px 0 #2D2D44;
  z-index:5;
}

/* Inner screen glow effect */
.phone-screen-content::before{
  content:'';
  position:absolute;top:0;left:0;right:0;
  height:60px;
  background:linear-gradient(180deg,rgba(255,255,255,0.5),transparent);
  pointer-events:none;
  z-index:0;
  border-radius:inherit;
}

/* Phone frame bottom home indicator */
.bottom-tabs::after{
  content:'';
  display:block;
  width:134px;height:5px;
  background:#1A1A2E;
  border-radius:3px;
  margin:4px auto 0;
  opacity:.2;
}

/* ============================================
   ENHANCED BALANCE CARD DETAILS
   ============================================ */
.balance-card{
  background-size:200% 200%;
  animation:gradientShift 8s ease infinite;
}
@keyframes gradientShift{
  0%{background-position:0% 50%}
  50%{background-position:100% 50%}
  100%{background-position:0% 50%}
}

/* ============================================
   ENHANCED CREDIT CARD — CONTACTLESS ICON
   ============================================ */
.card-widget .card-contactless{
  position:absolute;top:18px;right:52px;
  opacity:.5;z-index:1;
}
.card-widget .card-contactless svg{width:20px;height:20px}

/* Card network logos */
.card-brand-logo{
  position:absolute;bottom:18px;right:18px;
  z-index:1;opacity:.9;
}
.card-brand-logo svg{width:40px;height:auto}

/* ============================================
   ENHANCED TRANSACTION ITEMS
   ============================================ */
.tx-item{
  animation:fadeInUp .4s ease both;
}
.tx-item:nth-child(1){animation-delay:.05s}
.tx-item:nth-child(2){animation-delay:.1s}
.tx-item:nth-child(3){animation-delay:.15s}
.tx-item:nth-child(4){animation-delay:.2s}
.tx-item:nth-child(5){animation-delay:.25s}
.tx-item:nth-child(6){animation-delay:.3s}

.tx-item::after{
  content:'';
  position:absolute;inset:0;
  border-radius:var(--radius-lg);
  opacity:0;
  background:linear-gradient(90deg,transparent,rgba(244,63,94,0.03),transparent);
  transition:opacity .3s;
}
.tx-item:hover::after{opacity:1}
.tx-item{position:relative;overflow:hidden}

/* ============================================
   ENHANCED QUICK ACTIONS
   ============================================ */
.quick-action-icon::before{
  content:'';
  position:absolute;inset:0;border-radius:50%;
  background:inherit;
  filter:blur(8px);opacity:.4;
  z-index:-1;
}
.quick-action-icon{position:relative;z-index:1}

/* ============================================
   ENHANCED BILL CARDS
   ============================================ */
.bill-card{
  animation:fadeInUp .4s ease both;
  position:relative;overflow:hidden;
}
.bill-card:nth-child(1){animation-delay:.05s}
.bill-card:nth-child(2){animation-delay:.1s}
.bill-card:nth-child(3){animation-delay:.15s}

.bill-card::before{
  content:'';
  position:absolute;left:0;top:0;bottom:0;
  width:3px;border-radius:3px;
  background:var(--primary);opacity:0;
  transition:opacity .3s;
}
.bill-card:hover::before{opacity:1}

.bill-pay-btn{
  position:relative;overflow:hidden;
}
.bill-pay-btn::after{
  content:'';
  position:absolute;inset:0;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,0.2),transparent);
  transform:translateX(-100%);
  transition:transform .4s;
}
.bill-pay-btn:hover::after{transform:translateX(100%)}

/* ============================================
   ENHANCED SCHEDULE ITEMS
   ============================================ */
.schedule-item{
  animation:fadeInUp .4s ease both;
  transition:all .2s;
}
.schedule-item:nth-child(1){animation-delay:.05s}
.schedule-item:nth-child(2){animation-delay:.1s}
.schedule-item:nth-child(3){animation-delay:.15s}
.schedule-item:hover{transform:translateX(4px)}

/* ============================================
   ENHANCED SETTINGS LIST ITEMS
   ============================================ */
.settings-item{
  animation:fadeInUp .4s ease both;
  transition:all .2s;
}
.settings-item:nth-child(1){animation-delay:.03s}
.settings-item:nth-child(2){animation-delay:.06s}
.settings-item:nth-child(3){animation-delay:.09s}
.settings-item:nth-child(4){animation-delay:.12s}
.settings-item:nth-child(5){animation-delay:.15s}
.settings-item:nth-child(6){animation-delay:.18s}
.settings-item:hover{
  transform:translateX(4px);
}
.settings-item:active{
  transform:scale(0.98);
}

/* ============================================
   CATEGORY BUDGET — ENHANCED
   ============================================ */
.category-budget{
  animation:fadeInUp .4s ease both;
}
.category-budget:nth-child(1){animation-delay:.05s}
.category-budget:nth-child(2){animation-delay:.1s}
.category-budget:nth-child(3){animation-delay:.15s}
.category-budget:nth-child(4){animation-delay:.2s}
.category-budget:nth-child(5){animation-delay:.25s}

.category-budget-bar{
  position:relative;overflow:hidden;
}
.category-budget-fill::after{
  content:'';
  position:absolute;inset:0;
  background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,0.3) 50%,transparent 100%);
  background-size:200% 100%;
  animation:shimmer 2s infinite;
}

/* ============================================
   ENHANCED DONUT CHART
   ============================================ */
.donut-chart{
  transition:transform .4s ease;
}
.donut-chart:hover{
  transform:scale(1.05);
}
.donut-chart::after{
  content:'';
  position:absolute;
  inset:6px;
  border-radius:50%;
  background:transparent;
  box-shadow:inset 0 2px 8px rgba(0,0,0,0.06);
  pointer-events:none;
}

/* ============================================
   ENHANCED INSIGHT CARD
   ============================================ */
.insight-card{
  animation:fadeInUp .5s ease both;
  animation-delay:.3s;
  transition:all .3s;
  position:relative;overflow:hidden;
}
.insight-card::before{
  content:'';
  position:absolute;top:-20px;right:-20px;
  width:60px;height:60px;border-radius:50%;
  background:rgba(245,158,11,0.1);
}
.insight-card:hover{
  transform:translateY(-2px);
  box-shadow:var(--shadow-md);
}

/* ============================================
   SPENDING TREND — ENHANCED BARS
   ============================================ */
.mini-bar{
  position:relative;overflow:hidden;
  background:var(--bg-input);
  border-radius:4px;
}
.mini-bar-inner{
  border-radius:4px;
}
.mini-bar-item{
  animation:fadeInUp .4s ease both;
}
.mini-bar-item:nth-child(1){animation-delay:.05s}
.mini-bar-item:nth-child(2){animation-delay:.1s}
.mini-bar-item:nth-child(3){animation-delay:.15s}
.mini-bar-item:nth-child(4){animation-delay:.2s}
.mini-bar-item:nth-child(5){animation-delay:.25s}
.mini-bar-item:nth-child(6){animation-delay:.3s}

.mini-bar-item:hover .mini-bar-inner{
  opacity:1 !important;
  filter:brightness(1.1);
}

/* ============================================
   ENHANCED PROFILE AVATAR
   ============================================ */
.profile-avatar{
  transition:transform .3s ease;
  position:relative;
}
.profile-avatar:hover{
  transform:scale(1.05);
}
.profile-avatar::after{
  content:'';
  position:absolute;inset:-4px;
  border-radius:50%;
  border:3px solid var(--pastel-coral);
  opacity:0;
  transition:opacity .3s;
}
.profile-avatar:hover::after{opacity:1}

/* ============================================
   THEME TOGGLE — ENHANCED
   ============================================ */
.theme-toggle{
  position:relative;
}
.theme-toggle::after{
  content:'';
  position:absolute;top:4px;left:4px;
  width:18px;height:18px;
  border-radius:50%;
  background:radial-gradient(circle at 60% 40%,#FFD700,#FFA500);
  opacity:0;transition:opacity .3s;
  pointer-events:none;
}
.theme-toggle.on::after{
  left:auto;right:4px;
  background:radial-gradient(circle at 60% 40%,#94A3B8,#64748B);
}

/* ============================================
   LOGOUT BUTTON — ENHANCED
   ============================================ */
.logout-btn{
  position:relative;overflow:hidden;
}
.logout-btn::before{
  content:'';
  position:absolute;inset:0;
  background:linear-gradient(90deg,transparent,rgba(244,63,94,0.05),transparent);
  transform:translateX(-100%);
  transition:transform .5s;
}
.logout-btn:hover::before{transform:translateX(100%)}

/* ============================================
   QR PAY BUTTON — ENHANCED
   ============================================ */
.qr-pay-btn{
  position:relative;overflow:hidden;
}
.qr-pay-btn::before{
  content:'';
  position:absolute;inset:0;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,0.15),transparent);
  transform:translateX(-100%);
}
.qr-pay-btn:hover::before{
  animation:slideShine .8s ease;
}
@keyframes slideShine{
  0%{transform:translateX(-100%)}
  100%{transform:translateX(100%)}
}

/* ============================================
   PAY CONTACTS — ENHANCED
   ============================================ */
.pay-contact{
  animation:fadeInUp .4s ease both;
}
.pay-contact:nth-child(1){animation-delay:0s}
.pay-contact:nth-child(2){animation-delay:.05s}
.pay-contact:nth-child(3){animation-delay:.1s}
.pay-contact:nth-child(4){animation-delay:.15s}
.pay-contact:nth-child(5){animation-delay:.2s}
.pay-contact:nth-child(6){animation-delay:.25s}

.pay-contact-avatar{
  position:relative;
}
.pay-contact-avatar::after{
  content:'';
  position:absolute;inset:-3px;
  border-radius:50%;
  border:2px solid transparent;
  transition:border-color .3s;
}
.pay-contact:hover .pay-contact-avatar::after{
  border-color:var(--primary);
}

/* ============================================
   ENHANCED HERO PHONE GLOW
   ============================================ */
.hero-phone-wrap::before{
  content:'';
  position:absolute;
  width:300px;height:300px;
  border-radius:50%;
  background:radial-gradient(circle,rgba(244,63,94,0.12),transparent 70%);
  z-index:-1;
  top:50%;left:50%;
  transform:translate(-50%,-50%);
  animation:pulse 4s ease-in-out infinite;
}
.hero-phone-wrap{position:relative}

/* ============================================
   HERO BADGE ANIMATION
   ============================================ */
.hero-badge{
  animation:fadeInUp .6s ease both;
  animation-delay:.1s;
}
.hero-headline{
  animation:fadeInUp .6s ease both;
  animation-delay:.2s;
}
.hero-sub{
  animation:fadeInUp .6s ease both;
  animation-delay:.3s;
}
.hero-store-buttons{
  animation:fadeInUp .6s ease both;
  animation-delay:.4s;
}
.hero-proof{
  animation:fadeInUp .6s ease both;
  animation-delay:.5s;
}
.hero-phone{
  animation:fadeInUp .8s ease both;
  animation-delay:.3s;
}

/* ============================================
   STORE BUTTON — ENHANCED
   ============================================ */
.store-btn{
  position:relative;overflow:hidden;
}
.store-btn::before{
  content:'';
  position:absolute;inset:0;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,0.08),transparent);
  transform:translateX(-100%);
  transition:transform .5s;
}
.store-btn:hover::before{transform:translateX(100%)}

/* ============================================
   FEATURE CARD — ENHANCED HOVER
   ============================================ */
.feature-card{
  position:relative;overflow:hidden;
}
.feature-card::before{
  content:'';
  position:absolute;top:-50px;right:-50px;
  width:120px;height:120px;
  border-radius:50%;
  opacity:0;transition:opacity .4s;
}
.feature-card:nth-child(1)::before{background:rgba(59,130,246,0.06)}
.feature-card:nth-child(2)::before{background:rgba(34,197,94,0.06)}
.feature-card:nth-child(3)::before{background:rgba(139,92,246,0.06)}
.feature-card:nth-child(4)::before{background:rgba(244,63,94,0.06)}
.feature-card:hover::before{opacity:1}

/* ============================================
   TESTIMONIAL CARD — ENHANCED
   ============================================ */
.testimonial-card{
  position:relative;overflow:hidden;
}
.testimonial-card::before{
  content:'\201C';
  position:absolute;top:12px;right:20px;
  font-size:4rem;font-weight:900;
  color:var(--pastel-coral);
  line-height:1;font-family:Georgia,serif;
}

/* ============================================
   STAT ITEM — ENHANCED COUNTERS
   ============================================ */
.stat-item{
  position:relative;
}
.stat-item::after{
  content:'';
  position:absolute;
  right:0;top:25%;bottom:25%;
  width:1px;
  background:var(--border);
}
.stat-item:last-child::after{display:none}
.stat-value{
  transition:color .3s;
}
.stat-item:hover .stat-value{
  color:var(--primary-dark);
}

/* ============================================
   CTA SECTION — ENHANCED
   ============================================ */
.cta-section{
  position:relative;
}
.cta-section::after{
  content:'';
  position:absolute;bottom:-100px;left:-100px;
  width:350px;height:350px;border-radius:50%;
  background:radial-gradient(circle,rgba(139,92,246,0.06),transparent 70%);
  pointer-events:none;
}
.cta-phone{
  animation:float 6s ease-in-out infinite;
}
@keyframes float{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-12px)}
}

/* ============================================
   FOOTER — ENHANCED
   ============================================ */
.footer-social a{
  position:relative;overflow:hidden;
}
.footer-social a::before{
  content:'';
  position:absolute;inset:0;
  background:var(--primary);
  border-radius:50%;
  transform:scale(0);transition:transform .3s;
  z-index:0;
}
.footer-social a:hover::before{transform:scale(1)}
.footer-social a .material-icons-outlined{position:relative;z-index:1}

.footer ul a{
  position:relative;
  display:inline-block;
}
.footer ul a::after{
  content:'';
  position:absolute;bottom:-2px;left:0;
  width:0;height:1px;
  background:#fff;
  transition:width .3s;
}
.footer ul a:hover::after{width:100%}

/* ============================================
   SCROLLBAR STYLING (webkit browsers)
   ============================================ */
.phone-screen-content::-webkit-scrollbar{width:0;height:0}

body::-webkit-scrollbar{
  width:8px;
}
body::-webkit-scrollbar-track{
  background:var(--bg-page);
}
body::-webkit-scrollbar-thumb{
  background:var(--text-dim);
  border-radius:4px;
}
body::-webkit-scrollbar-thumb:hover{
  background:var(--text-secondary);
}

/* ============================================
   LANDING PAGE — NAV LINK INDICATOR
   ============================================ */
.topnav-links a{
  position:relative;
}
.topnav-links a::after{
  content:'';
  position:absolute;bottom:0;left:50%;
  width:0;height:2px;
  background:var(--primary);
  transition:width .3s,left .3s;
  border-radius:1px;
}
.topnav-links a:hover::after,
.topnav-links a.active::after{
  width:60%;left:20%;
}

/* ============================================
   CARD CAROUSEL ENHANCED SHADOWS
   ============================================ */
.cards-swiper .swiper-slide-active .card-widget{
  box-shadow:0 12px 40px rgba(0,0,0,0.15);
}
.cards-swiper .swiper-slide:not(.swiper-slide-active) .card-widget{
  opacity:.7;
  transform:scale(.95);
}

/* ============================================
   LOADING/SKELETON PLACEHOLDER STYLE
   ============================================ */
.skeleton{
  background:linear-gradient(90deg,var(--bg-input) 25%,var(--bg-hover) 50%,var(--bg-input) 75%);
  background-size:200% 100%;
  animation:shimmer 1.5s infinite;
  border-radius:var(--radius-sm);
}

/* ============================================
   SELECTION COLOR
   ============================================ */
::selection{
  background:rgba(244,63,94,0.15);
  color:var(--text-primary);
}
::-moz-selection{
  background:rgba(244,63,94,0.15);
  color:var(--text-primary);
}

/* ============================================
   FOCUS STYLES (Accessibility)
   ============================================ */
a:focus-visible,
button:focus-visible,
.bottom-tab:focus-visible,
.settings-item:focus-visible{
  outline:2px solid var(--primary);
  outline-offset:2px;
  border-radius:var(--radius-sm);
}

/* ============================================
   REDUCED MOTION PREFERENCE
   ============================================ */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:0.01ms !important;
    animation-iteration-count:1 !important;
    transition-duration:0.01ms !important;
  }
  .hero-phone{transform:rotate(-6deg)}
  .hero-phone:hover{transform:rotate(-6deg)}
  .cta-phone{animation:none}
}

/* ============================================
   DARK MODE HINTS (for toggle preview)
   ============================================ */
.dark-mode .phone-screen-content.gray-bg{
  background:#1E1E2E;
}
.dark-mode .tx-item,
.dark-mode .bill-card,
.dark-mode .schedule-item,
.dark-mode .settings-item{
  background:#2A2A3C;
}

/* ============================================
   BADGE / CHIP COMPONENTS
   ============================================ */
.chip{
  display:inline-flex;align-items:center;gap:4px;
  padding:4px 10px;border-radius:20px;
  font-size:.72rem;font-weight:600;
}
.chip-coral{background:var(--pastel-coral);color:var(--primary)}
.chip-blue{background:var(--pastel-blue);color:var(--info)}
.chip-green{background:var(--pastel-green);color:var(--success)}
.chip-purple{background:var(--pastel-purple);color:var(--purple)}

/* ============================================
   TOOLTIP STYLE
   ============================================ */
[data-tooltip]{
  position:relative;
}
[data-tooltip]::before{
  content:attr(data-tooltip);
  position:absolute;bottom:calc(100% + 8px);left:50%;
  transform:translateX(-50%);
  background:#0F172A;color:#fff;
  padding:6px 12px;border-radius:6px;
  font-size:.72rem;font-weight:500;
  white-space:nowrap;
  opacity:0;pointer-events:none;
  transition:opacity .2s;z-index:10;
}
[data-tooltip]:hover::before{opacity:1}

/* ============================================
   LANDING PAGE HERO IMAGE (Unsplash)
   ============================================ */
.hero-image-wrap{
  position:relative;
  border-radius:var(--radius-xl);
  overflow:hidden;
  box-shadow:var(--shadow-lg);
}
.hero-image-wrap img{
  width:100%;height:auto;
  display:block;
}

/* ============================================
   RESPONSIVE FINE-TUNING
   ============================================ */
@media(max-width:1024px){
  .hero-headline{font-size:2.8rem}
  .section-title{font-size:2.2rem}
}
@media(max-width:768px){
  .hero{padding:48px 0 40px}
  .section{padding:56px 0}
  .hero-headline{font-size:2.2rem}
  .section-title{font-size:1.8rem}
  .section-sub{font-size:.95rem}
  .features-grid{grid-template-columns:1fr;max-width:400px}
  .stats-strip{grid-template-columns:repeat(2,1fr)}
  .stat-item::after{display:none}
  .hero-phone-wrap{flex:none}
  .hero-phone{width:240px}
  .previews-row{gap:16px}
  .preview-phone{width:180px}
}
@media(max-width:480px){
  .hero-headline{font-size:1.8rem}
  .hero-sub{font-size:.92rem}
  .hero-store-buttons{flex-direction:column;align-items:stretch}
  .store-btn{justify-content:center}
  .cta-store-buttons{flex-direction:column;align-items:center}
  .stats-strip{padding:24px 0}
  .stat-value{font-size:1.4rem}
}

/* ============================================
   PRINT STYLES
   ============================================ */
@media print{
  .demo-banner,.topnav,.bottom-tabs,.hamburger{display:none}
  .phone-frame{box-shadow:none;border:1px solid #ccc}
  .hero-phone{transform:none}
  .cta-phone{animation:none}
  body{background:#fff}
}
