/* ════════════════════════════════════════════
   PrimeFix v2 — styles.css
   ════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,300;0,9..144,700;0,9..144,900;1,9..144,300&family=DM+Sans:wght@300;400;500;600;700&display=swap');

:root {
  --teal:        #0EAFA0;
  --teal-light:  #E6F7F5;
  --teal-mid:    #B2E8E3;
  --blue:        #1859C5;
  --blue-light:  #EEF3FC;
  --dark:        #0D1117;
  --mid:         #3D4451;
  --soft:        #6B7280;
  --border:      #E8EAED;
  --bg:          #FAFAFA;
  --white:       #FFFFFF;
  --amber:       #F59E0B;
  --amber-light: #FFF8E7;

  --font-display: 'Fraunces', Georgia, serif;
  --font-body:    'DM Sans', sans-serif;

  --radius-sm: 8px;
  --radius-md: 14px;
  --radius-lg: 24px;
  --radius-xl: 36px;

  --shadow-sm: 0 1px 3px rgba(0,0,0,0.06);
  --shadow-md: 0 4px 16px rgba(0,0,0,0.08);
  --shadow-lg: 0 12px 40px rgba(0,0,0,0.10);
  --shadow-xl: 0 24px 64px rgba(0,0,0,0.12);
}

*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body { font-family:var(--font-body); background:var(--bg); color:var(--dark); line-height:1.6; -webkit-font-smoothing:antialiased; overflow-x:hidden; }

/* ── ANIMATIONS ── */
@keyframes fadeUp   { from{opacity:0;transform:translateY(24px)} to{opacity:1;transform:translateY(0)} }
@keyframes float    { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-8px)} }
@keyframes pulseRing{ 0%{transform:scale(1);opacity:.4} 100%{transform:scale(1.6);opacity:0} }

.anim-fade-up  { animation: fadeUp .7s cubic-bezier(.22,1,.36,1) both; }
.anim-delay-1  { animation-delay:.1s; }
.anim-delay-2  { animation-delay:.2s; }
.anim-delay-3  { animation-delay:.3s; }
.anim-delay-4  { animation-delay:.4s; }

