:root {
  --bg: #f6fbfb;
  --white: #ffffff;
  --navy: #0b2149;
  --navy-2: #18335f;
  --teal: #17d5b5;
  --teal-dark: #0bb39d;
  --text: #25324b;
  --muted: #66738a;
  --border: #dfeeee;
  --shadow: 0 18px 50px rgba(11, 33, 73, 0.08);
  --radius: 22px;
  --radius-sm: 16px;
  --container: 1180px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: 'Inter', system-ui, sans-serif;
  background: linear-gradient(180deg, #ffffff 0%, var(--bg) 100%);
  color: var(--text);
}
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
.container { width: min(calc(100% - 32px), var(--container)); margin: 0 auto; }
.section { padding: 44px 0; }
.section-heading { text-align: center; margin-bottom: 26px; }
.section-heading h2 { font-size: clamp(1.8rem, 3vw, 2.7rem); margin: 0 0 8px; color: var(--navy); }
.section-heading h2 span { color: var(--teal-dark); }
.section-heading p { margin: 0; color: var(--muted); }

.site-header {
  position: sticky; top: 0; z-index: 30;
  background: rgba(255,255,255,0.92);
  backdrop-filter: blur(14px);
  border-bottom: 1px solid rgba(20, 71, 111, 0.08);
}
.header-inner {
  display: grid; grid-template-columns: auto 1fr auto auto; gap: 24px;
  align-items: center; min-height: 84px;
}
.brand { display: inline-flex; align-items: center; gap: 12px; }
.brand-mark {
  display: inline-grid; place-items: center;
  width: 58px; height: 58px; border-radius: 50%;
  color: var(--teal); background: rgba(23, 213, 181, 0.12);
}
.brand-mark svg { width: 40px; height: 40px; }
.brand-name { display: block; font-size: 2rem; line-height: 1; color: var(--navy); font-weight: 800; }
.brand-name span { color: var(--teal-dark); }
.brand small { color: var(--muted); display: block; margin-top: 3px; }
.main-nav { display: flex; gap: 26px; justify-content: center; }
.main-nav a {
  color: var(--navy); font-weight: 600; position: relative; padding: 6px 0;
}
.main-nav a:hover::after,
.main-nav a:focus-visible::after {
  content: ''; position: absolute; left: 0; right: 0; bottom: -4px; height: 3px;
  background: var(--teal); border-radius: 99px;
}
.menu-toggle { display: none; }

.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 10px;
  min-height: 54px; padding: 0 24px; border-radius: 16px; border: 1px solid transparent;
  font-weight: 700; transition: .25s ease; cursor: pointer;
}
.btn:hover { transform: translateY(-2px); }
.btn-primary {
  background: linear-gradient(135deg, var(--teal-dark), var(--teal));
  color: white; box-shadow: 0 14px 30px rgba(23, 213, 181, 0.25);
}
.btn-secondary {
  background: white; color: var(--navy); border-color: rgba(24, 51, 95, 0.15);
}

.hero { padding: 42px 0 26px; }
.hero-grid {
  display: grid; grid-template-columns: 1.05fr 0.95fr; gap: 26px; align-items: center;
}
.eyebrow {
  display: inline-block; padding: 10px 14px; border-radius: 999px;
  font-size: .9rem; font-weight: 800; color: var(--teal-dark);
  background: rgba(23, 213, 181, 0.12); margin-bottom: 14px;
}
.hero-copy h1 {
  margin: 0 0 14px; font-size: clamp(2.8rem, 6vw, 5rem); line-height: .98; color: var(--navy);
}
.hero-copy h1 span { color: var(--teal-dark); display: block; }
.hero-copy p {
  color: var(--muted); font-size: 1.14rem; line-height: 1.7; max-width: 650px;
}
.hero-actions { display: flex; gap: 14px; flex-wrap: wrap; margin: 28px 0 22px; }
.mini-benefits { display: flex; flex-wrap: wrap; gap: 22px; list-style: none; padding: 0; margin: 0; color: var(--navy-2); font-weight: 600; }
.mini-benefits li::before { content: '✓'; color: var(--teal-dark); font-weight: 800; margin-right: 8px; }

