:root{
  --ink:#0f172a;
  --muted:#475569;
  --line:rgba(226,232,240,.9);
  --brand:#BFF746;
  --brand2:#2F4B2A;
  --soft:#BFF746;
  --card:#ffffff;
  --shadow: 0 18px 50px rgba(15,23,42,.10);
  --r:22px;
  --max: 1260px;
}
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, "Apple Color Emoji","Segoe UI Emoji";
  color:var(--ink);
  background: linear-gradient(180deg, #ffffff 0%, #f2faf4 100%);
  line-height:1.7;
}
a{color:inherit}
.wrap{max-width:var(--max); margin:0 auto; padding:0 18px}

/* Transparent overlay header */
.topbar{
  position:fixed; top:0; left:0; right:0; z-index:60;
  background:transparent;
}
.topbar.scrolled{
  background: rgba(255,255,255,.62);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  border-bottom: 1px solid rgba(226,232,240,.70);
  box-shadow: 0 18px 54px rgba(15,23,42,.14);
}
.topbar .inner{
  display:flex; align-items:center; justify-content:space-between; gap:14px;
  padding:14px 0;
}
.brand{display:flex; align-items:center; gap:10px; text-decoration:none; font-weight:900}
.brand img{height:34px; filter: drop-shadow(0 6px 12px rgba(0,0,0,.08));}
.badge{
  font-size:12px; color:var(--muted);
  border:1px solid var(--line);
  padding:6px 10px; border-radius:14px;
  background:rgba(255,255,255,.82);
  white-space:nowrap;
}
.btn{
  display:inline-flex; align-items:center; justify-content:center;
  padding:14px 20px;
  border-radius:14px;
  text-decoration:none;
  font-weight:900;
  font-size:14.5px;
  border:1px solid transparent;
  transition:.18s ease;
}
.btn.primary{
  background: #BFF746;
  color:#fff;
  border:1px solid #BFF746;
  box-shadow: 0 10px 20px rgba(0,0,0,.14);
}
.btn.primary:hover{
  transform: translateY(-2px);
  box-shadow: 0 18px 34px #BFF746;
}
.btn.ghost{
  background:rgba(255,255,255,.82);
  border-color:var(--line);
}
.btn.ghost:hover{background:#fff}

/* Slider hero */
.hero{
  margin-bottom: 110px;
  position:relative;
  height:min(92vh, 820px);
  min-height:620px;
  overflow:hidden;
}
.slide{
  position:absolute; inset:0;
  opacity:0;
  transition: opacity .8s ease;
}
.slide.active{opacity:1}
.slide img{
  width:100%; height:100%;
  object-fit:cover;
  display:block;
  filter:saturate(1.02) contrast(1.02);
}
.hero::after{
  content:"";
  position:absolute; inset:0;
  background: linear-gradient(90deg, rgba(0,0,0,.85) 0%, rgba(0,0,0,.75) 45%, rgba(0,0,0,.45) 75%, rgba(0,0,0,.25) 100%);
}
.hero::before{
  content:"";
  position:absolute; inset:0;
  background: radial-gradient(900px 520px at 0% 30%, #BFF746, transparent 55%);
  pointer-events:none;
}
.hero-content{
  position:relative;
  z-index:2;
  padding-top:92px;
  height:100%;
  display:flex;
  align-items:center;
}
.kicker{ color:#ffffff; border-color: rgba(255,255,255,.4); background: rgba(0,0,0,.35); 
  display:inline-flex; align-items:center; gap:10px;
  background:#BFF746;
  border:1px solid #BFF746;
  padding:8px 12px;
  border-radius:14px;
  font-weight:900;
  color:var(--brand2);
  font-size:13px;
}
.kicker i{width:7px;height:7px;border-radius:14px;background:var(--brand); display:inline-block}
h1{ color:#ffffff; 
  margin:14px 0 10px;
  font-size: clamp(30px, 4.6vw, 52px);
  line-height:1.06;
  letter-spacing:-1px;
  max-width: 880px;
}
.sub{ color:#ffffff; 
  max-width: 840px;
  color:var(--muted);
  font-size: clamp(16px, 2.25vw, 18.5px);
  margin:0 0 18px;
}
.hero-actions{display:flex; gap:10px; flex-wrap:wrap; align-items:center}
.pills{margin-top:14px; display:flex; flex-wrap:wrap; gap:10px}
.pill{
  font-size:12px; color:var(--muted);
  border:1px solid var(--line);
  padding:6px 10px; border-radius:14px;
  background:rgba(255,255,255,.84);
  white-space:nowrap;
}
.dots{
  position:absolute; left:50%; bottom:18px;
  transform:translateX(-50%);
  display:flex; gap:10px;
  z-index:5;
}
.dot{
  width:10px; height:10px; border-radius:14px;
  border:1px solid rgba(15,23,42,.25);
  background:rgba(255,255,255,.7);
  cursor:pointer;
}
.dot.active{background:#BFF746; border-color:#BFF746}

/* Layout */
main{padding: 34px 0 64px}
.grid{
  display:grid;
  grid-template-columns: 1.35fr .65fr;
  gap:22px;
  align-items:start;
}
@media (max-width: 980px){ .grid{grid-template-columns:1fr} }
.card{
  background:var(--card);
  border:1px solid var(--line);
  border-radius: var(--r);
  box-shadow: var(--shadow);
}
.article{padding:34px 34px 24px}
.article h2{margin:34px 0 12px; font-size:22px; letter-spacing:-.2px}
.article p{margin:10px 0}
.muted{color:var(--muted)}
.hr{height:1px;background:rgba(226,232,240,.9);border:0;margin:26px 0}
.callout{
  margin:16px 0;
  background: linear-gradient(180deg, #BFF746, rgba(255,255,255,1));
  border:1px solid #BFF746;
  border-radius: 18px;
  padding:16px;
}
.list{
  margin:12px 0 0;
  padding:0;
  list-style:none;
  display:grid;
  gap:10px;
}
.list li{
  display:flex; gap:10px; align-items:flex-start;
  padding:12px 12px;
  border:1px solid rgba(226,232,240,.9);
  border-radius:16px;
  background:#fff;
}
.check{
  flex:0 0 auto;
  width:22px;height:22px;border-radius:14px;
  background:#BFF746;
  border:1px solid #BFF746;
  display:grid; place-items:center;
  color:var(--brand2);
  font-weight:950;
  margin-top:2px;
}
.aside{padding:16px; position:sticky; top:88px}
@media (max-width:980px){ .aside{position:static} }
.aside h3{
  margin:8px 6px 12px;
  font-size:15px;
  color:var(--muted);
  letter-spacing:.22px;
  text-transform:uppercase;
}
.product{
  display:grid;
  grid-template-columns: 92px 1fr;
  gap:12px;
  padding:12px;
  border:1px solid rgba(226,232,240,.9);
  border-radius:18px;
  background:#fff;
  margin:10px 6px;
}
.thumb{
  width:92px; height:92px;
  border-radius:16px;
  overflow:hidden;
  border:1px solid rgba(226,232,240,.9);
  background:#f8fafc;
  display:grid; place-items:center;
}
.thumb img{width:100%; height:100%; object-fit:cover; display:block}
.p-title{margin:0; font-size:14px; line-height:1.25; letter-spacing:-.2px}
.p-price{margin:6px 0 8px; font-weight:950; color:var(--brand2)}
.p-mini{margin:0 0 10px; color:var(--muted); font-size:12.5px}
.p-actions{display:flex; gap:10px; flex-wrap:wrap}
.p-actions .btn{padding:10px 12px; font-size:13px}

/* Footer */
footer{
  padding:22px 0 46px;
  color:var(--muted);
  font-size:12.5px;
  border-top:1px solid rgba(226,232,240,.9);
  background:#fff;
}
.footergrid{
  display:flex; gap:14px; flex-wrap:wrap; align-items:center; justify-content:space-between;
}
.footerlinks{display:flex; gap:12px; flex-wrap:wrap}
.footerlinks a{text-decoration:none; border-bottom:1px dotted rgba(71,85,105,.6)}
.footerlinks a:hover{border-bottom-color:#BFF746}
.notice{
  font-size:13px;
  color:var(--muted);
  padding:10px 12px;
  border:1px dashed #BFF746;
  border-radius:16px;
  background:#BFF746;
}

.hero-content .pill{
  color:#ffffff;
  border-color: rgba(255,255,255,.4);
  background: rgba(0,0,0,.35);
}
.hero-content .badge{
  color:#ffffff;
  border-color: rgba(255,255,255,.4);
  background: rgba(0,0,0,.35);
}

.hero-content h1,
.hero-content .sub,
.hero-content .kicker,
.hero-content .pill,
.hero-content .badge,
.hero-content a,
.hero-content span{
  color:#ffffff !important;
}

.hero-content .kicker,
.hero-content .pill,
.hero-content .badge{
  border-color: rgba(255,255,255,.6) !important;
  background: rgba(0,0,0,.45) !important;
}

/* Scroll reveal animations */
.reveal{
  opacity:1;
  transform:none;
}
.js .reveal{
  opacity:0;
  transform: translateY(16px);
  transition: opacity .7s ease, transform .7s ease;
  will-change: opacity, transform;
}
.js .reveal.is-visible{
  opacity:1;
  transform:none;
}
.reveal.delay-1{transition-delay:.06s}
.reveal.delay-2{transition-delay:.12s}
.reveal.delay-3{transition-delay:.18s}

.social{
  display:flex;
  align-items:center;
  gap:10px;
}
.social-link{
  width:36px; height:36px;
  display:inline-flex;
  align-items:center; justify-content:center;
  border-radius:14px;
  border:1px solid rgba(226,232,240,.9);
  background: linear-gradient(180deg, rgba(255,255,255,.95), #BFF746);
  box-shadow: 0 10px 24px rgba(15,23,42,.08);
  text-decoration:none;
  transition: transform .18s ease;
}
.social-link:hover{ transform: translateY(-2px); }


/* Dark mode (toggle adds .dark on <body>) */
body.dark{
  background: #212121 !important;
  color: #ffffff;
}
body.dark .topbar.scrolled{
  background: rgba(33,33,33,.62);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  border-bottom-color: rgba(255,255,255,.10);
  box-shadow: 0 22px 60px rgba(0,0,0,.60);
}
body.dark .badge,
body.dark .pill,
body.dark .kicker{
  background: rgba(255,255,255,.08) !important;
  border-color: rgba(255,255,255,.16) !important;
  color:#ffffff !important;
}
body.dark .btn.ghost{
  background: rgba(255,255,255,.08);
  border-color: rgba(255,255,255,.16);
  color:#ffffff;
}
body.dark .btn.ghost:hover{ background: rgba(255,255,255,.12); }
body.dark .card{
  background: rgba(33,33,33,.72);
  border-color: rgba(255,255,255,.10);
  box-shadow: 0 18px 50px rgba(0,0,0,.45);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}
body.dark .thumb{ background:#1b1b1b; border-color: rgba(255,255,255,.10); }
body.dark .muted{ color: rgba(255,255,255,.74); }
body.dark .list li{
  background:#212121;
  border-color: rgba(255,255,255,.10);
}
body.dark .table{
  border-color: rgba(255,255,255,.10);
}
body.dark .table th{
  background:#1b1b1b;
  color: rgba(255,255,255,.75);
}
body.dark .table td{
  border-bottom-color: rgba(255,255,255,.10);
}
body.dark footer{
  background:#212121;
  border-top-color: rgba(255,255,255,.10);
}
body.dark .footerlinks a{ color: rgba(255,255,255,.78); }
body.dark .notice{
  background: rgba(255,255,255,.06);
  border-color: rgba(255,255,255,.18);
  color: rgba(255,255,255,.74);
}
body.dark .social-link{
  border-color: rgba(255,255,255,.12);
  background: linear-gradient(180deg, rgba(255,255,255,.10), #BFF746);
}
/* Dark mode switch */
.theme-switch{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:8px 10px;
  border-radius: 14px;
  border:1px solid rgba(226,232,240,.9);
  background: rgba(255,255,255,.72);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}
.topbar.scrolled .theme-switch{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:8px 10px;
  border-radius: 14px;
  border:1px solid rgba(226,232,240,.9);
  background: rgba(255,255,255,.72);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}
body.dark .theme-switch{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:8px 10px;
  border-radius: 14px;
  border:1px solid rgba(226,232,240,.9);
  background: rgba(255,255,255,.72);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}
.theme-label{ font-size:12px; color: rgba(71,85,105,1); font-weight:800; }
body.dark .theme-label{ color: rgba(255,255,255,.82); }
.switch{
  position:relative;
  width:44px;
  height:24px;
  flex:0 0 auto;
}
.switch input{ opacity:0; width:0; height:0; }
.slider{
  position:absolute; inset:0;
  border-radius:14px;
  background: rgba(15,23,42,.12);
  border:1px solid rgba(15,23,42,.14);
  transition:.2s ease;
}
.slider:before{
  content:"";
  position:absolute;
  height:18px; width:18px;
  left:3px; top:50%;
  transform: translateY(-50%);
  border-radius:14px;
  background:#fff;
  box-shadow: 0 6px 16px rgba(15,23,42,.20);
  transition:.2s ease;
}
.switch input:checked + .slider{
  background: #BFF746;
  border-color: #BFF746;
}
.switch input:checked + .slider:before{
  transform: translate(20px,-50%);
}
body.dark .slider{
  background: rgba(255,255,255,.10);
  border-color: rgba(255,255,255,.16);
}


body.dark .callout{
  background: rgba(33,33,33,.55) !important;
  border:1px solid rgba(255,255,255,.10) !important;
  color:#ffffff !important;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  box-shadow: 0 18px 44px rgba(0,0,0,.45);
  border-left: 4px solid #BFF746;
}

/* Smooth theme transitions */
body, .card, footer, .topbar.scrolled, .badge, .pill, .kicker, .btn, .list li, .callout, .notice, .social-link, .table, .table th, .table td{
  transition: background-color .25s ease, color .25s ease, border-color .25s ease, box-shadow .25s ease;
}


/* Dark mode Quick Picks adjustments */
body.dark .p-title{
  color:#000000 !important;
}
body.dark .p-actions .btn{
  background:#000000 !important;
  color:#ffffff !important;
  border-color:#000000 !important;
}
body.dark .p-actions .btn:hover{
  background:#111111 !important;
}

/* Quick Picks hover elevate */
.product{
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.product:hover{
  transform: translateY(-4px);
  box-shadow: 0 18px 40px rgba(15,23,42,.12);
  border-color: #BFF746;
}
body.dark .product:hover{
  box-shadow: 0 22px 44px rgba(0,0,0,.55);
  border-color: #BFF746;
}

.header-cta{ margin-right:8px; }
@media(max-width:520px){
  .header-cta{ margin-right:8px; } /* keep header clean on very small screens */
}

.mode-label{
  font-size:12.5px;
  font-weight:900;
  letter-spacing:.2px;
  color: rgba(15,23,42,.78);
  min-width: 44px;
  text-align: right;
}
body.dark .mode-label{
  color: rgba(255,255,255,.85);
}

/* Switch icons */
.slider{
  position:absolute; inset:0;
  border-radius:14px;
  background: rgba(15,23,42,.12);
  border:1px solid rgba(15,23,42,.14);
  transition:.2s ease;
}
.slider:after{
  content:"☀";
  position:absolute;
  right:7px;
  top:50%;
  transform: translateY(-50%);
  font-size:12px;
  opacity:.75;
}
.switch input:checked + .slider:after{
  content:"☾";
  right:9px;
  opacity:.85;
}
body.dark .slider:after{
  opacity:.85;
}

.section-title{font-size:clamp(28px,3.4vw,44px);letter-spacing:-.9px;line-height:1.12;margin:0 0 10px}

.section-sub{margin:0;color:var(--muted);font-size:17px;max-width:860px}
/* Minimal productivity sections */
.section{padding: 86px 0}
.section-compact{padding: 28px 0 12px}
.section-head{margin-bottom:22px}
.flow-bar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  border:1px solid rgba(226,232,240,.9);
  background: rgba(255,255,255,.70);
  border-radius: 18px;
  padding: 14px 16px;
  box-shadow: 0 12px 34px rgba(15,23,42,.06);
}
.flow-item{display:flex; align-items:center; gap:12px; min-width: 0}
.flow-icon{
  width:30px; height:30px; border-radius:10px;
  background: #BFF746;
  border:1px solid #BFF746;
  display:grid; place-items:center;
  color: #BFF746;
  font-weight:900;
  flex: 0 0 auto;
}
.flow-title{font-weight:950; letter-spacing:-.2px; font-size:13.5px}
.flow-sub{color: var(--muted); font-size:12.5px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; max-width: 220px}
.flow-sep{width:1px; height:30px; background: rgba(226,232,240,.9)}
@media(max-width: 980px){
  .flow-bar{flex-direction:column; align-items:stretch}
  .flow-sep{display:none}
  .flow-sub{max-width:100%; white-space:normal}
}

.preview-grid{
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap: 18px;
  align-items:stretch;
}
@media(max-width:980px){ .preview-grid{grid-template-columns:1fr} }
.preview-visual, .preview-copy{border-radius: 22px}
.preview-visual{padding:18px}
.preview-caption{font-size:12.5px; margin-top:10px}
.preview-mock{
  position:relative;
  height: 260px;
  border-radius: 18px;
  border:1px solid rgba(226,232,240,.9);
  background: linear-gradient(180deg, rgba(255,255,255,.92), #BFF746);
  overflow:hidden;
}
.pm{
  position:absolute;
  border-radius: 16px;
  border:1px solid rgba(226,232,240,.9);
  background:#fff;
  box-shadow: 0 14px 32px rgba(15,23,42,.10);
}
.pm-1{width:56%; height:70%; left:8%; top:14%}
.pm-2{width:44%; height:56%; right:10%; top:10%; opacity:.96}
.pm-3{width:40%; height:48%; right:18%; bottom:12%; opacity:.92}

.preview-copy{padding:18px}
.h3{margin:0 0 12px; letter-spacing:-.2px}
.mini-list{list-style:none; padding:0; margin:0; display:grid; gap:10px}
.mini-list li{display:flex; gap:10px; align-items:flex-start; color: var(--ink)}
.mini-dot{width:7px;height:7px;border-radius:999px;background: #BFF746; margin-top:7px; flex:0 0 auto}
.mini-callout{
  margin-top:14px;
  padding:12px 12px;
  border-radius: 16px;
  border:1px solid rgba(226,232,240,.9);
  background: rgba(255,255,255,.72);
  color: var(--muted);
}

/* Quick Picks: minimal productivity card */
.bestfor{margin:0 0 10px; font-size:12.5px; color: var(--muted)}
.p-actions{gap:10px}
.p-actions .btn{padding:10px 12px; font-size:13.5px; border-radius: 12px}
.p-actions .btn.ghost{background: transparent; border-color: rgba(226,232,240,.9)}
.p-actions .btn.primary{box-shadow: 0 10px 18px rgba(0,0,0,.14)}

/* Dark mode tweaks for new sections */
body.dark .flow-bar,
body.dark .preview-mock,
body.dark .mini-callout{
  background: rgba(33,33,33,.72);
  border-color: rgba(255,255,255,.10);
}
body.dark .flow-sep{ background: rgba(255,255,255,.10) }
body.dark .pm{ background: rgba(255,255,255,.06); border-color: rgba(255,255,255,.10); box-shadow: 0 18px 44px rgba(0,0,0,.55) }
body.dark .mini-list li{ color:#fff }
body.dark .flow-sub, body.dark .bestfor, body.dark .mini-callout{ color: rgba(255,255,255,.74) }
body.dark .p-actions .btn.ghost{ border-color: rgba(255,255,255,.16); color:#fff }
/* Minimal header on scroll */
.topbar.scrolled .badge{display:none}
@media(max-width:760px){
  .topbar .badge{display:none}
}

/* Hero parallax */
.hero{
  position:relative;
  --shift: 0px;
}
.hero-parallax{
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    radial-gradient(900px 520px at 18% calc(10% + var(--shift)), #BFF746, transparent 60%),
    radial-gradient(780px 420px at 86% calc(20% + var(--shift)), #BFF746, transparent 58%),
    linear-gradient(180deg, rgba(255,255,255,.08), #BFF746);
  transform: translateY(calc(var(--shift) * .25));
  transition: background-position .4s ease;
}
.hero-floats .float{
  position:absolute;
  border-radius: 999px;
  border:1px solid rgba(255,255,255,.18);
  background: rgba(255,255,255,.08);
  box-shadow: 0 24px 60px rgba(0,0,0,.12);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  animation: floaty 10s ease-in-out infinite;
}
.hero-floats .f1{ width:120px; height:120px; left: 8%; top: 34%; animation-duration: 12s; opacity:.55}
.hero-floats .f2{ width:90px; height:90px; right: 10%; top: 18%; animation-duration: 14s; opacity:.45}
.hero-floats .f3{ width:140px; height:140px; right: 18%; bottom: 14%; animation-duration: 16s; opacity:.35}
@keyframes floaty{
  0%,100%{ transform: translateY(0) translateX(0); }
  50%{ transform: translateY(-14px) translateX(8px); }
}
body.dark .hero-parallax{
  background:
    radial-gradient(900px 520px at 18% calc(10% + var(--shift)), #BFF746, transparent 60%),
    radial-gradient(780px 420px at 86% calc(20% + var(--shift)), #BFF746, transparent 58%),
    linear-gradient(180deg, rgba(0,0,0,.18), #BFF746);
}
body.dark .hero-floats .float{
  border-color: rgba(255,255,255,.10);
  background: rgba(255,255,255,.05);
  box-shadow: 0 28px 70px rgba(0,0,0,.55);
}
/* Quick Picks premium */
.product{
  position:relative;
  overflow:hidden;
}
.product .thumb{
  transition: transform .35s ease;
}
.product:hover .thumb{
  transform: scale(1.03);
}
.product:hover{
  box-shadow: 0 20px 46px rgba(15,23,42,.12);
  border-color: #BFF746;
}
.product:after{
  content:"";
  position:absolute;
  inset:-40px;
  background: radial-gradient(420px 220px at 30% 0%, #BFF746, transparent 60%);
  opacity:0;
  transition: opacity .35s ease;
  pointer-events:none;
}
.product:hover:after{ opacity:1; }

.badge-pop{
  position:absolute;
  top:12px; right:12px;
  padding:6px 10px;
  border-radius:999px;
  font-size:12px;
  font-weight:900;
  letter-spacing:.2px;
  color: #BFF746;
  background: #BFF746;
  border:1px solid #BFF746;
}
body.dark .badge-pop{
  color: rgba(255,255,255,.92);
  background: #BFF746;
  border-color: #BFF746;
}
/* Results + compare + trust */
.results-grid{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}
@media(max-width:980px){ .results-grid{grid-template-columns:1fr} }
.result-card{
  border-radius: 22px;
  border:1px solid rgba(226,232,240,.9);
  background:#fff;
  padding: 18px;
  box-shadow: 0 14px 36px rgba(15,23,42,.06);
}
.result-card .emoji{font-size:22px; margin-bottom:10px}
.result-card h3{margin:0 0 8px; letter-spacing:-.3px}
.result-card p{margin:0; color: var(--muted)}

.compare-grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}
@media(max-width:980px){ .compare-grid{grid-template-columns:1fr} }
.compare-card{
  border-radius: 22px;
  border:1px solid rgba(226,232,240,.9);
  background:#fff;
  padding: 18px;
  box-shadow: 0 14px 36px rgba(15,23,42,.06);
}
.compare-title{font-weight:950; letter-spacing:-.3px; margin-bottom:12px}
.compare-list{margin:0; padding-left: 18px; color: var(--muted); display:grid; gap:8px}

.trust-bar{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
  padding: 14px;
  border-radius: 22px;
  border:1px solid rgba(226,232,240,.9);
  background: rgba(255,255,255,.72);
  box-shadow: 0 12px 34px rgba(15,23,42,.06);
}
@media(max-width:980px){ .trust-bar{grid-template-columns:1fr 1fr} }
@media(max-width:520px){ .trust-bar{grid-template-columns:1fr} }
.trust-item{display:flex; gap:10px; align-items:center}
.trust-ic{font-size:18px}
.trust-title{font-weight:950; letter-spacing:-.2px; font-size:13.5px}
.trust-sub{color: var(--muted); font-size:12.5px}

body.dark .result-card,
body.dark .compare-card{
  background: rgba(33,33,33,.72);
  border-color: rgba(255,255,255,.10);
  box-shadow: 0 18px 44px rgba(0,0,0,.55);
}
body.dark .result-card p,
body.dark .compare-list,
body.dark .trust-sub{ color: rgba(255,255,255,.74) }
body.dark .trust-bar{
  background: rgba(33,33,33,.72);
  border-color: rgba(255,255,255,.10);
}

/* Enhanced preview gallery */
.preview-visual{
  padding: 24px;
  min-height: 520px;
}

.preview-gallery{
  display:grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 18px;
}

.preview-img{
  border-radius: 18px;
  overflow:hidden;
  box-shadow: 0 18px 40px rgba(0,0,0,.12);
  transition: transform .4s ease, box-shadow .4s ease;
}

.preview-img img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

.preview-img:hover{
  transform: scale(1.02);
  box-shadow: 0 24px 60px #BFF746;
}

@media(max-width:980px){
  .preview-gallery{
    grid-template-columns: 1fr;
  }
}
/* Payment trust badges */
.paytrust{
  margin: -48px auto 42px;
  max-width: var(--max);
  padding: 14px 16px;
  border-radius: 22px;
  border:1px solid rgba(226,232,240,.9);
  background: rgba(255,255,255,.72);
  box-shadow: 0 12px 34px rgba(15,23,42,.06);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 14px;
}
.paytrust-title{
  font-weight:950;
  letter-spacing:-.2px;
  font-size:13.5px;
}
.paytrust-sub{
  color: var(--muted);
  font-size:12.5px;
}
.paytrust-badges{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  justify-content:flex-end;
}
.pay-badge{
  padding:8px 12px;
  border-radius: 999px;
  font-size:12.5px;
  font-weight:900;
  letter-spacing:.2px;
  color: rgba(15,23,42,.82);
  background: rgba(15,23,42,.04);
  border:1px solid rgba(226,232,240,.95);
}
body.dark .paytrust{
  background: rgba(33,33,33,.72);
  border-color: rgba(255,255,255,.10);
  box-shadow: 0 18px 44px rgba(0,0,0,.55);
}
body.dark .pay-badge{
  color: rgba(255,255,255,.86);
  background: rgba(255,255,255,.06);
  border-color: rgba(255,255,255,.12);
}
@media(max-width: 980px){
  .paytrust{margin: -36px 0 34px; flex-direction:column; align-items:flex-start}
  .paytrust-badges{justify-content:flex-start}
}

.payment-trust{padding-top:20px;padding-bottom:60px}
.paytrust{
  border-radius:22px;
  border:1px solid rgba(226,232,240,.9);
  background: rgba(255,255,255,.85);
  box-shadow: 0 12px 34px rgba(15,23,42,.08);
  padding:18px 22px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px;
}
.paytrust-title{font-weight:900;font-size:14px;letter-spacing:-.2px}
.paytrust-sub{font-size:13px;color:var(--muted)}
.paytrust-badges{display:flex;gap:12px;flex-wrap:wrap}
.pay-badge{
  padding:8px 14px;
  border-radius:999px;
  font-size:12px;
  font-weight:700;
  background:#f5f5f5;
  border:1px solid #e5e5e5;
}
body.dark .paytrust{
  background: rgba(33,33,33,.85);
  border-color: rgba(255,255,255,.12);
}
body.dark .pay-badge{
  background: rgba(255,255,255,.08);
  border-color: rgba(255,255,255,.15);
  color:#fff;
}
@media(max-width:900px){
  .paytrust{flex-direction:column;align-items:flex-start}
}

.footer-payments{
  margin-top: 30px;
  display:flex;
  justify-content:center;
  align-items:center;
  gap:24px;
  flex-wrap:wrap;
}
.footer-payments img{
  height:28px;
  opacity:.85;
  transition:opacity .3s ease, transform .3s ease;
}
.footer-payments img:hover{
  opacity:1;
  transform:translateY(-2px);
}
body.dark .footer-payments img{
  filter: brightness(0) invert(1);
  opacity:.9;
}
/* As seen */
.as-seen{
  padding: 18px 0 10px;
}
.as-seen-inner{
  display:flex;
  align-items:center;
  gap: 16px;
  border:1px solid rgba(226,232,240,.9);
  background: rgba(255,255,255,.62);
  border-radius: 18px;
  padding: 14px 16px;
  box-shadow: 0 12px 34px rgba(15,23,42,.06);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}
.as-seen-label{
  font-size: 12.5px;
  font-weight: 900;
  letter-spacing: .2px;
  color: rgba(15,23,42,.70);
  white-space: nowrap;
}
body.dark .as-seen-inner{
  border-color: rgba(255,255,255,.10);
  background: rgba(33,33,33,.62);
  box-shadow: 0 18px 44px rgba(0,0,0,.55);
}
body.dark .as-seen-label{
  color: rgba(255,255,255,.78);
}
body.dark @media(max-width: 760px){
  .as-seen-inner{flex-direction: column; align-items:flex-start}
  }
/* As seen press */
.as-seen-press{ padding: 24px 0 10px; }
.as-seen-press-inner{
  position:relative;
  border-radius: 22px;
  border:1px solid rgba(226,232,240,.9);
  background: rgba(255,255,255,.85);
  box-shadow: 0 12px 34px rgba(15,23,42,.06);
  padding: 18px 18px 20px;
  text-align:center;
  overflow:hidden;
}
.press-head{
  display:flex;
  align-items:center;
  justify-content:center;
  gap: 14px;
  margin-bottom: 10px;
}
.press-label{
  font-size: 12px;
  letter-spacing: .42em;
  font-weight: 900;
  color: rgba(15,23,42,.55);
}
.press-line{
  height:1px;
  width: 180px;
  background: rgba(15,23,42,.18);
}
.press-laurel{
  position:absolute;
  inset: 0;
  display:flex;
  align-items:center;
  justify-content:center;
  pointer-events:none;
}
.press-laurel img{
  width: min(620px, 92%);
  opacity: 1;
}
@media(max-width:760px){
  .press-line{ width: 120px; }
  .press-label{ letter-spacing: .32em; }
  }

/* Dark mode */
body.dark .as-seen-press-inner{
  background: rgba(33,33,33,.78);
  border-color: rgba(255,255,255,.10);
  box-shadow: 0 18px 44px rgba(0,0,0,.55);
}
body.dark .press-label{ color: rgba(255,255,255,.65); }
body.dark .press-line{ background: rgba(255,255,255,.16); }
body.dark .press-laurel img{ filter: brightness(0) invert(1); opacity: .22; }
body.dark /* Luxury trust section */
.lux-trust{ padding: 26px 0 8px; }
.lux-trust-card{
  border-radius: 22px;
  border: 1px solid rgba(226,232,240,.9);
  background: rgba(255,255,255,.82);
  box-shadow: 0 14px 44px rgba(15,23,42,.08);
  padding: 18px 18px 16px;
  text-align:center;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}
.lux-proof{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
  text-align:left;
}
.proof-item{
  border-radius: 16px;
  border: 1px solid rgba(226,232,240,.9);
  background: rgba(255,255,255,.70);
  padding: 12px 12px;
}
.proof-num{
  font-weight: 950;
  letter-spacing: -.2px;
  font-size: 16px;
  color: rgba(15,23,42,.90);
}
.proof-cap{
  margin-top: 4px;
  font-size: 12.5px;
  color: rgba(15,23,42,.56);
}
@media(max-width: 980px){
  .lux-line{ width: 120px; }
  .lux-proof{ grid-template-columns: 1fr 1fr; }
}
@media(max-width: 520px){
  .lux-proof{ grid-template-columns: 1fr; }
}

/* Dark mode */
body.dark .lux-trust-card{
  background: rgba(33,33,33,.78);
  border-color: rgba(255,255,255,.10);
  box-shadow: 0 20px 56px rgba(0,0,0,.55);
}
body.dark .lux-label{ color: rgba(255,255,255,.62); }
body.dark .lux-line{ background: rgba(255,255,255,.16); }
body.dark .lux-sub{ color: rgba(255,255,255,.62); }
body.dark 
body.dark .lux-divider{ background: rgba(255,255,255,.12); }
body.dark .proof-item{
  background: rgba(255,255,255,.06);
  border-color: rgba(255,255,255,.10);
}
body.dark .proof-num{ color: rgba(255,255,255,.92); }
body.dark .proof-cap{ color: rgba(255,255,255,.68); }


/* Narrow luxury trust section */
.lux-trust .wrap{
  max-width: 980px;
  margin: 0 auto;
}


/* Make lux-proof 70% width and centered */
.lux-proof{
  width: 70%;
  margin: 0 auto;
}
@media(max-width: 980px){
  .lux-proof{
    width: 90%;
  }
}


.btn.primary{ color:#000 !important; }
.btn.primary:hover{ color:#000 !important; }





/* Full feature product cards */
.product-feature{
  margin: 60px auto;
}

.feature-card{
  display: flex;
  gap: 40px;
  align-items: center;
  background: rgba(255,255,255,.75);
  border-radius: 28px;
  padding: 40px;
  box-shadow: 0 20px 60px rgba(0,0,0,.06);
}

.feature-image img{
  width: 280px;
  border-radius: 18px;
}

.feature-title{
  font-size: 28px;
  font-weight: 800;
  margin-bottom: 10px;
}

.feature-price{
  font-size: 22px;
  font-weight: 700;
  color: #BFF746;
  margin-bottom: 14px;
}

.feature-tags{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-bottom:16px;
}

.chip{
  padding:6px 14px;
  border-radius:20px;
  background:#f2f2f2;
  font-size:13px;
}

.feature-desc{
  font-size:16px;
  line-height:1.6;
  margin-bottom:20px;
}

.feature-actions{
  display:flex;
  gap:16px;
}

@media(max-width: 980px){
  .feature-card{
    flex-direction:column;
    text-align:center;
  }
  .feature-image img{
    width:220px;
  }
}

body.dark .feature-card{
  background: rgba(33,33,33,.7);
}

body.dark .chip{
  background: rgba(255,255,255,.1);
}



/* How it works */
.how-it-works {
  padding: 80px 0;
}

.steps {
  display: flex;
  gap: 40px;
  justify-content: space-between;
}

.step {
  flex: 1;
}

.step h3 {
  font-size: 18px;
  margin-bottom: 10px;
}

.step p {
  opacity: .8;
  line-height: 1.6;
}



.callout h2 {
  font-size: 28px;
  margin-bottom: 10px;
}

.callout p {
  font-size: 16px;
}

/* FAQ */
.faq {
  padding: 80px 0;
}

.faq-item {
  margin-bottom: 30px;
}

.faq-item h4 {
  font-size: 18px;
  margin-bottom: 6px;
}

.faq-item p {
  opacity: .8;
  line-height: 1.6;
}

@media(max-width: 900px){
  .steps {
    flex-direction: column;
  }
}

/* Mid hero */
.mid-hero{
  position: relative;
  margin: 48px auto 10px;
  border-radius: 28px;
  overflow: hidden;
  max-width: 1200px;
  height: 360px;
  box-shadow: 0 20px 70px rgba(0,0,0,.10);
}
.mid-hero-bg{
  position:absolute;
  inset:0;
  background-image: url('assets/hero_planning.jpg');
  background-size: cover;
  background-position: center;
  transform: scale(1.02);
}
.mid-hero::after{
  content:"";
  position:absolute;
  inset:0;
  background: linear-gradient(180deg, rgba(0,0,0,.20), rgba(0,0,0,.30));
}
.mid-hero-inner{
  position:relative;
  z-index:2;
  height:100%;
  display:flex;
  align-items:flex-end;
  justify-content:center;
  padding: 22px;
}
.mid-hero-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding: 12px 22px;
  border-radius: 999px;
  background: rgba(21, 45, 25, .92);
  color: #fff;
  font-weight: 700;
  letter-spacing: .2px;
  text-decoration:none;
  border: 1px solid rgba(255,255,255,.20);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  box-shadow: 0 10px 24px rgba(0,0,0,.22);
  transition: transform .2s ease, box-shadow .2s ease, background .2s ease;
}
.mid-hero-btn:hover{
  transform: translateY(-2px);
  box-shadow: 0 14px 30px rgba(0,0,0,.28);
  background: rgba(21, 45, 25, 1);
}
body.dark .mid-hero{
  box-shadow: 0 28px 90px rgba(0,0,0,.55);
}
@media(max-width: 980px){
  .mid-hero{
    max-width: 92%;
    height: 280px;
    border-radius: 24px;
  }
}
/* === Unified premium feature card style (applies to ALL feature cards) === */
.product-feature{
  margin: 54px auto;
}
.feature-card{
  max-width: 1200px;
  margin: 0 auto;
  display: flex;
  gap: 46px;
  align-items: center;
  padding: 44px 46px;
  border-radius: 36px;
  background: rgba(255,255,255,.82);
  border: 1px solid rgba(15,23,42,.08);
  box-shadow: 0 30px 90px rgba(0,0,0,.08);
}
.feature-image{
  flex: 0 0 420px;
}
.feature-image img{
  width: 100%;
  height: auto;
  border-radius: 28px;
  box-shadow: 0 18px 60px rgba(0,0,0,.12);
}
.feature-content{
  flex: 1 1 auto;
  min-width: 0;
}
.feature-title{
  font-size: 44px;
  line-height: 1.05;
  letter-spacing: -0.8px;
  margin: 0 0 18px;
}
.feature-price{
  font-size: 34px;
  font-weight: 900;
  letter-spacing: -0.4px;
  color: #BFF746;
  margin: 0 0 18px;
}
.feature-tags{
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin: 0 0 22px;
}
.chip{
  display: inline-flex;
  align-items: center;
  padding: 10px 18px;
  border-radius: 999px;
  background: rgba(15,23,42,.04);
  border: 1px solid rgba(15,23,42,.08);
  color: rgba(15,23,42,.80);
  font-size: 16px;
  font-weight: 600;
}
.feature-desc{
  font-size: 22px;
  line-height: 1.5;
  color: rgba(15,23,42,.78);
  margin: 0 0 28px;
  max-width: 780px;
}
.feature-actions{
  display: flex;
  gap: 18px;
  flex-wrap: wrap;
}
.feature-actions .btn{
  padding: 16px 26px;
  font-size: 18px;
  border-radius: 18px;
}
.feature-actions .btn.primary{
  background: #BFF746;
  color: #000 !important;
  box-shadow: 0 18px 40px rgba(0,0,0,.14);
}
.feature-actions .btn.ghost{
  background: rgba(255,255,255,.70);
  border: 1px solid rgba(15,23,42,.14);
}
/* Dark mode */
body.dark .feature-card{
  background: rgba(33,33,33,.62);
  border-color: rgba(255,255,255,.10);
  box-shadow: 0 40px 120px rgba(0,0,0,.55);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
}
body.dark .chip{
  background: rgba(255,255,255,.08);
  border-color: rgba(255,255,255,.12);
  color: rgba(255,255,255,.82);
}
body.dark .feature-desc{
  color: rgba(255,255,255,.74);
}
body.dark .feature-actions .btn.ghost{
  background: rgba(33,33,33,.35);
  border-color: rgba(255,255,255,.18);
  color: rgba(255,255,255,.90);
}
/* Responsive */
@media (max-width: 1100px){
  .feature-card{ gap: 34px; padding: 34px; border-radius: 30px; }
  .feature-image{ flex-basis: 360px; }
  .feature-title{ font-size: 36px; }
  .feature-desc{ font-size: 18px; }
}
@media (max-width: 900px){
  .feature-card{ flex-direction: column; text-align: left; }
  .feature-image{ flex-basis: auto; width: 100%; max-width: 520px; }
  .feature-title{ font-size: 34px; }
}



/* === FORCE: Feature cards match the newest premium layout === */
.product-feature{ margin: 58px auto; }

.product-feature .feature-image{ flex: 0 0 440px; }
.product-feature .feature-image img{
  width: 100%;
  border-radius: 30px;
  box-shadow: 0 22px 70px rgba(0,0,0,.14);
}
.product-feature .feature-title{
  font-size: 46px;
  line-height: 1.06;
  letter-spacing: -0.9px;
  margin: 0 0 18px;
}
.product-feature .feature-price{
  font-size: 34px;
  font-weight: 900;
  letter-spacing: -0.4px;
  color: #BFF746;
  margin: 0 0 18px;
}
.product-feature .feature-tags{
  display:flex;
  flex-wrap:wrap;
  gap: 12px;
  margin: 0 0 22px;
}
.product-feature .chip{
  padding: 10px 18px;
  border-radius: 999px;
  background: rgba(15,23,42,.04);
  border: 1px solid rgba(15,23,42,.10);
  font-size: 16px;
  font-weight: 650;
}
.product-feature .feature-desc{
  font-size: 22px;
  line-height: 1.55;
  color: rgba(15,23,42,.78);
  margin: 0 0 30px;
  max-width: 820px;
}
.product-feature .feature-actions{ display:flex; gap:18px; flex-wrap:wrap; }
.product-feature .feature-actions .btn{
  padding: 16px 28px;
  font-size: 18px;
  border-radius: 18px;
}
.product-feature .feature-actions .btn.primary{
  background: #BFF746;
  color: #000 !important;
  box-shadow: 0 18px 44px rgba(0,0,0,.14);
}
.product-feature .feature-actions .btn.ghost{
  background: rgba(255,255,255,.70);
  border: 1px solid rgba(15,23,42,.16);
}
/* Dark mode */
body.dark .product-feature .feature-card{
  background: rgba(33,33,33,.62);
  border-color: rgba(255,255,255,.12);
  box-shadow: 0 46px 140px rgba(0,0,0,.60);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
}
body.dark .product-feature .chip{
  background: rgba(255,255,255,.08);
  border-color: rgba(255,255,255,.14);
  color: rgba(255,255,255,.84);
}
body.dark .product-feature .feature-desc{ color: rgba(255,255,255,.74); }
body.dark .product-feature .feature-actions .btn.ghost{
  background: rgba(33,33,33,.35);
  border-color: rgba(255,255,255,.18);
  color: rgba(255,255,255,.92);
}
/* Responsive */
@media (max-width: 1100px){
  .product-feature .feature-card{ gap: 34px; padding: 36px; border-radius: 32px; }
  .product-feature .feature-image{ flex-basis: 360px; }
  .product-feature .feature-title{ font-size: 38px; }
  .product-feature .feature-desc{ font-size: 18px; }
}
@media (max-width: 900px){
  .product-feature .feature-card{ flex-direction: column; align-items:flex-start; }
  .product-feature .feature-image{ flex-basis: auto; width: 100%; max-width: 560px; }
  .product-feature .feature-title{ font-size: 34px; }
}



/* === Feature cards: unified size & style (matches newest product cards) === */
.product-feature{ margin: 56px auto; }

.product-feature .feature-image{ flex: 0 0 470px; }
.product-feature .feature-image img{
  width: 100%;
  height: auto;
  border-radius: 34px;
  box-shadow: 0 24px 90px rgba(0,0,0,.18);
}
.product-feature .feature-title{
  font-size: 56px;
  line-height: 1.02;
  letter-spacing: -1.1px;
  margin: 0 0 18px;
}
.product-feature .feature-price{
  font-size: 44px;
  font-weight: 900;
  letter-spacing: -0.6px;
  color: #BFF746;
  margin: 0 0 22px;
}
.product-feature .feature-tags{
  display:flex;
  flex-wrap:wrap;
  gap: 14px;
  margin: 0 0 26px;
}
.product-feature .chip{
  padding: 12px 22px;
  border-radius: 999px;
  background: rgba(15,23,42,.05);
  border: 1px solid rgba(15,23,42,.10);
  color: rgba(15,23,42,.78);
  font-size: 18px;
  font-weight: 650;
}
.product-feature .feature-desc{
  font-size: 24px;
  line-height: 1.55;
  color: rgba(15,23,42,.78);
  margin: 0 0 34px;
  max-width: 860px;
}
.product-feature .feature-actions{ display:flex; gap: 18px; flex-wrap:wrap; }
.product-feature .feature-actions .btn{
  padding: 18px 32px;
  font-size: 20px;
  border-radius: 18px;
}
.product-feature .feature-actions .btn.primary{
  background: #BFF746;
  color: #000 !important;
  box-shadow: 0 18px 44px rgba(0,0,0,.16);
}
.product-feature .feature-actions .btn.ghost{
  background: rgba(255,255,255,.70);
  border: 1px solid rgba(15,23,42,.18);
}

/* DARK MODE (matches screenshot: glass + border) */
body.dark .product-feature .feature-card{
  background: rgba(33,33,33,.58);
  border: 1px solid rgba(255,255,255,.10);
  box-shadow: 0 46px 160px rgba(0,0,0,.70);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
}
body.dark .product-feature .feature-title{ color: rgba(255,255,255,.92); }
body.dark .product-feature .feature-desc{ color: rgba(255,255,255,.74); }
body.dark .product-feature .chip{
  background: rgba(255,255,255,.08);
  border-color: rgba(255,255,255,.14);
  color: rgba(255,255,255,.84);
}
body.dark .product-feature .feature-actions .btn.ghost{
  background: rgba(0,0,0,.20);
  border-color: rgba(255,255,255,.18);
  color: rgba(255,255,255,.90);
}
/* keep buttons readable */
body.dark .product-feature .feature-actions .btn.primary{ color:#000 !important; }

/* responsive */
@media (max-width: 1200px){
  .product-feature .feature-card{ padding: 44px; gap: 40px; border-radius: 36px; }
  .product-feature .feature-image{ flex-basis: 420px; }
  .product-feature .feature-title{ font-size: 46px; }
  .product-feature .feature-price{ font-size: 38px; }
  .product-feature .feature-desc{ font-size: 20px; }
}
@media (max-width: 920px){
  .product-feature .feature-card{
    flex-direction: column;
    align-items: flex-start;
    padding: 34px;
  }
  .product-feature .feature-image{ width: 100%; flex-basis: auto; max-width: 560px; }
  .product-feature .feature-title{ font-size: 38px; }
}



/* === Premium 2026 layout tuning === */
:root{
  --lux-max: 1280px;
  --lux-pad: 56px;
  --lux-radius: 44px;
}

/* Center main flow */
.product-feature{
  padding: 0 18px;
}


/* Alternating rhythm */
.product-feature.reverse .feature-card{
  flex-direction: row-reverse;
}
.product-feature.reverse .feature-content{
  padding-right: 0;
}

/* Slightly tighter luxury container for text measure */
.product-feature .feature-desc{
  max-width: 780px !important;
}

/* Extra breathing room between cards */
.product-feature{ margin: 64px auto !important; }

/* Responsive */
@media (max-width: 1200px){
  :root{ --lux-max: 1140px; --lux-pad: 44px; --lux-radius: 36px; }
}
@media (max-width: 900px){
  .product-feature.reverse .feature-card{ flex-direction: column; }
}





  display: flex;
  align-items: center;
  justify-content: space-between;
}

.callout-content {
  padding-left: 16px;
}

.callout .btn {
  margin-right: 20px;
}



/* ===== Simple Footer Social Icons (Match Payment Style) ===== */
.footer-social {
  display: flex;
  justify-content: center;
  gap: 28px;
  margin-top: 28px;
}

.footer-social a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 34px;
  height: 34px;
  border-radius: 0;
  background: none;
  box-shadow: none;
  transition: opacity .3s ease, transform .3s ease;
}

.footer-social svg {
  width: 22px;
  height: 22px;
  fill: currentColor;
  color: #BFF746;
  opacity: .85;
}

.footer-social a:hover svg {
  opacity: 1;
  transform: translateY(-2px);
}

/* Dark mode */
body.dark .footer-social svg {
  color: #BFF746;
  opacity: .9;
}
/* Social icons styled like payment logos */
.social-pay{
  display:flex;
  justify-content:center;
  align-items:center;
  gap:24px;
}
.social-pay img{
  height:28px;
  opacity:.85;
  transition:opacity .3s ease, transform .3s ease;
}
.social-pay img:hover{
  opacity:1;
  transform:translateY(-2px);
}
/* Ensure ALL product feature cards share identical width */



/* Remove old article wrapper influence */
.card.article{
  all: unset;
}



/* ===== Force identical width & size for ALL feature-cards ===== */
:root{ --feature-max: 1240px; }
.product-feature{ padding-left: 18px; padding-right: 18px; }

/* Ensure image column size matches across all cards */
.product-feature .feature-image{ flex: 0 0 470px !important; }
@media (max-width: 1200px){
  .product-feature .feature-image{ flex-basis: 420px !important; }
}
@media (max-width: 920px){
  .product-feature .feature-image{ flex-basis: auto !important; width: 100% !important; }
}




/* ===== Updated Feature Content Width ===== */
.feature-content {
    flex: 1 1 auto !important;
    
}

/* ===== Force Full Width Feature Content ===== */
.feature-content {
    width: 100% !important;
}



/* ===== Final Feature Content Rule ===== */
.feature-content {
    width: 100% !important;
}


/* Guard: feature-card consistency (applies equally to all products) */







/* prevent flex layout from squashing content */
.callout{ justify-content: initial !important; align-items: initial !important; }
.callout .container{ max-width:100% !important; width:100% !important; }








.product-feature .feature-card {
    width: 127% !important;
}


/* =========================
   RESPONSIVE SYSTEM (2026)
   ========================= */

/* Global safety */
*,
*::before,
*::after { box-sizing: border-box; }
img, svg, video { max-width: 100%; height: auto; }
html { -webkit-text-size-adjust: 100%; }
body { overflow-x: hidden; }

/* Layout containers */
.container,
.wrap,
.inner,
.section-inner {
  width: 100%;
  max-width: 1240px;
  margin-left: auto;
  margin-right: auto;
  padding-left: 18px;
  padding-right: 18px;
}

/* Buttons tap targets */
.btn, button, a.btn {
  min-height: 44px;
}

/* HERO / SLIDER */
.hero,
.hero-slider,
.slider,
.header-slider {
  width: 100%;
}

.hero-slide,
.slide {
  min-height: clamp(420px, 58vh, 760px);
}

@media (max-width: 900px) {
  .hero-slide,
  .slide {
    min-height: 480px;
  }
}

@media (max-width: 600px) {
  .hero-slide,
  .slide {
    min-height: 520px;
  }
}

/* Sticky header + nav overflow handling */
header, .header, .site-header {
  width: 100%;
}
.nav, nav, .menu, .header-menu {
  max-width: 100%;
}
.nav a, nav a, .menu a {
  white-space: nowrap;
}

/* FEATURE CARDS (Products)
   Desktop keeps your 127% width.
   Tablet/Mobile collapses cleanly and prevents overflow.
*/
@media (max-width: 1200px) {
  .product-feature .feature-card {
    width: 100% !important;
    max-width: 100% !important;
  }
}

/* Card layout: stack on smaller screens */
@media (max-width: 900px) {
  .product-feature { padding-left: 14px; padding-right: 14px; }
  .product-feature .feature-card {
    width: 100% !important;
    max-width: 100% !important;
    padding: 28px !important;
    border-radius: 22px !important;
  }
  .product-feature .feature-card {
    display: flex !important;
    flex-direction: column !important;
    gap: 18px !important;
  }
  .product-feature .feature-image {
    width: 100% !important;
    flex: 0 0 auto !important;
  }
  .product-feature .feature-image img {
    width: 100%;
    aspect-ratio: 16 / 10;
    object-fit: cover;
    border-radius: 18px;
  }
  .product-feature .feature-content {
    width: 100% !important;
  }
  .feature-actions {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
  }
  .feature-actions .btn {
    flex: 1 1 220px;
  }
}

/* Small phones */
@media (max-width: 520px) {
  .product-feature .feature-card {
    padding: 22px !important;
    border-radius: 20px !important;
  }
  .feature-title { font-size: 1.35rem !important; line-height: 1.15 !important; }
  .feature-desc { font-size: 0.98rem !important; }
  .feature-price { font-size: 1.05rem !important; }
  .feature-actions .btn {
    width: 100%;
    flex: 1 1 100%;
  }
}

/* PREVIEW GRID / OTHER GRIDS */
.preview-grid,
.grid,
.cards,
.card-grid {
  display: grid;
  gap: clamp(14px, 2vw, 22px);
}

@media (min-width: 901px) {
  .preview-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 900px) {
  .preview-grid { grid-template-columns: 1fr; }
}

/* Mid hero section */
.mid-hero,
.mid-hero-inner {
  width: 100%;
}
@media (max-width: 900px) {
  .mid-hero-inner {
    padding: 26px 18px !important;
  }
}

/* Footer: stack nicely */
footer, .footer {
  width: 100%;
}
.footer-row, .footer-inner, .footer-bottom {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  justify-content: center;
  text-align: center;
}
.footer-payments, .footer-social {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 12px;
}

/* Typography breathing room */
.section-title, h2, h3 {
  letter-spacing: -0.5px;
}
@media (max-width: 900px) {
  section { scroll-margin-top: 90px; }
}


/* Mobile nav wrap (no JS required) */
@media (max-width: 760px){
  nav, .nav, .menu, .header-menu{
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
  }
  nav::-webkit-scrollbar, .nav::-webkit-scrollbar, .menu::-webkit-scrollbar{ display:none; }
}

