/* Design: B-2-γ-II | font:playfair | palette:warm-amber | extras:waves,urgency,chart,colored-ing
 * Uniq: prefix=imo- | radius=14 | cardpad=24 | secpad=48 | pulse=3.4s | hue+0
 * Reviews: 4 | rating=4.7 | revCount=287 | titleSep=·
 * Brand: imosteon-tr-2026-04 (first build) */

/* ============== RESET + TOKENS ============== */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body { font-family: 'Inter', system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  font-size: 16px; line-height: 1.65; color: var(--text); background: var(--bg);
  -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility;
  overflow-x: hidden; }
img { max-width: 100%; height: auto; display: block; }
button { font-family: inherit; cursor: pointer; border: none; background: none; }
a { color: inherit; text-decoration: none; }
input, button, select, textarea { font-family: inherit; font-size: inherit; }
ul { list-style: none; }

:root {
  /* Palette: refined-terracotta-sage (softer warm + calming green undertone) */
  --primary: #C75A3D;
  --primary-rgb: 199,90,61;
  --primary-dark: #9A4128;
  --primary-pale: #FBEADF;
  --accent: #E8A95B;
  --accent-rgb: 232,169,91;
  --accent-pale: #FBEFD8;
  --surface: #FAF6EE;
  --bg: #FCFAF5;
  --text: #232E48;
  --text-soft: #404868;
  --muted: #5C6680;
  --line: #EBE3D1;
  --dark-bg: #1F2A3F;
  --success: #3FA862;
  --danger: #D04A3B;
  /* UI tokens */
  --radius-sm: 8px;
  --radius: 14px;
  --radius-lg: 20px;
  --radius-full: 999px;
  --shadow-sm: 0 4px 12px rgba(27,36,64,.06);
  --shadow: 0 12px 28px rgba(27,36,64,.10);
  --shadow-lg: 0 24px 60px rgba(27,36,64,.18);
  --star-color: #E8A95B;
  --discount-bg: #C75A3D;
  --discount-color: #fff;
  /* Fonts */
  --font-display: 'Playfair Display', 'Cormorant', Georgia, serif;
  --font-body: 'Inter', system-ui, sans-serif;
  /* Layout */
  --container: 1180px;
  --header-h: 68px;
  --section-py: 48px;
  --section-py-mob: 36px;
  /* Highlight colors */
  --hl-primary: 199,90,61;
  --hl-accent: 232,169,91;
  --hl-green: 78,144,98;
  --hl-blue: 75,127,178;
  --hl-purple: 138,108,176;
  --hl-teal: 80,148,148;
  --hl-rose: 198,90,120;
}

/* ============== TYPOGRAPHY ============== */
h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-display); font-weight: 700; color: var(--text);
  line-height: 1.18; letter-spacing: -.012em;
}
h1 { font-size: 2.8rem; line-height: 1.1; }
h2 { font-size: 1.85rem; margin-bottom: 14px; position: relative; }
h2:not(.h2-plain)::after { content: ""; display: block; width: 36px; height: 3px; margin-top: 8px;
  background: linear-gradient(90deg, var(--primary), var(--accent)); border-radius: 2px; opacity: .6; }
.dark-section h2::after { opacity: .85; }
h3 { font-size: 1.25rem; }
h4 { font-size: 1.05rem; }
p { margin-bottom: 14px; color: var(--text-soft); }
.eyebrow { display: inline-block; font-family: var(--font-body); font-size: .78rem;
  font-weight: 700; letter-spacing: .12em; text-transform: uppercase;
  color: var(--primary-dark); margin-bottom: 10px; }
strong { color: var(--text); font-weight: 700; }
small { font-size: .82rem; color: var(--muted); }

/* Highlights — flat-bottom underline (skill rule #34) */
.hl, .hl-accent, .hl-green, .hl-blue, .hl-purple, .hl-teal, .hl-rose {
  background-image: linear-gradient(180deg, transparent 62%, rgba(var(--hl-primary), .42) 62%, rgba(var(--hl-primary), .42) 100%);
  -webkit-box-decoration-break: clone; box-decoration-break: clone;
  padding: 0 3px; border-radius: 3px; font-weight: 600;
}
.hl-accent { background-image: linear-gradient(180deg, transparent 62%, rgba(var(--hl-accent), .50) 62%, rgba(var(--hl-accent), .50) 100%); }
.hl-green  { background-image: linear-gradient(180deg, transparent 62%, rgba(var(--hl-green), .40) 62%, rgba(var(--hl-green), .40) 100%); }
.hl-blue   { background-image: linear-gradient(180deg, transparent 62%, rgba(var(--hl-blue), .38) 62%, rgba(var(--hl-blue), .38) 100%); }
.hl-purple { background-image: linear-gradient(180deg, transparent 62%, rgba(var(--hl-purple), .38) 62%, rgba(var(--hl-purple), .38) 100%); }
.hl-teal   { background-image: linear-gradient(180deg, transparent 62%, rgba(var(--hl-teal), .40) 62%, rgba(var(--hl-teal), .40) 100%); }
.hl-rose   { background-image: linear-gradient(180deg, transparent 62%, rgba(var(--hl-rose), .42) 62%, rgba(var(--hl-rose), .42) 100%); }

