/* ============================================================
   HOSTELROOM — LANDING V2 · 3D DEPTH + FLOATING CARDS
   Premium light theme with deep shadows, perspective cards,
   gradient mesh and floating animated elements.
   ============================================================ */

/* ── 1. RESET & VARIABLES ─────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{font-size:16px;scroll-behavior:smooth;-webkit-text-size-adjust:100%;overflow-x:hidden;}
body{
  font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,'Helvetica Neue',Arial,sans-serif;
  background:#F4F6FF;color:#0F172A;
  line-height:1.6;-webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;height:auto;display:block;}
a{color:inherit;text-decoration:none;}
ul{list-style:none;}

:root{
  /* Brand */
  --violet:    #6D28D9;
  --violet-2:  #7C3AED;
  --blue:      #3B82F6;
  --cyan:      #06B6D4;
  --pink:      #EC4899;
  --amber:     #F59E0B;
  --green:     #10B981;

  /* Gradient text */
  --grad-text: linear-gradient(135deg,#6D28D9 0%,#3B82F6 50%,#06B6D4 100%);
  --grad-cta:  linear-gradient(135deg,#7C3AED 0%,#3B82F6 100%);
  --grad-hero: linear-gradient(135deg,#0F0C29 0%,#302B63 50%,#24243E 100%);

  /* Surfaces */
  --bg:        #F4F6FF;
  --surface:   #FFFFFF;
  --surface-2: #F8FAFF;
  --border:    rgba(0,0,0,.07);
  --border-md: rgba(0,0,0,.11);

  /* Text */
  --text:      #0F172A;
  --text-2:    #334155;
  --text-3:    #64748B;
  --text-4:    #94A3B8;

  /* Shadows — layered for depth */
  --sh-xs:  0 1px 2px rgba(0,0,0,.04);
  --sh-sm:  0 1px 3px rgba(0,0,0,.06),0 4px 8px rgba(109,40,217,.06);
  --sh-md:  0 2px 6px rgba(0,0,0,.06),0 8px 24px rgba(109,40,217,.08),0 16px 48px rgba(59,130,246,.06);
  --sh-lg:  0 4px 12px rgba(0,0,0,.06),0 16px 48px rgba(109,40,217,.12),0 32px 80px rgba(59,130,246,.08);
  --sh-xl:  0 8px 24px rgba(0,0,0,.07),0 24px 64px rgba(109,40,217,.18),0 48px 120px rgba(59,130,246,.12);
  --sh-float:0 20px 60px rgba(109,40,217,.22),0 40px 100px rgba(59,130,246,.16);

  /* Radii */
  --r:     10px;--r-lg:16px;--r-xl:20px;--r-2xl:28px;--r-full:9999px;

  /* Transitions */
  --t: 200ms cubic-bezier(.4,0,.2,1);
  --t-spring: 400ms cubic-bezier(.34,1.56,.64,1);

  /* ── Compatibility aliases (v1 → v2) ────────────────────── */
  --primary:       #6D28D9;
  --primary-dark:  #5B21B6;
  --primary-light: rgba(109,40,217,.08);
  --gray-50:  #F8FAFF;
  --gray-100: #F1F5F9;
  --gray-200: #E2E8F0;
  --gray-300: #CBD5E1;
  --gray-400: #94A3B8;
  --gray-500: #64748B;
  --gray-600: #475569;
  --gray-700: #334155;
  --gray-900: #0F172A;
}

/* ── 2. UTILITIES ─────────────────────────────────────────── */
.container{width:100%;max-width:1160px;margin:0 auto;padding:0 28px;}
.container-sm{width:100%;max-width:780px;margin:0 auto;padding:0 28px;}
.text-center{text-align:center;}
.hidden{display:none!important;}
.mt-2{margin-top:8px;}.mt-4{margin-top:16px;}.mt-6{margin-top:24px;}.mt-8{margin-top:32px;}.mt-12{margin-top:48px;}
.mb-2{margin-bottom:8px;}.mb-4{margin-bottom:16px;}.mb-6{margin-bottom:24px;}
.grad-text{
  background:var(--grad-text);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;
}

/* ── 3. ANIMATED BLOBS (background) ───────────────────────── */
.blob-canvas{
  position:absolute;inset:0;overflow:hidden;pointer-events:none;z-index:0;
}
.blob{
  position:absolute;border-radius:50%;filter:blur(80px);opacity:.45;
  animation:blobDrift 18s ease-in-out infinite;
}
.blob-1{width:600px;height:600px;background:radial-gradient(circle,#A78BFA,#7C3AED);top:-180px;right:-80px;animation-duration:20s;}
.blob-2{width:500px;height:500px;background:radial-gradient(circle,#93C5FD,#3B82F6);bottom:-100px;left:-120px;animation-delay:4s;animation-duration:24s;}
.blob-3{width:400px;height:400px;background:radial-gradient(circle,#6EE7B7,#06B6D4);top:30%;left:40%;animation-delay:8s;animation-duration:22s;}
@keyframes blobDrift{
  0%,100%{transform:translate(0,0) scale(1);}
  33%{transform:translate(30px,-20px) scale(1.05);}
  66%{transform:translate(-20px,15px) scale(.97);}
}

/* ── 4. BUTTONS ───────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:12px 26px;border-radius:var(--r-full);
  font-size:15px;font-weight:700;cursor:pointer;border:none;
  transition:transform var(--t),box-shadow var(--t),background var(--t),opacity var(--t);
  white-space:nowrap;text-decoration:none;min-height:48px;
  position:relative;overflow:hidden;
}
.btn::after{
  content:"";position:absolute;inset:0;border-radius:inherit;
  background:rgba(255,255,255,0);transition:background .15s;
}
.btn:hover::after{background:rgba(255,255,255,.08);}
.btn:active{transform:scale(.96)!important;}

.btn-primary{
  background:var(--grad-cta);color:#fff;
  box-shadow:0 4px 16px rgba(109,40,217,.35),0 2px 4px rgba(0,0,0,.15);
}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(109,40,217,.45),0 4px 8px rgba(0,0,0,.15);}

.btn-outline{
  background:#fff;color:var(--violet);
  border:2px solid rgba(109,40,217,.2);
  box-shadow:var(--sh-sm);
}
.btn-outline:hover{transform:translateY(-2px);box-shadow:var(--sh-md);border-color:rgba(109,40,217,.35);}

.btn-ghost{background:rgba(255,255,255,.6);color:var(--text-2);border:1.5px solid var(--border);backdrop-filter:blur(8px);}
.btn-ghost:hover{background:rgba(255,255,255,.9);color:var(--text);}

.btn-dark{background:#0F172A;color:#fff;box-shadow:0 4px 14px rgba(0,0,0,.3);}
.btn-dark:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.35);}

.btn-lg{padding:16px 34px;font-size:16px;min-height:56px;}
.btn-sm{padding:8px 18px;font-size:13px;min-height:38px;}
.btn-icon{width:44px;height:44px;padding:0;}

/* ── 5. NAVBAR ────────────────────────────────────────────── */
.navbar{
  position:sticky;top:0;z-index:200;
  background:rgba(244,246,255,.82);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid rgba(109,40,217,.08);
  transition:box-shadow .2s;
}
.navbar.scrolled{box-shadow:0 2px 20px rgba(109,40,217,.1);}
.navbar-inner{display:flex;align-items:center;gap:16px;height:68px;}
.navbar-logo{
  display:flex;align-items:center;gap:10px;
  font-size:20px;font-weight:900;color:var(--text);flex-shrink:0;
}
.navbar-logo-icon{
  width:38px;height:38px;border-radius:11px;
  background:var(--grad-cta);
  display:flex;align-items:center;justify-content:center;
  font-size:18px;
  box-shadow:0 4px 12px rgba(109,40,217,.35);
}
.navbar-links{display:flex;align-items:center;gap:2px;margin-left:20px;}
.navbar-links a{
  padding:7px 16px;border-radius:var(--r-full);
  font-size:14px;font-weight:600;color:var(--text-3);
  transition:background var(--t),color var(--t);
}
.navbar-links a:hover,.navbar-links a.active{background:rgba(109,40,217,.08);color:var(--violet);}
.navbar-spacer{flex:1;}
.navbar-actions{display:flex;align-items:center;gap:10px;}
.navbar-user-pill{
  display:none;align-items:center;gap:8px;
  padding:8px 16px 8px 10px;border-radius:var(--r-full);
  background:rgba(109,40,217,.1);color:var(--violet);
  font-size:13px;font-weight:700;text-decoration:none;
  border:1.5px solid rgba(109,40,217,.2);
  transition:all var(--t);
}
.navbar-user-pill.visible{display:inline-flex;}
.navbar-user-pill:hover{background:rgba(109,40,217,.16);}
.navbar-hamburger{
  display:none;background:none;border:none;cursor:pointer;
  padding:8px;flex-direction:column;gap:5px;
}
.navbar-hamburger span{display:block;width:22px;height:2px;background:var(--text);border-radius:2px;transition:all .25s;}
.mobile-menu{
  display:none;background:rgba(244,246,255,.97);
  backdrop-filter:blur(20px);border-bottom:1px solid var(--border);
  padding:14px 28px 22px;
}
.mobile-menu.open{display:block;}
.mobile-menu a{
  display:block;padding:12px 0;font-size:15px;font-weight:600;
  color:var(--text-2);border-bottom:1px solid var(--border);
}
.mobile-menu a:last-child{border-bottom:none;}

/* ── 6. HERO ──────────────────────────────────────────────── */
.hero{
  position:relative;overflow:hidden;
  padding:80px 0 0;
  background:linear-gradient(160deg,#EEF2FF 0%,#F4F6FF 40%,#EFF6FF 100%);
}
.hero::after{
  content:"";position:absolute;bottom:0;left:0;right:0;height:120px;
  background:linear-gradient(to bottom,transparent,#F4F6FF);
  z-index:2;pointer-events:none;
}
.hero-inner{
  position:relative;z-index:3;
  display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;
  padding-bottom:0;
}
.hero-left{}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  padding:6px 16px;border-radius:var(--r-full);
  background:#fff;border:1.5px solid rgba(109,40,217,.15);
  font-size:13px;font-weight:700;color:var(--violet);
  box-shadow:var(--sh-sm);margin-bottom:22px;
}
.hero-eyebrow-dot{
  width:8px;height:8px;border-radius:50%;
  background:var(--green);
  box-shadow:0 0 0 3px rgba(16,185,129,.2);
  animation:pulse 2s ease-in-out infinite;
}
@keyframes pulse{
  0%,100%{box-shadow:0 0 0 3px rgba(16,185,129,.2);}
  50%{box-shadow:0 0 0 6px rgba(16,185,129,.1);}
}
.hero h1{
  font-size:clamp(40px,5.5vw,66px);font-weight:900;
  line-height:1.05;letter-spacing:-2.5px;
  margin-bottom:22px;color:var(--text);
}
.hero h1 em{font-style:normal;}
.hero-sub{
  font-size:18px;color:var(--text-3);line-height:1.7;
  max-width:480px;margin-bottom:36px;
}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:44px;}
.hero-trust{
  display:flex;align-items:center;gap:16px;flex-wrap:wrap;
}
.hero-trust-avatars{display:flex;}
.hero-trust-avatars span{
  width:32px;height:32px;border-radius:50%;border:2.5px solid #fff;
  background:var(--grad-cta);color:#fff;font-size:11px;font-weight:800;
  display:flex;align-items:center;justify-content:center;
  margin-left:-8px;box-shadow:var(--sh-sm);
}
.hero-trust-avatars span:first-child{margin-left:0;}
.hero-trust-text{font-size:13px;color:var(--text-3);font-weight:600;}
.hero-trust-text strong{color:var(--text);font-weight:800;}

/* 3D floating hero visual */
.hero-right{
  display:flex;align-items:flex-end;justify-content:center;
  position:relative;
}
.hero-3d-wrapper{
  width:100%;max-width:540px;
  transform:perspective(1400px) rotateX(6deg) rotateY(-8deg) rotateZ(1deg);
  transition:transform .6s var(--t-spring);
  transform-style:preserve-3d;
  filter:drop-shadow(0 40px 80px rgba(109,40,217,.22)) drop-shadow(0 20px 40px rgba(59,130,246,.16));
}
.hero-3d-wrapper:hover{
  transform:perspective(1400px) rotateX(2deg) rotateY(-4deg) rotateZ(.5deg);
}
.hero-mockup{
  background:#fff;border-radius:18px;overflow:hidden;
  border:1px solid rgba(109,40,217,.1);
}
.hero-mockup-bar{
  height:38px;background:#0F172A;display:flex;align-items:center;
  gap:7px;padding:0 16px;
}
.hero-mockup-dot{width:11px;height:11px;border-radius:50%;}
.hero-mockup-address{
  flex:1;margin-left:10px;height:20px;border-radius:10px;
  background:rgba(255,255,255,.08);max-width:200px;
}
.hero-mockup-body{
  background:#F1F5F9;
  display:grid;grid-template-columns:200px 1fr;min-height:400px;
}
.hero-mockup-sidebar{
  background:#0F172A;padding:18px 10px;
  display:flex;flex-direction:column;gap:3px;
}
.hmsi{/* hero mockup sidebar item */
  padding:8px 12px;border-radius:8px;
  font-size:11px;color:rgba(255,255,255,.4);
  display:flex;align-items:center;gap:8px;
}
.hmsi.active{background:rgba(109,40,217,.3);color:#C4B5FD;}
.hmsi-brand{
  margin-bottom:14px;font-size:13px;font-weight:800;color:#fff;
  padding:0 4px;display:flex;align-items:center;gap:8px;
}
.hmsi-brand-icon{
  width:28px;height:28px;border-radius:7px;
  background:var(--grad-cta);
  display:flex;align-items:center;justify-content:center;font-size:14px;
}
.hero-mockup-content{padding:16px;display:flex;flex-direction:column;gap:12px;}
.hmc-stat-row{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;}
.hmc-stat{
  background:#fff;border-radius:10px;padding:12px;
  box-shadow:0 1px 4px rgba(0,0,0,.07),0 4px 12px rgba(109,40,217,.06);
}
.hmc-stat-val{font-size:17px;font-weight:900;margin-bottom:2px;}
.hmc-stat-lbl{font-size:9px;color:#94A3B8;text-transform:uppercase;letter-spacing:.5px;}
.hmc-card{
  background:#fff;border-radius:10px;padding:13px;
  box-shadow:0 1px 4px rgba(0,0,0,.07),0 4px 12px rgba(109,40,217,.06);
}
.hmc-card-head{font-size:10px;font-weight:800;color:#475569;text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px;}
.hmc-row{
  display:flex;align-items:center;justify-content:space-between;
  padding:7px 0;border-bottom:1px solid #F1F5F9;
}
.hmc-row:last-child{border-bottom:none;}
.hmc-name{font-size:11px;font-weight:700;color:#0F172A;}
.hmc-sub{font-size:9px;color:#94A3B8;margin-top:1px;}
.hmc-row-right{display:flex;align-items:center;gap:5px;}
.hmc-amt{font-size:11px;font-weight:800;color:#DC2626;}
.hmc-btn{
  font-size:9px;font-weight:800;padding:3px 9px;border-radius:10px;
  background:linear-gradient(135deg,#6D28D9,#3B82F6);color:#fff;border:none;
  cursor:default;
}

/* Floating chips around hero mockup */
.hero-chip{
  position:absolute;
  background:#fff;border-radius:var(--r-full);
  padding:7px 14px;
  display:flex;align-items:center;gap:7px;
  font-size:12px;font-weight:700;
  box-shadow:0 8px 28px rgba(0,0,0,.1),0 2px 6px rgba(0,0,0,.06);
  border:1px solid var(--border);
  white-space:nowrap;
  animation:floatChip 4s ease-in-out infinite;
}
.hero-chip-1{bottom:26%;left:-30px;animation-delay:0s;}
.hero-chip-2{top:22%;right:-24px;animation-delay:1.5s;}
.hero-chip-3{bottom:10%;right:8%;animation-delay:3s;}
@keyframes floatChip{
  0%,100%{transform:translateY(0);}
  50%{transform:translateY(-8px);}
}

/* ── 7. MARQUEE ───────────────────────────────────────────── */
.marquee-section{
  background:#fff;padding:20px 0;
  border-top:1px solid var(--border);border-bottom:1px solid var(--border);
  overflow:hidden;position:relative;z-index:4;
}
.marquee-track{
  display:flex;gap:0;width:max-content;
  animation:marquee 28s linear infinite;
}
.marquee-section:hover .marquee-track{animation-play-state:paused;}
@keyframes marquee{0%{transform:translateX(0);}100%{transform:translateX(-50%);}}
.marquee-item{
  display:flex;align-items:center;gap:10px;
  padding:0 36px;border-right:1px solid var(--border);
  font-size:13px;font-weight:700;color:var(--text-3);
  white-space:nowrap;
}
.marquee-item span:first-child{font-size:16px;}
.marquee-item strong{color:var(--text);}

/* ── 8. SECTION COMMONS ───────────────────────────────────── */
.section{padding:96px 0;}
.section-sm{padding:64px 0;}
.section-alt{background:#fff;}
.section-tag{
  display:inline-flex;align-items:center;gap:6px;
  padding:5px 14px;border-radius:var(--r-full);
  background:rgba(109,40,217,.08);color:var(--violet);
  font-size:12px;font-weight:800;letter-spacing:.6px;text-transform:uppercase;
  margin-bottom:14px;border:1px solid rgba(109,40,217,.12);
}
.section-title{
  font-size:clamp(28px,4vw,46px);font-weight:900;
  letter-spacing:-1.5px;line-height:1.1;margin-bottom:16px;
}
.section-sub{font-size:17px;color:var(--text-3);line-height:1.7;max-width:560px;}
.section-header{margin-bottom:60px;}

/* ── 9. 3D FEATURE CARDS ──────────────────────────────────── */
.features-bento{
  display:grid;
  grid-template-columns:repeat(12,1fr);
  grid-template-rows:auto;
  gap:20px;
}
.feat-card{
  background:#fff;border-radius:var(--r-xl);
  border:1px solid var(--border);
  padding:28px;overflow:hidden;position:relative;
  box-shadow:var(--sh-sm);
  transition:transform var(--t-spring),box-shadow var(--t-spring);
  transform-style:preserve-3d;
  cursor:default;
  will-change:transform;
}
.feat-card:hover{box-shadow:var(--sh-xl);}
/* Card layout variants */
.feat-card-xl{grid-column:span 5;}
.feat-card-lg{grid-column:span 4;}
.feat-card-md{grid-column:span 3;}
/* Accent color strip */
.feat-card::before{
  content:"";
  position:absolute;top:0;left:0;right:0;height:3px;
  background:var(--grad-cta);opacity:0;
  transition:opacity .2s;border-radius:var(--r-xl) var(--r-xl) 0 0;
}
.feat-card:hover::before{opacity:1;}

.feat-icon{
  width:52px;height:52px;border-radius:14px;
  display:flex;align-items:center;justify-content:center;
  font-size:24px;margin-bottom:18px;
  box-shadow:var(--sh-sm);
  flex-shrink:0;
}
.feat-icon-v{background:linear-gradient(135deg,#EDE9FE,#DDD6FE);}
.feat-icon-b{background:linear-gradient(135deg,#DBEAFE,#BFDBFE);}
.feat-icon-g{background:linear-gradient(135deg,#D1FAE5,#A7F3D0);}
.feat-icon-o{background:linear-gradient(135deg,#FEF3C7,#FDE68A);}
.feat-icon-r{background:linear-gradient(135deg,#FEE2E2,#FECACA);}
.feat-icon-c{background:linear-gradient(135deg,#CFFAFE,#A5F3FC);}

.feat-title{font-size:17px;font-weight:800;margin-bottom:8px;color:var(--text);}
.feat-desc{font-size:14px;color:var(--text-3);line-height:1.65;}

/* Visual inside large cards */
.feat-visual{
  margin-top:18px;border-radius:12px;overflow:hidden;
  background:var(--bg);border:1px solid var(--border);
  font-size:11px;
}
.feat-visual-row{
  display:flex;align-items:center;justify-content:space-between;
  padding:9px 12px;border-bottom:1px solid var(--border);
}
.feat-visual-row:last-child{border-bottom:none;}
.feat-visual-name{font-size:11px;font-weight:700;}
.feat-visual-sub{font-size:9px;color:var(--text-4);}
.feat-visual-badge{
  font-size:9px;font-weight:800;padding:2px 8px;border-radius:20px;
  background:#FEF3C7;color:#D97706;
}
.feat-visual-badge.paid{background:#D1FAE5;color:#059669;}
.feat-mini-btn{
  font-size:9px;font-weight:800;padding:3px 9px;border-radius:10px;
  background:var(--grad-cta);color:#fff;border:none;
}

/* WhatsApp card preview */
.feat-wa-msg{
  background:#DCF8C6;border-radius:10px 10px 10px 2px;
  padding:10px 12px;margin:12px 8px;font-size:11px;color:#1a1a1a;
  line-height:1.5;max-width:220px;
  box-shadow:0 1px 3px rgba(0,0,0,.1);
}
.feat-wa-time{font-size:9px;color:#92A58C;text-align:right;margin-top:4px;}
.feat-wa-bg{background:#E5DDD5;border-radius:10px;padding:4px;margin-top:12px;}

/* P&L mini chart */
.feat-chart{display:flex;align-items:flex-end;gap:6px;height:60px;margin-top:14px;padding:0 4px;}
.feat-bar{
  flex:1;border-radius:4px 4px 0 0;
  transition:height .4s ease;
}
.feat-bar.income{background:linear-gradient(180deg,#6D28D9,#A78BFA);}
.feat-bar.expense{background:linear-gradient(180deg,#EF4444,#FCA5A5);}

/* ── 10. SPLIT FEATURE SECTION ────────────────────────────── */
.split-section{
  display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;
}
.split-section.reverse .split-visual{order:-1;}
.split-list{display:flex;flex-direction:column;gap:16px;margin-top:24px;}
.split-item{
  display:flex;gap:14px;
  padding:16px;border-radius:var(--r-lg);
  border:1px solid var(--border);background:#fff;
  box-shadow:var(--sh-xs);
  transition:box-shadow var(--t),transform var(--t);
}
.split-item:hover{box-shadow:var(--sh-md);transform:translateX(4px);}
.split-item-icon{
  width:40px;height:40px;border-radius:10px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;font-size:18px;
  background:rgba(109,40,217,.08);
}
.split-item-title{font-size:14px;font-weight:800;margin-bottom:3px;}
.split-item-desc{font-size:13px;color:var(--text-3);line-height:1.5;}
.split-visual{
  border-radius:var(--r-2xl);overflow:hidden;
  box-shadow:var(--sh-xl);border:1px solid var(--border);
  background:#fff;transform:perspective(1000px) rotateY(4deg);
  transition:transform var(--t-spring);
}
.split-visual:hover{transform:perspective(1000px) rotateY(0deg);}

/* Step card inside split visual */
.step-card{
  padding:22px;background:#fff;
}
.step-num-badge{
  width:32px;height:32px;border-radius:50%;
  background:var(--grad-cta);color:#fff;font-size:13px;font-weight:900;
  display:flex;align-items:center;justify-content:center;
  margin-bottom:12px;box-shadow:0 4px 12px rgba(109,40,217,.35);
}
.step-title-sm{font-size:14px;font-weight:800;margin-bottom:6px;}
.step-desc-sm{font-size:12px;color:var(--text-3);line-height:1.6;}

/* ── 11. HOW IT WORKS ─────────────────────────────────────── */
.steps-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;position:relative;}
.steps-grid::before{
  content:"";position:absolute;top:48px;left:calc(16.6% + 24px);
  right:calc(16.6% + 24px);height:2px;
  background:linear-gradient(90deg,var(--violet),var(--blue),var(--cyan));
  border-radius:2px;z-index:0;
  opacity:.3;
}
.step-box{
  text-align:center;padding:32px 24px;
  background:#fff;border-radius:var(--r-xl);border:1px solid var(--border);
  box-shadow:var(--sh-sm);position:relative;z-index:1;
  transition:transform var(--t-spring),box-shadow var(--t-spring);
}
.step-box:hover{transform:translateY(-6px);box-shadow:var(--sh-lg);}
.step-circle{
  width:56px;height:56px;border-radius:50%;
  background:var(--grad-cta);color:#fff;
  font-size:22px;font-weight:900;
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 18px;
  box-shadow:0 8px 20px rgba(109,40,217,.35),0 0 0 8px rgba(109,40,217,.08);
}
.step-box-title{font-size:17px;font-weight:800;margin-bottom:8px;}
.step-box-desc{font-size:14px;color:var(--text-3);line-height:1.65;}

/* ── 12. PRICING ──────────────────────────────────────────── */
.pricing-wrap{display:grid;grid-template-columns:1fr 1fr;gap:24px;max-width:820px;margin:0 auto;}
.price-card{
  background:#fff;border-radius:var(--r-2xl);
  border:1.5px solid var(--border);
  padding:40px 36px;position:relative;
  box-shadow:var(--sh-md);
  transition:transform var(--t-spring),box-shadow var(--t-spring);
}
.price-card:hover{transform:translateY(-6px);box-shadow:var(--sh-xl);}
.price-card.popular{
  border-color:var(--violet);
  box-shadow:0 0 0 4px rgba(109,40,217,.1),var(--sh-xl);
  transform:translateY(-12px);
}
.price-card.popular:hover{transform:translateY(-18px);}
.price-pop-badge{
  position:absolute;top:-16px;left:50%;transform:translateX(-50%);
  background:var(--grad-cta);color:#fff;
  font-size:12px;font-weight:800;padding:5px 18px;
  border-radius:var(--r-full);white-space:nowrap;
  box-shadow:0 4px 12px rgba(109,40,217,.4);
}
.price-plan{font-size:13px;font-weight:800;color:var(--text-3);text-transform:uppercase;letter-spacing:.7px;margin-bottom:14px;}
.price-amount-row{display:flex;align-items:baseline;gap:4px;margin-bottom:6px;}
.price-curr{font-size:24px;font-weight:800;color:var(--text);}
.price-num{font-size:52px;font-weight:900;letter-spacing:-2px;color:var(--text);line-height:1;}
.price-per{font-size:15px;color:var(--text-4);margin-left:2px;}
.price-note{font-size:13px;color:var(--text-4);margin-bottom:28px;}
.price-divider{border:none;border-top:1px solid var(--border);margin:20px 0;}
.price-features{display:flex;flex-direction:column;gap:11px;margin-bottom:30px;}
.price-features li{
  display:flex;align-items:center;gap:10px;
  font-size:14px;color:var(--text-2);
}
.price-features li .pi{/* price item icon */
  width:22px;height:22px;border-radius:50%;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  font-size:11px;font-weight:900;
  background:rgba(109,40,217,.08);color:var(--violet);
}
.price-features li.off{color:var(--text-4);}
.price-features li.off .pi{background:var(--bg);color:var(--text-4);}

/* ── 13. TESTIMONIALS ─────────────────────────────────────── */
.testimonials-wrap{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:20px;
}
.testi-card{
  background:#fff;border-radius:var(--r-xl);
  border:1px solid var(--border);
  padding:28px;
  box-shadow:var(--sh-sm);
  transition:transform var(--t-spring),box-shadow var(--t-spring);
}
.testi-card:hover{transform:translateY(-5px);box-shadow:var(--sh-lg);}
.testi-card:nth-child(2){transform:translateY(-8px);}
.testi-card:nth-child(2):hover{transform:translateY(-14px);}
.testi-stars{color:#F59E0B;font-size:14px;letter-spacing:2px;margin-bottom:14px;}
.testi-text{
  font-size:15px;line-height:1.75;color:var(--text-2);
  margin-bottom:20px;font-style:italic;
  position:relative;padding-left:18px;
}
.testi-text::before{
  content:""";position:absolute;left:0;top:-4px;
  font-size:36px;color:rgba(109,40,217,.15);line-height:1;
  font-family:Georgia,serif;font-style:normal;
}
.testi-author{display:flex;align-items:center;gap:12px;}
.testi-av{
  width:46px;height:46px;border-radius:50%;
  background:var(--grad-cta);color:#fff;
  font-size:15px;font-weight:900;
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;box-shadow:0 4px 10px rgba(109,40,217,.25);
}
.testi-name{font-size:14px;font-weight:800;}
.testi-role{font-size:12px;color:var(--text-4);}

/* ── 14. NUMBERS SECTION ──────────────────────────────────── */
.numbers-grid{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:0;
  background:#fff;border-radius:var(--r-2xl);
  border:1px solid var(--border);
  box-shadow:var(--sh-md);overflow:hidden;
}
.num-item{
  padding:40px 32px;text-align:center;
  border-right:1px solid var(--border);
  transition:background var(--t);
}
.num-item:last-child{border-right:none;}
.num-item:hover{background:rgba(109,40,217,.03);}
.num-val{
  font-size:46px;font-weight:900;letter-spacing:-2px;
  background:var(--grad-text);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;
  line-height:1;margin-bottom:8px;
}
.num-lbl{font-size:14px;color:var(--text-3);font-weight:600;}

/* ── 15. CTA ──────────────────────────────────────────────── */
.cta-section{
  margin:0 28px 80px;
  border-radius:var(--r-2xl);
  background:linear-gradient(135deg,#1E1B4B 0%,#3730A3 35%,#1D4ED8 70%,#0EA5E9 100%);
  padding:80px 60px;
  text-align:center;color:#fff;
  overflow:hidden;position:relative;
  box-shadow:var(--sh-float);
}
.cta-section::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(ellipse 50% 80% at 20% 50%,rgba(124,58,237,.3) 0%,transparent 60%),
    radial-gradient(ellipse 40% 60% at 80% 30%,rgba(14,165,233,.25) 0%,transparent 60%);
  pointer-events:none;
}
.cta-inner,.cta-section .container{position:relative;z-index:1;}
.cta-section h2{font-size:clamp(28px,4vw,48px);font-weight:900;letter-spacing:-1.5px;margin-bottom:14px;}
.cta-section p{font-size:18px;opacity:.75;margin-bottom:36px;max-width:480px;margin-left:auto;margin-right:auto;}
.cta-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;}

/* ── 16. FOOTER ───────────────────────────────────────────── */
.footer{background:#0A0A14;color:#fff;padding:64px 0 0;}
.footer-top{
  display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;
  gap:40px;padding-bottom:48px;
  border-bottom:1px solid rgba(255,255,255,.07);
}
.footer-brand{}
.footer-logo{
  display:flex;align-items:center;gap:10px;
  font-size:18px;font-weight:900;margin-bottom:14px;
}
.footer-logo-icon{
  width:34px;height:34px;border-radius:9px;
  background:var(--grad-cta);
  display:flex;align-items:center;justify-content:center;font-size:16px;
  box-shadow:0 4px 12px rgba(109,40,217,.35);
}
.footer-tagline{font-size:14px;color:rgba(255,255,255,.4);line-height:1.7;max-width:240px;}
.footer-col-title{font-size:12px;font-weight:800;color:rgba(255,255,255,.4);text-transform:uppercase;letter-spacing:.7px;margin-bottom:14px;}
.footer-col ul{display:flex;flex-direction:column;gap:9px;}
.footer-col ul a{font-size:14px;color:rgba(255,255,255,.55);transition:color .15s;}
.footer-col ul a:hover{color:#fff;}
.footer-bottom{
  display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;
  padding:20px 0;font-size:13px;color:rgba(255,255,255,.3);
}
.footer-bottom a{color:rgba(255,255,255,.4);}
.footer-bottom a:hover{color:#fff;}

/* ── 17. PAGE HERO (inner pages) ──────────────────────────── */
.page-hero{
  background:linear-gradient(135deg,#1E1B4B 0%,#312E81 50%,#1D4ED8 100%);
  color:#fff;padding:64px 0;text-align:center;position:relative;overflow:hidden;
}
.page-hero::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(ellipse 60% 80% at 50% 100%,rgba(109,40,217,.2) 0%,transparent 70%);
}
.page-hero .container{position:relative;z-index:1;}
.page-hero h1{font-size:clamp(28px,4vw,50px);font-weight:900;letter-spacing:-1.5px;margin-bottom:12px;}
.page-hero p{font-size:17px;opacity:.7;max-width:520px;margin:0 auto;}
.page-hero-breadcrumb{
  display:flex;align-items:center;justify-content:center;gap:6px;
  font-size:13px;color:rgba(255,255,255,.4);margin-bottom:16px;
}
.page-hero-breadcrumb a{color:rgba(255,255,255,.5);}
.page-hero-breadcrumb a:hover{color:#fff;}

/* ── 18. ANNOUNCEMENT ─────────────────────────────────────── */
.announcement-bar{
  background:var(--grad-cta);color:#fff;
  text-align:center;padding:10px 24px;
  font-size:13px;font-weight:700;
  display:flex;align-items:center;justify-content:center;gap:10px;
}
.announcement-bar a{color:#fff;text-decoration:underline;text-underline-offset:2px;}
.announcement-close{background:none;border:none;color:rgba(255,255,255,.6);cursor:pointer;font-size:16px;padding:0 0 0 10px;margin-left:auto;}

/* ── 19. INNER PAGE COMPONENTS ────────────────────────────── */
.contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:56px;align-items:start;}
.contact-info{display:flex;flex-direction:column;gap:28px;}
.contact-item{display:flex;gap:16px;align-items:flex-start;}
.contact-item-icon{
  width:46px;height:46px;border-radius:12px;
  background:rgba(109,40,217,.08);color:var(--violet);
  font-size:22px;display:flex;align-items:center;justify-content:center;flex-shrink:0;
  border:1px solid rgba(109,40,217,.12);
}
.contact-item-title{font-size:15px;font-weight:800;margin-bottom:3px;}
.contact-item-value{font-size:14px;color:var(--text-3);}
.contact-form{
  background:#fff;border:1px solid var(--border);
  border-radius:var(--r-2xl);padding:40px;
  box-shadow:var(--sh-lg);
}
.form-group{margin-bottom:18px;}
.form-label{display:block;font-size:14px;font-weight:700;color:var(--text-2);margin-bottom:7px;}
.form-input{
  width:100%;padding:11px 15px;border-radius:var(--r);
  border:1.5px solid var(--border-md);font-size:14px;
  background:#fff;color:var(--text);transition:border-color .15s;outline:none;
}
.form-input:focus{border-color:var(--violet);box-shadow:0 0 0 3px rgba(109,40,217,.1);}
.form-input::placeholder{color:var(--text-4);}
textarea.form-input{resize:vertical;min-height:120px;}
.form-row-2{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.form-success{display:none;text-align:center;padding:28px;background:rgba(109,40,217,.06);border-radius:var(--r-xl);color:var(--violet);}
.form-success.visible{display:block;}
.form-success-icon{font-size:40px;margin-bottom:10px;}

/* Pricing inner page */
.pricing-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;max-width:900px;margin:0 auto;}
.pricing-card{background:#fff;border:1.5px solid var(--border);border-radius:var(--r-2xl);padding:38px 32px;position:relative;box-shadow:var(--sh-md);transition:transform var(--t-spring),box-shadow var(--t-spring);}
.pricing-card:hover{transform:translateY(-6px);box-shadow:var(--sh-xl);}
.pricing-card.popular{border-color:var(--violet);box-shadow:0 0 0 4px rgba(109,40,217,.1),var(--sh-xl);}
.pricing-badge{position:absolute;top:-14px;left:50%;transform:translateX(-50%);background:var(--grad-cta);color:#fff;font-size:12px;font-weight:800;padding:4px 16px;border-radius:var(--r-full);white-space:nowrap;}
.pricing-plan{font-size:13px;font-weight:800;color:var(--text-3);text-transform:uppercase;letter-spacing:.6px;margin-bottom:12px;}
.pricing-price{display:flex;align-items:baseline;gap:4px;margin-bottom:8px;}
.pricing-currency{font-size:22px;font-weight:800;color:var(--text);}
.pricing-amount{font-size:48px;font-weight:900;letter-spacing:-2px;color:var(--text);line-height:1;}
.pricing-period{font-size:15px;color:var(--text-4);margin-left:2px;}
.pricing-note{font-size:13px;color:var(--text-4);margin-bottom:24px;}
.pricing-divider{border:none;border-top:1px solid var(--border);margin:18px 0;}
.pricing-features{list-style:none;margin-bottom:26px;display:flex;flex-direction:column;gap:10px;}
.pricing-features li{display:flex;align-items:center;gap:10px;font-size:14px;color:var(--text-2);}
.pricing-features li::before{content:"✓";width:21px;height:21px;border-radius:50%;background:rgba(109,40,217,.08);color:var(--violet);font-size:11px;font-weight:900;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.pricing-features li.disabled{color:var(--text-4);}
.pricing-features li.disabled::before{background:var(--bg);color:var(--text-4);content:"×";}

/* Compare table */
.compare-table{width:100%;border-collapse:collapse;border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--sh-md);}
.compare-table th,.compare-table td{padding:14px 20px;text-align:left;border-bottom:1px solid var(--border);}
.compare-table thead{background:#0F172A;color:#fff;}
.compare-table thead th{font-size:13px;font-weight:700;letter-spacing:.3px;}
.compare-table thead th:not(:first-child){text-align:center;}
.compare-table td:not(:first-child){text-align:center;font-weight:600;}
.compare-table tbody tr:hover{background:rgba(109,40,217,.03);}
.compare-table tbody tr:last-child td{border-bottom:none;}
.compare-table .check{color:var(--green);font-size:18px;}
.compare-table .cross{color:var(--text-4);font-size:18px;}
.compare-table .highlight-col{background:rgba(109,40,217,.03);}

/* Legal pages */
.legal-body{max-width:760px;margin:0 auto;padding:64px 28px 96px;}
.legal-body h2{font-size:20px;font-weight:800;margin:36px 0 10px;}
.legal-body h3{font-size:16px;font-weight:700;margin:20px 0 8px;color:var(--text-2);}
.legal-body p,.legal-body li{font-size:15px;color:var(--text-2);line-height:1.75;margin-bottom:12px;}
.legal-body ul{padding-left:20px;list-style:disc;}
.legal-meta{font-size:13px;color:var(--text-4);margin-bottom:32px;padding-bottom:20px;border-bottom:1px solid var(--border);}

/* Badges */
.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:var(--r-full);font-size:12px;font-weight:700;}
.badge-success{background:#D1FAE5;color:#059669;}
.badge-violet{background:rgba(109,40,217,.1);color:var(--violet);}
.badge-orange{background:#FEF3C7;color:#D97706;}

/* ── 20a. MISSING COMPONENTS (compatibility + new) ───────── */

/* Section variants */
.section-muted{background:#fff;}

/* White button (used in dark CTA sections) */
.btn-white{background:#fff;color:var(--violet);box-shadow:0 4px 16px rgba(255,255,255,.2);}
.btn-white:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(255,255,255,.3);}

/* Footer grid alias (v1 compat) */
.footer-grid{
  display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;
  gap:40px;padding-bottom:48px;
  border-bottom:1px solid rgba(255,255,255,.07);
}
@media(max-width:900px){.footer-grid{grid-template-columns:1fr 1fr;}}
@media(max-width:480px){.footer-grid{grid-template-columns:1fr;}}

/* FAQ accordion */
.faq-list{display:flex;flex-direction:column;border:1px solid var(--border);border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--sh-sm);}
.faq-item{border-bottom:1px solid var(--border);}
.faq-item:last-child{border-bottom:none;}
.faq-question{
  width:100%;text-align:left;background:#fff;border:none;
  padding:20px 26px;font-size:15px;font-weight:700;color:var(--text);
  cursor:pointer;display:flex;justify-content:space-between;align-items:center;
  transition:background var(--t),color var(--t);font-family:inherit;
}
.faq-question:hover{background:rgba(109,40,217,.03);}
.faq-item.open .faq-question{color:var(--violet);background:rgba(109,40,217,.04);}
.faq-icon{font-size:22px;font-weight:400;color:var(--text-3);transition:transform .25s;line-height:1;}
.faq-item.open .faq-icon{transform:rotate(45deg);}
.faq-answer{
  display:none;padding:0 26px 20px;
  font-size:14px;color:var(--text-3);line-height:1.8;
  background:#fff;
}
.faq-item.open .faq-answer{display:block;}

/* Feature card grid (features page) */
.features-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:18px;margin-top:40px;}
.feature-card{
  background:#fff;border:1px solid var(--border);border-radius:var(--r-xl);
  padding:26px;box-shadow:var(--sh-sm);
  transition:transform var(--t-spring),box-shadow var(--t-spring);
}
.feature-card:hover{transform:translateY(-5px);box-shadow:var(--sh-lg);}
.feature-icon{
  width:50px;height:50px;border-radius:13px;
  display:flex;align-items:center;justify-content:center;
  font-size:22px;margin-bottom:16px;box-shadow:var(--sh-xs);
}
.feature-icon.green{background:linear-gradient(135deg,#D1FAE5,#A7F3D0);}
.feature-icon.blue{background:linear-gradient(135deg,#DBEAFE,#BFDBFE);}
.feature-icon.orange{background:linear-gradient(135deg,#FEF3C7,#FDE68A);}
.feature-icon.purple{background:linear-gradient(135deg,#EDE9FE,#DDD6FE);}
.feature-icon.teal{background:linear-gradient(135deg,#CFFAFE,#A5F3FC);}
.feature-icon.red{background:linear-gradient(135deg,#FEE2E2,#FECACA);}
.feature-title{font-size:15px;font-weight:800;margin-bottom:7px;color:var(--text);}
.feature-desc{font-size:13px;color:var(--text-3);line-height:1.65;}

/* Trust pills row */
.trust-row{display:flex;justify-content:center;gap:28px;flex-wrap:wrap;margin-top:44px;padding-top:36px;border-top:1px solid var(--border);}
.trust-pill{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--text-3);font-weight:600;}
.trust-pill span{font-size:20px;}

/* ── 20. RESPONSIVE ───────────────────────────────────────── */
@media(max-width:1024px){
  .feat-card-xl{grid-column:span 6;}
  .feat-card-lg{grid-column:span 6;}
  .feat-card-md{grid-column:span 6;}
}
@media(max-width:900px){
  .footer-top{grid-template-columns:1fr 1fr;}
  .footer-brand{grid-column:1/-1;}
  .numbers-grid{grid-template-columns:repeat(2,1fr);}
  .contact-grid{grid-template-columns:1fr;}
}
@media(max-width:768px){
  .section{padding:64px 0;}
  .cta-section{margin:0 16px 60px;padding:56px 32px;}
  .hero-inner{grid-template-columns:1fr;text-align:center;}
  .hero-left{order:0;}
  .hero-right{order:1;display:none;}
  .hero h1{font-size:38px;letter-spacing:-1px;}
  .hero-sub{font-size:16px;margin-left:auto;margin-right:auto;}
  .hero-actions{justify-content:center;}
  .hero-trust{justify-content:center;}
  .navbar-links,.navbar-actions .btn-ghost{display:none;}
  .navbar-hamburger{display:flex;}
  .features-bento{grid-template-columns:1fr;}
  .feat-card-xl,.feat-card-lg,.feat-card-md{grid-column:span 1;}
  .split-section{grid-template-columns:1fr;}
  .split-section.reverse .split-visual{order:0;}
  .steps-grid{grid-template-columns:1fr;}
  .steps-grid::before{display:none;}
  .pricing-wrap{grid-template-columns:1fr;}
  .price-card.popular{transform:none;}
  .price-card.popular:hover{transform:translateY(-6px);}
  .testimonials-wrap{grid-template-columns:1fr;}
  .testi-card:nth-child(2){transform:none;}
}
@media(max-width:480px){
  .container{padding:0 16px;}
  .hero{padding:56px 0 0;}
  .cta-section{margin:0 12px 48px;padding:44px 24px;border-radius:var(--r-xl);}
  .cta-actions{flex-direction:column;align-items:center;}
  .numbers-grid{grid-template-columns:1fr 1fr;}
  .num-item{padding:28px 16px;}
  .num-val{font-size:34px;}
  .footer-top{grid-template-columns:1fr;}
  .form-row-2{grid-template-columns:1fr;}
  .pricing-grid{grid-template-columns:1fr;}
  .hero-actions .btn{width:100%;justify-content:center;}
}