.hero-visual {
  position: relative; min-height: 580px; border-radius: 36px; overflow: hidden;
  background:
    radial-gradient(circle at 70% 30%, rgba(23, 213, 181, 0.28), transparent 34%),
    linear-gradient(180deg, #f2ffff 0%, #eff8f7 100%);
  border: 1px solid rgba(23, 213, 181, 0.12);
}
.hero-glow {
  position: absolute; width: 430px; height: 430px; border-radius: 50%;
  right: 26px; top: 18px; border: 2px solid rgba(23, 213, 181, 0.18);
  box-shadow: inset 0 0 0 30px rgba(23, 213, 181, 0.04), inset 0 0 0 60px rgba(23, 213, 181, 0.03);
}
.hero-glow::before, .hero-glow::after {
  content: ''; position: absolute; border-radius: 50%; inset: 38px; border: 2px solid rgba(23, 213, 181, 0.14);
}
.hero-glow::after { inset: 76px; }
.badge {
  position: absolute; display: inline-flex; flex-direction: column; align-items: center; justify-content: center;
  text-align: center; font-weight: 800; z-index: 3;
}
.badge-discount {
  top: 44px; right: 28px; width: 132px; height: 132px; border-radius: 50%;
  background: linear-gradient(180deg, #24ddbe, #10c0a6); color: var(--navy);
  box-shadow: var(--shadow);
}
.badge-discount strong { display: block; font-size: 2rem; line-height: 1.05; }
.price-tag {
  position: absolute; top: 56px; left: 44%; transform: translateX(-50%) rotate(6deg);
  width: 74px; height: 96px; border-radius: 16px; background: var(--navy); color: var(--teal);
  display: grid; place-items: center; font-size: 2.3rem; font-weight: 800; box-shadow: var(--shadow);
}
.price-tag::before {
  content: ''; position: absolute; width: 12px; height: 12px; border-radius: 50%; background: var(--white); top: 12px; left: 50%; transform: translateX(-50%);
}
.product-card {
  position: absolute; display: grid; place-items: center; background: var(--white); border-radius: 24px;
  box-shadow: var(--shadow); font-size: 3.4rem; border: 1px solid rgba(11, 33, 73, 0.06);
}
.phone { width: 120px; height: 220px; top: 78px; left: 55%; }
.laptop { width: 220px; height: 140px; top: 225px; left: 39%; font-size: 4rem; }
.airfryer { width: 150px; height: 200px; top: 126px; right: 118px; font-size: 3.8rem; }
.shoes { width: 160px; height: 86px; bottom: 112px; left: 48%; font-size: 3.2rem; }
.grocery { width: 160px; height: 170px; top: 275px; right: 22px; font-size: 4rem; }
.box { width: 100px; height: 100px; bottom: 58px; right: 108px; font-size: 2.8rem; }
.notification-card {
  position: absolute; display: flex; align-items: center; gap: 14px; left: 47%; bottom: 28px;
  transform: translateX(-20%); background: var(--white); padding: 16px 18px; border-radius: 18px;
  box-shadow: var(--shadow); z-index: 3;
}
.notification-card strong { display: block; color: var(--navy); }
.notification-card small { display: block; color: var(--muted); margin-top: 4px; }
.bell { font-size: 1.8rem; }

.benefits { padding: 22px 0 8px; }
.benefit-grid {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px;
}
.benefit-card {
  background: rgba(255,255,255,0.88); border: 1px solid var(--border); border-radius: var(--radius);
  padding: 24px; box-shadow: var(--shadow); display: flex; gap: 16px; align-items: flex-start;
}
.icon-circle, .plan-badge, .avatar, .step-icon {
  width: 62px; height: 62px; border-radius: 50%; display: grid; place-items: center;
  background: linear-gradient(180deg, rgba(23,213,181,0.18), rgba(23,213,181,0.08));
  color: var(--teal-dark); font-size: 1.7rem; flex: 0 0 auto;
}
.benefit-card h3 { margin: 0 0 8px; color: var(--navy); }
.benefit-card p { margin: 0; color: var(--muted); line-height: 1.6; }

.category-grid {
  display: grid; grid-template-columns: repeat(6, 1fr); gap: 14px;
}
.category-pill {
  background: var(--white); border: 1px solid var(--border); border-radius: 18px; padding: 18px 16px;
  text-align: center; font-weight: 700; color: var(--navy); box-shadow: var(--shadow);
}
.category-pill span { display: inline-block; margin-right: 8px; }

.steps-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px;
}
.step-card {
  position: relative; background: var(--white); border-radius: var(--radius); padding: 28px 24px 24px;
  border: 1px solid var(--border); box-shadow: var(--shadow); text-align: center;
}
.step-number {
  position: absolute; top: 16px; left: 16px; width: 36px; height: 36px; border-radius: 50%;
  display: grid; place-items: center; background: var(--teal-dark); color: white; font-weight: 800;
}
.step-icon { margin: 10px auto 16px; }
.step-card h3 { margin: 0 0 10px; color: var(--navy); font-size: 1.28rem; }
.step-card p { margin: 0; color: var(--muted); line-height: 1.7; }

.plan-card {
  background: var(--white); border-radius: 28px; border: 1px solid var(--border); box-shadow: var(--shadow);
  padding: 34px; display: grid; grid-template-columns: 1.2fr 1fr 0.9fr; gap: 26px; align-items: center;
}
.plan-label { margin: 0 0 6px; color: var(--muted); font-weight: 700; }
.plan-intro { display: flex; gap: 18px; align-items: center; }
.plan-intro h2 { margin: 0 0 8px; font-size: 2.7rem; color: var(--navy); }
.plan-intro h2 span { color: var(--teal-dark); }
.plan-intro p:last-child { margin: 0; color: var(--muted); line-height: 1.6; }
.plan-features { list-style: none; padding: 0; margin: 0; }
.plan-features li { margin: 12px 0; color: var(--navy); font-weight: 600; }
.plan-features li::before { content: '✔'; color: var(--teal-dark); margin-right: 10px; }
.plan-cta-box { text-align: center; }
.plan-cta-box small { display: block; color: var(--muted); margin-top: 12px; line-height: 1.6; }

.testimonial-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px;
}
.testimonial-card {
  background: var(--white); border: 1px solid var(--border); border-radius: var(--radius);
  padding: 24px; box-shadow: var(--shadow);
}
.person { display: flex; align-items: center; gap: 14px; margin-bottom: 12px; }
.avatar { font-weight: 800; background: linear-gradient(180deg, rgba(23,213,181,0.28), rgba(23,213,181,0.1)); }
.person strong { display: block; color: var(--navy); }
.person span { color: #00ad93; font-size: .95rem; }
.testimonial-card p { color: var(--muted); line-height: 1.7; margin: 0; }

.faq-grid {
  display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px;
}
.faq-grid details {
  background: var(--white); border: 1px solid var(--border); border-radius: 18px; padding: 0 18px; box-shadow: var(--shadow);
}
.faq-grid summary {
  list-style: none; cursor: pointer; font-weight: 700; color: var(--navy); padding: 22px 0; position: relative;
}
.faq-grid summary::-webkit-details-marker { display: none; }
.faq-grid summary::after {
  content: '+'; position: absolute; right: 0; top: 50%; transform: translateY(-50%); font-size: 1.6rem; color: var(--teal-dark);
}
.faq-grid details[open] summary::after { content: '–'; }
.faq-grid details p { margin: 0 0 20px; color: var(--muted); line-height: 1.7; }

.site-footer {
  margin-top: 34px; background: linear-gradient(135deg, #08162f, #0e2b5e); color: rgba(255,255,255,0.92);
  padding: 36px 0;
}
.footer-grid {
  display: grid; grid-template-columns: 1.1fr 1fr 0.9fr; gap: 26px; align-items: center;
}
.footer-brand .brand-name, .footer-brand small, .footer-handle, .copyright, .footer-support p { color: rgba(255,255,255,0.9); }
.footer-handle, .copyright { margin: 10px 0 0; }
.footer-support h3 { margin: 0 0 8px; }
.footer-points { list-style: none; padding: 0; margin: 0; }
.footer-points li { margin: 10px 0; font-weight: 600; }

@media (max-width: 1080px) {
  .header-inner { grid-template-columns: auto auto auto; }
  .main-nav {
    position: absolute; left: 0; right: 0; top: 84px; background: rgba(255,255,255,0.98);
    border-bottom: 1px solid rgba(20, 71, 111, 0.08); padding: 18px 24px;
    display: none; flex-direction: column; align-items: flex-start;
  }
  .main-nav.is-open { display: flex; }
  .menu-toggle {
    display: inline-flex; align-items: center; justify-content: center;
    width: 46px; height: 46px; border-radius: 12px; border: 1px solid var(--border);
    background: white; color: var(--navy); font-size: 1.35rem; justify-self: end;
  }
  .header-cta { display: none; }
  .hero-grid, .benefit-grid, .category-grid, .steps-grid, .plan-card, .testimonial-grid, .faq-grid, .footer-grid {
    grid-template-columns: 1fr;
  }
  .hero-visual { min-height: 620px; }
}

@media (max-width: 760px) {
  .brand-name { font-size: 1.7rem; }
  .hero { padding-top: 24px; }
  .hero-copy h1 { font-size: clamp(2.25rem, 10vw, 4rem); }
  .hero-copy p { font-size: 1rem; }
  .hero-actions { flex-direction: column; }
  .mini-benefits { gap: 10px; }
  .hero-visual { min-height: 700px; }
  .price-tag { left: 22%; top: 40px; }
  .badge-discount { right: 18px; top: 18px; width: 110px; height: 110px; }
  .badge-discount strong { font-size: 1.5rem; }
  .phone { top: 96px; left: 56%; width: 100px; height: 200px; }
  .airfryer { top: 170px; right: 24px; width: 128px; height: 176px; }
  .laptop { left: 12px; top: 250px; width: 190px; }
  .grocery { right: 10px; top: 370px; width: 145px; height: 160px; }
  .shoes { left: 18px; bottom: 144px; width: 138px; }
  .box { right: 20px; bottom: 120px; }
  .notification-card {
    left: 50%; transform: translateX(-50%); width: calc(100% - 28px); bottom: 24px;
  }
  .plan-card { padding: 24px; }
}


.category-grid-expanded {
  grid-template-columns: repeat(6, 1fr);
}

@media (max-width: 1080px) {
  .category-grid-expanded { grid-template-columns: repeat(3, 1fr); }
}

@media (max-width: 760px) {
  .category-grid-expanded { grid-template-columns: repeat(2, 1fr); }
}
