
:root {
  --purple: #9F78FF;
  --blue: #7AA0FF;
  --pink: #F89ABC;
  --green: #2AA06D;
  --dark: #213943;
  --cream: #F4EFEA;
  --bg: #ffffff;
  --card: rgba(255,255,255,0.88);
  --border: rgba(33,57,67,0.12);
  --shadow: 0 18px 45px rgba(33,57,67,0.10);
  --radius: 22px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family: 'Poppins', system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color: var(--dark);
  background: radial-gradient(1200px 600px at 10% 0%, rgba(248,154,188,0.16), transparent 55%),
              radial-gradient(1100px 700px at 90% 10%, rgba(159,120,255,0.22), transparent 55%),
              linear-gradient(180deg, #ffffff 0%, #ffffff 55%, rgba(122,160,255,0.08) 100%);
}

a{color:inherit;text-decoration:none}
.container{width:min(1100px, 92vw); margin: 0 auto;}

/* HEADER */
.header{
  position: sticky; top:0; z-index:999;
  backdrop-filter: blur(10px);
  background: linear-gradient(90deg, rgba(159,120,255,0.92), rgba(122,160,255,0.92));
  border-bottom: 1px solid rgba(255,255,255,0.25);
}
.header-inner{
  display:flex; align-items:center; justify-content:space-between;
  padding: 12px 0;
}
.brand{
  display:flex; align-items:center; gap:12px;
}
.brand img{height:46px; width:auto; display:block; filter: drop-shadow(0 10px 18px rgba(0,0,0,0.18));}
.header-actions{display:flex; align-items:center; gap:10px;}
.icon-btn{
  width:40px;height:40px;border-radius:14px;
  display:grid;place-items:center;
  border:1px solid rgba(255,255,255,0.35);
  background: rgba(255,255,255,0.14);
  color:#fff;
  transition: all 0.2s ease;
}
.icon-btn:hover{background: rgba(255,255,255,0.22)}

.hamburger{
  width:44px;height:44px;border-radius:16px;
  border:1px solid rgba(255,255,255,0.35);
  background: rgba(255,255,255,0.14);
  cursor:pointer;
  display:grid; place-items:center;
  transition: all 0.2s ease;
}
.hamburger span{
  display:block; width:18px; height:2px; background:#fff; border-radius:2px;
  position:relative;
  transition: all 0.3s ease;
}
.hamburger span:before,.hamburger span:after{
  content:""; position:absolute; left:0; width:18px; height:2px; background:#fff; border-radius:2px;
  transition: all 0.3s ease;
}
.hamburger span:before{top:-6px}
.hamburger span:after{top:6px}

.drawer-backdrop{
  position:fixed; inset:0; background:rgba(0,0,0,0.28);
  opacity:0; pointer-events:none; transition:opacity .2s ease;
  z-index:998;
}
.drawer{
  position:fixed; top:0; right:-360px; height:100%; width:360px;
  background: rgba(255,255,255,0.96);
  backdrop-filter: blur(10px);
  border-left: 1px solid rgba(33,57,67,0.10);
  box-shadow: -20px 0 60px rgba(33,57,67,0.18);
  transition:right .25s ease;
  z-index:999;
  padding:18px;
  overflow-y: auto;
}
.drawer.open{right:0}
.drawer-backdrop.open{opacity:1; pointer-events:auto}
.drawer h3{margin:6px 0 14px}
.drawer a{display:block; padding:12px 12px; border-radius:16px; border:1px solid rgba(33,57,67,0.10); margin-bottom:10px; transition: all 0.2s ease;}
.drawer a:hover{background:rgba(159,120,255,0.08)}

/* HERO SECTION */
.hero{padding: 52px 0 18px;}
.hero-grid{display:grid; grid-template-columns: 1.05fr 0.95fr; gap: 26px; align-items:center;}
.hero-card{
  border-radius: var(--radius);
  background: var(--card);
  border:1px solid var(--border);
  box-shadow: var(--shadow);
  padding: 26px;
}
.kicker{
  display:inline-flex; gap:10px; align-items:center;
  padding: 10px 12px; border-radius: 999px;
  background: rgba(248,154,188,0.18);
  border: 1px solid rgba(248,154,188,0.35);
  font-weight:600;
  font-size: 13px;
}
.kicker .dot{width:10px;height:10px;border-radius:999px;background:var(--pink);}

h1{margin:16px 0 10px; line-height:1.05; font-size: clamp(30px, 3.2vw, 48px); font-weight: 800;}
.lead{margin:0 0 18px; font-size: 16px; opacity:0.92; line-height: 1.45;}

/* URGENCY BOX */
.urgency-box{
  background: linear-gradient(135deg, rgba(248,154,188,0.15), rgba(159,120,255,0.15));
  border: 1px solid rgba(248,154,188,0.35);
  border-radius: 16px;
  padding: 14px 16px;
  margin: 16px 0;
}
.urgency-badge{
  display: inline-block;
  background: linear-gradient(90deg, var(--pink), var(--purple));
  color: white;
  padding: 6px 12px;
  border-radius: 999px;
  font-weight: 700;
  font-size: 12px;
}
.urgency-text{
  margin: 8px 0 0;
  font-size: 14px;
  font-weight: 600;
}

/* SOCIAL PROOF */
.social-proof{
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
  margin: 16px 0;
  padding: 12px 0;
  border-top: 1px solid rgba(33,57,67,0.10);
  border-bottom: 1px solid rgba(33,57,67,0.10);
}
.proof-item{
  font-size: 13px;
  font-weight: 600;
  display: flex;
  align-items: center;
  gap: 6px;
}

/* CTA BUTTONS */
.cta-row{display:flex; gap:12px; flex-wrap:wrap; align-items:center; margin: 16px 0;}
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  padding: 12px 16px;
  border-radius: 18px;
  border: 1px solid rgba(33,57,67,0.10);
  background: #fff;
  box-shadow: 0 12px 30px rgba(33,57,67,0.12);
  font-weight:700;
  cursor: pointer;
  transition: all 0.2s ease;
  font-size: 14px;
}
.btn-primary{
  color:#fff;
  border: 0;
  background: linear-gradient(90deg, var(--purple), var(--blue));
}
.btn-primary:hover{
  filter: brightness(1.05);
  transform: translateY(-2px);
  box-shadow: 0 16px 40px rgba(159,120,255,0.3);
}
.btn-secondary:hover{
  background: rgba(159,120,255,0.06);
  transform: translateY(-2px);
}

