/* ============================================
   AUTO1SOURCE — MASTER STYLESHEET (RESPONSIVE)
   Design Tokens from Figma + Component Library
   ============================================ */

/* RESET */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}

/* TOKENS */
:root{
  /* Colors */
  --navy:#1a2d5a;
  --teal:#03466e;
  --red:#f53a31;
  --dark-red:#df2b26;
  --deep-red:#610300;
  --dark:#111827;
  --muted:#7a8494;
  --light-bg:#f8f9fb;
  --footer-bg:#0f172a;
  --border:#eef0f4;
  --bar-bg:#dde8f0;
  --red-hover:#df2b26;
  --light-gray:#f3f4f6;

  /* Typography */
  --fh:'Sora',sans-serif;
  --fb:'DM Sans',sans-serif;

  /* Shared radii & shadows */
  --r-sm:8px;
  --r-md:10px;
  --r-lg:18px;
  --shadow-card:0 8px 24px rgba(0,0,0,.08);

  /* Fluid side padding — replaces fixed 240px */
  --px: clamp(20px, 6vw, 240px);
}

html{scroll-behavior:smooth}
body{font-family:var(--fb);color:var(--dark);background:#fff;overflow-x:hidden;-webkit-font-smoothing:antialiased}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
button{font-family:var(--fb);cursor:pointer}
ul{list-style:none}


/* ===========================
   BUTTONS
   =========================== */
.btn-navy{
  display:inline-flex;align-items:center;justify-content:center;
  background:var(--navy);color:#fff;padding:14px 28px;border-radius:11px;
  font-weight:600;font-size:16px;box-shadow:0 4px 14px rgba(26,45,90,.35);
  border:none;cursor:pointer;transition:opacity .2s
}
.btn-navy:hover{opacity:.88}

.btn-teal{
  display:inline-flex;align-items:center;justify-content:center;
  background:var(--teal);color:#fff;padding:14px 28px;border-radius:11px;
  font-weight:600;font-size:16px;box-shadow:0 4px 14px rgba(3,70,110,.35);
  border:none;cursor:pointer;transition:opacity .2s
}
.btn-teal:hover{opacity:.88}

.btn-red{
  display:inline-flex;align-items:center;justify-content:center;
  background:var(--red);color:#fff;padding:14px 28px;border-radius:11px;
  font-weight:600;font-size:16px;box-shadow:0 4px 14px rgba(245,58,49,.35);
  border:none;cursor:pointer;transition:opacity .2s
}
.btn-red:hover{opacity:.88}

.btn-white{
  background:#fff;color:var(--teal);padding:14px 28px;border-radius:10px;
  font-weight:700;font-size:14.7px;box-shadow:0 4px 16px rgba(0,0,0,.08);
  border:none;cursor:pointer;transition:opacity .2s
}
.btn-white:hover{opacity:.9}

.btn-outline{
  border:2px solid rgba(255,255,255,.4);background:transparent;color:#fff;
  padding:12px 28px;border-radius:10px;font-weight:600;font-size:14.7px;
  cursor:pointer;transition:border-color .2s
}
.btn-outline:hover{border-color:rgba(255,255,255,.7)}

.btn-outline-dark{
  border:2px solid var(--navy);background:transparent;color:var(--navy);
  padding:12px 28px;border-radius:10px;font-weight:600;font-size:14.7px;
  cursor:pointer;transition:all .2s
}
.btn-outline-dark:hover{background:var(--navy);color:#fff}


/* ===========================
   NAV
   =========================== */
.nav{
  position:fixed;top:0;left:0;right:0;height:72px;
  background:rgba(255,255,255,.97);z-index:1000;
  display:flex;align-items:center;padding:0 var(--px);
  backdrop-filter:blur(10px);border-bottom:1px solid rgba(0,0,0,.04)
}
.nav-logo img{height:36px}
.nav-links{display:flex;align-items:center;gap:2px;margin-left:0px}
.nav-link{
  padding:8px 14px;font-size:14.7px;font-weight:500;color:#3d4452;
  border-radius:8px;cursor:pointer;white-space:nowrap;transition:background .15s
}
.nav-link:hover{background:rgba(0,0,0,.04)}
.nav-link.bold{font-weight:600;color:var(--navy)}
.nav-link .chev{font-size:10px;margin-left:3px;opacity:.5}
.nav-link.active{background:rgba(3,70,110,.08);color:var(--teal);font-weight:600}
.nav-cta{
  margin-left:20px;background:var(--navy);color:#fff;padding:13px 28px;
  border-radius:10px;font-weight:600;font-size:14.7px;
  box-shadow:0 4px 14px rgba(26,45,90,.35);cursor:pointer;border:none;
  white-space:nowrap;transition:opacity .2s
}
.nav-cta:hover{opacity:.88}


/* ===========================
   SECTION HEADERS (reusable)
   =========================== */
.sec-hdr{text-align:center;margin-bottom:48px}
.sec-hdr h2{font-family:var(--fh);font-weight:800;font-size:41.6px;letter-spacing:-.832px;line-height:1.2}
.sec-hdr p{font-size:17.6px;color:var(--muted);margin-top:8px;line-height:1.7}
.sec-hdr-left{margin-bottom:40px}
.sec-hdr-left h2{font-family:var(--fh);font-weight:800;font-size:41.6px;letter-spacing:-.832px;line-height:1.2}
.sec-hdr-left p{font-size:17.6px;color:var(--muted);margin-top:8px;line-height:1.7}


/* ===========================
   HERO (Homepage)
   =========================== */
.hero{padding-top:40px;position:relative;background:rgba(255,244,244,.54);overflow:hidden;min-height:1020px;padding-bottom:60px}
.hero-inner{max-width:100%;margin:0 auto;padding:120px 0 0 var(--px);position:relative;min-height:948px}
.hero-text{width:580px;max-width:100%;position:relative;z-index:3}
.hero-text h1{font-family:var(--fh);font-weight:800;font-size:70px;line-height:1.05;letter-spacing:-1.04px}
.hero-sub{font-size:16.8px;line-height:1.6;color:var(--muted);margin:24px 0 32px}
.hero-sub .r{color:var(--red)}
.hero-dash{
  position:absolute;right:-40px;top:20px;
  border-radius:30px;overflow:hidden;z-index:4
}
.hero-dash img{width:100%;height:100%;object-fit:cover}
.hero-bg{
  position:absolute;right:0;top:362px;width:924px;height:621px;
  border-radius:40px 0 0 40px;overflow:hidden;z-index:1
}
.hero-bg img{width:100%;height:100%;object-fit:cover}
.hero-bg::after{content:'';position:absolute;inset:0;background:linear-gradient(to right,rgba(0,0,0,.6),transparent)}
.hero-quote{
  position:absolute;left:var(--px);bottom:-230px;background:#fff;border-radius:10px;
  box-shadow:0 4px 16.7px rgba(0,0,0,.1);padding:28px 32px;width:551px;max-width:calc(100% - (var(--px) * 2));z-index:5
}
.hero-quote .stars{color:#f59e0b;font-size:15px;margin-bottom:10px;letter-spacing:3px}
.hero-quote .qt{font-size:16.8px;line-height:1.6;color:var(--muted);margin-bottom:14px}
.hero-quote .au{font-weight:700;font-size:16.8px}


/* ===========================
   PAGE HERO (Inner pages)
   =========================== */
.page-hero{
  padding:140px var(--px) 80px;
  background:linear-gradient(135deg,#f8f9fb 0%,#eef2f7 100%);
  text-align:center;position:relative;overflow:hidden
}
.page-hero h1{
  font-family:var(--fh);font-weight:800;font-size:30px;
  line-height:1.2;letter-spacing:-1.04px;margin-bottom:16px
}
.page-hero .subtitle{
  font-size:17.6px;line-height:1.7;color:var(--muted);
  max-width:600px;margin:0 auto 32px
}
.page-hero .subtitle .r{color:var(--red)}


/* ===========================
   DARK PAGE HERO (used on feature/detail pages)
   =========================== */
.dark-hero{
  background:linear-gradient(180deg,#04101f 0%,#071e3d 100%);
  padding:140px var(--px) 80px;
  position:relative;overflow:hidden;color:#fff
}
.dark-hero-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;
  max-width:1400px;margin:0 auto
}
.dark-hero h1{
  font-family:var(--fh);font-weight:800;font-size:44px;
  line-height:1.15;letter-spacing:-.8px;margin-bottom:16px;color:#fff
}
.dark-hero h1 .r{color:var(--red)}
.dark-hero .sub{
  font-size:16px;line-height:1.65;color:rgba(255,255,255,.7);
  max-width:520px
}
.dark-hero-visual{
  background:#fff;border-radius:14px;padding:20px 22px;
  box-shadow:0 20px 50px rgba(0,0,0,.3);color:var(--dark)
}
.dh-dots{display:flex;gap:6px;margin-bottom:14px}
.dh-dots span{width:11px;height:11px;border-radius:50%}
.dh-dots span:nth-child(1){background:#ff5f57}
.dh-dots span:nth-child(2){background:#ffbd2e}
.dh-dots span:nth-child(3){background:#28ca42}
.dh-title{font-weight:700;font-size:13px;margin-bottom:12px;color:#333}
.dh-row{
  display:flex;align-items:center;justify-content:space-between;
  padding:10px 0;border-bottom:1px solid #f0f0f0;font-size:13px
}
.dh-row:last-child{border-bottom:none}
.dh-row .l{display:flex;align-items:center;gap:10px}
.dh-row .dot{width:6px;height:6px;border-radius:50%;background:var(--red)}
.dh-pill{
  padding:3px 10px;border-radius:100px;font-size:11px;font-weight:600
}
.dh-pill.g{background:#dcfce7;color:#15803d}
.dh-pill.b{background:#dbeafe;color:#1d4ed8}
.dh-pill.y{background:#fef3c7;color:#b45309}
.dh-pill.o{background:#ffedd5;color:#c2410c}


/* ===========================
   PAIN POINTS
   =========================== */
.pain{background:var(--light-bg);padding:110px var(--px)}
.pain-grid{display:flex;gap:80px;align-items:flex-start}
.pain-left{flex:0 0 567px;max-width:100%}
.pain-left h2{font-family:var(--fh);font-weight:700;font-size:30px;line-height:1.2;letter-spacing:-1.5px;margin-bottom:12px}
.pain-left .sub{font-size:14.7px;line-height:1.75;color:var(--muted);margin-bottom:28px}
.pi{margin-bottom:14px}
.pi-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:5px}
.pi-row .t{font-weight:600;font-size:13.4px}
.pi-row .p{font-weight:700;font-size:12px;color:var(--navy)}
.bar{height:8px;background:var(--bar-bg);border-radius:100px;overflow:hidden}
.bar-f{height:100%;border-radius:100px;background:linear-gradient(to right,var(--deep-red),var(--dark-red))}
.pain-btn{
  margin-top:24px;width:100%;padding:14px;background:var(--navy);color:#fff;
  border:none;border-radius:10px;font-weight:600;font-size:14.7px;
  cursor:pointer;box-shadow:0 4px 14px rgba(26,45,90,.35);transition:opacity .2s
}
.pain-btn:hover{opacity:.88}
.pain-stats{display:flex;margin-top:28px;border-top:1px solid #e5e7eb;padding-top:18px}
.ps{flex:1;text-align:center;position:relative}
.ps+.ps::before{content:'';position:absolute;left:0;top:50%;transform:translateY(-50%);width:1px;height:36px;background:#e5e7eb}
.ps .n{font-family:var(--fh);font-weight:800;font-size:25.6px}
.ps .plus{font-family:var(--fh);font-weight:700;font-size:16px;color:#e12a26}
.ps .u{font-family:var(--fh);font-weight:700;font-size:16px;color:#e12a26}
.ps .l{font-weight:600;font-size:10.4px;color:var(--muted);text-transform:uppercase;letter-spacing:.832px;margin-top:4px;line-height:1.3}
.pain-right{flex:1;min-width:0}
.pain-right img{width:100%;border-radius:8px;}
.badge-row{display:flex;gap:18px;margin-top:20px;justify-content:center;flex-wrap:wrap}
.badge-r{
  border:1px solid var(--red);border-radius:10px;padding:13px 20px;
  box-shadow:0 4px 14px var(--red);font-weight:800;font-size:16px;
  color:var(--red);text-transform:capitalize;display:flex;align-items:center;gap:8px
}


/* ===========================
   MORE THAN SOFTWARE
   =========================== */
.more{background:#f7f8fa;padding:110px var(--px)}
.more-grid{display:flex;gap:60px;align-items:center}
.more-imgs{flex:0 0 500px;max-width:100%;position:relative;height:460px}
.more-img1{position:absolute;top:0;left:0;width:360px;height:320px;max-width:75%;border-radius:18px;overflow:hidden;box-shadow:0 16px 48px rgba(0,0,0,.1)}
.more-img1 img{width:100%;height:100%;object-fit:cover}
.more-img2{position:absolute;bottom:0;right:0;width:290px;height:248px;max-width:60%;border-radius:18px;overflow:hidden;border:4px solid #fff;box-shadow:0 20px 60px rgba(0,0,0,.18)}
.more-img2 img{width:100%;height:100%;object-fit:cover}
.more-price{
  position:absolute;bottom:20px;left:0;background:var(--navy);
  border-radius:16px;padding:16px 24px;box-shadow:0 8px 28px rgba(26,45,90,.4);color:#fff
}
.more-price .amt{font-family:var(--fh);font-weight:800;font-size:30.4px}
.more-price .per{font-weight:700;font-size:9.9px;text-transform:uppercase;letter-spacing:1.19px;opacity:.8;margin-top:2px}
.more-right{flex:1;min-width:0}
.more-right h2{font-family:var(--fh);font-weight:800;font-size:41.6px;line-height:1.18;letter-spacing:-1.04px;margin-bottom:32px;text-transform:capitalize}
.more-right h2 .r{color:var(--red)}
.ci{display:flex;gap:16px;margin-bottom:24px;align-items:flex-start}
.ci-ico{
  width:52px;height:52px;background:#f7d2d2;border-radius:14px;
  display:flex;align-items:center;justify-content:center;
  font-size:28px;color:var(--red);font-weight:700;flex-shrink:0
}
.ci-txt h4{font-weight:700;font-size:14.7px;margin-bottom:4px}
.ci-txt p{font-size:13.4px;line-height:1.6;color:var(--muted)}
.more-tip{font-weight:800;font-size:14px;color:var(--red);text-transform:capitalize;margin:8px 0 24px}


/* ===========================
   FEATURES GRID
   =========================== */
.feat{background:rgba(27,46,90,.09);padding:100px var(--px)}
.feat-inner{max-width:1400px;margin:0 auto}
.feat-grid{display:grid;grid-template-columns:284px 1fr 1fr 1fr;grid-template-rows:auto auto;gap:12px}
.fc{border-radius:18px;padding:22px;overflow:hidden}
.fc .iw{width:54px;height:54px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:24px;margin-bottom:10px}
.fc h3{font-family:var(--fh);font-weight:800;font-size:15.2px;letter-spacing:-.152px;margin-bottom:6px}
.fc p{font-size:12px;line-height:1.65;color:#6b7280}
.fc .arr{width:28px;height:28px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13.6px;margin-top:12px;cursor:pointer}
.fc-dark{
  grid-row:1/3;background:linear-gradient(145deg,#071529,#0b2545 40%,#0a3a6e);
  color:#fff;display:flex;flex-direction:column;justify-content:flex-end;
  position:relative;overflow:hidden
}
.fc-dark::before{content:'';position:absolute;top:-40px;right:-40px;width:220px;height:220px;border-radius:50%;background:radial-gradient(circle,rgba(14,196,216,.18),transparent 70%)}
.fc-dark .emoji{font-size:51.2px;margin-bottom:24px}
.fc-dark h3{font-family:var(--fh);font-weight:800;font-size:24.8px;letter-spacing:-.62px;color:#fff;margin-bottom:10px}
.fc-dark p{color:rgba(255,255,255,.6)}
.fc-dark .lnk{font-weight:700;font-size:12px;color:#fff;letter-spacing:.24px;margin-top:16px}
.fc-blue{background:linear-gradient(135deg,#dbeeFF,#c7e2ff)}
.fc-blue .iw{background:rgba(59,130,246,.15)}
.fc-blue .arr{background:rgba(59,130,246,.2);color:#2563eb}
.fc-green{background:linear-gradient(135deg,#d1fae5,#bbf7d0)}
.fc-green .iw{background:rgba(16,185,129,.15)}
.fc-green .arr{background:rgba(16,185,129,.2);color:#059669}
.fc-orange{background:linear-gradient(135deg,#ffe4cc,#ffd0a8)}
.fc-orange .iw{background:rgba(249,115,22,.15)}
.fc-orange .arr{background:rgba(249,115,22,.2);color:#ea580c}
.fc-cyan{background:linear-gradient(135deg,#cffafe,#a5f3fc);grid-column:2/4}
.fc-cyan .iw{background:rgba(3,70,110,.15)}
.fc-cyan .arr{background:rgba(3,70,110,.2);color:#0891b2}
.fc-purple{background:linear-gradient(135deg,#ede9fe,#ddd6fe)}
.fc-purple .iw{background:rgba(139,92,246,.15)}
.fc-purple .arr{background:rgba(139,92,246,.2);color:#7c3aed}


/* ===========================
   SHOP TYPE CARDS
   =========================== */
.shops{background:#fff;padding:100px var(--px)}
.shops-inner{max-width:1400px;margin:0 auto}
.shops-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.sc{background:#fff;border:1px solid var(--border);border-radius:16px;overflow:hidden;box-shadow:0 2px 10px rgba(0,0,0,.05);transition:transform .2s,box-shadow .2s}
.sc:hover{transform:translateY(-4px);box-shadow:0 8px 24px rgba(0,0,0,.1)}
.sc-img{height:200px;position:relative;overflow:hidden}
.sc-img img{width:100%;height:100%;object-fit:cover}
.sc-img::after{content:'';position:absolute;inset:0;background:linear-gradient(to bottom,rgba(5,15,30,0) 30%,rgba(5,15,30,.55))}
.sc-badge{
  position:absolute;bottom:12px;left:12px;width:60px;height:60px;
  background:var(--teal);border-radius:12px;display:flex;align-items:center;
  justify-content:center;font-size:22px;box-shadow:0 4px 16px rgba(3,70,110,.4);
  backdrop-filter:blur(4px);z-index:2;color:#fff
}
.sc-body{padding:16px 20px 20px}
.sc-body h3{font-family:var(--fh);font-weight:800;font-size:14.7px;margin-bottom:8px}
.sc-body p{font-size:12px;line-height:1.6;color:var(--muted);margin-bottom:12px}
.sc-body .lnk{font-weight:700;font-size:12px;color:var(--teal)}


/* ===========================
   STEPS TIMELINE
   =========================== */
.steps{background:linear-gradient(169deg,#04101f,#071e3d 55%,#041529);padding:80px var(--px)}
.steps-inner{max-width:1400px;margin:0 auto}
.steps-row{position:relative;display:flex;justify-content:space-between;gap:20px;padding-top:0}
.steps-row::before{content:'';position:absolute;top:34px;left:0;right:0;height:2.5px;background:var(--red)}
.step{text-align:center;width:200px;position:relative;flex:1}
.step-n{
  width:69px;height:69px;border:2.5px solid var(--red);border-radius:50%;
  background:#fff;display:flex;align-items:center;justify-content:center;
  font-family:var(--fh);font-weight:800;font-size:22px;color:var(--red);
  margin:0 auto 20px;box-shadow:0 0 0 7.6px #fff;position:relative
}
.step-t{font-family:var(--fh);font-weight:700;font-size:18px;color:#fff;line-height:1.22}


/* ===========================
   TESTIMONIALS
   =========================== */
.testi{background:var(--light-bg);padding:100px var(--px)}
.testi-inner{max-width:1400px;margin:0 auto}
.testi-wrap{display:flex;align-items:center;gap:40px}
.t-arr{
  width:46px;height:46px;background:var(--teal);border-radius:50%;
  display:flex;align-items:center;justify-content:center;color:#fff;
  font-size:25.6px;cursor:pointer;box-shadow:0 4px 16px rgba(0,0,0,.08);
  border:none;flex-shrink:0;transition:opacity .2s
}
.t-arr:hover{opacity:.85}
.t-card{
  background:#fff;border-radius:20px;box-shadow:0 4px 16px rgba(0,0,0,.08);
  padding:68px 60px 68px 85px;flex:1;position:relative;min-width:0
}
.t-card .bq{position:absolute;left:40px;top:24px;font-family:var(--fh);font-weight:800;font-size:112px;color:var(--dark-red);opacity:.6;line-height:.7}
.t-card .tx{font-weight:600;font-size:17.6px;line-height:1.7;margin-bottom:16px;position:relative}
.t-card .nm{font-family:var(--fh);font-weight:700;font-size:14.7px;color:var(--teal)}
.t-card .loc{font-size:13.4px;color:var(--muted)}
.t-dots{display:flex;gap:6px;justify-content:center;margin-top:28px;align-items:center}
.t-dots .d{width:10px;height:10px;border-radius:50%;background:#c4c9d4;cursor:pointer}
.t-dots .d.on{width:13px;height:13px;background:var(--teal)}


/* ===========================
   CTA SECTION
   =========================== */
.cta-sec{background:var(--teal);padding:80px var(--px);text-align:center}
.cta-sec h2{font-family:var(--fh);font-weight:800;font-size:41.6px;letter-spacing:-.832px;color:#fff;margin-bottom:16px;line-height:1.2}
.cta-sec p{font-size:17.6px;line-height:1.7;color:rgba(255,255,255,.8);max-width:510px;margin:0 auto 32px}
.cta-btns{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}


/* ===========================
   FOOTER
   =========================== */
.footer{background:var(--footer-bg);padding:70px var(--px) 0;color:rgba(255,255,255,.45)}
.footer-inner{display:grid;grid-template-columns:350px 1fr 1fr 1fr 1fr;gap:40px;max-width:1400px;margin:0 auto}
.footer-brand .logo{height:40px;margin-bottom:4px;filter:brightness(0) invert(.6)}
.footer-brand .desc{font-size:13.4px;line-height:1.75;margin-top:16px}
.footer-socials{display:flex;gap:8px;margin-top:16px}
.footer-socials a{
  width:36px;height:36px;background:rgba(255,255,255,.07);border-radius:9px;
  display:flex;align-items:center;justify-content:center;font-size:13.4px;
  color:rgba(255,255,255,.5);transition:background .15s
}
.footer-socials a:hover{background:rgba(255,255,255,.12)}
.ft-col h4{
  font-family:var(--fh);font-weight:700;font-size:13.4px;
  color:rgba(255,255,255,.55);text-transform:uppercase;
  letter-spacing:1.344px;margin-bottom:18px
}
.ft-col li{margin-bottom:10px}
.ft-col li a{font-size:13.4px;color:rgba(255,255,255,.45);transition:color .15s}
.ft-col li a:hover{color:rgba(255,255,255,.7)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);margin-top:40px;padding:20px 0;font-size:13.4px;color:rgba(255,255,255,.3);max-width:1400px;margin-left:auto;margin-right:auto}


/* ===========================
   PRICING PAGE
   =========================== */
.pricing-cards{display:flex;gap:24px;justify-content:center;padding:0 var(--px) 80px;flex-wrap:wrap}
.price-card{
  background:#fff;border:1px solid var(--border);border-radius:20px;
  padding:40px 32px;flex:1;min-width:280px;max-width:380px;box-shadow:0 2px 12px rgba(0,0,0,.05);
  transition:transform .2s,box-shadow .2s
}
.price-card:hover{transform:translateY(-4px);box-shadow:0 12px 32px rgba(0,0,0,.1)}
.price-card.featured{border:2px solid var(--red);position:relative}
.price-card.featured::before{
  content:'Most Popular';position:absolute;top:-14px;left:50%;transform:translateX(-50%);
  background:var(--red);color:#fff;font-weight:700;font-size:12px;
  padding:4px 16px;border-radius:20px;white-space:nowrap
}
.price-card .plan-name{font-family:var(--fh);font-weight:700;font-size:18px;margin-bottom:8px}
.price-card .plan-price{font-family:var(--fh);font-weight:800;font-size:48px;color:var(--dark);margin-bottom:4px}
.price-card .plan-price span{font-size:18px;font-weight:600;color:var(--muted)}
.price-card .plan-desc{font-size:14px;color:var(--muted);line-height:1.55;margin-bottom:24px}
.price-card .plan-features{margin-bottom:28px}
.price-card .plan-features li{
  font-size:14px;color:var(--dark);padding:8px 0;
  border-bottom:1px solid #f3f4f6;display:flex;align-items:center;gap:8px
}
.price-card .plan-features li::before{content:'✓';color:var(--red);font-weight:700}


/* ===========================
   INTEGRATIONS PAGE
   =========================== */
.integrations-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:24px;
  padding:0 var(--px) 80px;max-width:1400px;margin:0 auto
}
.integ-card{
  background:#fff;border:1px solid var(--border);border-radius:16px;
  padding:32px 24px;text-align:center;box-shadow:0 2px 8px rgba(0,0,0,.04);
  transition:transform .2s,box-shadow .2s
}
.integ-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px rgba(0,0,0,.1)}
.integ-card img{height:48px;margin:0 auto 16px;object-fit:contain}
.integ-card h3{font-family:var(--fh);font-weight:700;font-size:15px;margin-bottom:6px}
.integ-card p{font-size:12px;line-height:1.5;color:var(--muted)}
.integ-category{padding:50px var(--px) 0;margin-bottom:48px;max-width:1400px;margin-left:auto;margin-right:auto}
.integ-category h3{
  font-family:var(--fh);font-weight:700;font-size:20px;
  margin-bottom:8px;color:var(--dark)
}
.integ-category p{font-size:14px;color:var(--muted);margin-bottom:24px}


/* ===========================
   MOBILE APP PAGE
   =========================== */
.app-showcase{display:flex;align-items:center;gap:80px;padding:0 var(--px) 80px;max-width:1400px;margin:0 auto}
.app-screens{flex:0 0 480px;max-width:100%;position:relative}
.app-screens img{width:100%;border-radius:24px;box-shadow:0 20px 60px rgba(0,0,0,.15)}
.app-info{flex:1;min-width:0}
.app-info h2{font-family:var(--fh);font-weight:800;font-size:32px;letter-spacing:-.5px;margin-bottom:16px;line-height:1.25}
.app-info p{font-size:16px;line-height:1.65;color:var(--muted);margin-bottom:24px}
.app-feature{display:flex;gap:14px;margin-bottom:20px;align-items:flex-start}
.app-feature .af-ico{
  width:44px;height:44px;background:rgba(3,70,110,.1);border-radius:12px;
  display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0
}
.app-feature h4{font-weight:700;font-size:14.7px;margin-bottom:2px}
.app-feature p{font-size:13px;color:var(--muted);line-height:1.55}
.app-badges{display:flex;gap:12px;margin-top:28px;flex-wrap:wrap}
.app-badges img{height:44px}


/* ===========================
   SHOP TYPE DETAIL PAGES
   =========================== */
.shop-detail-hero{
  padding:140px var(--px) 80px;
  position:relative;overflow:hidden
}
.shop-detail-hero .bg{
  position:absolute;inset:0;z-index:0
}
.shop-detail-hero .bg img{width:100%;height:100%;object-fit:cover}
.shop-detail-hero .bg::after{content:'';position:absolute;inset:0;background:linear-gradient(to right,rgba(0,0,0,.8),rgba(0,0,0,.3))}
.shop-detail-hero .content{position:relative;z-index:1;max-width:600px;color:#fff}
.shop-detail-hero .content h1{font-family:var(--fh);font-weight:800;font-size:52px;line-height:1.2;letter-spacing:-1.04px;margin-bottom:16px}
.shop-detail-hero .content p{font-size:17.6px;line-height:1.7;opacity:.85;margin-bottom:32px}

.benefits-section{padding:80px var(--px);background:var(--light-bg)}
.benefits-inner{max-width:1400px;margin:0 auto}
.benefits-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.benefit-card{
  background:#fff;border-radius:16px;padding:28px 24px;
  border:1px solid var(--border);box-shadow:0 2px 8px rgba(0,0,0,.04)
}
.benefit-card .b-ico{
  width:52px;height:52px;border-radius:14px;display:flex;align-items:center;
  justify-content:center;font-size:24px;margin-bottom:14px;
  background:rgba(3,70,110,.1)
}
.benefit-card h3{font-family:var(--fh);font-weight:700;font-size:16px;margin-bottom:8px}
.benefit-card p{font-size:13.4px;line-height:1.6;color:var(--muted)}


/* ===========================
   GENERAL CONTENT SECTIONS
   =========================== */
.content-section{padding:80px var(--px)}
.content-section.alt{background:var(--light-bg)}
.content-inner{max-width:1400px;margin:0 auto}
.split-section{display:flex;gap:60px;align-items:center}
.split-section.reverse{flex-direction:row-reverse}
.split-section .text{flex:1;min-width:0}
.split-section .visual{flex:0 0 480px;max-width:100%}
.split-section .visual img{width:100%;border-radius:18px;box-shadow:0 16px 48px rgba(0,0,0,.1)}
.split-section .text h2{font-family:var(--fh);font-weight:800;font-size:32px;letter-spacing:-.5px;margin-bottom:16px;line-height:1.25}
.split-section .text p{font-size:16px;line-height:1.65;color:var(--muted);margin-bottom:20px}

/* Feature check list (used on feature pages) */
.feat-checks{margin-top:20px}
.feat-check{display:flex;gap:14px;margin-bottom:18px;align-items:flex-start}
.feat-check .chk{
  width:28px;height:28px;border-radius:8px;background:#fee;
  display:flex;align-items:center;justify-content:center;
  color:var(--red);font-weight:700;flex-shrink:0;font-size:14px
}
.feat-check .txt h4{font-weight:700;font-size:15px;margin-bottom:4px;color:var(--dark)}
.feat-check .txt p{font-size:13.4px;line-height:1.55;color:var(--muted);margin:0}


/* ===========================
   BLOG CARDS
   =========================== */
.blogs-page{padding:80px var(--px);max-width:1400px;margin:0 auto}
.blogs-page-title{
  font-family:var(--fh);font-weight:800;font-size:36px;
  letter-spacing:-.8px;margin-bottom:32px;padding-bottom:16px;
  border-bottom:1px solid var(--border)
}
.blog-featured{display:grid;grid-template-columns:1.2fr 1fr;gap:40px;align-items:stretch;margin-bottom:48px}
.blog-featured-img{border-radius:var(--r-lg);overflow:hidden;aspect-ratio:4/3;background:var(--light-gray)}
.blog-featured-img img{width:100%;height:100%;object-fit:cover}
.blog-featured-content{display:flex;flex-direction:column;justify-content:center;gap:12px}
.blog-date{font-size:.72rem;font-weight:700;color:var(--teal);text-transform:uppercase;letter-spacing:.06em}
.blog-featured-content h2{font-size:1.5rem;font-family:var(--fh);font-weight:800;line-height:1.3}
.blog-featured-content p{font-size:.875rem;color:var(--muted);line-height:1.6}
.read-more-link{display:inline-flex;align-items:center;gap:6px;font-size:.8125rem;font-weight:600;color:var(--dark);transition:color .15s}
.read-more-link:hover{color:var(--teal)}
.read-more-arrow{width:24px;height:24px;border-radius:4px;background:var(--teal);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-size:.8rem}
.blog-grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-bottom:32px}
.blog-card{border-radius:var(--r-lg);overflow:hidden;background:#fff;transition:box-shadow .18s,transform .18s;display:flex;flex-direction:column}
.blog-card:hover{box-shadow:var(--shadow-card);transform:translateY(-3px)}
.blog-card-img{aspect-ratio:4/3;overflow:hidden;background:var(--light-gray);border-radius:var(--r-lg)}
.blog-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.blog-card:hover .blog-card-img img{transform:scale(1.05)}
.blog-card-body{padding:14px 4px 20px}
.blog-card-body h3{font-size:1rem;font-weight:700;margin:6px 0 8px;line-height:1.3;font-family:var(--fh)}
.blog-card-body p{font-size:.8rem;line-height:1.55;color:var(--muted);margin-bottom:10px}


/* ===========================
   VEHICLE OWNER PAGE
   =========================== */
.vo-seamless{padding:80px var(--px);background:var(--light-bg)}
.vo-seamless-inner{max-width:1400px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.vo-seamless h2{font-family:var(--fh);font-weight:800;font-size:34px;line-height:1.25;margin-bottom:12px;letter-spacing:-.5px}
.vo-seamless > .vo-seamless-inner > div > .sub{font-size:15px;color:var(--muted);line-height:1.6;margin-bottom:28px}
.vo-seamless-img{border-radius:14px;overflow:hidden;aspect-ratio:4/3;background:var(--light-gray)}
.vo-seamless-img img{width:100%;height:100%;object-fit:cover}
.vo-feat-list{display:flex;flex-direction:column;gap:12px}
.vo-feat-item{
  background:#fff;border-radius:12px;padding:14px 18px;
  box-shadow:0 2px 8px rgba(0,0,0,.05);display:flex;gap:12px;align-items:flex-start
}
.vo-feat-item .chk{
  width:28px;height:28px;border-radius:8px;background:#fee;
  display:flex;align-items:center;justify-content:center;
  color:var(--red);flex-shrink:0;font-weight:700
}
.vo-feat-item h4{font-weight:700;font-size:14px;margin-bottom:2px}
.vo-feat-item p{font-size:12.5px;color:var(--muted);line-height:1.5;margin:0}

.vo-steps{padding:80px var(--px);background:#fff;text-align:center}
.vo-steps-inner{max-width:1100px;margin:0 auto}
.vo-steps h2{font-family:var(--fh);font-weight:800;font-size:34px;margin-bottom:8px}
.vo-steps .sub{color:var(--muted);margin-bottom:48px;font-size:15px}
.vo-steps-row{display:grid;grid-template-columns:repeat(3,1fr);gap:40px}
.vo-step-card{text-align:center}
.vo-step-num{
  width:46px;height:46px;border-radius:8px;background:var(--red);
  color:#fff;display:flex;align-items:center;justify-content:center;
  font-weight:800;font-family:var(--fh);font-size:18px;margin:0 auto 18px
}
.vo-step-card h3{font-family:var(--fh);font-weight:700;font-size:17px;margin-bottom:8px}
.vo-step-card p{font-size:13.4px;color:var(--muted);line-height:1.55}

.vo-simplified{padding:80px var(--px);background:var(--light-bg)}
.vo-simplified-inner{max-width:1400px;margin:0 auto}
.vo-simplified-title{text-align:center;margin-bottom:48px}
.vo-simplified-title h2{font-family:var(--fh);font-weight:800;font-size:34px;margin-bottom:8px}
.vo-simplified-title p{color:var(--muted);font-size:15px}
.vo-grid6{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.vo-grid-card{
  background:#fff;border-radius:14px;overflow:hidden;
  box-shadow:0 2px 8px rgba(0,0,0,.05);display:flex;flex-direction:column
}
.vo-grid-card-img{aspect-ratio:16/10;overflow:hidden;background:var(--light-gray)}
.vo-grid-card-img img{width:100%;height:100%;object-fit:cover}
.vo-grid-card-body{padding:18px 20px 20px}
.vo-grid-card-body .vic{
  width:32px;height:32px;border-radius:8px;background:#fee;
  display:flex;align-items:center;justify-content:center;
  color:var(--red);margin-bottom:10px;font-size:14px
}
.vo-grid-card-body h3{font-family:var(--fh);font-weight:700;font-size:15px;margin-bottom:6px}
.vo-grid-card-body p{font-size:12.5px;color:var(--muted);line-height:1.55}

.vo-quote{padding:80px var(--px);background:#fff;text-align:center}
.vo-quote-inner{max-width:700px;margin:0 auto;position:relative}
.vo-quote .q{font-family:var(--fh);font-size:38px;color:var(--red);line-height:1;margin-bottom:20px}
.vo-quote p{font-size:16px;line-height:1.7;color:var(--dark);margin-bottom:20px}
.vo-quote .author{font-weight:700;font-size:13px;color:var(--muted)}


/* ============================================
   📱 RESPONSIVE BREAKPOINTS 📱
   ============================================ */

/* ── Tablet landscape & small desktop ── */
@media (max-width: 1200px) {
  .hero-text{width:100%;max-width:560px}
  .hero-dash{display:none}
  .hero-bg{display:none}
  .hero{min-height:auto;padding-bottom:40px}
  .hero-inner{min-height:auto;padding-top:110px;padding-right:var(--px)}
  .hero-quote{position:relative;left:0;bottom:auto;margin-top:32px;width:100%;max-width:560px}

  .feat-grid{grid-template-columns:repeat(3,1fr);grid-template-rows:auto}
  .fc-dark{grid-row:auto;grid-column:1/-1}
  .fc-cyan{grid-column:auto}

  .integrations-grid{grid-template-columns:repeat(3,1fr)}
}

/* ── Tablet portrait ── */
@media (max-width: 960px) {
  .sec-hdr h2,.sec-hdr-left h2{font-size:32px}
  .sec-hdr p,.sec-hdr-left p{font-size:15.5px}

  .hero-text h1{font-size:48px}
  .hero-sub{font-size:15.5px}

  .pain{padding:70px var(--px)}
  .pain-grid{flex-direction:column;gap:40px}
  .pain-left{flex:1 1 auto;width:100%}

  .more{padding:70px var(--px)}
  .more-grid{flex-direction:column;gap:40px}
  .more-imgs{flex:1 1 auto;width:100%;max-width:500px;margin:0 auto}
  .more-right h2{font-size:32px}

  .feat{padding:70px var(--px)}
  .feat-grid{grid-template-columns:repeat(2,1fr)}
  .fc-dark{grid-column:1/-1}
  .fc-cyan{grid-column:auto}

  .shops{padding:70px var(--px)}
  .shops-grid{grid-template-columns:repeat(2,1fr)}

  .steps{padding:60px var(--px)}
  .steps-row{flex-wrap:wrap;gap:30px 10px;justify-content:center}
  .steps-row::before{display:none}
  .step{width:calc(50% - 20px);flex:0 0 auto}

  .testi{padding:70px var(--px)}
  .t-card{padding:50px 30px 40px 40px}
  .t-card .bq{font-size:80px;left:20px;top:12px}
  .t-card .tx{font-size:15.5px}

  .cta-sec h2{font-size:32px}

  .footer{padding:50px var(--px) 0}
  .footer-inner{grid-template-columns:1fr 1fr;gap:30px}
  .footer-brand{grid-column:1/-1}

  .pricing-cards{flex-direction:column;align-items:center}
  .price-card{max-width:500px;width:100%}

  .integrations-grid{grid-template-columns:repeat(2,1fr)}

  .app-showcase{flex-direction:column;gap:50px}
  .app-screens{flex:1 1 auto;max-width:400px;margin:0 auto}
  .app-info h2{font-size:28px}

  .shop-detail-hero .content h1{font-size:40px;line-height:1.15}
  .benefits-grid{grid-template-columns:repeat(2,1fr)}

  .split-section{flex-direction:column;gap:40px}
  .split-section.reverse{flex-direction:column}
  .split-section .visual{flex:1 1 auto;width:100%;max-width:600px;margin:0 auto}
  .split-section .text h2{font-size:28px}

  .dark-hero{padding:120px var(--px) 70px}
  .dark-hero-grid{grid-template-columns:1fr;gap:40px}
  .dark-hero h1{font-size:34px}

  .blog-featured{grid-template-columns:1fr;gap:20px}
  .blog-featured-content h2{font-size:1.3rem}
  .blog-grid3{grid-template-columns:repeat(2,1fr)}

  .vo-seamless-inner{grid-template-columns:1fr;gap:40px}
  .vo-steps-row{grid-template-columns:1fr;gap:30px;max-width:400px;margin:0 auto}
  .vo-grid6{grid-template-columns:repeat(2,1fr)}

  .content-section{padding:60px var(--px)}
}

/* ── Mobile ── */
@media (max-width: 640px) {
  :root{--px:18px}

  .sec-hdr{margin-bottom:32px}
  .sec-hdr h2,.sec-hdr-left h2{font-size:26px;line-height:1.2}
  .sec-hdr p,.sec-hdr-left p{font-size:14.5px}

  .hero-inner{padding-top:100px}
  .hero-text h1{font-size:36px;line-height:1.1}
  .hero-sub{font-size:14.5px;margin:18px 0 24px}
  .hero-quote{padding:20px 22px}
  .hero-quote .qt{font-size:14.5px}

  .page-hero{padding:110px var(--px) 60px}
  .page-hero h1{font-size:26px;line-height:1.2}
  .page-hero .subtitle{font-size:15px}

  .pain-left h2{font-size:24px}
  .pain-stats{flex-wrap:wrap;gap:12px 0}
  .ps{flex:0 0 33.33%}
  .ps .n{font-size:20px}
  .ps .l{font-size:9.5px}

  .more-right h2{font-size:26px;line-height:1.2}
  .more-imgs{height:380px;max-width:360px}
  .more-img1{width:280px;height:240px}
  .more-img2{width:220px;height:190px}

  .feat-grid{grid-template-columns:1fr}
  .fc-dark h3{font-size:22px}

  .shops-grid{grid-template-columns:1fr}

  .step{width:100%}
  .step-t{font-size:16px}

  .testi-wrap{gap:10px}
  .t-arr{width:38px;height:38px;font-size:20px}
  .t-card{padding:48px 24px 32px 28px}
  .t-card .bq{font-size:60px;left:14px;top:8px}
  .t-card .tx{font-size:14.5px;line-height:1.6}

  .cta-sec{padding:60px var(--px)}
  .cta-sec h2{font-size:26px;line-height:1.2}
  .cta-sec p{font-size:14.5px}
  .cta-btns{flex-direction:column;align-items:stretch}
  .cta-btns button{width:100%}

  .footer-inner{grid-template-columns:1fr;gap:24px}
  .footer-brand{grid-column:auto}

  .integrations-grid{grid-template-columns:1fr}
  .integ-category{padding:30px var(--px) 0}

  .app-info h2{font-size:24px}
  .app-badges{justify-content:center}

  .shop-detail-hero{padding:110px var(--px) 60px}
  .shop-detail-hero .content h1{font-size:28px;line-height:1.15}
  .shop-detail-hero .content p{font-size:15px}
  .benefits-grid{grid-template-columns:1fr}

  .split-section .text h2{font-size:24px}

  .dark-hero{padding:100px var(--px) 60px}
  .dark-hero h1{font-size:26px;line-height:1.2}
  .dark-hero .sub{font-size:14.5px}
  .dark-hero-visual{padding:16px}

  .blogs-page{padding:50px var(--px)}
  .blogs-page-title{font-size:26px}
  .blog-grid3{grid-template-columns:1fr}
  .blog-featured-content h2{font-size:1.15rem}

  .vo-seamless h2,.vo-steps h2,.vo-simplified-title h2{font-size:24px}
  .vo-grid6{grid-template-columns:1fr}

  .feat-check .txt h4{font-size:14px}
  .feat-check .txt p{font-size:12.5px}

  .btn-navy,.btn-teal,.btn-red,.btn-white,.btn-outline,.btn-outline-dark{
    padding:12px 22px;font-size:14px
  }
}

/* ── Small mobile ── */
@media (max-width: 380px) {
  .hero-text h1{font-size:30px}
  .more-imgs{height:320px;max-width:280px}
  .more-img1{width:230px;height:200px}
  .more-img2{width:180px;height:155px}
  .t-card{padding:44px 20px 28px 24px}
  .sec-hdr h2,.sec-hdr-left h2{font-size:23px}
  .pain-stats{flex-direction:column;gap:16px}
  .ps{flex:1 1 100%}
  .ps+.ps::before{display:none}
}

/* Utility */
.no-scroll{overflow:hidden}