html{scroll-behavior:smooth}
*{box-sizing:border-box}
body{margin:0;font-family:Poppins,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;color:#223;line-height:1.6;background:#fff}
.header{background:#ffb703;color:#fff;padding:28px 0;text-align:center}
.header .logo img{max-width:420px;height:auto;display:block;margin:0 auto 10px auto}
@media (max-width:520px){.header .logo img{max-width:280px}}
.header h1{margin:0 0 6px 0;font-size:2rem;letter-spacing:.5px}
.nav{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;background:#023047}
.nav a{color:#fff;text-decoration:none;padding:12px 18px;border-radius:6px}
.nav a:hover{background:#ffb703;color:#102}
.section{padding:48px 16px}
.section.alt{background:#f6f8fb}
.container{max-width:1100px;margin:0 auto}
.container.narrow{max-width:760px}
h2{color:#023047;margin:0 0 16px 0;text-transform:uppercase;letter-spacing:.5px}
.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px}
.card{background:#fff;border:1px solid #e8eef5;border-radius:12px;padding:18px;box-shadow:0 2px 6px rgba(0,0,0,.05)}
.card img.prod-thumb{width:100%;height:auto;aspect-ratio:1/1;object-fit:cover;border-radius:12px}
.form{display:grid;gap:12px}
.form input,.form textarea,.form select{padding:12px;border:1px solid #ccd6e3;border-radius:10px;font-size:1rem}
.form button{padding:12px 18px;background:#023047;color:#fff;border:none;border-radius:10px;font-weight:600;cursor:pointer}
.form button:hover{background:#ffb703;color:#102}
.company-data{margin-top:12px;color:#555}
.footer{background:#023047;color:#fff;text-align:center;padding:24px 16px;position:relative}
.footer-sep{height:3px;background:#ffb703;opacity:.9}
.footer .links{margin-top:10px;font-weight:600;letter-spacing:.2px}
.hp{display:none !important}
.cf-turnstile{margin:12px 0}
.map-wrap{padding-top:24px;padding-bottom:24px;background:#f6f8fb}
.map-container{max-width:760px;text-align:center}
.map-frame{display:flex;justify-content:center}
.map-frame iframe{border-radius:14px;border:2px solid #ffb703}
.footer-flex{display:grid;grid-template-columns:1fr 1fr;gap:20px;align-items:start;justify-content:center;margin:10px 0 4px 0}
@media (max-width:720px){.footer-flex{grid-template-columns:1fr}}
.footer h3{margin:0 0 8px 0;color:#fff}
.form-inline{display:grid;grid-template-columns:1fr;gap:8px;justify-items:center}
.form-inline input[type="email"]{width:100%;max-width:360px;padding:10px;border-radius:10px;border:1px solid #ccd6e3}
.form-inline .privacy{font-size:.9rem;color:#e9edf3}
.form-inline button{background:#ffb703;color:#102;border:none;border-radius:10px;padding:10px 14px;font-weight:700;cursor:pointer}
.social-colored.horiz{list-style:none;padding:0;margin:8px 0;display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.social-colored.horiz li a{display:flex;align-items:center;gap:8px;text-decoration:none;color:#fff;font-weight:600}
.brand-ico{width:24px;height:24px;display:inline-block}
.payments{margin:12px 0}
.payments img{max-width:820px;width:100%;height:auto;border-radius:8px;display:inline-block}
.whatsapp-float{position:fixed;right:18px;bottom:18px;z-index:9999;width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:#25D366;color:#fff;text-decoration:none;box-shadow:0 6px 18px rgba(0,0,0,.18)}
.whatsapp-float svg{width:28px;height:28px;fill:#fff}
.back-to-top{position:fixed;right:18px;bottom:86px;z-index:9998;width:44px;height:44px;border:0;border-radius:50%;background:#ffb703;color:#102;font-weight:900;font-size:20px}
/* Galleria: 3 colonne + popup */
.gallery-page{background:linear-gradient(180deg,#f3f5f8 0%, #eef2f7 100%)}
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
@media (max-width:960px){.gallery-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:540px){.gallery-grid{grid-template-columns:1fr}}
.gthumb{display:block;border:1px solid #e6ecf5;border-radius:12px;overflow:hidden;background:#fff}
.gthumb img{width:100%;height:auto;display:block}
.lightbox{position:fixed;inset:0;background:rgba(0,0,0,.8);display:none;align-items:center;justify-content:center;padding:16px;z-index:10000}
.lightbox img{max-width:92vw;max-height:90vh;border-radius:12px}
.lightbox.show{display:flex}
.lightbox .nav{position:absolute;top:50%;transform:translateY(-50%);font-size:42px;color:#fff;background:rgba(0,0,0,.35);border:0;width:56px;height:56px;border-radius:50%;cursor:pointer}
.lightbox .prev{left:14px}.lightbox .next{right:14px}
.lightbox .close{position:absolute;top:14px;right:14px;font-size:32px;color:#fff;background:rgba(0,0,0,.35);border:0;width:48px;height:48px;border-radius:50%;cursor:pointer}

.card-link{display:block;text-decoration:none;color:inherit}
.card-link .card{transition:box-shadow .2s ease,transform .2s ease}
.card-link:hover .card{box-shadow:0 4px 12px rgba(0,0,0,.12);transform:translateY(-2px)}

header .container p { color: #000; }

.badge-cat{
  display:inline-block;
  font-size:12px;
  padding:2px 8px;
  border-radius:999px;
  background:#f1f3f5;
  margin-bottom:6px;
}

.responsive-table{
  width:100%;
  overflow-x:auto;
}

.responsive-table table{
  width:100%;
  border-collapse:collapse;
}

.responsive-table th,
.responsive-table td{
  padding:8px 10px;
  border-bottom:1px solid #e6ecf5;
  text-align:left;
}

.btn-outline{
  background:transparent;
  border:1px solid #ccc;
  color:#333;
}

.shop-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  margin-bottom:1rem;
}

.shop-filters{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:.5rem;
  margin-bottom:1.5rem;
  font-size:.9rem;
}

.shop-filters a{
  padding:4px 10px;
  border-radius:999px;
  border:1px solid #ddd;
  text-decoration:none;
  font-size:.85rem;
}

.shop-filters a.active{
  background:#333;
  color:#fff;
  border-color:#333;
}

.user-pill{
  margin-left:16px;
  padding:6px 12px;
  border-radius:999px;
  background:#ffb703;
  color:#102;
  font-size:.9rem;
  font-weight:600;
  display:inline-flex;
  align-items:center;
  gap:6px;
}
.user-link{
  margin-left:10px;
  font-size:.85rem;
}


/* Barra utente loggato sotto il menu */
.nav-userbar{
  background:#ffe8a3;
  color:#102;
  text-align:center;
  padding:6px 10px;
  font-size:.9rem;
}
.nav-userbar strong{
  font-weight:700;
}
.nav-userbar a{
  color:#023047;
  font-weight:600;
  margin-left:10px;
  text-decoration:none;
}
.nav-userbar a:hover{
  text-decoration:underline;
}


/* =========================
   Shop 2.0 – Toolbar filtri
   ========================= */
.sr-only{
  position:absolute!important;
  width:1px;height:1px;
  padding:0;margin:-1px;
  overflow:hidden;clip:rect(0,0,0,0);
  white-space:nowrap;border:0;
}
.shop-toolbar{
  max-width:1100px;
  margin:18px auto 10px;
  padding:14px 14px 10px;
  background:#fff;
  border:1px solid rgba(0,0,0,.08);
  border-radius:14px;
  box-shadow:0 8px 24px rgba(0,0,0,.06);
}
.shop-toolbar__row{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  align-items:center;
}
.shop-toolbar__field{
  display:flex;
  align-items:center;
}
.shop-toolbar__field input,
.shop-toolbar__field select{
  height:40px;
  border-radius:10px;
  border:1px solid rgba(0,0,0,.15);
  padding:0 12px;
  outline:none;
  background:#fff;
}
.shop-toolbar__field--search{
  flex:1 1 320px;
  min-width:260px;
}
.shop-toolbar__field--search input{
  width:100%;
}
.shop-toolbar__actions{
  display:flex;
  gap:8px;
  margin-left:auto;
}
.btn{
  height:40px;
  padding:0 14px;
  border-radius:10px;
  border:1px solid rgba(0,0,0,.15);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  text-decoration:none;
  font-weight:700;
  cursor:pointer;
}
.btn-primary{
  background:#f4b400;
  border-color:#f4b400;
  color:#fff;
}
.btn-primary:hover{ filter:brightness(.95); }
.btn-ghost{
  background:#fff;
  color:#111;
}
.btn-ghost:hover{ background:rgba(0,0,0,.04); }

.shop-toolbar__meta{
  display:flex;
  gap:10px;
  align-items:center;
  margin-top:10px;
  color:rgba(0,0,0,.70);
  font-size:.95rem;
}
.shop-toolbar__badge{
  background:#ffe8a3;
  color:#111;
  padding:4px 10px;
  border-radius:999px;
  font-weight:800;
  font-size:.85rem;
}


.footer a{color:inherit}
.footer .legal-links{margin-top:10px;display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.footer .legal-links a{text-decoration:none;border-bottom:1px solid rgba(255,255,255,.35)}
.footer .legal-links a:hover{border-bottom-color:#fff}
.card ul{margin:0;padding-left:22px}
.card ul li{margin:6px 0}


/* Quantità grammi più leggibile */
.grams-picker{
  width:100%;
  max-width:300px;
  margin:6px auto 2px;
}
.grams-picker__label{
  display:block;
  margin-bottom:8px;
  font-weight:800;
  font-size:1.02rem;
  color:#1e2540;
}
.grams-picker__controls{
  display:grid;
  grid-template-columns:58px minmax(0,1fr) 58px;
  gap:10px;
  align-items:center;
}
.grams-picker__btn{
  width:58px;
  height:58px;
  padding:0;
  border:0;
  border-radius:14px !important;
  background:#f4b400 !important;
  color:#141b34 !important;
  font-size:34px;
  font-weight:900;
  line-height:1;
  display:flex;
  align-items:center;
  justify-content:center;
  box-shadow:0 4px 12px rgba(244,180,0,.25);
}
.grams-picker__btn:hover{ filter:brightness(.97); }
.grams-picker__input-wrap{
  height:58px;
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  align-items:center;
  background:#fffdf7;
  border:2px solid #d9cda3;
  border-radius:16px;
  padding:0 14px;
  box-sizing:border-box;
}
.grams-picker__input{
  width:100%;
  min-width:0;
  height:100%;
  border:0 !important;
  outline:none;
  background:transparent;
  text-align:center;
  font-size:2rem;
  line-height:1;
  font-weight:900;
  color:#141b34;
  padding:0 4px;
  -moz-appearance:textfield;
}
.grams-picker__input::-webkit-outer-spin-button,
.grams-picker__input::-webkit-inner-spin-button{
  -webkit-appearance:none;
  margin:0;
}
.grams-picker__unit{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:28px;
  margin-left:8px;
  font-weight:800;
  font-size:1.5rem;
  color:#6d7487;
}
.grams-quick{
  display:grid !important;
  grid-template-columns:repeat(4, minmax(0,1fr));
  gap:8px;
  margin-top:10px !important;
}
.grams-quick .btn-grams{
  min-height:40px;
  padding:8px 6px !important;
  border-radius:12px !important;
  font-size:.95rem;
  font-weight:800;
  background:#f4b400 !important;
  color:#141b34 !important;
}
.qty-standard-label{
  display:grid;
  gap:6px;
  width:100%;
  max-width:220px;
  font-weight:700;
}
.qty-standard-input{
  width:100%;
  height:46px;
  border:1px solid #ccd6e3;
  border-radius:12px;
  padding:0 12px;
  box-sizing:border-box;
  font-size:1.05rem;
  font-weight:700;
}
@media (max-width:640px){
  .grams-picker{
    max-width:100%;
  }
  .grams-picker__controls{
    grid-template-columns:54px minmax(0,1fr) 54px;
    gap:8px;
  }
  .grams-picker__btn{
    width:54px;
    height:54px;
    font-size:30px;
  }
  .grams-picker__input-wrap{
    height:54px;
    padding:0 12px;
  }
  .grams-picker__input{
    font-size:1.8rem;
  }
  .grams-picker__unit{
    font-size:1.35rem;
    min-width:24px;
  }
  .grams-quick{
    grid-template-columns:repeat(2, minmax(0,1fr));
  }
}


.footer-company{margin:18px 0 10px;opacity:.95;line-height:1.7}
.footer-company p{margin:4px 0}
.footer-company a{color:inherit;text-decoration:underline}
.legal-links a{margin:0 4px}
.privacy a{color:inherit;text-decoration:underline;font-weight:700}
.legal-page{background:#fff;border-radius:18px;box-shadow:0 10px 35px rgba(0,0,0,.08);padding:34px}
.legal-page h1,.legal-page h2{margin-top:0}
.cookie-banner{position:fixed;left:24px;right:24px;bottom:24px;z-index:9999;background:rgba(20,20,20,.96);color:#fff;border-radius:18px;box-shadow:0 16px 44px rgba(0,0,0,.30);display:flex;align-items:center;justify-content:space-between;gap:18px;padding:18px 22px;backdrop-filter:blur(8px)}
.cookie-banner__text{font-size:15px;line-height:1.6;max-width:820px}
.cookie-banner__text a{color:#fff;text-decoration:underline}
.cookie-banner__actions{display:flex;gap:10px;flex-wrap:wrap}
.cookie-btn{border:0;border-radius:999px;padding:12px 18px;font-weight:700;cursor:pointer;background:#c8a74e;color:#111;box-shadow:0 4px 14px rgba(0,0,0,.18)}
.cookie-btn--secondary{background:#fff;color:#111}
@media (max-width: 768px){.cookie-banner{left:12px;right:12px;bottom:12px;padding:16px;flex-direction:column;align-items:flex-start}.cookie-banner__actions{width:100%}.cookie-btn{width:100%}.legal-page{padding:22px}}

.cookie-btn{text-decoration:none;display:inline-flex;align-items:center;justify-content:center}


/* Spedizione PRO */
.shipping-pro-box{margin-top:10px;padding:12px 14px;border:1px solid #dbe7f3;border-radius:12px;background:linear-gradient(180deg,#f8fbff 0%,#f3f7fb 100%);box-shadow:0 4px 14px rgba(2,48,71,.05)}
.shipping-pro-box--compact{padding:10px 12px;border-radius:10px}
.shipping-pro-box--summary{margin-top:12px}
.shipping-pro-box__top{display:flex;align-items:center;gap:8px;flex-wrap:wrap;color:#0f3554;font-size:.96rem}
.shipping-pro-box__icon{font-size:1rem;line-height:1}
.shipping-pro-box__title{font-weight:800;color:#0b3558}
.shipping-pro-box__eta{font-weight:700;color:#16324f}
.shipping-pro-box__bottom{margin-top:6px;font-size:.9rem;color:#4b5563}
.shipping-pro-box__note{margin-top:6px;font-size:.86rem;color:#52606d}
.shipping-pro-box__badge{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;background:#eaf4ff;color:#0b5ea8;font-weight:700;font-size:.78rem}
@media (max-width:640px){.shipping-pro-box{padding:10px 12px}.shipping-pro-box__top{font-size:.92rem}}

/* Homepage conversione pulita */
.site-topbar{padding:20px 0;background:linear-gradient(180deg,#ffb703 0%,#f2a900 100%);color:#102}
.topbar-inner{display:flex;align-items:center;justify-content:center;gap:22px;text-align:left}
.logo-link{display:block;flex:0 0 auto}
.site-topbar .logo img{max-width:320px;margin:0}
.topbar-copy h1{margin:0 0 4px;font-size:2rem;color:#fff}
.topbar-copy p{margin:0;color:#102;font-weight:500}
.nav-main{position:sticky;top:0;z-index:50;box-shadow:0 6px 18px rgba(0,0,0,.08)}
.home-hero{background:linear-gradient(180deg,#f8fbff 0%,#eef4fb 100%);padding:42px 16px 28px;border-bottom:1px solid #e4edf7}
.hero-grid{display:grid;grid-template-columns:minmax(0,1.35fr) minmax(280px,.8fr);gap:24px;align-items:stretch}
.hero-copy,.hero-panel-card{background:#fff;border:1px solid #e4edf7;border-radius:22px;box-shadow:0 14px 34px rgba(2,48,71,.08)}
.hero-copy{padding:30px}
.hero-kicker{display:inline-block;padding:7px 12px;border-radius:999px;background:#ffe9a9;color:#7a4b00;font-weight:800;font-size:.85rem;text-transform:uppercase;letter-spacing:.5px;margin-bottom:14px}
.home-hero h2{font-size:2.3rem;line-height:1.12;margin:0 0 14px;color:#023047;text-transform:none;letter-spacing:0}
.home-hero p{font-size:1.05rem;color:#445;max-width:780px;margin:0}
.hero-actions{display:flex;flex-wrap:wrap;gap:12px;margin:24px 0 20px}
.hero-btn{display:inline-flex;align-items:center;justify-content:center;min-height:48px;padding:0 20px;border-radius:14px;text-decoration:none;font-weight:800;border:1px solid transparent;transition:transform .18s ease,box-shadow .18s ease,background .18s ease;color:#102}
.hero-btn:hover{transform:translateY(-1px);box-shadow:0 10px 24px rgba(2,48,71,.15)}
.hero-btn--primary{background:#023047;color:#fff}
.hero-btn--secondary{background:#ffb703;color:#102}
.hero-btn--ghost{background:#fff;border-color:#cdd8e4;color:#023047}
.hero-benefits{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.hero-benefit{padding:14px 16px;border-radius:16px;background:#f7fbff;border:1px solid #e3edf7;display:flex;flex-direction:column;gap:2px}
.hero-benefit strong{color:#023047;font-size:1rem}
.hero-benefit span{color:#556270;font-size:.94rem}
.hero-panel{display:grid;gap:16px}
.hero-panel-card{padding:22px}
.hero-panel-card h3{margin:0 0 8px;color:#023047;font-size:1.2rem}
.hero-panel-card p{margin:0 0 12px;font-size:.98rem}
.hero-panel-card a{display:inline-flex;text-decoration:none;font-weight:800;color:#023047}
.hero-panel-card--promo{background:linear-gradient(180deg,#023047 0%,#034364 100%);color:#fff;border-color:#023047}
.hero-panel-card--promo h3,.hero-panel-card--promo a,.hero-panel-card--promo p{color:#fff}
.panel-badge{display:inline-block;background:#ffb703;color:#102;padding:6px 10px;border-radius:999px;font-size:.78rem;font-weight:900;text-transform:uppercase;margin-bottom:12px}
.panel-list{margin:0;padding-left:18px;color:#445}
.panel-list li+li{margin-top:8px}
.home-highlight-bar{padding:0 16px 36px;background:linear-gradient(180deg,#eef4fb 0%,#fff 100%)}
.highlight-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.highlight-card{display:flex;align-items:flex-start;gap:14px;padding:20px;border-radius:18px;background:#fff;border:1px solid #e4edf7;text-decoration:none;color:#223;box-shadow:0 10px 24px rgba(2,48,71,.06)}
.highlight-card strong{display:block;color:#023047;font-size:1.05rem;margin-bottom:3px}
.highlight-card p{margin:0;color:#556270;font-size:.95rem;line-height:1.45}
.highlight-icon{width:44px;height:44px;display:inline-flex;align-items:center;justify-content:center;border-radius:14px;background:#ffe9a9;font-size:1.3rem;flex:0 0 auto}
.section-lead{max-width:760px;margin:0 0 20px;color:#556270;font-size:1.02rem}
@media (max-width:980px){
  .topbar-inner{flex-direction:column;text-align:center}
  .hero-grid{grid-template-columns:1fr}
}
@media (max-width:760px){
  .home-hero{padding-top:28px}
  .site-topbar .logo img{max-width:250px}
  .topbar-copy h1{font-size:1.6rem}
  .home-hero h2{font-size:1.85rem}
  .hero-benefits,.highlight-grid{grid-template-columns:1fr}
  .hero-copy{padding:22px}
}


/* Blocco commerciale sotto prodotti */
.home-action-blocks{padding-top:10px}
.action-shell{background:linear-gradient(180deg,#f9fbff 0%,#f3f7fc 100%);border:1px solid #dfe8f3;border-radius:24px;padding:28px;box-shadow:0 12px 32px rgba(2,48,71,.08)}
.action-head{text-align:left;margin-bottom:20px}
.action-kicker{display:inline-block;margin-bottom:8px;font-size:.92rem;font-weight:700;color:#6b7a8c;background:#eaf1f8;border-radius:999px;padding:7px 12px}
.action-head h2{margin-bottom:10px}
.action-head .section-lead{max-width:900px;color:#566273}
.action-benefits{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin:18px 0 20px}
.action-benefit-card{display:flex;align-items:flex-start;gap:14px;background:#fff;border:1px solid #e3ebf4;border-radius:18px;padding:18px;box-shadow:0 8px 22px rgba(2,48,71,.05)}
.action-benefit-icon{width:46px;height:46px;border-radius:14px;display:flex;align-items:center;justify-content:center;background:#fff4d6;font-size:1.35rem;flex:0 0 46px}
.action-benefit-card strong{display:block;color:#023047;font-size:1.02rem;line-height:1.3;margin-bottom:4px}
.action-benefit-card span{display:block;color:#5d6978;font-size:.94rem;line-height:1.5}
.action-cards-grid{grid-template-columns:repeat(3,1fr);gap:18px}
.action-card{position:relative;border-radius:22px;padding:22px;box-shadow:0 12px 30px rgba(2,48,71,.08);border:1px solid #e3ebf4;overflow:hidden}
.action-card:before{content:"";position:absolute;left:0;top:0;right:0;height:5px;background:#ffb703}
.action-card--promo:before{background:#fb8500}
.action-card--whatsapp:before{background:#25D366}
.action-card-top{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:12px}
.action-card-icon{width:52px;height:52px;border-radius:16px;display:flex;align-items:center;justify-content:center;background:#eef4fb;font-size:1.5rem}
.action-card--promo .action-card-icon{background:#fff1e7}
.action-card--whatsapp .action-card-icon{background:#e9fbef}
.action-card-tag{display:inline-block;font-size:.8rem;font-weight:700;color:#023047;background:#eef4fb;border-radius:999px;padding:7px 10px}
.action-card--promo .action-card-tag{background:#fff1e7}
.action-card--whatsapp .action-card-tag{background:#e9fbef}
.action-card h3{text-transform:none;letter-spacing:0;margin:0 0 10px;color:#023047;font-size:1.45rem}
.action-card p{margin:0 0 18px;color:#566273;min-height:72px}
.action-card-btn{display:inline-flex;align-items:center;justify-content:center;min-height:46px;padding:0 18px;border-radius:12px;background:#023047;color:#fff !important;text-decoration:none;font-weight:700;box-shadow:0 8px 18px rgba(2,48,71,.18)}
.action-card--promo .action-card-btn{background:#fb8500}
.action-card--whatsapp .action-card-btn{background:#25D366}
.action-card-btn:hover{transform:translateY(-1px);filter:brightness(.98)}
@media (max-width:960px){.action-benefits,.action-cards-grid{grid-template-columns:1fr}}
@media (max-width:640px){.action-shell{padding:20px;border-radius:18px}.action-card{padding:18px}.action-card h3{font-size:1.25rem}.action-card p{min-height:0}}


/* ===== Promo signup PRO ===== */
.promo-signup-section{padding-top:18px;padding-bottom:26px}
.promo-signup-shell{display:grid;grid-template-columns:minmax(0,1.3fr) minmax(320px,.9fr);gap:28px;background:linear-gradient(180deg,#f7fbff 0%,#eef5fb 100%);border:1px solid #dbe7f2;border-radius:28px;padding:34px;box-shadow:0 18px 44px rgba(2,48,71,.08)}
.promo-signup-kicker{display:inline-block;background:#e9f2fb;color:#023047;font-weight:800;font-size:.86rem;border-radius:999px;padding:8px 12px;margin-bottom:12px}
.promo-signup-copy h2{margin:0 0 12px;color:#023047;font-size:2.15rem;line-height:1.16;text-transform:uppercase;letter-spacing:.02em}
.promo-signup-lead{margin:0 0 22px;color:#4c5a6b;font-size:1.06rem;line-height:1.8;max-width:820px}
.promo-info-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}
.promo-info-card{background:#fff;border:1px solid #e3ebf4;border-radius:22px;padding:20px;box-shadow:0 10px 24px rgba(2,48,71,.05);min-height:170px}
.promo-info-card--accent{background:linear-gradient(135deg,#023047 0%,#0c567c 100%);border-color:#023047}
.promo-info-icon{width:52px;height:52px;border-radius:16px;display:flex;align-items:center;justify-content:center;background:#fff4d6;font-size:1.45rem;margin-bottom:14px}
.promo-info-card--accent .promo-info-icon{background:rgba(255,255,255,.18)}
.promo-info-card h3{margin:0 0 8px;color:#023047;font-size:1.18rem;text-transform:none;letter-spacing:0}
.promo-info-card p{margin:0;color:#5d6978;line-height:1.65}
.promo-info-card--accent h3,.promo-info-card--accent p{color:#fff}
.promo-signup-panel{background:#0f2940;color:#fff;border-radius:26px;padding:28px;box-shadow:0 18px 40px rgba(2,48,71,.18);display:flex;flex-direction:column;gap:14px;position:relative;overflow:hidden}
.promo-signup-panel:before{content:"";position:absolute;right:-60px;top:-60px;width:180px;height:180px;border-radius:50%;background:rgba(255,255,255,.06)}
.promo-signup-panel > *{position:relative;z-index:1}
.promo-panel-badge{display:inline-flex;align-self:flex-start;background:#ffb703;color:#102;font-weight:900;border-radius:999px;padding:8px 12px;font-size:.84rem}
.promo-signup-panel h3{margin:0;font-size:1.75rem;line-height:1.2;color:#fff;text-transform:none;letter-spacing:0}
.promo-signup-panel p{margin:0;color:rgba(255,255,255,.88);line-height:1.7}
.promo-signup-form{display:grid;gap:12px;margin-top:6px}
.promo-signup-form input[type="email"]{width:100%;min-height:52px;border-radius:14px;border:1px solid rgba(255,255,255,.16);padding:0 15px;background:#fff;color:#102;font-size:1rem;outline:none}
.promo-signup-form input[type="email"]:focus{border-color:#ffb703;box-shadow:0 0 0 3px rgba(255,183,3,.18)}
.promo-privacy{display:flex;gap:10px;align-items:flex-start;color:rgba(255,255,255,.92);font-size:.94rem;line-height:1.5}
.promo-privacy a{color:#fff;text-decoration:underline}
.promo-submit-btn,.promo-whatsapp-btn{display:flex;align-items:center;justify-content:center;min-height:50px;border-radius:14px;font-weight:800;text-decoration:none;border:none;cursor:pointer;transition:transform .18s ease, filter .18s ease}
.promo-submit-btn{background:#ffb703;color:#102;box-shadow:0 10px 24px rgba(255,183,3,.22)}
.promo-whatsapp-btn{background:#25D366;color:#fff;box-shadow:0 10px 24px rgba(37,211,102,.18)}
.promo-submit-btn:hover,.promo-whatsapp-btn:hover{transform:translateY(-1px);filter:brightness(.98)}
.promo-mini-tags{display:grid;gap:8px;margin-top:4px}
.promo-mini-tags span{display:flex;align-items:center;gap:8px;padding:10px 12px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.08);border-radius:12px;color:#fff;font-size:.92rem}
@media (max-width:980px){.promo-signup-shell{grid-template-columns:1fr;padding:24px}.promo-signup-copy h2{font-size:1.8rem}}
@media (max-width:640px){.promo-info-grid{grid-template-columns:1fr}.promo-signup-copy h2{font-size:1.45rem}.promo-signup-panel{padding:22px;border-radius:20px}.promo-info-card{min-height:0;padding:18px}}

.hero-promo-list{display:grid;gap:12px;margin:10px 0 14px}
.hero-promo-item{display:block;padding:14px 15px;border-radius:16px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.14);text-decoration:none;color:#fff;transition:transform .18s ease,background .18s ease,border-color .18s ease}
.hero-promo-item:hover{transform:translateY(-1px);background:rgba(255,255,255,.16);border-color:rgba(255,255,255,.24)}
.hero-promo-topline{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:8px}
.hero-promo-topline strong{display:block;font-size:1rem;line-height:1.35;color:#fff}
.hero-promo-chip{display:inline-flex;align-items:center;padding:5px 9px;border-radius:999px;background:#ffb703;color:#102;font-size:.74rem;font-weight:900;white-space:nowrap}
.hero-promo-prices{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.hero-promo-old{text-decoration:line-through;opacity:.7;font-weight:700}
.hero-promo-new{font-size:1.08rem;font-weight:900;color:#fff}
.hero-promo-note{display:block;margin-top:7px;font-size:.9rem;line-height:1.45;color:rgba(255,255,255,.88)}