.countdown{
  display:grid; grid-template-columns: repeat(4,1fr);
  gap: 10px; margin-top: 16px;
}
.timebox{
  border-radius: 18px;
  background: rgba(255,255,255,0.90);
  border: 1px solid rgba(33,57,67,0.10);
  padding: 12px 10px;
  text-align:center;
}
.timebox b{display:block; font-size: 26px; line-height:1;}
.timebox span{font-size: 12px; opacity:0.75; font-weight:600}

.hero-art{
  position:relative;
  border-radius: var(--radius);
  overflow:hidden;
  background: linear-gradient(180deg, rgba(248,154,188,0.12), rgba(159,120,255,0.16));
  border:1px solid rgba(33,57,67,0.10);
  box-shadow: var(--shadow);
  min-height: 420px;
}
.hero-art .bgimg{position:absolute; inset:0; width:100%; height:100%; object-fit:cover; opacity:0.92;}
.hero-art .overlay{position:absolute; inset:0; background: radial-gradient(700px 400px at 20% 20%, rgba(255,255,255,0.55), transparent 60%),
                                   linear-gradient(180deg, rgba(0,0,0,0.00), rgba(0,0,0,0.10));}
.hero-art .sticker{position:absolute; top:16px; left:16px; width:180px; height:auto;}
.hero-art .tagline{position:absolute; left:16px; right:16px; bottom:18px; color:#fff; text-shadow: 0 10px 30px rgba(0,0,0,0.35);}
.hero-art .tagline h2{margin:0; font-size: 26px; line-height:1.15;}
.hero-art .tagline p{margin:8px 0 0; opacity:0.95}

/* SECTIONS */
.section{padding: 36px 0;}
.section-title{display:flex; align-items:flex-end; justify-content:space-between; gap:14px; margin-bottom: 14px;}
.section-title h2{margin:0; font-size: 26px; font-weight: 700;}
.section-title p{margin:0; opacity:0.78; font-size: 14px;}

.grid-2{display:grid; grid-template-columns: 1fr 1fr; gap: 18px;}
.grid-3{display:grid; grid-template-columns: repeat(3,1fr); gap: 18px;}
.card{border-radius: var(--radius); background: var(--card); border:1px solid var(--border); box-shadow: var(--shadow); padding: 18px;}
.card h3{margin: 0 0 10px; font-weight: 700;}
.badges{display:flex; gap:10px; flex-wrap:wrap; margin-top: 12px}
.badge{display:inline-flex; align-items:center; gap:8px; padding: 10px 12px; border-radius: 999px; border:1px solid rgba(33,57,67,0.10); background: rgba(255,255,255,0.88); font-weight:600; font-size: 13px;}
.badge .mini{width:22px;height:22px; border-radius:8px; display:inline-grid; place-items:center; background: rgba(248,154,188,0.20);}

/* STEP NUMBERS */
.step-number{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--purple), var(--blue));
  color: white;
  font-weight: 800;
  font-size: 20px;
  margin-bottom: 12px;
}