/* ============== LAYOUT ============== */
.container { max-width: var(--container); margin: 0 auto; padding: 0 20px; }
section { padding: var(--section-py) 0; position: relative; }
section.tight { padding: 32px 0; }
.bg-cream { background: var(--surface); }
.bg-pale { background: linear-gradient(180deg, #FFF8F0 0%, #FFEFE0 100%); }
.bg-dark { background: var(--dark-bg); color: #fff; }
.bg-dark h2, .bg-dark h3, .bg-dark h4 { color: #fff; }
.bg-dark p { color: rgba(255,255,255,.78); }
.center { text-align: center; }

/* Wave dividers */
.wave { display: block; width: 100%; line-height: 0; }
.wave svg { width: 100%; height: 56px; display: block; }

/* ============== PROMO BAR ============== */
.promo-bar { height: 40px; background: linear-gradient(90deg, var(--primary), var(--accent), var(--primary));
  background-size: 200% 100%; animation: imo-shimmer 6.5s linear infinite;
  color: #fff; display: flex; align-items: center; justify-content: center;
  font-size: .82rem; font-weight: 600; letter-spacing: .02em; position: relative; z-index: 60; padding: 0 12px; }
.promo-bar span { display: inline-flex; align-items: center; gap: 6px; }
.promo-bar .sep { opacity: .55; margin: 0 12px; }
@keyframes imo-shimmer { 0% { background-position: 0 0; } 100% { background-position: 200% 0; } }

/* ============== HEADER ============== */
.header { position: sticky; top: 0; z-index: 50; background: #FFFCF7;
  backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--line); height: var(--header-h);
  box-shadow: 0 2px 14px rgba(27,36,64,.06); }
.header-inner { display: flex; align-items: center; justify-content: space-between; height: 100%; gap: 16px; }
.logo { display: inline-flex; align-items: center; gap: 8px; font-family: var(--font-display);
  font-size: 1.35rem; font-weight: 800; color: var(--text); letter-spacing: -.02em; }
.logo-mark { width: 30px; height: 30px; border-radius: 8px;
  background: linear-gradient(135deg, var(--primary), var(--accent)); display: inline-flex;
  align-items: center; justify-content: center; color: #fff; font-weight: 800; font-size: .95rem;
  font-family: var(--font-body); box-shadow: 0 4px 12px rgba(var(--primary-rgb), .35); }
.header-nav { display: flex; align-items: center; gap: 22px; }
.header-nav a { font-size: .92rem; color: var(--text-soft); font-weight: 500; transition: color .2s; }
.header-nav a:hover { color: var(--primary); }
.header-cta { display: inline-flex; align-items: center; gap: 8px; padding: 10px 18px;
  background: var(--primary); color: #fff; border-radius: var(--radius-full);
  font-weight: 700; font-size: .92rem; box-shadow: 0 6px 14px rgba(var(--primary-rgb), .35); transition: transform .15s, box-shadow .2s; }
.header-cta:hover { transform: translateY(-1px); box-shadow: 0 10px 22px rgba(var(--primary-rgb), .42); }
.header-cta svg { width: 16px; height: 16px; }
.hamburger { display: none; width: 40px; height: 40px; border-radius: 10px;
  background: var(--surface); align-items: center; justify-content: center;
  border: 1px solid var(--line); }
.hamburger span { display: block; width: 18px; height: 2px; background: var(--text);
  position: relative; border-radius: 2px; }
.hamburger span::before, .hamburger span::after { content: ""; position: absolute; left: 0;
  width: 18px; height: 2px; background: var(--text); border-radius: 2px; }
.hamburger span::before { top: -6px; }
.hamburger span::after { top: 6px; }

/* ============== HERO (Layout B — centered stacked) ============== */
.hero { padding: 32px 0 56px; background: linear-gradient(180deg, #FFF4E5 0%, #FFFCF7 100%);
  position: relative; overflow: hidden; }
.hero::before { content: ""; position: absolute; inset: 0; opacity: .35; pointer-events: none;
  background: radial-gradient(900px 400px at 80% -10%, rgba(var(--accent-rgb), .35), transparent 60%),
              radial-gradient(700px 360px at 0% 110%, rgba(var(--primary-rgb), .25), transparent 60%);
  animation: imo-bg 22s ease-in-out infinite alternate; }
@keyframes imo-bg { 0% { transform: translate3d(0,0,0); } 100% { transform: translate3d(-30px, 20px, 0); } }
/* Hero B: single column, image centered ABOVE text — works at all widths */
.hero-inner { position: relative; z-index: 1; display: flex; flex-direction: column; align-items: center; gap: 22px; text-align: center; }
.hero-side { order: -1; width: 100%; max-width: 420px; }
.hero-copy { display: flex; flex-direction: column; align-items: center; max-width: 720px; }
.hero-copy .hero-lead { margin-left: auto; margin-right: auto; }
.hero-copy h1 { max-width: 760px; }
.hero-copy h1 { margin-bottom: 18px; }
.hero-copy h1 .h1-accent { color: var(--primary); }
.hero-lead { font-size: 1.08rem; color: var(--text-soft); margin-bottom: 22px; max-width: 540px; }
.trust-pills { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 22px; }
.trust-pill { display: inline-flex; align-items: center; gap: 6px; padding: 6px 12px;
  background: #fff; border: 1px solid var(--line); border-radius: var(--radius-full);
  font-size: .82rem; font-weight: 600; color: var(--text-soft); box-shadow: var(--shadow-sm); }
.trust-pill .star { color: var(--star-color); }

/* Hero image dual pattern */
.hero-image-desktop { display: block; }
.hero-image-mobile { display: none; }
.hero-img { max-height: 360px; max-width: 360px; width: auto; object-fit: contain; margin: 0 auto;
  filter: drop-shadow(0 30px 50px rgba(27,36,64,.18)); }
.hero-side { display: flex; align-items: center; justify-content: center; position: relative; }
.hero-orb { position: absolute; border-radius: 50%; filter: blur(40px); opacity: .55; pointer-events: none; }
.hero-orb-1 { width: 220px; height: 220px; background: rgba(var(--primary-rgb), .35); top: 20%; right: -10%; animation: imo-orb 17s ease-in-out infinite; }
.hero-orb-2 { width: 180px; height: 180px; background: rgba(var(--accent-rgb), .45); bottom: 5%; left: -10%; animation: imo-orb 15s ease-in-out infinite reverse; }
@keyframes imo-orb { 0%,100% { transform: translate(0,0) scale(1); } 50% { transform: translate(20px, -20px) scale(1.08); } }

/* Hero badges (desktop only) */
.hero-badges { position: absolute; inset: 0; pointer-events: none; }
.hb { position: absolute; padding: 8px 14px; background: #fff; border-radius: var(--radius-full);
  font-size: .82rem; font-weight: 700; box-shadow: var(--shadow); display: inline-flex; align-items: center; gap: 6px;
  animation: imo-float 3.6s ease-in-out infinite; }
.hb-oficial { top: 14%; left: 4%; color: #fff; background: var(--success); animation-delay: .2s; }
.hb-rating { top: 56%; right: 6%; color: var(--text); animation-delay: .8s; }
.hb-rating .star { color: var(--star-color); }
.hb-delivery { bottom: 12%; left: 6%; color: var(--primary-dark); background: var(--accent-pale); animation-delay: 1.4s; }
@keyframes imo-float { 0%, 100% { transform: translateY(0); } 50% { transform: translateY(-6px); } }

/* ============== OFFER BOX (REF-1 — inline form) ============== */
.offer-box { background: #fff; border-radius: var(--radius-lg); padding: 20px;
  box-shadow: var(--shadow-lg); border: 1px solid var(--line); position: relative; }
.offer-box .offer-img { max-width: 220px; margin: 0 auto 14px; display: block; }
.offer-name { text-align: center; font-family: var(--font-display); font-size: 1.45rem; font-weight: 700;
  margin-bottom: 4px; color: var(--text); }
.offer-qty { text-align: center; font-size: .85rem; color: var(--muted); margin-bottom: 14px; }
.price-block { text-align: center; padding: 14px 16px; border-radius: var(--radius);
  background: linear-gradient(135deg, rgba(var(--primary-rgb), .08), rgba(var(--accent-rgb), .14));
  margin-bottom: 16px; }
.price-row { display: flex; justify-content: center; align-items: baseline; gap: 10px; flex-wrap: wrap; }
.price-old { font-size: 1.05rem; color: var(--muted); text-decoration: line-through; font-weight: 500; }
.price-new { font-size: 2rem; font-weight: 800; color: var(--primary-dark); font-family: var(--font-display); letter-spacing: -.02em; }
.price-badge { display: inline-flex; align-items: center; padding: 5px 11px; background: var(--discount-bg);
  color: var(--discount-color); border-radius: var(--radius-full); font-size: .78rem; font-weight: 800;
  letter-spacing: .03em; animation: imo-pulse 3.4s ease-in-out infinite; box-shadow: 0 6px 14px rgba(214,69,59,.32); }
.price-badge--sm { font-size: .68rem; padding: 3px 8px; }
@keyframes imo-pulse { 0%, 100% { transform: scale(1); } 50% { transform: scale(1.06); } }
.payment-pills { display: flex; flex-wrap: wrap; justify-content: center; gap: 6px; margin-top: 10px; }
.payment-pill { font-size: .72rem; padding: 4px 9px; background: #fff; border: 1px solid var(--line);
  border-radius: var(--radius-full); color: var(--text-soft); font-weight: 600; }

/* Form fields */
.form-row { display: grid; gap: 10px; margin-bottom: 12px; }
.field { position: relative; }
.field-icon { position: absolute; left: 14px; top: 50%; transform: translateY(-50%);
  width: 18px; height: 18px; color: var(--muted); pointer-events: none; }
.field-cc { position: absolute; left: 14px; top: 50%; transform: translateY(-50%);
  font-size: .9rem; font-weight: 600; color: var(--text-soft); pointer-events: none; }
.field input { width: 100%; padding: 14px 14px 14px 42px; border: 1.5px solid var(--line);
  border-radius: var(--radius); font-size: 1rem; background: #fff; color: var(--text);
  transition: border-color .15s, box-shadow .15s; }
.field input:focus { outline: none; border-color: var(--primary); box-shadow: 0 0 0 3px rgba(var(--primary-rgb), .14); }
.field-phone input { padding-left: 56px; }
.btn-cta { display: flex; align-items: center; justify-content: center; gap: 8px;
  width: 100%; padding: 16px; background: linear-gradient(135deg, var(--primary), var(--primary-dark));
  color: #fff; border-radius: var(--radius); font-weight: 800; font-size: 1.02rem;
  box-shadow: 0 12px 28px rgba(var(--primary-rgb), .35); cursor: pointer;
  transition: transform .15s, box-shadow .2s; letter-spacing: .01em; }
.btn-cta:hover { transform: translateY(-2px); box-shadow: 0 16px 36px rgba(var(--primary-rgb), .45); }
.btn-cta:active { transform: translateY(0); }
.btn-cta svg { width: 20px; height: 20px; }
.btn-discount-pill::after { content: "-50%"; display: inline-block; padding: 3px 8px;
  background: rgba(255,255,255,.22); border-radius: var(--radius-full); font-size: .72rem; font-weight: 800; margin-left: 6px; }
.form-trust { display: flex; flex-wrap: wrap; justify-content: center; gap: 14px; margin-top: 12px;
  font-size: .76rem; color: var(--muted); }
.form-trust span { display: inline-flex; align-items: center; gap: 4px; }

/* ============== TRUST BAR ============== */
.trust-bar { padding: 24px 0; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line);
  background: #fff; }
.trust-bar-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; text-align: center; }
.tb-item { display: flex; flex-direction: column; align-items: center; gap: 6px; }
.tb-icon { width: 44px; height: 44px; border-radius: 12px;
  background: linear-gradient(135deg, var(--primary-pale), var(--accent-pale));
  display: inline-flex; align-items: center; justify-content: center; color: var(--primary-dark); }
.tb-icon svg { width: 22px; height: 22px; }
.tb-text { font-size: .82rem; font-weight: 600; color: var(--text); }

/* ============== CARDS (γ glass) ============== */
.card { background: rgba(255,255,255,.72); backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px);
  border: 1px solid rgba(255,255,255,.6); border-radius: var(--radius); padding: 24px;
  box-shadow: 0 8px 24px rgba(27,36,64,.08); transition: transform .2s, box-shadow .2s; text-align: center; }
.card:hover { transform: translateY(-3px); box-shadow: 0 18px 40px rgba(27,36,64,.12); }
.card .card-icon { width: 52px; height: 52px; border-radius: 14px; display: inline-flex;
  align-items: center; justify-content: center; margin-bottom: 14px; font-size: 1.6rem; }
.card h3 { margin-bottom: 8px; }
.card p { font-size: .92rem; }

/* Multi-color card cycle (skill rule — never single brand-color tint) */
.cards-grid { display: grid; gap: 18px; }
.cards-grid > .card:nth-child(6n+1) .card-icon { background: rgba(46,160,67,.14); color: #1F7A2C; }
.cards-grid > .card:nth-child(6n+2) .card-icon { background: rgba(31,111,235,.14); color: #1A4FAD; }
.cards-grid > .card:nth-child(6n+3) .card-icon { background: rgba(130,80,223,.14); color: #5C3BAA; }
.cards-grid > .card:nth-child(6n+4) .card-icon { background: rgba(245,166,35,.18); color: #A66B0E; }
.cards-grid > .card:nth-child(6n+5) .card-icon { background: rgba(20,158,158,.14); color: #0E7878; }
.cards-grid > .card:nth-child(6n+0) .card-icon { background: rgba(224,67,113,.14); color: #B43658; }
.cards-grid > .card:nth-child(6n+1) h3 { color: #1F7A2C; }
.cards-grid > .card:nth-child(6n+2) h3 { color: #1A4FAD; }
.cards-grid > .card:nth-child(6n+3) h3 { color: #5C3BAA; }
.cards-grid > .card:nth-child(6n+4) h3 { color: #A66B0E; }
.cards-grid > .card:nth-child(6n+5) h3 { color: #0E7878; }
.cards-grid > .card:nth-child(6n+0) h3 { color: #B43658; }

.grid-3 { grid-template-columns: repeat(3, 1fr); }
.grid-2 { grid-template-columns: repeat(2, 1fr); }
.grid-4 { grid-template-columns: repeat(4, 1fr); }

/* ============== CAUSE CARDS (Section 4.5) ============== */
.cause-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; margin-top: 24px; }
.cause-card { background: #fff; border-radius: var(--radius); padding: 22px; box-shadow: var(--shadow-sm);
  border-top: 4px solid var(--primary); position: relative; overflow: hidden; text-align: left; }
.cause-card:nth-child(1) { border-top-color: #1F7A2C; }
.cause-card:nth-child(2) { border-top-color: #1A4FAD; }
.cause-card:nth-child(3) { border-top-color: #5C3BAA; }
.cause-card .cause-pct { font-family: var(--font-display); font-size: 2.2rem; font-weight: 800;
  letter-spacing: -.02em; line-height: 1; margin-bottom: 8px; }
.cause-card:nth-child(1) .cause-pct { color: #1F7A2C; }
.cause-card:nth-child(2) .cause-pct { color: #1A4FAD; }
.cause-card:nth-child(3) .cause-pct { color: #5C3BAA; }
.cause-card h3 { font-size: 1.08rem; margin-bottom: 6px; }
.cause-card p { font-size: .9rem; margin: 0; }

/* ============== INGREDIENT CARDS (colored headers) ============== */
.ing-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.ing-card { background: #fff; border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow-sm);
  border: 1px solid var(--line); }
.ing-head { padding: 18px 20px; color: #fff; }
.ing-head h3 { color: #fff; margin-bottom: 4px; font-size: 1.12rem; }
.ing-head .ing-tag { font-size: .74rem; opacity: .85; letter-spacing: .06em; text-transform: uppercase; font-weight: 700; }
.ing-card:nth-child(6n+1) .ing-head { background: linear-gradient(135deg, #2EA043, #1F7A2C); }
.ing-card:nth-child(6n+2) .ing-head { background: linear-gradient(135deg, #1F6FEB, #1A4FAD); }
.ing-card:nth-child(6n+3) .ing-head { background: linear-gradient(135deg, #8250DF, #5C3BAA); }
.ing-card:nth-child(6n+4) .ing-head { background: linear-gradient(135deg, #F5A623, #C7821A); }
.ing-card:nth-child(6n+5) .ing-head { background: linear-gradient(135deg, #149E9E, #0E7878); }
.ing-card:nth-child(6n+0) .ing-head { background: linear-gradient(135deg, #E04371, #B43658); }
.ing-body { padding: 18px 20px; }
.ing-body p { font-size: .9rem; }
.ing-dose { display: inline-block; margin-top: 6px; padding: 4px 10px;
  background: var(--surface); border-radius: var(--radius-full); font-size: .76rem; font-weight: 700; color: var(--text-soft); }

/* ============== QUIZ ============== */
.quiz-box { background: #fff; border-radius: var(--radius-lg); padding: 28px; box-shadow: var(--shadow);
  border: 1px solid var(--line); max-width: 720px; margin: 0 auto; }
.quiz-step { display: none; }
.quiz-step.active { display: block; animation: imo-fade .3s ease-out; }
@keyframes imo-fade { from { opacity: 0; transform: translateY(6px); } to { opacity: 1; transform: translateY(0); } }
.quiz-q { font-family: var(--font-display); font-size: 1.3rem; margin-bottom: 18px; }
.quiz-options { display: grid; gap: 10px; }
.quiz-opt { padding: 14px 18px; border: 1.5px solid var(--line); border-radius: var(--radius);
  background: var(--surface); cursor: pointer; font-weight: 600; color: var(--text); text-align: left;
  transition: all .15s; font-size: .95rem; }
.quiz-opt:hover { border-color: var(--primary); background: var(--primary-pale); }
.quiz-progress { height: 6px; background: var(--line); border-radius: var(--radius-full); margin-bottom: 18px; overflow: hidden; }
.quiz-progress-bar { height: 100%; background: linear-gradient(90deg, var(--primary), var(--accent));
  border-radius: var(--radius-full); transition: width .3s; }
.quiz-result { text-align: center; padding: 14px 0; }
.quiz-result h3 { font-size: 1.4rem; margin-bottom: 8px; color: var(--primary-dark); }

/* ============== INCL/EXCL (Section 9 — two columns) ============== */
.incl-excl { display: grid; grid-template-columns: 1fr 1fr; gap: 22px; margin-top: 18px; }
.incl-excl-col { background: #fff; border-radius: var(--radius); padding: 22px; box-shadow: var(--shadow-sm); }
.incl-excl-col.incl { border-top: 4px solid var(--success); }
.incl-excl-col.excl { border-top: 4px solid var(--danger); }
.incl-excl h3 { display: flex; align-items: center; gap: 8px; font-size: 1.15rem; margin-bottom: 14px; }
.incl-excl ul { display: grid; gap: 10px; }
.incl-list li, .excl-list li { display: flex; align-items: flex-start; gap: 10px; font-size: .94rem; color: var(--text-soft); line-height: 1.5; }
.incl-list li::before { content: "✓"; flex: 0 0 22px; height: 22px; border-radius: 50%; background: var(--success); color: #fff;
  display: inline-flex; align-items: center; justify-content: center; font-weight: 800; font-size: .8rem; margin-top: 2px; }
.excl-list li::before { content: "✗"; flex: 0 0 22px; height: 22px; border-radius: 50%; background: var(--danger); color: #fff;
  display: inline-flex; align-items: center; justify-content: center; font-weight: 800; font-size: .8rem; margin-top: 2px; }

/* ============== HOW-TO-ORDER V2 (Section 12.5) ============== */
.howto { background: linear-gradient(135deg, #2C1A52, #6E2C9D 50%, var(--primary)); color: #fff;
  padding: 56px 0; border-radius: var(--radius-lg); margin: 16px 0; overflow: hidden; position: relative; }
.howto::before { content: ""; position: absolute; inset: 0; opacity: .25; pointer-events: none;
  background: radial-gradient(600px 280px at 80% 0%, rgba(245,166,35,.6), transparent 60%); }
.howto h2 { color: #fff; }
.howto h2::after { background: rgba(255,255,255,.6); }
.howto-lead { color: rgba(255,255,255,.85); max-width: 640px; margin: 0 auto 28px; text-align: center; }
.howto-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; position: relative; z-index: 1; }
.howto-tile { background: rgba(255,255,255,.10); backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px);
  border: 1px solid rgba(255,255,255,.18); border-radius: var(--radius); padding: 28px 22px; text-align: center; position: relative; }
.howto-icon { width: 84px; height: 84px; border-radius: 22px;
  background: rgba(255,255,255,.14); border: 1px solid rgba(255,255,255,.25);
  display: inline-flex; align-items: center; justify-content: center; margin-bottom: 14px; }
.howto-icon svg { width: 36px; height: 36px; color: #fff; }
.os-num { position: absolute; top: -14px; right: -14px; width: 36px; height: 36px; border-radius: 50%;
  background: var(--accent); color: var(--text); font-weight: 800; font-size: 1.05rem;
  display: inline-flex; align-items: center; justify-content: center; box-shadow: 0 8px 18px rgba(0,0,0,.25); }
.howto-tile h4 { color: #fff; font-size: 1.18rem; margin-bottom: 6px; }
.howto-tile p { color: rgba(255,255,255,.78); font-size: .92rem; margin: 0; }

/* ============== CHART SECTION (12.7) ============== */
.chart-section { background: var(--dark-bg); color: #fff; border-radius: var(--radius-lg); padding: 40px 28px; }
.chart-section h2 { color: #fff; }
.chart-section h2::after { background: var(--accent); opacity: .9; }
.chart-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 28px; align-items: center; margin-top: 24px; }
.chart-bars { display: grid; gap: 18px; }
.chart-row { display: grid; grid-template-columns: 130px 1fr 60px; gap: 12px; align-items: center; }
.chart-label { font-size: .92rem; color: rgba(255,255,255,.85); }
.chart-track { height: 14px; background: rgba(255,255,255,.10); border-radius: 999px; overflow: hidden; }
.chart-fill { height: 100%; background: linear-gradient(90deg, var(--accent), var(--primary)); border-radius: 999px; width: 0; transition: width 1.2s cubic-bezier(.34,1.56,.64,1); }
.chart-pct { font-weight: 800; font-family: var(--font-display); font-size: 1.05rem; color: var(--accent); text-align: right; }
.chart-note { font-size: .82rem; color: rgba(255,255,255,.6); margin-top: 18px; }

/* ============== MID CTA (dark) ============== */
.mid-cta { background: var(--dark-bg); color: #fff; border-radius: var(--radius-lg); padding: 40px 28px; text-align: center; position: relative; overflow: hidden; }
.mid-cta::before { content: ""; position: absolute; inset: 0; opacity: .25;
  background: radial-gradient(500px 250px at 50% 100%, rgba(var(--primary-rgb), .55), transparent 60%); }
.mid-cta-inner { position: relative; z-index: 1; max-width: 520px; margin: 0 auto; display: flex; flex-direction: column; align-items: center; }
.mid-cta-inner > * { width: 100%; }
.mid-cta-inner > img { width: auto; }
.mid-cta h2 { color: #fff; margin-bottom: 12px; }
.mid-cta h2::after { background: var(--accent); margin-left: auto; margin-right: auto; opacity: .9; }
.mid-cta p { color: rgba(255,255,255,.82); margin-bottom: 18px; }
.mid-cta .price-block { background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.14); }
.mid-cta .price-old { color: rgba(255,255,255,.55); }
.mid-cta .price-new { color: #fff; }
.mid-cta .btn-cta { max-width: 360px; margin: 0 auto; }

/* ============== TESTIMONIALS (Grid II) ============== */
.test-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.test-card { background: #fff; border-radius: var(--radius); padding: 22px; box-shadow: var(--shadow-sm); border: 1px solid var(--line); position: relative; }
.test-card::before { content: "\""; position: absolute; top: 8px; right: 16px; font-family: Georgia, serif; font-size: 3.5rem; color: rgba(var(--primary-rgb), .12); line-height: 1; pointer-events: none; }
.test-stars { color: var(--star-color); margin-bottom: 8px; font-size: .92rem; letter-spacing: 2px; }
.test-text { font-family: 'Inter', sans-serif; font-style: normal; font-weight: 500; font-size: 1rem;
  line-height: 1.7; letter-spacing: -.005em; margin-bottom: 14px; color: var(--text); }
.test-author { display: flex; align-items: center; gap: 10px; }
.test-avatar { width: 40px; height: 40px; border-radius: 50%; background: linear-gradient(135deg, var(--primary), var(--accent));
  color: #fff; display: inline-flex; align-items: center; justify-content: center; font-weight: 800; font-size: .92rem;
  font-family: var(--font-body); flex-shrink: 0; }
.test-meta { font-size: .85rem; }
.test-name { font-weight: 700; color: var(--text); }
.test-loc { color: var(--muted); font-size: .8rem; }
.test-verified { display: inline-flex; align-items: center; gap: 4px; margin-left: auto; padding: 3px 8px;
  background: rgba(46,160,67,.12); color: #1F7A2C; border-radius: var(--radius-full); font-size: .68rem; font-weight: 700; }

/* ============== DOCTOR CARD (14.5) ============== */
.doctor-card { display: grid; grid-template-columns: 280px 1fr; gap: 28px; background: #fff;
  border-radius: var(--radius-lg); padding: 30px; box-shadow: var(--shadow); border: 1px solid var(--line);
  align-items: center; }
.doctor-photo { width: 100%; aspect-ratio: 1; border-radius: var(--radius); background: linear-gradient(135deg, var(--primary-pale), var(--accent-pale));
  display: flex; align-items: center; justify-content: center; overflow: hidden; }
.doctor-photo svg { width: 70%; height: 70%; color: var(--primary-dark); opacity: .55; }
.doctor-info .doctor-badge { display: inline-block; padding: 5px 12px; background: var(--primary-pale); color: var(--primary-dark);
  border-radius: var(--radius-full); font-size: .72rem; font-weight: 800; letter-spacing: .08em; text-transform: uppercase; margin-bottom: 10px; }
.doctor-info h3 { font-size: 1.45rem; margin-bottom: 4px; }
.doctor-spec { color: var(--text-soft); font-size: .95rem; margin-bottom: 4px; }
.doctor-cred { color: var(--muted); font-size: .85rem; margin-bottom: 14px; }
.doctor-quote { font-family: 'Inter', sans-serif; font-style: normal; font-weight: 500; font-size: 1.04rem;
  line-height: 1.75; color: var(--text); position: relative; padding-left: 16px;
  border-left: 3px solid var(--primary); margin-bottom: 12px; }
.doctor-disclaimer { font-size: .78rem; color: var(--muted); font-style: italic; padding: 10px 12px;
  background: var(--surface); border-radius: var(--radius-sm); border-left: 2px solid var(--accent); }

/* ============== FAQ ============== */
.faq-list { display: grid; gap: 10px; max-width: 820px; margin: 0 auto; }
.faq-item { background: #fff; border-radius: var(--radius); border: 1px solid var(--line); overflow: hidden; transition: box-shadow .15s; }
.faq-item:hover { box-shadow: var(--shadow-sm); }
.faq-item[open] { box-shadow: var(--shadow); border-color: rgba(var(--primary-rgb), .35); }
.faq-q { padding: 16px 22px; font-weight: 700; cursor: pointer; list-style: none; display: flex; justify-content: space-between; align-items: center; gap: 14px; font-size: .98rem; color: var(--text); }
.faq-q::-webkit-details-marker { display: none; }
.faq-q::after { content: "+"; font-size: 1.4rem; color: var(--primary); transition: transform .2s; flex-shrink: 0; }
.faq-item[open] .faq-q::after { content: "−"; }
.faq-a { padding: 0 22px 18px; color: var(--text-soft); font-size: .94rem; line-height: 1.75; }
.faq-a > p { margin: 0 0 10px; }
.faq-a > p:last-child { margin-bottom: 0; }
.faq-a strong.faq-lead { color: var(--text); font-weight: 700; }
.faq-steps, .faq-bullets { margin: 8px 0 0; padding-left: 22px; }
.faq-steps li, .faq-bullets li { margin: 4px 0; padding-left: 4px; }
.faq-steps li::marker { color: var(--primary); font-weight: 700; }
.faq-bullets li::marker { color: var(--primary); }
.faq-group { display: grid; gap: 10px; }
.faq-group-title { font-family: var(--font-display); font-size: 1.05rem; font-weight: 700; color: var(--text); margin: 18px 0 4px; padding: 0 4px; letter-spacing: -0.01em; }
.faq-group-title:first-child { margin-top: 0; }

/* ============== REALISTIC EXPECTATIONS (16.4) ============== */
.real-table { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; margin-top: 18px; }
.real-col { border-radius: var(--radius); padding: 22px; }
.real-col.no { background: linear-gradient(180deg, #FFF1F0 0%, #FFE8E5 100%); border: 1px solid #F5C5BD; }
.real-col.yes { background: linear-gradient(180deg, #EEFAF0 0%, #DDF5E1 100%); border: 1px solid #B8E6BF; }
.real-col h3 { display: flex; align-items: center; gap: 8px; margin-bottom: 14px; font-size: 1.08rem; }
.real-col.no h3 { color: #B83A2D; }
.real-col.yes h3 { color: #1F7A2C; }
.real-col ul { display: grid; gap: 10px; }
.real-col li { display: flex; gap: 10px; font-size: .9rem; line-height: 1.55; color: var(--text); }
.real-col.no li::before { content: "✗"; flex: 0 0 18px; color: #B83A2D; font-weight: 800; }
.real-col.yes li::before { content: "✓"; flex: 0 0 18px; color: #1F7A2C; font-weight: 800; }
.real-note { text-align: center; font-size: .85rem; color: var(--muted); margin-top: 14px; }

/* ============== PHARMACY CARDS (Section 18) ============== */
.farma-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 14px; }
.farma-card { background: #fff; border-radius: var(--radius); padding: 18px; box-shadow: var(--shadow-sm); border: 1px solid var(--line); display: flex; flex-direction: column; gap: 8px; }
.farma-name { font-family: var(--font-display); font-size: 1.15rem; font-weight: 700; color: var(--text); }
.farma-status { display: inline-flex; align-items: center; gap: 6px; font-size: .82rem; font-weight: 700; color: var(--danger); }
.farma-reason { font-size: .85rem; color: var(--text-soft); line-height: 1.55; }
.farma-link { font-size: .82rem; color: var(--primary); font-weight: 600; margin-top: auto; }
.farma-link:hover { text-decoration: underline; }

/* ============== STICKY V2 (mobile mini-bar) ============== */
.sticky-v2 { position: fixed; left: 0; right: 0; bottom: 0; z-index: 40; padding: 10px 12px;
  background: linear-gradient(180deg, #1B2440 0%, #0F1730 100%); color: #fff;
  border-top-left-radius: 18px; border-top-right-radius: 18px;
  box-shadow: 0 -10px 30px rgba(0,0,0,.25); display: none; align-items: center; gap: 10px; }
.sticky-v2-thumb { width: 48px; height: 48px; border-radius: 12px; background: rgba(255,255,255,.10); padding: 4px; flex-shrink: 0; }
.sticky-v2-thumb img { width: 100%; height: 100%; object-fit: contain; }
.sticky-v2-info { flex: 1; min-width: 0; }
.sticky-v2-name { font-family: var(--font-display); font-weight: 600; font-size: .95rem; letter-spacing: -.01em; line-height: 1.2;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.sticky-v2-prices { display: flex; gap: 6px; align-items: baseline; font-size: .82rem; }
.sticky-v2-old { color: rgba(255,255,255,.55); text-decoration: line-through; }
.sticky-v2-new { color: var(--accent); font-weight: 800; font-size: .95rem; }
.sticky-v2-btn { padding: 9px 14px; background: var(--primary); color: #fff; border-radius: var(--radius-full);
  font-weight: 700; font-size: .82rem; flex-shrink: 0; white-space: nowrap; line-height: 1;
  box-shadow: 0 6px 14px rgba(var(--primary-rgb), .42); display: inline-flex; align-items: center; gap: 5px;
  transition: transform .15s, box-shadow .15s; }
.sticky-v2-btn:hover { transform: translateY(-1px); box-shadow: 0 8px 18px rgba(var(--primary-rgb), .55); }
.sticky-v2-btn::after { content: "-50%"; padding: 2px 6px; background: rgba(255,255,255,.22); border-radius: 999px; font-size: .64rem; font-weight: 800; }

/* ============== MODAL / POPUP ============== */
.modal-overlay { position: fixed; inset: 0; background: rgba(11,17,32,.62); backdrop-filter: blur(4px);
  z-index: 100; opacity: 0; visibility: hidden; transition: opacity .25s, visibility .25s;
  display: flex; align-items: center; justify-content: center; padding: 12px; }
.modal-overlay.active { opacity: 1; visibility: visible; }
.modal-content { background: #fff; border-radius: var(--radius-lg); width: 100%; max-width: 440px;
  max-height: calc(100dvh - 24px); overflow: hidden; display: flex; flex-direction: column;
  box-shadow: 0 30px 80px rgba(0,0,0,.35); position: relative; transform: translateY(10px); transition: transform .25s; }
.modal-overlay.active .modal-content { transform: translateY(0); }
.modal-close { position: absolute; top: 12px; right: 12px; width: 36px; height: 36px; border-radius: 50%;
  background: rgba(0,0,0,.06); display: flex; align-items: center; justify-content: center; z-index: 2; transition: background .15s; }
.modal-close:hover { background: rgba(0,0,0,.12); }
.modal-close::before { content: "×"; font-size: 1.5rem; line-height: 1; color: var(--text); }
.modal-body { padding: 18px 18px 14px; overflow-y: auto; overscroll-behavior: contain; -webkit-overflow-scrolling: touch; max-height: calc(100dvh - 32px); }
.modal-body .offer-img { max-width: 105px; margin: 0 auto 6px; }
.modal-body .offer-name { font-size: 1.12rem; margin-bottom: 2px; }
.modal-body .offer-qty { margin-bottom: 8px; }
.modal-body .price-block { padding: 8px 10px; margin-bottom: 10px; }
.modal-body .price-new { font-size: 1.45rem; }
.modal-body .form-row { gap: 8px; margin-bottom: 8px; }
.modal-body .field input { padding: 11px 12px 11px 38px; }
.modal-body .form-trust { font-size: .72rem; margin-top: 6px; }
.modal-body .btn-cta { padding: 12px; font-size: .98rem; }
.modal-body .trust-mini { margin-bottom: 8px; }
.modal-urgent { background: linear-gradient(90deg, var(--danger), var(--primary));
  color: #fff; padding: 8px 14px; font-size: .82rem; font-weight: 700; text-align: center;
  display: flex; align-items: center; justify-content: center; gap: 6px; }
.modal-urgent .pulse { width: 8px; height: 8px; border-radius: 50%; background: #fff; animation: imo-pulse 1.4s infinite; }
.md-icon { width: 18px; height: 18px; }
.md-submit { padding: 14px; }

/* ============== MODAL V3 (audioverde-style) ============== */
.modal-v3 .modal-close { background: rgba(0,0,0,.06); top: 14px; right: 14px; }
.modal-v3 .modal-body { text-align: center; padding: 22px 20px 16px; }
.modal-v3-img { width: 140px; height: 140px; object-fit: contain; margin: 0 auto 6px; display: block; }
.modal-v3-name { font-family: var(--font-display); font-size: 1.3rem; font-weight: 800; color: var(--text); margin-bottom: 12px; letter-spacing: -.01em; }
.modal-v3-price-row { display: flex; align-items: center; justify-content: center; gap: 10px; margin-bottom: 12px; }
.modal-v3-old { color: var(--muted); text-decoration: line-through; font-size: 1rem; }
.modal-v3-new { color: var(--primary); font-size: 1.85rem; font-weight: 800; font-family: var(--font-display); letter-spacing: -.02em; line-height: 1; }
.modal-v3-badge { background: var(--danger); color: #fff; padding: 4px 10px; border-radius: 999px; font-size: .78rem; font-weight: 800; }
.modal-v3-shipping { display: inline-flex; align-items: center; gap: 8px; background: linear-gradient(180deg, #2EA047, #1F7A35);
  color: #fff; padding: 9px 18px; border-radius: 999px; font-weight: 700; font-size: .92rem;
  margin-bottom: 18px; box-shadow: 0 4px 12px rgba(46,160,71,.32); }
.modal-v3-shipping svg { width: 16px; height: 16px; }
.modal-v3-trust-row { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; margin-bottom: 16px; }
.mvt-item { display: flex; flex-direction: column; align-items: center; gap: 6px; }
.mvt-icon { width: 44px; height: 44px; border-radius: 50%; display: inline-flex; align-items: center; justify-content: center;
  color: #fff; font-weight: 800; font-size: 1.05rem; box-shadow: 0 4px 10px rgba(0,0,0,.10); }
.mvt-icon svg { width: 22px; height: 22px; }
.mvt-icon-gold { background: linear-gradient(180deg, #F5B842, #D89320); }
.mvt-icon-green { background: linear-gradient(180deg, #2EA047, #1F7A35); }
.mvt-icon-orange { background: linear-gradient(180deg, var(--primary), var(--primary-dark)); }
.mvt-label { font-size: .72rem; font-weight: 600; color: var(--text); line-height: 1.2; text-align: center; }
.modal-v3 .form-row-stack { display: flex; flex-direction: column; gap: 8px; margin-bottom: 10px; }
.modal-v3 .field input { padding: 12px 12px 12px 38px; font-size: .95rem; background: #FFF8F0; border: 1px solid var(--line); }
.modal-v3 .field-phone input { padding-left: 64px; }
.modal-v3-cta { width: 100%; padding: 14px; font-size: 1rem; font-weight: 800;
  background: linear-gradient(95deg, var(--primary) 0%, #E8732D 50%, var(--accent) 100%);
  display: inline-flex; align-items: center; justify-content: center; gap: 8px; position: relative; }
.modal-v3-cta svg { width: 18px; height: 18px; }
.modal-v3-cta-badge { background: rgba(255,255,255,.22); color: #fff; padding: 3px 8px; border-radius: 999px; font-size: .72rem; font-weight: 800; margin-left: 4px; }
.modal-v3-mini-trust { display: flex; justify-content: center; gap: 14px; margin-top: 10px; flex-wrap: wrap; font-size: .76rem; color: var(--muted); }
.modal-v3-mini-trust span { display: inline-flex; align-items: center; gap: 4px; }
.modal-v3-mini-trust svg { width: 13px; height: 13px; color: var(--success, #2EA047); }
.modal-v3-callback { display: flex; align-items: center; justify-content: center; gap: 8px;
  background: linear-gradient(90deg, rgba(208,74,59,.08), rgba(var(--primary-rgb),.08));
  color: var(--text); padding: 10px 14px; border-radius: 12px; font-size: .82rem;
  margin-top: 14px; border: 1px solid rgba(var(--primary-rgb),.18); text-align: left; }
.modal-v3-callback svg { width: 16px; height: 16px; color: var(--danger); flex-shrink: 0; }
.modal-v3-callback strong { color: var(--primary-dark); }
@media (max-width: 480px) {
  .modal-v3 .modal-body { padding: 18px 16px 14px; }
  .modal-v3-img { width: 110px; height: 110px; }
  .modal-v3-name { font-size: 1.15rem; margin-bottom: 8px; }
  .modal-v3-price-row { gap: 8px; margin-bottom: 10px; }
  .modal-v3-new { font-size: 1.55rem; }
  .modal-v3-shipping { padding: 8px 14px; font-size: .82rem; margin-bottom: 12px; }
  .modal-v3-trust-row { gap: 4px; margin-bottom: 12px; }
  .mvt-icon { width: 38px; height: 38px; }
  .mvt-icon svg { width: 18px; height: 18px; }
  .mvt-label { font-size: .66rem; }
  .modal-v3-cta { padding: 12px; font-size: .92rem; }
  .modal-v3-callback { font-size: .74rem; padding: 8px 10px; margin-top: 10px; }
}

/* ============== FOOTER ============== */
.footer { background: var(--dark-bg); color: rgba(255,255,255,.78); padding: 48px 0 24px; }
.footer-top { text-align: center; margin-bottom: 28px; }
.footer-logo { font-family: var(--font-display); color: #fff; font-size: 1.5rem; font-weight: 800; margin-bottom: 8px; display: inline-block; }
.footer-tagline { color: rgba(255,255,255,.7); font-size: .92rem; max-width: 480px; margin: 0 auto; }
.footer-grid { max-width: 920px; margin: 0 auto; display: grid; grid-template-columns: repeat(4, 1fr); gap: 28px; padding: 28px 0; border-top: 1px solid rgba(255,255,255,.08); border-bottom: 1px solid rgba(255,255,255,.08); }
.footer-col h4 { color: #fff; font-family: var(--font-body); font-size: .85rem; letter-spacing: .12em; text-transform: uppercase; margin-bottom: 12px; font-weight: 800; }
.footer-col ul { display: grid; gap: 8px; }
.footer-col a { color: rgba(255,255,255,.92); font-size: .9rem; font-weight: 500; transition: color .15s; }
.footer .hl, .footer .hl-accent, .footer .hl-green, .footer .hl-blue, .footer .hl-purple, .footer .hl-teal { background: transparent; padding: 0; color: inherit; font-weight: inherit; }
.footer-col a:hover { color: var(--accent); }
.footer-col p { color: rgba(255,255,255,.7); font-size: .88rem; margin-bottom: 8px; }
.footer-bottom { text-align: center; padding-top: 22px; font-size: .8rem; color: rgba(255,255,255,.5); }
.footer-disclaimer { font-size: .76rem; color: rgba(255,255,255,.55); max-width: 720px; margin: 14px auto 0; line-height: 1.6; }

/* ============== UTILITIES ============== */
.section-head { text-align: center; max-width: 720px; margin: 0 auto 28px; }
.section-head .eyebrow { display: inline-block; }
.mt-12 { margin-top: 12px; } .mt-24 { margin-top: 24px; } .mt-36 { margin-top: 36px; }
.mb-12 { margin-bottom: 12px; } .mb-24 { margin-bottom: 24px; }
.flex { display: flex; } .gap-12 { gap: 12px; } .ai-c { align-items: center; } .jc-c { justify-content: center; } .jc-sb { justify-content: space-between; }
.hide-mob { display: block; } .show-mob { display: none; }

/* Subpage hero variant */
.subpage-hero { padding: 38px 0 24px; background: linear-gradient(180deg, #FFF4E5, #FFFCF7); }
.subpage-hero h1 { font-size: 2.1rem; margin-bottom: 10px; }
.crumbs { font-size: .82rem; color: var(--muted); margin-bottom: 8px; }

/* ============== BUYING GUIDE (5 horizontal cards) ============== */
.buy-guide { padding: 36px 0; }
.buy-guide-head { text-align: center; margin-bottom: 22px; }
.buy-guide-head h2 { display: inline-block; }
.buy-guide-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 12px; }
.buy-step { background: #fff; border: 1px solid var(--line); border-radius: var(--radius); padding: 18px 12px; text-align: center; position: relative; transition: transform .18s, box-shadow .18s; }
.buy-step:hover { transform: translateY(-3px); box-shadow: var(--shadow); }
.buy-step .bs-emoji { font-size: 2rem; line-height: 1; display: block; margin-bottom: 6px; }
.buy-step .bs-num { position: absolute; top: 8px; left: 10px; width: 22px; height: 22px; border-radius: 50%; background: var(--primary); color: #fff; font-size: .72rem; font-weight: 800; display: inline-flex; align-items: center; justify-content: center; }
.buy-step .bs-title { font-family: var(--font-display); font-size: .95rem; font-weight: 700; color: var(--text); margin-top: 4px; line-height: 1.25; }
.buy-step .bs-sub { font-size: .76rem; color: var(--muted); margin-top: 4px; line-height: 1.35; }
@media (max-width: 768px) {
  .buy-guide-grid { grid-template-columns: repeat(3, 1fr); gap: 8px; }
  .buy-step { padding: 14px 8px 12px; }
  .buy-step .bs-emoji { font-size: 1.5rem; }
  .buy-step .bs-title { font-size: .82rem; }
  .buy-step .bs-sub { font-size: .7rem; }
  .buy-step .bs-num { width: 18px; height: 18px; font-size: .62rem; top: 6px; left: 6px; }
}
@media (max-width: 480px) {
  .buy-guide-grid { grid-template-columns: repeat(3, 1fr); }
}

/* ============== OFFICIAL SITE BADGE ============== */
.official-badge { display: inline-flex; align-items: center; gap: 8px; padding: 7px 14px; background: linear-gradient(180deg, #fff, #FFF8F0); border: 1px solid rgba(var(--primary-rgb), .25); border-radius: var(--radius-full); font-size: .82rem; font-weight: 700; color: var(--text); box-shadow: var(--shadow-sm); }
.official-badge .ob-flag { font-size: 1.05rem; line-height: 1; }
.official-badge .ob-dot { width: 7px; height: 7px; border-radius: 50%; background: var(--success); box-shadow: 0 0 0 0 rgba(46,160,67,.55); animation: imo-ob-pulse 2.4s infinite; }
@keyframes imo-ob-pulse { 0%, 100% { box-shadow: 0 0 0 0 rgba(46,160,67,.55); } 50% { box-shadow: 0 0 0 6px rgba(46,160,67,0); } }

/* ============== TRUST MINI (in offer boxes / modal) ============== */
.trust-mini { display: grid; grid-template-columns: repeat(3, 1fr); gap: 6px; margin: 10px 0 12px; }
.trust-mini .tm { display: flex; flex-direction: column; align-items: center; gap: 2px; padding: 8px 4px; background: rgba(var(--primary-rgb), .04); border-radius: 10px; }
.trust-mini .tm-ico { font-size: 1.15rem; line-height: 1; }
.trust-mini .tm-lbl { font-size: .68rem; font-weight: 600; color: var(--text-soft); text-align: center; line-height: 1.15; }

/* ============== SOCIAL PROOF LINE ============== */
.social-proof { display: inline-flex; align-items: center; gap: 8px; font-size: .85rem; color: var(--text-soft); padding: 8px 14px; background: rgba(var(--accent-rgb), .12); border-radius: var(--radius-full); margin-top: 10px; white-space: nowrap; max-width: 100%; overflow: hidden; text-overflow: ellipsis; }
.social-proof .sp-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--success); animation: imo-pulse 2s infinite; flex-shrink: 0; }
.social-proof strong { color: var(--text); }

/* ============== STICKY-V2 OFFSET ============== */
body.has-sticky { padding-bottom: 76px; }
@media (min-width: 1024px) { .sticky-v2 { display: none; } body.has-sticky { padding-bottom: 0; } }

/* ============== FOOTER LINK EMOJI SPACING ============== */
.footer-col a .fc-emoji { display: inline-block; margin-right: 6px; opacity: .9; }
.footer-stance { display: inline-flex; align-items: center; gap: 6px; padding: 6px 12px; background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.1); border-radius: var(--radius-full); font-size: .8rem; color: rgba(255,255,255,.85); margin-top: 10px; }

/* ============== Slightly larger offer-box image ============== */
.offer-box .offer-img { max-width: 240px; }
@media (max-width: 480px) { .offer-box .offer-img { max-width: 200px; } }
.crumbs a { color: var(--primary); }
.crumbs a:hover { text-decoration: underline; }

/* ============== RESPONSIVE ============== */
@media (max-width: 1024px) {
  :root { --section-py: 40px; }
  .container { padding: 0 18px; }
  .header-nav { position: fixed; top: calc(var(--header-h) + 8px); left: 50%;
    transform: translate(-50%, -10px); width: 92%; max-width: 360px;
    height: auto; max-height: calc(100dvh - var(--header-h) - 24px);
    background: var(--surface); border: 1px solid var(--line);
    border-radius: 18px; box-shadow: var(--shadow-lg); padding: 16px;
    flex-direction: column; align-items: stretch; gap: 4px; opacity: 0; visibility: hidden;
    overflow-y: auto; transition: opacity .2s, transform .2s, visibility .2s; z-index: 55; }
  .header-nav.active { transform: translate(-50%, 0); opacity: 1; visibility: visible; }
  .header-nav a { padding: 12px 14px; border-radius: 10px; text-align: center; background: #fff; font-size: .95rem; }
  .header-nav a:hover { background: var(--primary-pale); }
  .hamburger { display: inline-flex; }
  .hero-inner { grid-template-columns: 1fr; gap: 22px; text-align: center; }
  .hero-side { order: -1; }
  .hero-copy { display: flex; flex-direction: column; align-items: center; }
  .hero-lead { margin-left: auto; margin-right: auto; }
  .trust-pills { justify-content: center; }
  .hero-badges { display: none; }
  .grid-3, .grid-4 { grid-template-columns: repeat(2, 1fr); }
  .ing-grid, .test-grid, .howto-grid, .cause-grid { grid-template-columns: repeat(2, 1fr); }
  .doctor-card { grid-template-columns: 200px 1fr; padding: 22px; gap: 18px; }
  .footer-grid { grid-template-columns: repeat(2, 1fr); gap: 22px; }
}
@media (max-width: 768px) {
  :root { --section-py: 36px; }
  body { font-size: 15.5px; }
  h1 { font-size: 1.85rem; }
  h2 { font-size: 1.55rem; }
  h3 { font-size: 1.12rem; }
  .promo-bar { font-size: .76rem; }
  .promo-bar .sep { margin: 0 8px; }
  .header-cta span { display: none; }
  .header-cta { padding: 9px 12px; }
  .hero { padding: 24px 0 36px; }
  .hero-img { max-height: 320px; }
  .hero-image-desktop { display: none; }
  .hero-image-mobile { display: block; }
  .grid-3, .grid-4, .grid-2 { grid-template-columns: 1fr; }
  .ing-grid, .test-grid, .howto-grid, .cause-grid { grid-template-columns: 1fr; }
  .incl-excl, .real-table, .chart-grid { grid-template-columns: 1fr; }
  .trust-bar-grid { grid-template-columns: repeat(2, 1fr); gap: 14px; }
  .doctor-card { grid-template-columns: 1fr; text-align: center; }
  .doctor-photo { max-width: 200px; margin: 0 auto; }
  .doctor-quote { text-align: left; }
  .footer-grid { grid-template-columns: 1fr; text-align: center; }
  .footer-col ul { justify-items: center; }
  .sticky-v2 { display: flex; }
  body.has-sticky { padding-bottom: 80px; }
  .hide-mob { display: none; } .show-mob { display: block; }
  .howto { padding: 40px 0; }
  .howto-grid { gap: 16px; }
}
@media (max-width: 480px) {
  h1 { font-size: 1.6rem; }
  h2 { font-size: 1.4rem; }
  .container { padding: 0 14px; }
  .offer-box { padding: 16px; }
  .price-new { font-size: 1.7rem; }
  .promo-bar { height: 36px; padding: 0 8px; }
  .promo-bar .sep:nth-of-type(2) { display: none; }
  .promo-bar span:nth-of-type(3) { display: none; }
  /* Trust pills shrink + wrap centered */
  .trust-pills { gap: 6px; justify-content: center; }
  .trust-pill { font-size: .76rem; padding: 5px 10px; }
  /* Social proof: shrink to fit one line */
  .social-proof { font-size: .72rem; padding: 6px 11px; gap: 6px; }
  /* Modal: tighter on small screens so form button visible */
  .modal-urgent { padding: 6px 12px; font-size: .74rem; }
  .modal-body { padding: 14px 14px 12px; }
  .modal-body .offer-img { max-width: 78px; margin-bottom: 4px; }
  .modal-body .offer-name { font-size: 1rem; }
  .modal-body .offer-qty { font-size: .78rem; margin-bottom: 6px; }
  .modal-body .price-block { padding: 6px 10px; margin-bottom: 8px; }
  .modal-body .price-new { font-size: 1.3rem; }
  .modal-body .form-row { gap: 6px; margin-bottom: 6px; }
  .modal-body .field input { padding: 10px 12px 10px 36px; font-size: .92rem; }
  .modal-body .btn-cta { padding: 11px; font-size: .92rem; }
  .modal-body .form-trust { font-size: .68rem; margin-top: 4px; }
  /* Buy-guide: 3+2 with second row centered */
  .buy-guide-grid { display: grid; grid-template-columns: repeat(6, 1fr); gap: 6px; }
  .buy-step { grid-column: span 2; padding: 12px 6px 10px; }
  .buy-step:nth-child(4) { grid-column: 2 / span 2; }
  .buy-step:nth-child(5) { grid-column: 4 / span 2; }
  .buy-step .bs-emoji { font-size: 1.4rem; }
  .buy-step .bs-title { font-size: .78rem; }
  .buy-step .bs-sub { font-size: .68rem; }
  /* Footer link contrast */
  .footer-col a { color: rgba(255,255,255,.92); font-weight: 500; }
}

/* ============== ACCESSIBILITY ============== */
:focus-visible { outline: 3px solid rgba(var(--primary-rgb), .55); outline-offset: 2px; border-radius: 4px; }
/* Note: brand explicitly opts out of reduce-motion stripping — animations are core to perceived
   product quality. We keep transitions normal regardless of OS preference. */

/* ============== OVERRIDES (palette refresh + UX polish) ============== */
/* Phone field: prevent +90 from overlapping placeholder digits */
.field-phone input { padding-left: 64px; }
.field-cc { font-weight: 700; color: var(--text); }
.field-cc::after { content: ""; position: absolute; right: -8px; top: 18%; height: 64%; width: 1px; background: var(--line); }

/* Encouraging "breathe" pulse on primary CTA — subtle scale + soft glow */
.btn-cta { position: relative; overflow: hidden; animation: imo-cta-breathe 3.6s ease-in-out infinite; }
.btn-cta::before { content: ""; position: absolute; inset: 0; background: linear-gradient(110deg, transparent 30%, rgba(255,255,255,.28) 50%, transparent 70%); transform: translateX(-110%); animation: imo-cta-shine 4.2s ease-in-out infinite; pointer-events: none; }
.btn-cta:hover { animation-play-state: paused; }
.btn-cta:hover::before { animation-play-state: paused; }
@keyframes imo-cta-breathe {
  0%, 100% { box-shadow: 0 12px 28px rgba(var(--primary-rgb), .35); }
  50%      { box-shadow: 0 14px 36px rgba(var(--primary-rgb), .50), 0 0 0 4px rgba(var(--primary-rgb), .10); }
}
@keyframes imo-cta-shine {
  0%, 60%  { transform: translateX(-110%); }
  80%      { transform: translateX(110%); }
  100%     { transform: translateX(110%); }
}

/* Compact modal — fits in viewport without scroll, two stacked rows */
.modal-content { max-width: 420px; max-height: calc(100dvh - 16px); border-radius: 16px; }
.modal-urgent { padding: 6px 12px; font-size: .76rem; }
.modal-body { padding: 14px 16px 12px; }
.modal-body .offer-img { max-width: 84px; margin: 0 auto 4px; }
.modal-body .offer-name { font-size: 1.05rem; margin-bottom: 0; }
.modal-body .offer-qty { margin-bottom: 6px; font-size: .76rem; }
.modal-body .price-block { padding: 6px 10px; margin-bottom: 8px; }
.modal-body .price-old { font-size: .92rem; }
.modal-body .price-new { font-size: 1.35rem; }
.modal-body .form-row { grid-template-columns: 1fr; gap: 7px; margin-bottom: 7px; }
.modal-body .field input { padding: 10px 12px 10px 38px; font-size: .94rem; }
.modal-body .field-phone input { padding-left: 60px; }
.modal-body .btn-cta { padding: 11px; font-size: .94rem; }
.modal-body .form-trust { font-size: .68rem; gap: 10px; margin-top: 5px; }
.modal-body .trust-mini { display: none; }

/* More colorful cards — cycle accents on benefit, cause, use-case grids */
.benefit-card:nth-child(6n+1) { border-top: 3px solid #C75A3D; }
.benefit-card:nth-child(6n+2) { border-top: 3px solid #4E9062; }
.benefit-card:nth-child(6n+3) { border-top: 3px solid #4B7FB2; }
.benefit-card:nth-child(6n+4) { border-top: 3px solid #8A6CB0; }
.benefit-card:nth-child(6n+5) { border-top: 3px solid #E8A95B; }
.benefit-card:nth-child(6n)   { border-top: 3px solid #C65A78; }
.benefit-card:nth-child(6n+1) .benefit-icon { background: rgba(199,90,61,.12);  color: #C75A3D; }
.benefit-card:nth-child(6n+2) .benefit-icon { background: rgba(78,144,98,.13);  color: #4E9062; }
.benefit-card:nth-child(6n+3) .benefit-icon { background: rgba(75,127,178,.13); color: #4B7FB2; }
.benefit-card:nth-child(6n+4) .benefit-icon { background: rgba(138,108,176,.13);color: #8A6CB0; }
.benefit-card:nth-child(6n+5) .benefit-icon { background: rgba(232,169,91,.18); color: #B07F30; }
.benefit-card:nth-child(6n)   .benefit-icon { background: rgba(198,90,120,.13); color: #C65A78; }

.use-card:nth-child(4n+1), .cause-card:nth-child(4n+1), .farma-card:nth-child(5n+1) { border-left: 3px solid #C75A3D; }
.use-card:nth-child(4n+2), .cause-card:nth-child(4n+2), .farma-card:nth-child(5n+2) { border-left: 3px solid #4B7FB2; }
.use-card:nth-child(4n+3), .cause-card:nth-child(4n+3), .farma-card:nth-child(5n+3) { border-left: 3px solid #4E9062; }
.use-card:nth-child(4n),   .cause-card:nth-child(4n),   .farma-card:nth-child(5n+4) { border-left: 3px solid #8A6CB0; }
.farma-card:nth-child(5n+5), .farma-card:nth-child(5n) { border-left: 3px solid #E8A95B; }

/* Buy-guide steps — colorful per step */
.buy-step:nth-child(1) .bs-num { background: #C75A3D; }
.buy-step:nth-child(2) .bs-num { background: #4B7FB2; }
.buy-step:nth-child(3) .bs-num { background: #4E9062; }
.buy-step:nth-child(4) .bs-num { background: #8A6CB0; }
.buy-step:nth-child(5) .bs-num { background: #C65A78; }
.buy-step:nth-child(1) { background: linear-gradient(180deg, #fff, rgba(199,90,61,.05)); }
.buy-step:nth-child(2) { background: linear-gradient(180deg, #fff, rgba(75,127,178,.05)); }
.buy-step:nth-child(3) { background: linear-gradient(180deg, #fff, rgba(78,144,98,.05)); }
.buy-step:nth-child(4) { background: linear-gradient(180deg, #fff, rgba(138,108,176,.05)); }
.buy-step:nth-child(5) { background: linear-gradient(180deg, #fff, rgba(198,90,120,.05)); }

/* Center offer image regardless of context (some inline styles override) */
.offer-box .offer-img, .mid-cta .offer-img { margin-left: auto !important; margin-right: auto !important; display: block; }
.mid-cta-img { max-width: 130px; margin: 0 auto 14px !important; filter: drop-shadow(0 16px 32px rgba(0,0,0,.35)); animation: imo-float 4.2s ease-in-out infinite; }

/* Soften animated bg / reduce visual noise */
.hero-bg-orb { animation-duration: 14s; }
.hb-bubble { animation-duration: 5.4s; }

/* Contrast bumps — guarantee WCAG AA on small text */
.test-loc { color: var(--text-soft); }
.form-trust { color: var(--text-soft); }
.trust-mini .tm-lbl { color: #1B2440 !important; font-weight: 700; }
.farma-status { color: #B53A1F; font-weight: 700; }