/* ── NAV ── */
.nav {
  position:fixed; top:0; left:0; right:0; z-index:200;
  padding:0 24px; transition:all .3s;
}
.nav.scrolled {
  background:rgba(255,255,255,.95);
  backdrop-filter:blur(20px);
  border-bottom:1px solid var(--border);
  box-shadow:var(--shadow-sm);
}
.nav-inner {
  max-width:1140px; margin:0 auto; height:72px;
  display:flex; align-items:center; justify-content:space-between;
}
.logo { display:flex; align-items:center; gap:10px; text-decoration:none; }
.logo-mark {
  width:40px; height:40px; border-radius:12px;
  background:linear-gradient(135deg,var(--teal),var(--blue));
  display:flex; align-items:center; justify-content:center;
  font-family:var(--font-display); font-size:22px; font-weight:900; color:#fff;
  box-shadow:0 4px 12px rgba(14,175,160,.35); transition:transform .2s;
}
.logo:hover .logo-mark { transform:rotate(-5deg) scale(1.05); }
.logo-wordmark { font-size:19px; font-weight:700; letter-spacing:-.4px; color:var(--dark); }
.logo-wordmark span { color:var(--teal); }
.logo-wordmark-light { font-size:19px; font-weight:700; letter-spacing:-.4px; color:#fff; }
.logo-wordmark-light span { color:var(--teal-mid); }

.nav-links { display:flex; align-items:center; gap:4px; }
.nav-link { text-decoration:none; font-size:14px; font-weight:500; color:var(--soft); padding:8px 14px; border-radius:var(--radius-sm); transition:all .2s; }
.nav-link:hover { color:var(--dark); background:#F3F4F6; }
.nav-link.active { color:var(--teal); font-weight:600; }
.nav-cta { display:inline-flex; align-items:center; gap:6px; background:var(--dark); color:#fff; font-size:14px; font-weight:600; text-decoration:none; padding:10px 20px; border-radius:var(--radius-md); margin-left:8px; transition:all .2s; }
.nav-cta:hover { background:var(--teal); transform:translateY(-1px); }

/* ── HERO ── */
.hero { min-height:100vh; display:flex; align-items:center; padding:120px 24px 80px; position:relative; overflow:hidden; background:var(--white); }
.hero-bg { position:absolute; inset:0; background:radial-gradient(ellipse 80% 60% at 70% 50%,rgba(14,175,160,.07) 0%,transparent 60%),radial-gradient(ellipse 60% 40% at 20% 80%,rgba(24,89,197,.05) 0%,transparent 50%); }
.hero-dots { position:absolute; inset:0; background-image:radial-gradient(circle,rgba(0,0,0,.06) 1px,transparent 1px); background-size:32px 32px; mask-image:radial-gradient(ellipse 100% 100% at 50% 50%,black 30%,transparent 80%); }
.hero-inner { position:relative; z-index:1; max-width:1140px; margin:0 auto; display:grid; grid-template-columns:1fr 1fr; align-items:center; gap:80px; }

.hero-eyebrow { display:inline-flex; align-items:center; gap:8px; background:var(--teal-light); color:var(--teal); font-size:12px; font-weight:700; letter-spacing:1px; text-transform:uppercase; padding:6px 14px; border-radius:30px; margin-bottom:28px; }
.hero-eyebrow-dot { width:6px; height:6px; border-radius:50%; background:var(--teal); position:relative; }
.hero-eyebrow-dot::after { content:''; position:absolute; inset:-3px; border-radius:50%; border:2px solid var(--teal); animation:pulseRing 1.5s ease-out infinite; }

.hero-title { font-family:var(--font-display); font-size:clamp(44px,5.5vw,72px); font-weight:900; line-height:1.05; letter-spacing:-2px; color:var(--dark); margin-bottom:24px; }
.hero-title em { font-style:italic; font-weight:300; color:var(--teal); }
.hero-desc { font-size:17px; font-weight:400; color:var(--soft); line-height:1.75; margin-bottom:40px; max-width:460px; }
.hero-actions { display:flex; align-items:center; gap:14px; flex-wrap:wrap; margin-bottom:52px; }

.btn-primary { display:inline-flex; align-items:center; gap:8px; background:var(--dark); color:#fff; font-family:var(--font-body); font-size:15px; font-weight:600; text-decoration:none; padding:15px 28px; border-radius:var(--radius-md); box-shadow:0 4px 20px rgba(13,17,23,.25); transition:all .25s; }
.btn-primary:hover { background:var(--teal); transform:translateY(-2px); box-shadow:0 8px 28px rgba(14,175,160,.35); }
.btn-secondary { display:inline-flex; align-items:center; gap:8px; background:transparent; color:var(--dark); font-family:var(--font-body); font-size:15px; font-weight:600; text-decoration:none; padding:15px 24px; border-radius:var(--radius-md); border:1.5px solid var(--border); transition:all .2s; }
.btn-secondary:hover { border-color:var(--teal); color:var(--teal); background:var(--teal-light); }

.hero-stats { display:flex; gap:32px; flex-wrap:wrap; }
.hero-stat-num { font-family:var(--font-display); font-size:28px; font-weight:700; color:var(--dark); letter-spacing:-1px; line-height:1; }
.hero-stat-label { font-size:12px; font-weight:500; color:var(--soft); margin-top:4px; }
.hero-stat-divider { width:1px; background:var(--border); align-self:stretch; }

/* phone mockup */
.hero-right { display:flex; justify-content:center; align-items:center; position:relative; }
.phone-wrap { position:relative; animation:float 4s ease-in-out infinite; }
.phone-frame { width:260px; height:520px; background:var(--dark); border-radius:40px; padding:12px; box-shadow:var(--shadow-xl),0 0 0 1px rgba(255,255,255,.1) inset; position:relative; z-index:2; }
.phone-screen { width:100%; height:100%; border-radius:30px; background:linear-gradient(160deg,#0EAFA0 0%,#1859C5 100%); overflow:hidden; position:relative; display:flex; flex-direction:column; padding:24px 20px 20px; }
.phone-notch { width:80px; height:24px; background:var(--dark); border-radius:0 0 16px 16px; margin:0 auto 20px; }
.phone-screen-label { font-size:10px; font-weight:700; letter-spacing:2px; color:rgba(255,255,255,.5); text-transform:uppercase; margin-bottom:6px; }
.phone-screen-title { font-family:var(--font-display); font-size:22px; font-weight:700; color:#fff; margin-bottom:20px; line-height:1.2; }
.phone-service-grid { display:grid; grid-template-columns:1fr 1fr; gap:10px; margin-bottom:16px; }
.phone-svc { background:rgba(255,255,255,.15); border-radius:14px; padding:14px 12px; backdrop-filter:blur(8px); }
.phone-svc-icon { font-size:22px; margin-bottom:6px; }
.phone-svc-name { font-size:11px; font-weight:700; color:#fff; }
.phone-svc-price { font-size:10px; color:rgba(255,255,255,.6); margin-top:2px; }
.phone-booking-card { background:rgba(255,255,255,.95); border-radius:16px; padding:14px 16px; margin-top:auto; }
.phone-booking-label { font-size:9px; font-weight:700; letter-spacing:1px; color:var(--soft); text-transform:uppercase; margin-bottom:6px; }
.phone-booking-row { display:flex; align-items:center; justify-content:space-between; }
.phone-booking-name { font-size:13px; font-weight:700; color:var(--dark); }
.phone-booking-status { font-size:10px; font-weight:700; background:#DCFCE7; color:#16A34A; padding:3px 8px; border-radius:20px; }

.float-card { position:absolute; background:var(--white); border-radius:var(--radius-md); padding:12px 16px; box-shadow:var(--shadow-lg); border:1px solid var(--border); display:flex; align-items:center; gap:10px; white-space:nowrap; z-index:3; }
.float-card-1 { top:60px; left:-80px; animation:float 3.5s ease-in-out infinite; }
.float-card-2 { bottom:80px; right:-70px; animation:float 4.5s ease-in-out infinite .5s; }
.float-icon { font-size:22px; }
.float-text-sm { font-size:10px; font-weight:500; color:var(--soft); }
.float-text-lg { font-size:13px; font-weight:700; color:var(--dark); }

/* ── SECTIONS ── */
.section { padding:100px 24px; }
.section-alt  { background:var(--white); }
.section-dark { background:var(--dark); }
.section-inner { max-width:1140px; margin:0 auto; }

.section-eyebrow { display:inline-flex; align-items:center; gap:8px; font-size:11px; font-weight:700; letter-spacing:2px; text-transform:uppercase; color:var(--teal); margin-bottom:16px; }
.section-eyebrow::before { content:''; display:block; width:20px; height:2px; background:var(--teal); border-radius:2px; }
.section-eyebrow.light { color:rgba(255,255,255,.7); }
.section-eyebrow.light::before { background:rgba(255,255,255,.5); }

.section-title { font-family:var(--font-display); font-size:clamp(32px,4vw,52px); font-weight:900; letter-spacing:-1.5px; color:var(--dark); line-height:1.1; margin-bottom:48px; }
.section-title.light { color:#fff; }
.section-title em { font-style:italic; font-weight:300; color:var(--teal); }
.section-title.light em { color:rgba(255,255,255,.7); }
.section-sub { font-size:17px; font-weight:400; color:var(--soft); line-height:1.7; margin-top:-32px; margin-bottom:48px; max-width:560px; }
.section-sub.light { color:rgba(255,255,255,.65); }

/* ── FEATURES STRIP ── */
.features-strip { background:var(--dark); }
.features-strip-inner { max-width:1140px; margin:0 auto; display:grid; grid-template-columns:repeat(4,1fr); }
.feature-strip-item { padding:40px 32px; border-right:1px solid rgba(255,255,255,.06); transition:background .2s; }
.feature-strip-item:last-child { border-right:none; }
.feature-strip-item:hover { background:rgba(255,255,255,.03); }
.feature-strip-icon { font-size:28px; margin-bottom:12px; }
.feature-strip-title { font-size:15px; font-weight:700; color:#fff; margin-bottom:6px; }
.feature-strip-desc { font-size:13px; color:rgba(255,255,255,.45); line-height:1.6; }

/* ── HOW IT WORKS ── */
.steps-layout { display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center; }
.steps-list { display:flex; flex-direction:column; }
.step-item { display:flex; gap:24px; padding:28px 0; border-bottom:1px solid var(--border); transition:all .2s; }
.step-item:last-child { border-bottom:none; }
.step-item:hover .step-item-icon { background:var(--teal); color:#fff; }
.step-item-num { flex-shrink:0; font-family:var(--font-display); font-size:13px; font-weight:700; color:var(--soft); width:28px; margin-top:2px; }
.step-item-title { font-size:17px; font-weight:700; color:var(--dark); margin-bottom:6px; }
.step-item-desc { font-size:14px; color:var(--soft); line-height:1.65; }
.step-item-content { flex:1; }
.step-item-icon { flex-shrink:0; width:44px; height:44px; border-radius:var(--radius-sm); background:var(--teal-light); display:flex; align-items:center; justify-content:center; font-size:20px; transition:all .2s; }

.steps-visual { background:linear-gradient(160deg,var(--teal) 0%,var(--blue) 100%); border-radius:var(--radius-xl); padding:48px 40px; position:relative; overflow:hidden; }
.steps-visual-bg { position:absolute; inset:0; background-image:radial-gradient(circle,rgba(255,255,255,.08) 1px,transparent 1px); background-size:24px 24px; }
.steps-visual-content { position:relative; z-index:1; }
.steps-visual-label { font-size:10px; font-weight:700; letter-spacing:2px; color:rgba(255,255,255,.5); text-transform:uppercase; margin-bottom:24px; }

.booking-preview { background:rgba(255,255,255,.12); backdrop-filter:blur(12px); border-radius:var(--radius-lg); padding:24px; border:1px solid rgba(255,255,255,.2); }
.bp-header { display:flex; justify-content:space-between; align-items:center; margin-bottom:20px; }
.bp-title { font-size:16px; font-weight:700; color:#fff; }
.bp-badge { font-size:11px; font-weight:700; background:rgba(255,255,255,.2); color:#fff; padding:4px 10px; border-radius:20px; }
.bp-row { display:flex; align-items:center; gap:12px; padding:12px 0; border-bottom:1px solid rgba(255,255,255,.1); }
.bp-row:last-child { border-bottom:none; padding-bottom:0; }
.bp-row-icon { width:32px; height:32px; border-radius:8px; background:rgba(255,255,255,.15); display:flex; align-items:center; justify-content:center; font-size:16px; }
.bp-row-label { font-size:11px; color:rgba(255,255,255,.5); }
.bp-row-value { font-size:13px; font-weight:600; color:#fff; }
.bp-row-content { flex:1; }

/* ── SERVICES ── */
.services-header { display:flex; justify-content:space-between; align-items:flex-end; margin-bottom:48px; flex-wrap:wrap; gap:16px; }
.services-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(200px,1fr)); gap:16px; }

.svc-card { background:var(--white); border-radius:var(--radius-lg); padding:28px 24px; border:1.5px solid var(--border); text-align:left; transition:all .25s cubic-bezier(.22,1,.36,1); cursor:pointer; position:relative; overflow:hidden; }
.svc-card::before { content:''; position:absolute; inset:0; background:linear-gradient(135deg,var(--teal),var(--blue)); opacity:0; transition:opacity .25s; }
.svc-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-lg); border-color:transparent; }
.svc-card:hover::before { opacity:1; }
.svc-card:hover .svc-icon-wrap { background:rgba(255,255,255,.2); }
.svc-card:hover .svc-name,
.svc-card:hover .svc-arrow { color:#fff; }
.svc-card:hover .svc-desc { color:rgba(255,255,255,.7); }
.svc-card:hover .svc-price { background:rgba(255,255,255,.2); color:#fff; }
.svc-card.coming-soon { opacity:.5; cursor:default; }
.svc-card.coming-soon:hover { transform:none; box-shadow:none; }
.svc-card.coming-soon:hover::before { opacity:0; }

.svc-card-inner { position:relative; z-index:1; }
.svc-top { display:flex; justify-content:space-between; align-items:flex-start; }
.svc-icon-wrap { width:52px; height:52px; border-radius:var(--radius-md); background:var(--teal-light); display:flex; align-items:center; justify-content:center; font-size:26px; margin-bottom:16px; transition:background .25s; }
.svc-arrow { color:var(--soft); font-size:18px; transition:color .25s; margin-top:4px; }
.svc-name { font-size:16px; font-weight:700; color:var(--dark); margin-bottom:4px; transition:color .25s; }
.svc-desc { font-size:13px; color:var(--soft); line-height:1.55; margin-bottom:16px; transition:color .25s; }
.svc-price { display:inline-block; background:var(--teal-light); color:var(--teal); font-size:12px; font-weight:700; border-radius:20px; padding:4px 12px; transition:all .25s; }
.svc-soon-badge { display:inline-block; background:var(--amber-light); color:var(--amber); font-size:11px; font-weight:700; border-radius:20px; padding:4px 12px; }

/* ── TESTIMONIALS ── */
.trust-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.trust-card { background:var(--bg); border-radius:var(--radius-lg); padding:32px 28px; border:1.5px solid var(--border); transition:all .2s; }
.trust-card:hover { transform:translateY(-3px); box-shadow:var(--shadow-md); border-color:var(--teal-mid); }
.trust-stars { color:var(--amber); font-size:14px; letter-spacing:2px; margin-bottom:16px; }
.trust-quote { font-family:var(--font-display); font-size:17px; font-weight:300; font-style:italic; color:var(--dark); line-height:1.65; margin-bottom:24px; }
.trust-author { display:flex; align-items:center; gap:12px; }
.trust-avatar { width:40px; height:40px; border-radius:50%; background:linear-gradient(135deg,var(--teal),var(--blue)); display:flex; align-items:center; justify-content:center; font-family:var(--font-display); font-size:18px; font-weight:700; color:#fff; }
.trust-author-name { font-size:14px; font-weight:700; color:var(--dark); }
.trust-author-loc  { font-size:12px; color:var(--soft); }

/* ── DOWNLOAD ── */
.download-layout { display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center; }
.download-app-btns { display:flex; flex-direction:column; gap:14px; max-width:320px; }

.btn-store { display:flex; align-items:center; gap:16px; background:var(--dark); color:#fff; text-decoration:none; padding:16px 24px; border-radius:var(--radius-md); border:1.5px solid rgba(255,255,255,.1); transition:all .25s; }
.btn-store:hover { background:#1A222E; transform:translateX(4px); box-shadow:var(--shadow-lg); }
.store-icon-wrap { width:44px; height:44px; border-radius:var(--radius-sm); background:rgba(255,255,255,.1); display:flex; align-items:center; justify-content:center; font-size:24px; flex-shrink:0; }
.store-label-sm { font-size:11px; color:rgba(255,255,255,.5); font-weight:500; }
.store-label-lg { font-size:17px; font-weight:700; color:#fff; letter-spacing:-.3px; }
.store-arrow { margin-left:auto; color:rgba(255,255,255,.3); font-size:18px; transition:color .2s; }
.btn-store:hover .store-arrow { color:var(--teal); }

.apk-note { font-size:12px; color:var(--soft); margin-top:8px; padding:10px 14px; background:var(--bg); border-radius:var(--radius-sm); border:1px solid var(--border); line-height:1.5; }

.download-qr-wrap { background:var(--white); border-radius:var(--radius-xl); padding:40px; box-shadow:var(--shadow-xl); text-align:center; border:1.5px solid var(--border); min-height:280px; display:flex; flex-direction:column; align-items:center; justify-content:center; }
.download-qr-title { font-family:var(--font-display); font-size:20px; font-weight:700; color:var(--dark); margin-bottom:8px; }
.download-qr-sub { font-size:14px; color:var(--soft); line-height:1.5; }

/* ── CONTACT ── */
.contact-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(260px,1fr)); gap:20px; }
.contact-card { background:var(--white); border-radius:var(--radius-lg); padding:36px 32px; border:1.5px solid var(--border); text-decoration:none; display:block; transition:all .25s; }
.contact-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-lg); border-color:var(--teal); }
.contact-icon-wrap { width:56px; height:56px; border-radius:var(--radius-md); background:var(--teal-light); display:flex; align-items:center; justify-content:center; font-size:28px; margin-bottom:20px; }
.contact-title { font-size:18px; font-weight:700; color:var(--dark); margin-bottom:8px; }
.contact-desc  { font-size:14px; color:var(--soft); line-height:1.65; margin-bottom:20px; }
.contact-action { font-size:14px; font-weight:700; color:var(--teal); }
.contact-action::after { content:' →'; }

/* ── FAQ ── */
.faq-list { max-width:760px; margin:0 auto; }
.faq-item { border-bottom:1px solid var(--border); }
.faq-item:first-child { border-top:1px solid var(--border); }
.faq-question { width:100%; background:none; border:none; cursor:pointer; display:flex; justify-content:space-between; align-items:center; padding:24px 0; gap:16px; font-family:var(--font-body); font-size:16px; font-weight:700; color:var(--dark); text-align:left; transition:color .2s; }
.faq-question:hover { color:var(--teal); }
.faq-chevron { width:28px; height:28px; border-radius:50%; background:var(--bg); flex-shrink:0; display:flex; align-items:center; justify-content:center; font-size:12px; color:var(--soft); transition:all .3s; border:1px solid var(--border); }
.faq-item.open .faq-chevron { background:var(--teal); color:#fff; border-color:var(--teal); transform:rotate(180deg); }
.faq-answer { font-size:15px; color:var(--soft); line-height:1.75; max-height:0; overflow:hidden; transition:max-height .35s ease,padding .35s ease; }
.faq-item.open .faq-answer { max-height:300px; padding-bottom:24px; }

/* ── PAGE HERO ── */
.page-hero { background:var(--dark); padding:140px 24px 80px; position:relative; overflow:hidden; text-align:center; }
.page-hero-bg { position:absolute; inset:0; background:radial-gradient(ellipse 80% 60% at 50% 0%,rgba(14,175,160,.15) 0%,transparent 60%); }
.page-hero-inner { position:relative; z-index:1; max-width:680px; margin:0 auto; }
.page-hero-title { font-family:var(--font-display); font-size:clamp(36px,5vw,56px); font-weight:900; color:#fff; letter-spacing:-1.5px; margin-bottom:14px; }
.page-hero-sub { font-size:17px; color:rgba(255,255,255,.55); }

/* ── PRIVACY ── */
.policy-wrap { max-width:760px; margin:0 auto; }
.policy-intro { font-size:16px; color:var(--soft); line-height:1.8; background:var(--teal-light); border-left:4px solid var(--teal); padding:24px 28px; border-radius:0 var(--radius-md) var(--radius-md) 0; margin-bottom:48px; }
.policy-block { margin-bottom:40px; }
.policy-block h2 { font-family:var(--font-display); font-size:22px; font-weight:700; color:var(--dark); margin-bottom:14px; letter-spacing:-.5px; }
.policy-block p { font-size:15px; color:var(--soft); line-height:1.8; margin-bottom:14px; }
.policy-block ul { padding-left:0; list-style:none; display:flex; flex-direction:column; gap:10px; margin-bottom:14px; }
.policy-block ul li { font-size:15px; color:var(--soft); line-height:1.7; padding-left:22px; position:relative; }
.policy-block ul li::before { content:'—'; position:absolute; left:0; color:var(--teal); font-weight:700; }
.inline-link { color:var(--blue); font-weight:600; text-decoration:none; }
.inline-link:hover { text-decoration:underline; }
.contact-info-box { background:var(--bg); border-radius:var(--radius-md); padding:24px 28px; display:flex; flex-direction:column; gap:14px; margin-top:16px; border:1px solid var(--border); }
.contact-info-row { display:flex; align-items:center; gap:16px; font-size:14px; font-weight:500; color:var(--soft); }
.contact-info-row span:first-child { min-width:100px; font-weight:600; }

/* ── FOOTER ── */
.footer { background:var(--dark); padding:64px 24px 40px; }
.footer-inner { max-width:1140px; margin:0 auto; }
.footer-top { display:grid; grid-template-columns:2fr 1fr 1fr; gap:60px; margin-bottom:60px; }
.footer-brand-desc { font-size:14px; color:rgba(255,255,255,.4); line-height:1.7; margin-top:16px; max-width:280px; }
.footer-col-title { font-size:12px; font-weight:700; letter-spacing:1.5px; text-transform:uppercase; color:rgba(255,255,255,.35); margin-bottom:20px; }
.footer-col-links { display:flex; flex-direction:column; gap:12px; }
.footer-col-links a { text-decoration:none; font-size:14px; font-weight:500; color:rgba(255,255,255,.5); transition:color .2s; }
.footer-col-links a:hover { color:#fff; }
.footer-bottom { padding-top:32px; border-top:1px solid rgba(255,255,255,.07); display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:12px; }
.footer-copy { font-size:13px; color:rgba(255,255,255,.25); }
.footer-tagline { font-size:13px; color:rgba(255,255,255,.2); font-style:italic; }

/* ── RESPONSIVE ── */
@media (max-width:960px) {
  .hero-inner { grid-template-columns:1fr; gap:60px; text-align:center; }
  .hero-right { display:none; }
  .hero-desc,.hero-actions,.hero-stats { max-width:100%; justify-content:center; }
  .steps-layout,.download-layout { grid-template-columns:1fr; gap:48px; }
  .trust-grid { grid-template-columns:1fr; }
  .footer-top { grid-template-columns:1fr; gap:40px; }
  .features-strip-inner { grid-template-columns:1fr 1fr; }
}
@media (max-width:640px) {
  .nav-cta { display:none; }
  .nav-link { padding:8px 10px; font-size:13px; }
  .section { padding:72px 20px; }
  .features-strip-inner { grid-template-columns:1fr; }
  .feature-strip-item { border-right:none; border-bottom:1px solid rgba(255,255,255,.06); }
  .services-grid { grid-template-columns:1fr 1fr; }
  .footer-bottom { flex-direction:column; text-align:center; }
}