/* BENEFITS GRID */
.benefits-grid{
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
}
.benefit-card{
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 20px;
  text-align: center;
  transition: all 0.3s ease;
}
.benefit-card:hover{
  transform: translateY(-4px);
  box-shadow: var(--shadow);
}
.benefit-icon{
  font-size: 40px;
  margin-bottom: 12px;
}
.benefit-card h3{
  margin: 0 0 8px;
  font-size: 16px;
}
.benefit-card p{
  margin: 0;
  font-size: 13px;
  opacity: 0.85;
  line-height: 1.5;
}

/* PRODUCTS */
.products{display:grid; grid-template-columns: repeat(4,1fr); gap: 14px;}
.product{
  border-radius: 22px;
  background: rgba(255,255,255,0.92);
  border: 1px solid rgba(33,57,67,0.12);
  box-shadow: 0 16px 40px rgba(33,57,67,0.12);
  overflow:hidden;
  display:flex; flex-direction:column;
  transition: all 0.3s ease;
}
.product:hover{
  transform: translateY(-4px);
  box-shadow: 0 24px 60px rgba(33,57,67,0.18);
}
.product .imgwrap{height: 180px; display:grid; place-items:center; background: radial-gradient(420px 220px at 60% 0%, rgba(159,120,255,0.14), transparent 60%),
                                                               radial-gradient(360px 220px at 10% 20%, rgba(248,154,188,0.14), transparent 55%);}
.product img{max-height: 180px; width:auto;}
.product .pbody{padding: 14px 14px 16px; display:flex; flex-direction:column; gap:8px;}
.product .ptop{display:flex; align-items:center; justify-content:space-between; gap:10px}
.product .ptop b{font-size: 14px; font-weight: 700;}
.product .icon{width:34px;height:34px; border-radius: 14px; background: rgba(248,154,188,0.20); border: 1px solid rgba(248,154,188,0.35); display:grid; place-items:center; overflow:hidden;}
.product .icon img{width:24px;height:24px;}
.product p{margin:0; font-size: 13px; opacity:0.88; line-height: 1.5;}
.product .meta{display:flex; gap:8px; flex-wrap:wrap; margin-top: 4px}
.pill{font-size: 12px; padding: 7px 10px; border-radius: 999px; border:1px solid rgba(33,57,67,0.10); background: rgba(244,239,234,0.65); font-weight:600;}

/* TABLE */
.table-wrap{overflow:auto; border-radius: var(--radius); border:1px solid rgba(33,57,67,0.10); box-shadow: var(--shadow);}
table{border-collapse:collapse; width:100%; min-width:760px; background: rgba(255,255,255,0.94)}
th,td{padding: 14px 14px; border-bottom:1px solid rgba(33,57,67,0.08); text-align:left;}
th{background: rgba(159,120,255,0.10); font-size: 13px; letter-spacing:0.2px; text-transform: uppercase; font-weight: 700;}
th.highlight{background: linear-gradient(135deg, rgba(159,120,255,0.15), rgba(248,154,188,0.15));}
td.highlight{background: rgba(248,154,188,0.08); font-weight: 600;}
tr:hover td{background: rgba(248,154,188,0.06)}
.total-row td{background:rgba(128,90,213,0.06); font-weight: 700;}
.savings-row td{background:rgba(159,120,255,0.10); font-weight: 700; color: var(--purple);}

.savings-highlight{
  background: linear-gradient(135deg, rgba(159,120,255,0.15), rgba(248,154,188,0.15));
  border: 1px solid rgba(248,154,188,0.35);
  border-radius: 16px;
  padding: 16px;
  margin-top: 16px;
  text-align: center;
  font-size: 16px;
  font-weight: 700;
}

/* TESTIMONIALS */
.testimonials-grid{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}
.testimonial{
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 20px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.testimonial .stars{
  font-size: 14px;
  letter-spacing: 2px;
}
.testimonial .quote{
  font-size: 14px;
  line-height: 1.6;
  font-style: italic;
  margin: 0;
  color: rgba(33,57,67,0.92);
}
.testimonial .author{
  display: flex;
  gap: 12px;
  align-items: center;
  margin-top: 8px;
  padding-top: 12px;
  border-top: 1px solid rgba(33,57,67,0.10);
}
.testimonial .avatar{
  font-size: 32px;
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(159,120,255,0.15);
  border-radius: 50%;
}
.testimonial .author strong{
  display: block;
  font-size: 13px;
}
.testimonial .author small{
  display: block;
  font-size: 12px;
  opacity: 0.75;
}

/* GUARANTEE */
.guarantee-section{
  background: linear-gradient(135deg, rgba(42,160,109,0.15), rgba(159,120,255,0.15));
}
.guarantee-box{
  background: var(--card);
  border: 2px solid var(--green);
  border-radius: var(--radius);
  padding: 32px;
  text-align: center;
}
.guarantee-box h2{
  margin: 0 0 12px;
  font-size: 24px;
  color: var(--green);
}
.guarantee-box p{
  margin: 0 0 8px;
  font-size: 16px;
  font-weight: 600;
}
.guarantee-note{
  opacity: 0.85;
  font-weight: 400;
}

/* FAQ */
.faq{display:grid; gap:12px;}
.faq details{background:#fff; border:1px solid rgba(33,57,67,.10); border-radius:16px; padding:12px 14px; box-shadow:0 8px 20px rgba(33,57,67,.06); transition: all 0.2s ease;}
.faq details[open]{
  background: rgba(159,120,255,0.05);
  border-color: rgba(159,120,255,0.35);
}
.faq summary{cursor:pointer; font-weight:700; list-style:none; font-size: 14px;}
.faq summary::-webkit-details-marker{display:none}
.faq summary::before{
  content: "▸";
  display: inline-block;
  margin-right: 8px;
  transition: transform 0.2s ease;
}
.faq details[open] summary::before{
  transform: rotate(90deg);
}
.faq .faq-body{margin-top:10px; color:rgba(33,57,67,.92); line-height:1.55; font-size: 13px;}

/* FORM */
.form-step{
  display: none;
}
.form-step.active{
  display: block;
}
.form-step-title{
  margin: 0 0 16px;
  font-size: 16px;
  font-weight: 700;
  color: var(--purple);
}

.form-grid{display:grid; grid-template-columns: 1fr 1fr; gap: 12px;}
label{font-size: 12px; font-weight:700; opacity:0.85; display:block; margin: 0 0 6px}
input, select{
  width:100%;
  padding: 12px 12px;
  border-radius: 16px;
  border: 1px solid rgba(33,57,67,0.14);
  background: rgba(255,255,255,0.92);
  outline:none;
  font-family: inherit;
  font-size: 14px;
  transition: all 0.2s ease;
}
input:focus, select:focus{
  border-color: rgba(159,120,255,0.65);
  box-shadow: 0 0 0 4px rgba(159,120,255,0.14);
}
input.success, select.success{
  border-color: var(--green);
  box-shadow: 0 0 0 4px rgba(42,160,109,0.14);
}
input.error, select.error{
  border-color: #D63B3B;
  box-shadow: 0 0 0 4px rgba(214,59,59,0.14);
}

.field{
  display: flex;
  flex-direction: column;
}
.field-2{grid-column: span 2;}

.small{font-size: 12px; opacity:0.76}
.error{
  color: #D63B3B;
  font-size: 12px;
  margin-top: 4px;
  display: block;
  min-height: 16px;
}
.error:empty{
  display: none;
}

.form-actions{
  display: flex;
  gap: 12px;
  margin-top: 20px;
  align-items: center;
}
.form-note{
  font-size: 12px;
  opacity: 0.75;
  margin-top: 12px;
  text-align: center;
}

/* FOOTER */
.footer{
  padding: 28px 0 42px;
  border-top: 1px solid rgba(33,57,67,0.10);
  background: linear-gradient(180deg, rgba(255,255,255,0.0), rgba(122,160,255,0.08));
}
.footer-grid{display:grid; grid-template-columns: 1.1fr 0.9fr; gap: 18px; align-items:start}
.footer small{display:block; opacity:0.78; line-height:1.55; font-size: 12px;}
.footer .mini-logo{width:110px; opacity:0.95}

/* RESPONSIVE */
@media (max-width: 980px){
  .hero-grid{grid-template-columns:1fr;}
  .products{grid-template-columns: repeat(2,1fr);}
  .grid-3{grid-template-columns: repeat(2,1fr);}
  .benefits-grid{grid-template-columns: repeat(2,1fr);}
  .testimonials-grid{grid-template-columns: repeat(2,1fr);}
}

@media (max-width: 768px){
  .hero-grid{grid-template-columns:1fr !important; gap:18px !important;}
  .cta-row{flex-direction:column; align-items:stretch;}
  .cta-row .btn{width:100%; justify-content:center;}
  .countdown{grid-template-columns:repeat(4,1fr);}
  .section{padding:44px 0;}
  .header{position:sticky; top:0; z-index:999;}
  main{padding-top:0;}
  .drawer{width:min(92vw, 360px);}
  .card{padding:16px;}
  .products{grid-template-columns:1fr !important;}
  .grid-3{grid-template-columns: 1fr !important;}
  .benefits-grid{grid-template-columns: 1fr !important;}
  .testimonials-grid{grid-template-columns: 1fr !important;}
  .form-grid{grid-template-columns: 1fr;}
  .field-2{grid-column: span 1;}
}

@media (max-width: 520px){
  .countdown{grid-template-columns: repeat(2,1fr);}
  .products{grid-template-columns: 1fr;}
  .form-grid{grid-template-columns: 1fr;}
  .drawer{width: 88vw}
  .social-proof{
    flex-direction: column;
    gap: 8px;
  }
  .proof-item{
    justify-content: center;
  }
}

@media (max-width: 480px){
  .header-inner{min-height:56px;}
  .brand img{height:34px; width:auto;}
  .icon-btn{width:36px; height:36px;}
  .hamburger{width:40px; height:40px;}
  .countdown{grid-template-columns:repeat(2,1fr); gap:10px;}
  .hero-card{padding:18px;}
  .hero h1{font-size:clamp(28px,3.2vw,44px); line-height:1.08; letter-spacing:-0.02em; margin:0 0 12px; font-weight:800;}
  .lead{font-size:16px;}
  .kicker{font-size:12px;}
  html{scroll-padding-top:70px;}
  section[id]{scroll-margin-top:70px;}
  .section-title{flex-direction: column; align-items: flex-start;}
  .section-title h2{font-size: 20px;}
  .section-title p{font-size: 12px;}
  .urgency-box{padding: 12px 14px;}
  .guarantee-box{padding: 20px;}
  .guarantee-box h2{font-size: 18px;}
  .footer-grid{grid-template-columns: 1fr;}
}

/* ANIMATIONS */
@keyframes slideIn {
  from {
    opacity: 0;
    transform: translateY(10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.product, .benefit-card, .testimonial, .card {
  animation: slideIn 0.5s ease-out;
}

/* UTILITY */
.highlight{
  color: var(--purple);
  font-weight: 700;
}



/* ---- Yupa.PET overrides (final) ---- */
.hero h1{
  font-size: clamp(28px, 4.6vw, 46px);
  line-height: 1.08;
  letter-spacing: -0.02em;
}
.hero .lead{
  font-size: clamp(15px, 1.5vw, 18px);
  line-height: 1.55;
}
.section-title h2{
  font-size: clamp(22px, 3.2vw, 34px);
  line-height: 1.15;
}
.section-title p{
  font-size: 16px;
  line-height: 1.6;
}
.grid-4{
  display:grid;
  grid-template-columns: repeat(4, minmax(0,1fr));
  gap: 14px;
}
.mini-card{
  background: rgba(255,255,255,0.9);
  border: 1px solid rgba(0,0,0,0.06);
  border-radius: 16px;
  padding: 16px;
}
.mini-ico{
  width: 42px;
  height: 42px;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius: 12px;
  background: rgba(0,0,0,0.04);
  margin-bottom: 10px;
  font-size: 20px;
}
.mini-card h3{
  margin: 0 0 6px 0;
  font-size: 16px;
}
.mini-card p{
  margin: 0;
  color: rgba(0,0,0,0.72);
  font-size: 14px;
  line-height: 1.55;
}
.compare .savings-row td[colspan="2"]{
  font-weight: 700;
}
@media (max-width: 980px){
  .grid-4{ grid-template-columns: repeat(2, minmax(0,1fr)); }
}
@media (max-width: 560px){
  .grid-4{ grid-template-columns: 1fr; }
  .hero-grid{ grid-template-columns: 1fr !important; }
  .hero-art{ order: -1; }
  .countdown{ gap: 8px; }
  .timebox b{ font-size: 18px; }
}

/* Success box + upsell */
.success-box{
  background: rgba(255,255,255,0.92);
  border: 1px solid rgba(0,0,0,0.08);
  border-radius: 18px;
  padding: 18px;
  margin: 0 0 14px 0;
}
.success-box h3{ margin: 0 0 6px 0; }
.success-actions{ display:flex; gap:10px; flex-wrap:wrap; margin-top:10px; }
.upsell{ margin-top:14px; padding-top:14px; border-top:1px dashed rgba(0,0,0,0.12); }
.mini-grid{ display:grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap:12px; margin: 10px 0 10px; }
.muted{ display:block; color: rgba(0,0,0,0.6); margin-top: 8px; }
@media (max-width: 780px){
  .mini-grid{ grid-template-columns: 1fr; }
}



/* v9 design system adjustments */
:root{
  --container: 1120px;
}
body{ overflow-x:hidden; }
.h1{ font-size: clamp(2rem, 3vw, 3rem); line-height: 1.05; letter-spacing: -0.02em; margin: 0 0 10px; }
.section-head .h1{ margin-top: 0; }

.topbar{ position: sticky; top: 0; z-index: 50; backdrop-filter: blur(10px); background: rgba(255,255,255,.78); border-bottom: 1px solid rgba(0,0,0,.06); }
.topbar-inner{ display:flex; align-items:center; justify-content:space-between; gap:14px; padding: 12px 0; }
.brand-logo{ height: 28px; width: auto; display:block; }
.icon-btn{ width: 40px; height: 40px; border-radius: 12px; display:flex; align-items:center; justify-content:center; border: 1px solid rgba(0,0,0,.08); background: rgba(255,255,255,.9); color: var(--text); }
.icon-btn:hover{ transform: translateY(-1px); box-shadow: 0 10px 24px rgba(0,0,0,.10); }
.hide-mobile{ display:inline-flex; }
@media(max-width: 820px){ .hide-mobile{ display:none; } }

.hero{ padding: 26px 0 8px; }
.hero-grid{ display:grid; grid-template-columns: 1.1fr .9fr; gap: 22px; align-items: stretch; }
@media(max-width: 980px){ .hero-grid{ grid-template-columns: 1fr; } }
.hero-card{ border-radius: 24px; padding: 22px; background: linear-gradient(180deg, rgba(255,255,255,.88), rgba(255,255,255,.72)); border: 1px solid rgba(0,0,0,.06); box-shadow: 0 16px 50px rgba(0,0,0,.06); }
.hero-card h1{ font-size: clamp(2.2rem, 3.2vw, 3.4rem); line-height: 1.02; margin: 12px 0 10px; letter-spacing: -0.03em;}
.lead{ font-size: 1.04rem; line-height: 1.55; margin: 0 0 16px; }

.pill{ display:inline-flex; align-items:center; gap:10px; padding: 10px 12px; border-radius: 999px; background: rgba(255, 224, 239, .65); border: 1px solid rgba(255, 140, 190, .35); font-weight: 600; }
.pill .dot{ width: 8px; height: 8px; border-radius: 99px; background: #ff4fa3; }

.trust-row{ display:flex; flex-wrap:wrap; gap: 10px 14px; margin: 12px 0 14px; }
.trust-item{ display:flex; align-items:center; gap: 8px; padding: 8px 10px; border-radius: 14px; border: 1px solid rgba(0,0,0,.06); background: rgba(255,255,255,.8); }
.trust-item strong{ font-weight: 800; }

.countdown{ margin-top: 10px; }
.countdown-label{ font-weight: 700; margin-bottom: 10px; }
.countdown-grid{ display:grid; grid-template-columns: repeat(4, 1fr); gap: 10px; }
.count-box{ border-radius: 18px; padding: 14px; background: rgba(255,255,255,.85); border: 1px solid rgba(0,0,0,.06); text-align:center; }
.count-num{ font-size: 1.7rem; font-weight: 800; line-height: 1; }
.count-lab{ color: rgba(0,0,0,.60); font-weight: 600; margin-top: 4px; }

.chip-row{ display:flex; flex-wrap:wrap; gap: 10px; margin-top: 12px; }
.chip{ padding: 10px 12px; border-radius: 999px; background: rgba(255,255,255,.85); border: 1px solid rgba(0,0,0,.06); font-weight: 700; }

.hero-media-card{ border-radius: 24px; overflow:hidden; border: 1px solid rgba(0,0,0,.06); box-shadow: 0 16px 50px rgba(0,0,0,.06); background: #fff; height: 100%; min-height: 360px; }
.hero-img{ width:100%; height:100%; object-fit: cover; display:block; }

.section{ padding: 56px 0; }
.section.soft{ background: linear-gradient(180deg, rgba(141,124,255,.12), rgba(255,255,255,0)); }
.section-head{ display:flex; align-items:flex-end; justify-content:space-between; gap: 16px; margin-bottom: 18px; }
.section-head h2{ margin:0; font-size: clamp(1.6rem, 2.2vw, 2.2rem); letter-spacing: -0.02em; }
.section-head p{ margin:0; max-width: 560px; }

.cards-4{ display:grid; grid-template-columns: repeat(4,1fr); gap: 14px; }
@media(max-width: 980px){ .cards-4{ grid-template-columns: repeat(2,1fr); } }
@media(max-width: 560px){ .cards-4{ grid-template-columns: 1fr; } }
.card{ border-radius: 22px; padding: 18px; border: 1px solid rgba(0,0,0,.06); background: rgba(255,255,255,.88); box-shadow: 0 10px 30px rgba(0,0,0,.04); }
.card-ico{ font-size: 26px; margin-bottom: 10px; }
.card h3{ margin: 0 0 6px; font-size: 1.05rem; }
.card p{ margin:0; color: rgba(0,0,0,.68); }

.steps{ display:grid; grid-template-columns: repeat(3, 1fr); gap: 12px; }
@media(max-width: 980px){ .steps{ grid-template-columns: 1fr; } }
.step{ border-radius: 22px; padding: 18px; background: rgba(255,255,255,.88); border: 1px solid rgba(0,0,0,.06); }
.step-n{ width: 36px; height: 36px; border-radius: 14px; display:flex; align-items:center; justify-content:center; font-weight: 800; background: rgba(141,124,255,.18); }
.step-t{ margin-top: 10px; font-weight: 800; }
.step-p{ margin-top: 6px; color: rgba(0,0,0,.68); }

.two-col{ display:grid; grid-template-columns: 1.1fr .9fr; gap: 18px; align-items:start; }
@media(max-width: 980px){ .two-col{ grid-template-columns: 1fr; } }
.checklist{ list-style:none; padding: 0; margin: 14px 0 0; }
.checklist li{ padding: 10px 12px; border-radius: 16px; border: 1px solid rgba(0,0,0,.06); background: rgba(255,255,255,.88); margin-bottom: 10px; }
.note{ margin-top: 14px; padding: 14px; border-radius: 18px; border: 1px solid rgba(255, 140, 190, .35); background: rgba(255, 224, 239, .45); }

.routine-card{ border-radius: 24px; padding: 18px; border: 1px solid rgba(0,0,0,.06); background: rgba(255,255,255,.88); box-shadow: 0 12px 36px rgba(0,0,0,.05); }
.routine-badge{ display:inline-flex; padding: 8px 10px; border-radius: 999px; background: rgba(141,124,255,.16); font-weight: 800; margin-bottom: 14px; }
.routine-grid{ display:grid; grid-template-columns: repeat(2, 1fr); gap: 12px; }
.routine-item{ display:flex; align-items:center; gap: 10px; padding: 10px 12px; border-radius: 18px; border: 1px solid rgba(0,0,0,.06); background: rgba(255,255,255,.92); }
.routine-item img{ width: 56px; height: 56px; object-fit: contain; border-radius: 14px; background: #fff; }
.routine-item span{ display:block; color: rgba(0,0,0,.62); font-size: .92rem; margin-top: 2px; }

.table-wrap{ border-radius: 24px; overflow:hidden; border: 1px solid rgba(0,0,0,.06); background: rgba(255,255,255,.92); }
.price-table{ width: 100%; border-collapse: collapse; }
.price-table th, .price-table td{ padding: 14px 14px; border-bottom: 1px solid rgba(0,0,0,.06); text-align:left; }
.price-table thead th{ background: rgba(141,124,255,.12); font-weight: 800; font-size: .88rem; text-transform: uppercase; letter-spacing: .06em; }
.price-table .col-highlight{ background: rgba(255, 224, 239, .30); font-weight: 700; }
.price-table tr.total td{ background: rgba(0,0,0,.03); }
.price-table tr.econ td{ background: rgba(141,124,255,.06); }
@media(max-width: 720px){
  .table-wrap{ overflow:auto; }
  .price-table{ min-width: 720px; }
}

.ig-grid{ display:grid; grid-template-columns: repeat(4,1fr); gap: 14px; }
@media(max-width: 980px){ .ig-grid{ grid-template-columns: repeat(2,1fr); } }
@media(max-width: 560px){ .ig-grid{ grid-template-columns: 1fr; } }
.ig-card{ border-radius: 22px; overflow:hidden; border: 1px solid rgba(0,0,0,.06); background: rgba(255,255,255,.88); box-shadow: 0 10px 30px rgba(0,0,0,.04); }
.ig-card img{ width:100%; height: 220px; object-fit: cover; display:block; }
.ig-body{ padding: 14px; }
.ig-body h3{ margin:0 0 6px; }
.ig-body p{ margin:0; color: rgba(0,0,0,.68); }

.testimonials{ display:grid; grid-template-columns: repeat(3,1fr); gap: 14px; }
@media(max-width: 980px){ .testimonials{ grid-template-columns: 1fr; } }
.t-card{ border-radius: 22px; padding: 18px; border: 1px solid rgba(0,0,0,.06); background: rgba(255,255,255,.92); }
.stars{ letter-spacing: 2px; margin-bottom: 8px; }
.t-user{ margin-top: 12px; font-weight: 800; }
.t-user span{ display:block; color: rgba(0,0,0,.62); font-weight: 600; font-size: .92rem; }

.guarantee{ margin-top: 16px; border-radius: 24px; padding: 18px; border: 2px solid rgba(45, 165, 98, .65); background: rgba(45, 165, 98, .08); }
.g-title{ font-weight: 900; font-size: 1.12rem; }
.g-text{ margin-top: 6px; color: rgba(0,0,0,.75); }

.faq details{ border-radius: 18px; border: 1px solid rgba(0,0,0,.06); background: rgba(255,255,255,.9); padding: 12px 14px; margin-bottom: 10px; }
.faq summary{ cursor:pointer; font-weight: 800; }
.faq-body{ margin-top: 10px; color: rgba(0,0,0,.72); }

.form-wrap{ border-radius: 24px; padding: 18px; background: rgba(255,255,255,.92); border: 1px solid rgba(0,0,0,.06); }
.form-grid{ display:grid; grid-template-columns: repeat(2, 1fr); gap: 12px; }
.field-wide{ grid-column: span 2; }
@media(max-width: 720px){ .form-grid{ grid-template-columns: 1fr; } .field-wide{ grid-column: auto; } }
.field label{ display:block; font-weight: 800; margin-bottom: 6px; }
.field input, .field select{ width:100%; padding: 12px 12px; border-radius: 14px; border: 1px solid rgba(0,0,0,.12); background: #fff; font: inherit; }
.field input:focus, .field select:focus{ outline: none; border-color: rgba(141,124,255,.75); box-shadow: 0 0 0 4px rgba(141,124,255,.15); }
.err{ display:block; min-height: 16px; color: #b00020; font-weight: 700; margin-top: 6px; }
.form-actions{ display:flex; flex-wrap:wrap; gap: 10px; margin-top: 12px; }

.toast-wrap{ padding: 14px 0 0; }
.toast{ border-radius: 24px; padding: 16px; border: 1px solid rgba(0,0,0,.06); background: rgba(255,255,255,.92); box-shadow: 0 12px 30px rgba(0,0,0,.06); }
.toast.success{ border-color: rgba(45,165,98,.55); }
.toast.danger{ border-color: rgba(176,0,32,.55); background: rgba(255, 222, 227, .55); }
.toast-title{ font-weight: 900; font-size: 1.05rem; }
.toast-actions{ display:flex; flex-wrap:wrap; gap: 10px; margin-top: 12px; }

.footer{ padding: 30px 0; border-top: 1px solid rgba(0,0,0,.06); background: rgba(255,255,255,.85); }
.footer-grid{ display:grid; grid-template-columns: 1.4fr .8fr .8fr; gap: 16px; }
@media(max-width: 980px){ .footer-grid{ grid-template-columns: 1fr; } }
.footer-logo{ height: 26px; width: auto; margin-bottom: 10px; }
.footer-links{ display:flex; flex-direction: column; gap: 10px; }
.footer-links a{ color: rgba(0,0,0,.72); font-weight: 700; text-decoration:none; }
.footer-links a:hover{ text-decoration: underline; }
.footer-bottom{ padding-top: 14px; }

.prose{ max-width: 820px; }
.prose h1{ margin-top: 0; }
.prose h2{ margin-top: 28px; }
.routine-page{ margin-top: 18px; }
.routine-timeline{ display:grid; grid-template-columns: 1fr; gap: 12px; margin-bottom: 18px; }
.rt-item{ display:flex; gap: 12px; align-items:flex-start; padding: 14px; border-radius: 22px; border: 1px solid rgba(0,0,0,.06); background: rgba(255,255,255,.92); }
.rt-dot{ width: 34px; height: 34px; border-radius: 14px; display:flex; align-items:center; justify-content:center; font-weight: 900; background: rgba(141,124,255,.16); flex: 0 0 auto; }
.rt-title{ font-weight: 900; }
.rt-text{ margin-top: 4px; color: rgba(0,0,0,.68); }

.product-grid{ display:grid; grid-template-columns: repeat(4, 1fr); gap: 14px; }
@media(max-width: 1100px){ .product-grid{ grid-template-columns: repeat(2,1fr); } }
@media(max-width: 560px){ .product-grid{ grid-template-columns: 1fr; } }
.p-card{ border-radius: 22px; padding: 16px; border: 1px solid rgba(0,0,0,.06); background: rgba(255,255,255,.92); }
.p-card img{ width:100%; height: 210px; object-fit: contain; border-radius: 18px; background: #fff; border: 1px solid rgba(0,0,0,.06); }
.p-card h3{ margin: 12px 0 6px; }
.p-card p{ margin: 0; color: rgba(0,0,0,.68); }
