@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@400;500;600;700;800&display=swap');

/* Reset */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --green:       #54613f;   /* header, footer */
  --green-dark:  #17351f;   /* badges, deep accents */
  --green-light: #c5db97;   /* light tag bg */
  --gold:        #d19c12;   /* CTA, accent */
  --gold-dark:   #b88510;
  --text:        #1a1a1a;
  --muted:       #666;
  --line:        #e5e5e5;
  --bg:          #f4f4f4;
  --card-bg:     #fff;
  --radius:      8px;
  --shadow:      0 2px 10px rgba(0,0,0,.10);
}

html, body { overflow-x: hidden; }
body { font-family: 'Poppins', system-ui, sans-serif; color: var(--text); background: var(--bg); line-height: 1.6; }

a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }
.container { max-width: 1160px; margin: 0 auto; padding: 0 24px; }

/* ── Header ─────────────────────────────────────────────────────────── */
.site-header { background: var(--green); }
.header-main { display: flex; align-items: center; justify-content: space-between; height: 68px; }
.logo img { height: 40px; }
.nav { display: flex; align-items: center; gap: 28px; }
.nav a { color: #fff; font-size: 13px; font-weight: 500; text-transform: uppercase; letter-spacing: .5px; transition: color .2s; }
.nav a:hover, .nav a.active { color: var(--gold); }
.nav-actions { display: flex; align-items: center; gap: 14px; }
.nav-actions a { color: #fff; font-size: 13px; display: flex; align-items: center; gap: 5px; }
.nav-actions a:hover { color: var(--gold); }

/* search bar */
.header-search { background: var(--gold); padding: 10px 0; }
.header-search .container { display: flex; align-items: center; gap: 0; }
.search-form { display: flex; flex: 1; gap: 0; }
.cat-select { padding: 10px 14px; border: none; border-radius: var(--radius) 0 0 var(--radius); font-size: 13px; font-family: inherit; background: rgba(255,255,255,.9); color: var(--green-dark); font-weight: 600; cursor: pointer; flex-shrink: 0; border-right: 1px solid var(--line); outline: none; }
.search-form input { flex: 1; padding: 10px 16px; border: none; border-radius: 0; font-size: 14px; font-family: inherit; outline: none; min-width: 0; }
.search-form button { background: var(--green); color: #fff; border: none; padding: 10px 28px; border-radius: 0 var(--radius) var(--radius) 0; font-size: 14px; font-weight: 600; cursor: pointer; font-family: inherit; white-space: nowrap; flex-shrink: 0; }
.search-form button:hover { background: var(--green-dark); }

/* trust bar */
.trust-bar { background: var(--green-dark); color: #fff; text-align: center; padding: 7px 0; font-size: 12px; font-weight: 500; letter-spacing: .3px; }
.trust-bar span { margin: 0 12px; }
.trust-bar span::before { content: '✓ '; }

/* ── Buttons ─────────────────────────────────────────────────────────── */
.btn { display: inline-flex; align-items: center; justify-content: center; gap: 6px; padding: 12px 24px; border-radius: var(--radius); font-size: 14px; font-weight: 700; cursor: pointer; transition: background .2s, transform .1s; border: 2px solid transparent; font-family: inherit; text-decoration: none; }
.btn:active { transform: scale(.98); }
.btn-primary { background: var(--gold); color: #fff; border-color: var(--gold); }
.btn-primary:hover { background: var(--gold-dark); border-color: var(--gold-dark); }
.btn-outline { background: transparent; color: var(--green); border-color: var(--green); }
.btn-outline:hover { background: var(--green); color: #fff; }
.btn-outline-white { background: transparent; color: #fff; border-color: #fff; }
.btn-outline-white:hover { background: #fff; color: var(--green); }
.btn-lg { padding: 15px 32px; font-size: 16px; }
.btn-sm { padding: 6px 14px; font-size: 13px; }
.btn-danger { background: #ef4444; color: #fff; border-color: #ef4444; }
.btn-danger:hover { background: #dc2626; }
.btn-full { width: 100%; }

/* ── Alerts / Flash ──────────────────────────────────────────────────── */
.alert { padding: 12px 16px; border-radius: var(--radius); margin-bottom: 20px; font-size: 14px; }
.alert-success { background: #f0fdf4; color: #166534; border: 1px solid #bbf7d0; }
.alert-error   { background: #fef2f2; color: #b91c1c; border: 1px solid #fecaca; }

/* ── Prices ──────────────────────────────────────────────────────────── */
.price-current { font-size: 17px; font-weight: 700; color: var(--gold); }
.price-old     { font-size: 13px; color: var(--muted); text-decoration: line-through; }
.price-free    { font-size: 17px; font-weight: 700; color: #16a34a; }

/* ── Pills / Category tags ───────────────────────────────────────────── */
.pill { display: inline-block; padding: 5px 14px; border-radius: 999px; font-size: 12px; font-weight: 600; background: var(--green-light); color: var(--green-dark); transition: background .2s; }
.pill:hover, .pill.active { background: var(--green); color: #fff; }

/* ── Forms ───────────────────────────────────────────────────────────── */
.form-group { margin-bottom: 18px; }
.form-group label { display: block; font-size: 13px; font-weight: 600; color: var(--muted); margin-bottom: 6px; }
.form-control { width: 100%; padding: 11px 14px; border: 1.5px solid var(--line); border-radius: var(--radius); font-size: 14px; font-family: inherit; transition: border-color .2s; background: #fff; }
.form-control:focus { outline: none; border-color: var(--green); }
textarea.form-control { resize: vertical; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }

/* ── Hero ────────────────────────────────────────────────────────────── */
.hero { background: linear-gradient(135deg, var(--green) 0%, #3d4a2c 100%); color: #fff; padding: 48px 0 40px; }
.hero-social-proof { display: flex; align-items: center; gap: 8px; font-size: 14px; opacity: .9; margin-bottom: 16px; }
.hero-stars { color: var(--gold); font-size: 15px; letter-spacing: 2px; }
.hero h1 { font-size: 42px; font-weight: 800; line-height: 1.2; margin-bottom: 16px; max-width: 640px; }
.hero p.hero-subtitle { font-size: 17px; opacity: .85; margin-bottom: 32px; max-width: 520px; }
.hero-actions { display: flex; gap: 14px; flex-wrap: wrap; margin-bottom: 28px; }
.hero-trust { display: flex; gap: 20px; font-size: 13px; opacity: .7; flex-wrap: wrap; }
.hero-trust span::before { content: '✓ '; }

/* ── Category strip on home ─────────────────────────────────────────── */
.categories-strip { background: #fff; padding: 20px 0; border-bottom: 1px solid var(--line); }
.category-pills { display: flex; flex-wrap: wrap; gap: 8px; }

/* ── Section headers ─────────────────────────────────────────────────── */
.section-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 24px; }
.section-title { font-size: 20px; font-weight: 800; text-transform: uppercase; letter-spacing: 1px; color: var(--text); position: relative; padding-left: 14px; }
.section-title::before { content: ''; position: absolute; left: 0; top: 50%; transform: translateY(-50%); width: 4px; height: 22px; background: var(--gold); border-radius: 2px; }

/* ── Products section ────────────────────────────────────────────────── */
.products-section { padding: 48px 0; }
.products-section + .products-section { padding-top: 0; }

/* ── Products toolbar (listing page) ────────────────────────────────── */
.products-page { padding: 36px 0 64px; }
.products-toolbar { display: flex; align-items: baseline; justify-content: space-between; margin-bottom: 20px; gap: 12px; flex-wrap: wrap; }
.products-toolbar-left { display: flex; align-items: baseline; gap: 12px; }
.products-toolbar-right { display: flex; align-items: center; }
.toolbar-title { font-size: 24px; font-weight: 800; color: var(--text); }
.sort-form { display: flex; }
.sort-select { padding: 8px 12px; border: 1.5px solid var(--line); border-radius: var(--radius); font-size: 13px; font-family: inherit; background: #fff; color: var(--text); cursor: pointer; outline: none; }
.sort-select:focus { border-color: var(--green); }

/* ── Product card ────────────────────────────────────────────────────── */
.products-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; }
.product-card { background: var(--card-bg); border-radius: var(--radius); box-shadow: var(--shadow); overflow: hidden; transition: transform .2s, box-shadow .2s; position: relative; }
.product-card:hover { transform: translateY(-4px); box-shadow: 0 8px 24px rgba(0,0,0,.16); }
.product-card-link { display: block; color: inherit; }
.product-card-cover--empty { width: 100%; height: 100%; background: var(--green-light); }
.product-card-overlay { position: absolute; inset: 0; background: rgba(0,0,0,.45); display: flex; align-items: center; justify-content: center; opacity: 0; transition: opacity .25s; }
.product-card:hover .product-card-overlay { opacity: 1; }
.product-card-cta { background: var(--gold); color: #fff; font-size: 13px; font-weight: 700; padding: 9px 20px; border-radius: 999px; white-space: nowrap; }
.product-card-body { padding: 14px 14px 16px; }
.product-card-title { font-size: 14px; font-weight: 600; line-height: 1.35; margin-bottom: 4px; color: var(--text); display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.product-card-excerpt { font-size: 11px; color: var(--muted); line-height: 1.4; margin-bottom: 8px; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.product-card-price { font-size: 15px; }

/* Skeleton de loading para imagens dos cards */
.product-card-cover { aspect-ratio: 3/4; overflow: hidden; background: #e0e0e0; position: relative; }
.product-card-cover::before { content: ''; position: absolute; inset: 0; background: linear-gradient(90deg, transparent 0%, rgba(255,255,255,.4) 50%, transparent 100%); background-size: 200% 100%; animation: skeleton-shimmer 1.4s ease-in-out infinite; z-index: 0; }
.product-card-cover img { width: 100%; height: 100%; object-fit: cover; transition: transform .35s; position: relative; z-index: 1; }
.product-card:hover .product-card-cover img { transform: scale(1.05); }
@keyframes skeleton-shimmer { 0% { background-position: -200% 0; } 100% { background-position: 200% 0; } }

/* Badges */
.badge-best-seller { position: absolute; top: 10px; left: 10px; background: var(--green-dark); color: #fff; font-size: 11px; font-weight: 700; padding: 3px 10px; border-radius: 999px; text-transform: uppercase; letter-spacing: .5px; z-index: 2; }
.badge-free-card { position: absolute; top: 10px; right: 10px; background: #16a34a; color: #fff; font-size: 11px; font-weight: 700; padding: 3px 10px; border-radius: 999px; z-index: 2; }

/* ── Breadcrumb ──────────────────────────────────────────────────────── */
.breadcrumb { display: flex; align-items: center; gap: 6px; font-size: 13px; color: var(--muted); padding: 16px 0; flex-wrap: wrap; }
.breadcrumb a:hover { color: var(--green); text-decoration: underline; }
.breadcrumb span { opacity: .5; }
.breadcrumb span:last-child { opacity: 1; color: var(--text); }

/* ── Product page ────────────────────────────────────────────────────── */
.product-page { padding: 48px 0; }
.product-layout { display: grid; grid-template-columns: 420px 1fr; gap: 60px; align-items: start; }
.product-cover { border-radius: var(--radius); box-shadow: var(--shadow); width: 100%; }
.product-gallery { display: flex; gap: 8px; margin-top: 12px; flex-wrap: wrap; }
.gallery-thumb { width: 64px; height: 64px; object-fit: cover; border-radius: 4px; cursor: pointer; border: 2px solid var(--line); }
.gallery-thumb:hover { border-color: var(--green); }
.product-cats { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 14px; }
.product-info h1 { font-size: 28px; font-weight: 800; line-height: 1.25; margin-bottom: 12px; }
.product-excerpt { color: var(--muted); font-size: 15px; margin-bottom: 20px; line-height: 1.7; }
.product-price-block { margin-bottom: 24px; display: flex; align-items: baseline; gap: 10px; }
.product-price-block .price-current { font-size: 30px; }
.product-price-block .price-free { font-size: 30px; }
.purchased-badge { font-size: 13px; color: #16a34a; margin-top: 10px; font-weight: 600; }
.product-description { margin-top: 28px; font-size: 15px; line-height: 1.8; color: #444; border-top: 1px solid var(--line); padding-top: 24px; }
.product-description h3 { font-size: 16px; font-weight: 700; margin-bottom: 12px; color: var(--text); }

/* Blocos de conversão */
.product-howto, .product-after-purchase, .product-faq { margin-top: 28px; padding-top: 24px; border-top: 1px solid var(--line); }
.product-howto h3, .product-after-purchase h3, .product-faq h3 { font-size: 16px; font-weight: 700; margin-bottom: 14px; color: var(--text); }
.howto-list { list-style: none; counter-reset: howto; display: flex; flex-direction: column; gap: 10px; }
.howto-list li { display: flex; align-items: flex-start; gap: 10px; font-size: 14px; color: #444; line-height: 1.5; counter-increment: howto; }
.howto-list li::before { content: counter(howto); background: var(--green); color: #fff; font-size: 11px; font-weight: 700; width: 20px; height: 20px; border-radius: 50%; display: flex; align-items: center; justify-content: center; flex-shrink: 0; margin-top: 1px; }
.after-list { list-style: none; display: flex; flex-direction: column; gap: 8px; }
.after-list li { display: flex; align-items: flex-start; gap: 8px; font-size: 14px; color: #444; line-height: 1.5; }
.after-list li::before { content: '✓'; color: var(--green); font-weight: 800; flex-shrink: 0; }
.faq-list { display: flex; flex-direction: column; gap: 4px; }
.faq-item { border: 1px solid var(--line); border-radius: 8px; overflow: hidden; }
.faq-item summary { padding: 13px 16px; font-size: 14px; font-weight: 600; cursor: pointer; list-style: none; display: flex; justify-content: space-between; align-items: center; color: var(--text); }
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary::after { content: '+'; font-size: 18px; font-weight: 400; color: var(--muted); flex-shrink: 0; }
.faq-item[open] summary::after { content: '×'; }
.faq-item[open] summary { background: #fafafa; }
.faq-item p { padding: 0 16px 14px; font-size: 14px; color: var(--muted); line-height: 1.6; }
.product-cta-repeat { margin-top: 28px; padding-top: 24px; border-top: 1px solid var(--line); }
.product-cta-price { text-align: center; font-size: 13px; color: var(--muted); margin-top: 10px; }

/* Social proof */
.social-proof { display: flex; align-items: center; gap: 8px; margin-bottom: 16px; }
.social-proof-stars { color: var(--gold); font-size: 15px; letter-spacing: 2px; }
.social-proof-text { font-size: 13px; color: var(--muted); font-weight: 500; }

/* Benefits list */
.product-benefits { list-style: none; margin: 0 0 20px; display: flex; flex-direction: column; gap: 8px; }
.product-benefits li { display: flex; align-items: flex-start; gap: 8px; font-size: 14px; color: #333; }
.product-benefits li::before { content: '✓'; color: var(--green); font-weight: 800; flex-shrink: 0; margin-top: 1px; }

/* Buy box */
.product-buy-box { background: #fafafa; border: 1.5px solid var(--line); border-radius: 12px; padding: 24px; margin: 20px 0; }
.price-old-wrap { display: flex; align-items: center; gap: 8px; margin-bottom: 4px; }
.discount-badge { background: #fef3c7; color: #92400e; font-size: 12px; font-weight: 700; padding: 2px 8px; border-radius: 999px; }
.product-price-block { margin-bottom: 16px; }
.product-price-block .price-current { font-size: 32px; font-weight: 800; display: block; }
.product-price-block .price-free { font-size: 32px; font-weight: 800; display: block; }
.free-note { font-size: 12px; color: var(--muted); text-align: center; margin-top: 8px; }

/* Guarantee */
.guarantee-badge { display: flex; align-items: center; gap: 12px; margin-top: 14px; padding: 12px; background: #f0fdf4; border-radius: 8px; }
.guarantee-icon { font-size: 24px; }
.guarantee-badge strong { font-size: 13px; color: #166534; }
.guarantee-badge small { font-size: 12px; color: #4b7a5c; display: block; }

/* Trust sidebar */
.product-trust { display: flex; flex-direction: column; gap: 8px; margin-top: 16px; padding: 16px; background: #f8f8f8; border-radius: 8px; }
.trust-item { display: flex; align-items: center; gap: 8px; font-size: 13px; color: var(--muted); }

/* Related & Upsell */
.related-section { background: #fff; border-top: 1px solid var(--line); padding-top: 48px; }
.upsell-section { background: #fffbf0; border-top: 3px solid var(--gold); }
.upsell-header { text-align: center; margin-bottom: 32px; }
.upsell-sub { color: var(--muted); font-size: 15px; margin-top: 6px; }

/* Lead Gate */
.lead-gate-page { padding: 48px 0 80px; }
.lead-gate-layout { display: grid; grid-template-columns: 340px 1fr; gap: 60px; align-items: start; }
.lead-gate-cover { position: relative; }
.lead-gate-cover img { border-radius: var(--radius); box-shadow: 0 8px 32px rgba(0,0,0,.15); width: 100%; }
.lead-gate-badge { position: absolute; top: -12px; left: 50%; transform: translateX(-50%); background: var(--gold); color: #fff; font-size: 12px; font-weight: 700; padding: 4px 16px; border-radius: 999px; text-transform: uppercase; letter-spacing: 1px; white-space: nowrap; }
.lead-gate-label { font-size: 12px; font-weight: 700; color: var(--gold); text-transform: uppercase; letter-spacing: 1px; margin-bottom: 10px; }
.lead-gate-form-wrap h1 { font-size: 28px; font-weight: 800; line-height: 1.25; margin-bottom: 12px; }
.lead-gate-excerpt { color: var(--muted); font-size: 15px; line-height: 1.7; margin-bottom: 24px; }
.lead-gate-cta-box { background: var(--green); color: #fff; border-radius: 12px; padding: 28px; margin-bottom: 24px; }
.lead-gate-cta-title { font-size: 18px; font-weight: 700; margin-bottom: 4px; }
.lead-gate-cta-sub { font-size: 14px; opacity: .8; margin-bottom: 20px; }
.lead-gate-form .form-control { border-color: transparent; }
.lead-gate-privacy { font-size: 12px; text-align: center; opacity: .7; margin-top: 10px; }
.lead-gate-desc h3 { font-size: 15px; font-weight: 700; margin-bottom: 8px; }
.lead-gate-desc p { font-size: 14px; color: var(--muted); line-height: 1.7; }

/* ── Auth pages ──────────────────────────────────────────────────────── */
.auth-page { min-height: 72vh; display: flex; align-items: center; justify-content: center; padding: 40px 24px; background: var(--bg); }
.auth-box { width: 100%; max-width: 420px; background: #fff; padding: 40px; border-radius: 16px; box-shadow: 0 4px 24px rgba(0,0,0,.10); }
.auth-logo { margin-bottom: 28px; background: var(--green); display: inline-flex; padding: 10px 16px; border-radius: 8px; }
.auth-box h1 { font-size: 22px; font-weight: 800; margin-bottom: 24px; color: var(--text); }
.auth-links { display: flex; gap: 8px; justify-content: center; font-size: 13px; color: var(--muted); margin-top: 20px; flex-wrap: wrap; }
.auth-links a { color: var(--green); font-weight: 600; }
.auth-links a:hover { text-decoration: underline; }

/* ── Account area ────────────────────────────────────────────────────── */
.account-page { padding: 48px 0; }
.account-layout { display: grid; grid-template-columns: 200px 1fr; gap: 40px; align-items: start; }
.account-nav { background: #fff; border-radius: var(--radius); padding: 8px; box-shadow: var(--shadow); }
.account-nav a { display: block; padding: 10px 14px; border-radius: 6px; font-size: 14px; font-weight: 500; color: var(--text); transition: background .15s; }
.account-nav a:hover { background: var(--bg); }
.account-nav a.active { background: var(--green); color: #fff; font-weight: 600; }
.account-content h1 { font-size: 22px; font-weight: 800; margin-bottom: 24px; }
.account-greeting { color: var(--muted); font-size: 15px; margin-bottom: 28px; }

/* Library grid */
.library-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.library-card { background: #fff; border-radius: var(--radius); box-shadow: var(--shadow); overflow: hidden; }
.library-card img { width: 100%; aspect-ratio: 3/4; object-fit: cover; }
.library-card-body { padding: 14px; }
.library-card-title { font-size: 14px; font-weight: 600; margin-bottom: 10px; }
.empty-state { text-align: center; padding: 48px 24px; color: var(--muted); }
.empty-state p { margin-bottom: 20px; }

/* ── Orders ──────────────────────────────────────────────────────────── */
.table { width: 100%; border-collapse: collapse; font-size: 14px; background: #fff; border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow); }
.table th, .table td { padding: 12px 16px; text-align: left; border-bottom: 1px solid var(--line); }
.table th { font-weight: 700; color: var(--muted); font-size: 12px; text-transform: uppercase; letter-spacing: .5px; background: var(--bg); }
.table tbody tr:hover { background: #fafafa; }
.table-actions { display: flex; gap: 8px; }

/* Badge */
.badge { display: inline-block; padding: 3px 10px; border-radius: 999px; font-size: 12px; font-weight: 600; }
.badge-paid      { background: #f0fdf4; color: #166534; }
.badge-pending   { background: #fffbeb; color: #92400e; }
.badge-cancelled, .badge-failed { background: #fef2f2; color: #b91c1c; }
.badge-green { background: #f0fdf4; color: #166534; }
.badge-gray  { background: #f1f5f9; color: #64748b; }
.badge-published { background: #f0fdf4; color: #166534; }
.badge-draft     { background: #f1f5f9; color: #64748b; }

/* ── Checkout ────────────────────────────────────────────────────────── */
.checkout-page { padding: 48px 0 80px; }
.checkout-layout { display: grid; grid-template-columns: 380px 1fr; gap: 48px; align-items: start; max-width: 900px; }
.checkout-product { display: grid; grid-template-columns: 120px 1fr; gap: 20px; align-items: start; background: #fff; border-radius: 12px; padding: 24px; box-shadow: var(--shadow); }
.checkout-product img { border-radius: var(--radius); width: 100%; box-shadow: 0 2px 8px rgba(0,0,0,.15); }
.checkout-product-info { display: flex; flex-direction: column; gap: 8px; }
.checkout-label { font-size: 11px; font-weight: 700; color: var(--muted); text-transform: uppercase; letter-spacing: 1px; }
.checkout-product h3 { font-size: 15px; font-weight: 700; line-height: 1.3; color: var(--text); }
.checkout-product .price-current { font-size: 20px; }
.checkout-form-wrap { background: #fff; padding: 32px; border-radius: 12px; box-shadow: var(--shadow); }
.checkout-form-wrap h2 { font-size: 20px; font-weight: 800; margin-bottom: 20px; }
.checkout-user-info { background: #f4f4f4; border-radius: 8px; padding: 12px 16px; margin-bottom: 20px; font-size: 14px; line-height: 1.6; }
.checkout-trust { display: flex; flex-direction: column; gap: 6px; margin-top: 12px; }
.checkout-trust .trust-item { font-size: 12px; color: var(--muted); display: flex; align-items: center; gap: 6px; }
.checkout-safe { font-size: 12px; color: var(--muted); text-align: center; margin-top: 14px; line-height: 1.6; }

/* ── Thanks page ─────────────────────────────────────────────────────── */
.thanks-page { display: flex; align-items: center; justify-content: center; min-height: 70vh; padding: 40px; }
.thanks-box { text-align: center; max-width: 480px; }
.thanks-icon { font-size: 64px; margin-bottom: 20px; }
.thanks-box h1 { font-size: 30px; font-weight: 800; margin-bottom: 12px; }
.thanks-box p { color: var(--muted); margin-bottom: 8px; }
.thanks-box .btn { margin-top: 24px; }

/* ── Error page ──────────────────────────────────────────────────────── */
.error-page { display: flex; flex-direction: column; align-items: center; justify-content: center; min-height: 70vh; text-align: center; }
.error-page h1 { font-size: 90px; font-weight: 900; color: var(--green); line-height: 1; }
.error-page p { font-size: 18px; color: var(--muted); margin: 12px 0 28px; }

/* ── Download page ───────────────────────────────────────────────────── */
.download-page { padding: 60px 0; }
.download-list { list-style: none; display: flex; flex-direction: column; gap: 12px; margin-top: 24px; }

/* ── Admin ───────────────────────────────────────────────────────────── */
.admin-page { padding: 40px 24px; max-width: 1160px; margin: 0 auto; }
.admin-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 32px; flex-wrap: wrap; gap: 12px; }
.admin-header h1 { font-size: 24px; font-weight: 800; }
.admin-nav { display: flex; gap: 16px; font-size: 14px; flex-wrap: wrap; align-items: center; }
.admin-nav a { color: var(--green); font-weight: 600; }
.stats-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; }
.stat-card { border: 1px solid var(--line); border-radius: var(--radius); padding: 24px; background: #fff; display: flex; flex-direction: column; gap: 6px; box-shadow: var(--shadow); }
.stat-value { font-size: 30px; font-weight: 800; color: var(--green); }
.stat-label { font-size: 13px; color: var(--muted); font-weight: 600; }
.admin-form { max-width: 720px; }
.form-control-file { display: block; width: 100%; padding: 8px 0; font-size: 14px; font-family: inherit; }
.field-hint { font-size: 12px; color: var(--muted); margin-top: 5px; }
.img-preview-wrap { display: flex; align-items: center; gap: 12px; margin-bottom: 10px; }
.img-preview { height: 80px; border-radius: var(--radius); box-shadow: var(--shadow); object-fit: cover; }
.img-preview-name { font-size: 12px; color: var(--muted); word-break: break-all; }
.gallery-admin-grid { display: flex; flex-wrap: wrap; gap: 10px; margin-bottom: 10px; }
.gallery-admin-item { position: relative; }
.gallery-admin-item img { width: 80px; height: 80px; object-fit: cover; border-radius: var(--radius); border: 1px solid var(--line); display: block; }
.btn-gallery-remove { position: absolute; top: -6px; right: -6px; width: 20px; height: 20px; border-radius: 50%; background: #ef4444; color: #fff; border: none; font-size: 14px; line-height: 1; cursor: pointer; display: flex; align-items: center; justify-content: center; padding: 0; }
.admin-form .form-group { margin-bottom: 20px; }
.admin-form .form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.admin-form label { display: block; font-size: 13px; font-weight: 600; color: var(--muted); margin-bottom: 6px; }
.admin-form .form-control { width: 100%; padding: 10px 12px; border: 1px solid var(--line); border-radius: var(--radius); font-size: 14px; box-sizing: border-box; font-family: inherit; }
.admin-form textarea.form-control { resize: vertical; }
.checkbox-group { display: flex; flex-wrap: wrap; gap: 10px; }
.checkbox-label { display: flex; align-items: center; gap: 6px; font-size: 14px; cursor: pointer; }
.form-actions { display: flex; gap: 12px; margin-top: 28px; }
.purchased-badge { font-size: 13px; color: #16a34a; margin-top: 8px; }

/* ── Minimal layout (checkout/obrigado) ─────────────────────────────── */
.header-minimal { background: var(--green); padding: 14px 0; border-bottom: 2px solid rgba(255,255,255,.1); }
.header-minimal-inner { display: flex; align-items: center; justify-content: space-between; }
.header-minimal-trust { font-size: 12px; color: rgba(255,255,255,.8); display: flex; align-items: center; gap: 6px; }
.footer-minimal { background: var(--green); padding: 16px 0; margin-top: 60px; }
.footer-minimal p { font-size: 12px; color: rgba(255,255,255,.6); text-align: center; }
.footer-minimal a { color: rgba(255,255,255,.7); text-decoration: underline; }

/* ── Mobile menu toggle ──────────────────────────────────────────────── */
.mobile-menu-toggle { display: none; background: none; border: none; color: #fff; cursor: pointer; padding: 4px; }
/* Mobile-only nav elements */
.nav-mobile-auth { display: none; }
.nav-desktop-only { /* shown on desktop by default */ }

/* ── Results count ───────────────────────────────────────────────────── */
.results-count { font-size: 13px; color: var(--muted); margin-bottom: 20px; }

/* ── Empty state ─────────────────────────────────────────────────────── */
.empty-state { text-align: center; padding: 60px 20px; }
.empty-state p { color: var(--muted); margin-bottom: 24px; }

/* ── Static pages ────────────────────────────────────────────────────── */
.static-page { padding: 48px 0 80px; }
.container--narrow { max-width: 760px; }
.static-page-body { background: #fff; padding: 40px; border-radius: 12px; box-shadow: var(--shadow); }
.static-page-body h2 { font-size: 20px; font-weight: 700; color: var(--green); margin: 28px 0 10px; border-left: 3px solid var(--gold); padding-left: 12px; }
.static-page-body h2:first-of-type { margin-top: 20px; }
.static-page-body p { color: var(--muted); margin-bottom: 12px; line-height: 1.8; }
.static-page-body ul { list-style: disc; padding-left: 20px; color: var(--muted); line-height: 1.8; margin-bottom: 12px; }
.static-page-body ul li { margin-bottom: 6px; }
.static-page-body a { color: var(--green); text-decoration: underline; }
.lead { font-size: 16px; color: var(--text); font-weight: 500; border-left: 3px solid var(--gold); padding-left: 16px; line-height: 1.8; }
.muted { color: var(--muted); font-size: 13px; }

/* ── Contact page ────────────────────────────────────────────────────── */
.contact-grid { display: grid; grid-template-columns: 1fr 1.4fr; gap: 48px; align-items: start; margin-top: 8px; }
.contact-info h2 { font-size: 22px; font-weight: 700; margin-bottom: 14px; color: var(--green); }
.contact-info p { color: var(--muted); line-height: 1.8; margin-bottom: 24px; }
.contact-channels { display: flex; flex-direction: column; gap: 12px; }
.contact-channel { display: flex; align-items: center; gap: 10px; font-size: 14px; color: var(--muted); }
.contact-channel a { color: var(--green); text-decoration: underline; }
.contact-channel svg { color: var(--green); flex-shrink: 0; }
.contact-form { background: #fff; padding: 32px; border-radius: 12px; box-shadow: var(--shadow); }
.contact-form .form-group { margin-bottom: 18px; }
.contact-form label { display: block; font-size: 13px; font-weight: 600; color: var(--muted); margin-bottom: 6px; }
.form-control { width: 100%; padding: 10px 14px; border: 1px solid var(--line); border-radius: var(--radius); font-size: 14px; font-family: inherit; outline: none; transition: border-color .2s; }
.form-control:focus { border-color: var(--green); }

/* ── Cart icon / badge ───────────────────────────────────────────────── */
.cart-icon-btn { position: relative; display: flex; align-items: center; color: #fff; padding: 4px; }
.cart-icon-btn:hover { color: var(--gold); }
.cart-badge { position: absolute; top: -6px; right: -8px; background: var(--gold); color: #fff; font-size: 10px; font-weight: 800; min-width: 18px; height: 18px; border-radius: 999px; display: flex; align-items: center; justify-content: center; padding: 0 4px; line-height: 1; }

/* ── Cart page ───────────────────────────────────────────────────────── */
.cart-page { padding: 40px 0 80px; }
.cart-title { font-size: 26px; font-weight: 800; margin-bottom: 32px; }
.cart-layout { display: grid; grid-template-columns: 1fr 340px; gap: 40px; align-items: start; }
.cart-items { display: flex; flex-direction: column; gap: 0; background: #fff; border-radius: 12px; box-shadow: var(--shadow); overflow: hidden; }
.cart-item { display: grid; grid-template-columns: 80px 1fr auto; gap: 16px; align-items: center; padding: 20px 24px; border-bottom: 1px solid var(--line); }
.cart-item:last-child { border-bottom: none; }
.cart-item-cover { display: block; width: 80px; flex-shrink: 0; }
.cart-item-cover img { width: 80px; height: 106px; object-fit: cover; border-radius: 6px; }
.cart-item-info { display: flex; flex-direction: column; gap: 6px; }
.cart-item-title { font-size: 15px; font-weight: 600; color: var(--text); line-height: 1.4; }
.cart-item-title:hover { color: var(--green); }
.cart-item-price { display: flex; align-items: baseline; gap: 8px; }
.btn-remove { background: none; border: none; cursor: pointer; color: var(--muted); padding: 6px; border-radius: 6px; display: flex; transition: color .2s, background .2s; }
.btn-remove:hover { color: #ef4444; background: #fef2f2; }
.cart-summary { position: sticky; top: 24px; }
.cart-summary-box { background: #fff; border-radius: 12px; box-shadow: var(--shadow); padding: 28px; }
.cart-summary-box h3 { font-size: 16px; font-weight: 800; margin-bottom: 20px; }
.cart-summary-rows { display: flex; flex-direction: column; gap: 10px; margin-bottom: 16px; padding-bottom: 16px; border-bottom: 1px solid var(--line); }
.cart-summary-row { display: flex; justify-content: space-between; font-size: 13px; gap: 12px; }
.cart-summary-row span:first-child { color: var(--muted); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.cart-summary-total { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 20px; font-weight: 700; font-size: 15px; }
.cart-total-price { font-size: 22px; color: var(--gold); font-weight: 800; }
.cart-trust { display: flex; align-items: center; gap: 6px; justify-content: center; font-size: 12px; color: var(--muted); margin-top: 14px; }
.cart-continue { display: block; text-align: center; font-size: 13px; color: var(--muted); margin-top: 14px; }
.cart-continue:hover { color: var(--green); }

/* ── Checkout: produto único ─────────────────────────────────────────── */
.checkout-sidebar { display: flex; flex-direction: column; gap: 16px; }
.checkout-product-card { background: #fff; border-radius: 12px; box-shadow: var(--shadow); padding: 24px; }
.checkout-product-single { display: grid; grid-template-columns: 96px 1fr; gap: 16px; align-items: start; margin-bottom: 16px; }
.checkout-product-single img { border-radius: var(--radius); width: 96px; box-shadow: 0 2px 8px rgba(0,0,0,.15); }
.checkout-product-info { display: flex; flex-direction: column; gap: 6px; }
.checkout-product-info h3 { font-size: 14px; font-weight: 700; line-height: 1.35; color: var(--text); }

/* ── Checkout: carrinho ──────────────────────────────────────────────── */
.checkout-cart-item { display: grid; grid-template-columns: 56px 1fr; gap: 12px; align-items: center; padding: 12px 0; border-bottom: 1px solid var(--line); }
.checkout-cart-item:last-of-type { border-bottom: none; }
.checkout-cart-item img { width: 56px; height: 74px; object-fit: cover; border-radius: 4px; }
.checkout-cart-item-info { display: flex; flex-direction: column; gap: 4px; }
.checkout-cart-item-title { font-size: 13px; font-weight: 600; line-height: 1.3; color: var(--text); }
.checkout-cart-total { display: flex; justify-content: space-between; align-items: baseline; padding-top: 12px; margin-top: 4px; border-top: 1.5px solid var(--line); font-weight: 700; font-size: 14px; }
.checkout-cart-total .price-current { font-size: 20px; }

/* ── Checkout: dados do comprador ────────────────────────────────────── */
.checkout-guest-form { background: #fafafa; border-radius: 10px; padding: 20px; margin-bottom: 20px; border: 1px solid var(--line); }
.checkout-user-info { display: flex; align-items: center; gap: 8px; background: #f0fdf4; border: 1px solid #bbf7d0; border-radius: 8px; padding: 12px 16px; margin-bottom: 20px; font-size: 14px; font-weight: 500; flex-wrap: wrap; }
.checkout-user-email { font-size: 13px; color: var(--muted); font-weight: 400; }

/* ── MP Bricks loading ───────────────────────────────────────────────── */
.mp-loading { display: flex; align-items: center; gap: 10px; color: var(--muted); font-size: 14px; padding: 20px 0; }
.mp-loading-spinner { width: 20px; height: 20px; border: 2px solid var(--line); border-top-color: var(--green); border-radius: 50%; animation: spin .7s linear infinite; flex-shrink: 0; }
@keyframes spin { to { transform: rotate(360deg); } }

/* ── PIX / Boleto pending ────────────────────────────────────────────── */
.checkout-pending { text-align: center; padding: 8px 0; }
.pix-container, .boleto-container { display: flex; flex-direction: column; align-items: center; gap: 16px; }
.pix-icon { font-size: 48px; }
.checkout-pending h3 { font-size: 20px; font-weight: 800; color: var(--text); }
.checkout-pending p { font-size: 14px; color: var(--muted); line-height: 1.6; max-width: 380px; }
.pix-qr { width: 200px; height: 200px; border: 1px solid var(--line); border-radius: 8px; padding: 8px; background: #fff; }
.pix-copy-wrap { display: flex; gap: 8px; width: 100%; max-width: 420px; }
.pix-copy-wrap .form-control { font-size: 11px; font-family: monospace; }
.pix-info { display: flex; align-items: center; gap: 6px; font-size: 13px !important; }
.pending-note { border-top: 1px solid var(--line); padding-top: 16px; margin-top: 8px; }
.pending-note a { color: var(--green); text-decoration: underline; }

/* ── Thanks page: lista de itens do carrinho ─────────────────────────── */
.thanks-items-list { list-style: none; text-align: left; background: #f8f8f8; border-radius: 8px; padding: 16px 20px; margin: 16px 0; display: flex; flex-direction: column; gap: 8px; }
.thanks-items-list li a { color: var(--green); font-size: 14px; font-weight: 500; }
.thanks-items-list li a:hover { text-decoration: underline; }

/* ── Add-to-cart button feedback ─────────────────────────────────────── */
.btn-cart-added { background: #f0fdf4 !important; color: #166534 !important; border-color: #bbf7d0 !important; }

/* ── Sticky CTA actions (mobile) ─────────────────────────────────────── */
.sticky-cta-actions { display: flex; gap: 8px; align-items: center; flex-shrink: 0; }

/* ── Sticky CTA (mobile product page) ───────────────────────────────── */
.sticky-cta { display: none; position: fixed; bottom: 0; left: 0; right: 0; background: var(--green); color: #fff; z-index: 900; box-shadow: 0 -2px 12px rgba(0,0,0,.2); transform: translateY(100%); transition: transform .3s ease; }
.sticky-cta--visible { transform: translateY(0); }
.sticky-cta-inner { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 12px 24px; }
.sticky-cta-title { font-size: 13px; font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; flex: 1; }
.sticky-cta-price { font-size: 14px; font-weight: 700; color: var(--gold); white-space: nowrap; }

/* ── Trust section (home) ────────────────────────────────────────────── */
.trust-section { background: var(--green); padding: 40px 0; margin-top: 0; }
.trust-strip { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }
.trust-strip-item { display: flex; align-items: center; gap: 14px; color: #fff; }
.trust-strip-item svg { opacity: .7; flex-shrink: 0; }
.trust-strip-item strong { display: block; font-size: 14px; font-weight: 700; }
.trust-strip-item span { font-size: 12px; opacity: .7; }

/* ── Product deliverables ─────────────────────────────────────────────── */
.product-deliverables { display: flex; flex-direction: column; gap: 8px; margin-bottom: 20px; }
.deliverable-item { display: flex; align-items: center; gap: 8px; font-size: 13px; color: #444; }
.deliverable-item svg { color: var(--green); flex-shrink: 0; }

/* ── Library (dashboard) ─────────────────────────────────────────────── */
.account-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 28px; flex-wrap: wrap; gap: 12px; }
.account-header h1 { font-size: 22px; font-weight: 800; margin: 0; }
.library-card-cover { display: block; position: relative; aspect-ratio: 3/4; overflow: hidden; }
.library-card-cover img { width: 100%; height: 100%; object-fit: cover; transition: transform .3s; }
.library-card:hover .library-card-cover img { transform: scale(1.04); }
.library-card-overlay { position: absolute; inset: 0; background: rgba(0,0,0,.45); display: flex; align-items: center; justify-content: center; opacity: 0; transition: opacity .25s; }
.library-card:hover .library-card-overlay { opacity: 1; }
.library-empty { display: flex; flex-direction: column; align-items: center; gap: 12px; padding: 60px 24px; color: var(--muted); }
.library-empty h3 { font-size: 18px; font-weight: 700; color: var(--text); }
.library-upsell { display: flex; align-items: center; justify-content: space-between; background: #fffbf0; border: 1px solid #fde68a; border-radius: 10px; padding: 16px 20px; margin-top: 28px; gap: 12px; flex-wrap: wrap; }
.library-upsell-text { font-size: 14px; color: #92400e; font-weight: 500; }

/* ── Lead gate: form-control-lg ──────────────────────────────────────── */
.form-control-lg { padding: 14px 16px; font-size: 15px; }
.lead-gate-cta-box { background: var(--green); color: #fff; border-radius: 14px; padding: 28px; }
.lead-gate-cta-title { font-size: 17px; font-weight: 700; margin-bottom: 20px; }
.lead-gate-form .form-control { border-color: transparent; background: rgba(255,255,255,.95); }
.lead-gate-privacy { font-size: 12px; opacity: .7; text-align: center; margin-top: 10px; display: flex; align-items: center; justify-content: center; gap: 5px; }

/* ── Lead magnet section (home) ─────────────────────────────────────── */
.lead-magnet-section { background: #f8f6f0; border-top: 1px solid #e8e0cc; padding: 48px 0; }
.lead-magnet-inner { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: center; }
.lead-magnet-label { display: inline-block; font-size: 11px; font-weight: 700; color: var(--gold); text-transform: uppercase; letter-spacing: 1.5px; margin-bottom: 10px; }
.lead-magnet-text h3 { font-size: 22px; font-weight: 800; line-height: 1.3; margin-bottom: 10px; color: var(--text); }
.lead-magnet-text p { font-size: 14px; color: var(--muted); line-height: 1.7; margin-bottom: 20px; }
.lead-magnet-products { display: flex; gap: 16px; }
.lead-magnet-card { display: flex; flex-direction: column; background: #fff; border-radius: var(--radius); box-shadow: var(--shadow); overflow: hidden; flex: 1; transition: transform .2s; }
.lead-magnet-card:hover { transform: translateY(-3px); }
.lead-magnet-card img { width: 100%; aspect-ratio: 3/4; object-fit: cover; }
.lead-magnet-card-body { padding: 10px 12px 12px; display: flex; flex-direction: column; gap: 6px; }
.lead-magnet-card-title { font-size: 12px; font-weight: 600; line-height: 1.35; color: var(--text); display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.lead-magnet-free-badge { font-size: 11px; font-weight: 700; color: #16a34a; }

/* ── Footer ──────────────────────────────────────────────────────────── */
.site-footer { background: var(--green); color: #fff; padding: 56px 0 28px; margin-top: 80px; }
.footer-grid { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 48px; margin-bottom: 48px; }
.footer-brand .logo-footer img { height: 36px; margin-bottom: 16px; }
.footer-brand p { font-size: 13px; opacity: .8; line-height: 1.7; }
.footer-col h4 { font-size: 14px; font-weight: 700; text-transform: uppercase; letter-spacing: .8px; margin-bottom: 14px; opacity: .6; }
.footer-col ul { list-style: none; display: flex; flex-direction: column; gap: 8px; }
.footer-col ul li a { font-size: 14px; opacity: .85; transition: opacity .2s; }
.footer-col ul li a:hover { opacity: 1; text-decoration: underline; }
.footer-bottom { border-top: 1px solid rgba(255,255,255,.15); padding-top: 20px; display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 12px; }
.footer-bottom p { font-size: 12px; opacity: .6; }
.footer-bottom-trust { display: flex; align-items: center; gap: 6px; font-size: 12px; opacity: .5; color: #fff; }
.trust-badges { display: flex; align-items: center; gap: 10px; }
.trust-badges img { height: 30px; opacity: .8; }

/* ═══════════════════════════════════════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════════════════════════════════════ */

/* ── Tablet (≤900px) ─────────────────────────────────────────────────── */
@media (max-width: 900px) {
  .products-grid         { grid-template-columns: repeat(3, 1fr); }
  .product-layout        { grid-template-columns: 1fr; }
  .checkout-layout       { grid-template-columns: 1fr; max-width: 600px; }
  .account-layout        { grid-template-columns: 1fr; }
  .footer-grid           { grid-template-columns: 1fr 1fr; gap: 32px; }
  .footer-grid > :first-child { grid-column: 1 / -1; }
  .hero h1               { font-size: 30px; }
  .hero-actions          { flex-direction: column; align-items: flex-start; gap: 10px; }
  .stats-grid            { grid-template-columns: 1fr 1fr; }
  .library-grid          { grid-template-columns: repeat(3, 1fr); }
  .lead-gate-layout      { grid-template-columns: 1fr; }
  .lead-gate-cover       { max-width: 260px; margin: 0 auto; }
  .admin-form .form-row  { grid-template-columns: 1fr; }
  .cart-layout           { grid-template-columns: 1fr; }
  .cart-summary          { position: static; }
  .trust-strip           { grid-template-columns: repeat(2, 1fr); }
  .contact-grid          { grid-template-columns: 1fr; gap: 32px; }
  .products-page         { padding: 24px 0 48px; }
  .lead-magnet-inner     { grid-template-columns: 1fr; gap: 28px; }
}

/* ── Sticky CTA aparece abaixo de 768px ─────────────────────────────── */
@media (max-width: 768px) {
  .sticky-cta { display: block; }
}

/* ── Mobile (≤600px) ─────────────────────────────────────────────────── */
@media (max-width: 600px) {

  /* Container menor pra mais respiro interno */
  .container { padding: 0 16px; }

  /* ── Header ── */
  .site-header { position: relative; z-index: 900; }
  .header-main { height: 58px; }
  .logo img    { height: 32px; }

  /* Hamburguer */
  .mobile-menu-toggle { display: flex; align-items: center; justify-content: center; width: 40px; height: 40px; }

  /* Nav: escondido por padrão, dropdown quando aberto */
  .nav { display: none; }
  .nav--open {
    display: flex; flex-direction: column; align-items: stretch;
    position: absolute; top: 58px; left: 0; right: 0;
    background: var(--green-dark);
    border-top: 1px solid rgba(255,255,255,.15);
    box-shadow: 0 12px 32px rgba(0,0,0,.35);
    z-index: 800;
    padding-bottom: 8px;
  }
  .nav--open > a {
    padding: 14px 20px; font-size: 15px; font-weight: 600; color: #fff;
    border-bottom: 1px solid rgba(255,255,255,.08);
    display: flex; align-items: center; gap: 10px;
  }
  .nav--open > a:last-of-type { border-bottom: none; }
  .nav--open > a:hover { background: rgba(255,255,255,.06); }

  /* Mobile auth links no dropdown */
  .nav-mobile-auth {
    display: flex; flex-direction: column;
    border-top: 1px solid rgba(255,255,255,.2);
    margin-top: 4px; padding-top: 4px;
  }
  .nav-mobile-auth a {
    padding: 13px 20px; font-size: 14px; color: rgba(255,255,255,.8);
    display: flex; align-items: center; gap: 10px;
    border-bottom: 1px solid rgba(255,255,255,.06);
  }
  .nav-mobile-auth a:last-child { border-bottom: none; }

  /* Nav-actions desktop: esconde tudo exceto carrinho */
  .nav-desktop-only { display: none !important; }
  .nav-actions { gap: 4px; }
  .cart-icon-btn { padding: 8px; }

  /* Barra de busca: esconde no mobile (busca via loja) */
  .header-search { display: none; }

  /* Trust bar: esconde (info repetida no hero e no footer) */
  .trust-bar { display: none; }

  /* ── Hero ── */
  .hero { padding: 28px 0 24px; }
  .hero-social-proof { font-size: 12px; gap: 6px; margin-bottom: 10px; }
  .hero-stars { font-size: 13px; }
  .hero h1 { font-size: 21px; line-height: 1.3; margin-bottom: 10px; word-break: break-word; }
  .hero p.hero-subtitle { font-size: 14px; line-height: 1.5; margin-bottom: 18px; max-width: 100%; }
  .hero-actions { flex-direction: column; align-items: stretch; gap: 10px; margin-bottom: 20px; }
  .hero-actions .btn { width: 100%; justify-content: center; padding: 13px 20px; font-size: 15px; }
  .hero-trust { display: none; }

  /* ── Category strip ── */
  .categories-strip { padding: 10px 0; border-bottom: 1px solid var(--line); }
  .category-pills { flex-wrap: nowrap; overflow-x: auto; gap: 6px; padding-bottom: 2px; -webkit-overflow-scrolling: touch; scrollbar-width: none; }
  .category-pills::-webkit-scrollbar { display: none; }
  .pill { white-space: nowrap; padding: 5px 12px; font-size: 12px; }

  /* ── Seções ── */
  .products-section { padding: 20px 0; }
  .products-section + .products-section { padding-top: 0; }
  .section-header { margin-bottom: 12px; }
  .section-title { font-size: 13px; letter-spacing: .4px; }
  .section-header .btn { font-size: 12px; padding: 5px 12px; }

  /* ── Grid de produtos ── */
  .products-grid { grid-template-columns: repeat(2, 1fr); gap: 10px; }
  .product-card-body { padding: 9px 9px 11px; }
  .product-card-title { font-size: 11px; line-height: 1.35; -webkit-line-clamp: 3; }
  .product-card-excerpt { display: none; }
  .product-card-price { font-size: 11px; margin-top: 4px; }
  .price-current { font-size: 13px; }
  .price-free    { font-size: 13px; }
  .badge-best-seller, .badge-free-card { font-size: 10px; padding: 2px 7px; top: 7px; }

  /* ── Página de listagem ── */
  .products-page { padding: 14px 0 60px; }
  .products-toolbar { flex-direction: column; align-items: flex-start; gap: 8px; }
  .toolbar-title { font-size: 18px; }
  .results-count { margin-bottom: 12px; }

  /* ── Produto individual ── */
  .product-page { padding: 0 0 90px; }
  .breadcrumb { padding: 10px 0; font-size: 11px; gap: 3px; }
  .product-layout { gap: 20px; }
  .product-cover { max-width: 200px; margin: 0 auto; }
  .product-info h1 { font-size: 19px; line-height: 1.3; margin-bottom: 10px; }
  .product-excerpt { font-size: 13px; margin-bottom: 16px; }
  .product-cats { margin-bottom: 10px; }
  .product-benefits { gap: 6px; }
  .product-benefits li { font-size: 13px; }
  .product-deliverables { gap: 5px; margin-bottom: 14px; }
  .deliverable-item { font-size: 12px; }
  .product-buy-box { padding: 14px; margin: 14px 0; }
  .product-price-block { margin-bottom: 12px; }
  .product-price-block .price-current { font-size: 26px; }
  .product-price-block .price-free    { font-size: 26px; }
  .product-trust { padding: 10px 12px; gap: 6px; }
  .trust-item { font-size: 12px; }
  .product-description { padding-top: 20px; margin-top: 20px; font-size: 14px; }
  .product-description h3 { font-size: 15px; }

  /* ── Sticky CTA (produto mobile) ── */
  .sticky-cta-inner { padding: 10px 16px; gap: 8px; }
  .sticky-cta-title { display: none; }
  .sticky-cta-price { font-size: 16px; font-weight: 800; flex-shrink: 0; }
  .sticky-cta-actions { gap: 8px; }
  .sticky-cta-actions .btn-sm { font-size: 13px; padding: 9px 16px; }

  /* ── Lead gate (gratuitos) ── */
  .lead-gate-page { padding: 16px 0 48px; }
  .lead-gate-layout { gap: 20px; }
  .lead-gate-cover { max-width: 150px; }
  .lead-gate-form-wrap h1 { font-size: 19px; }
  .lead-gate-cta-box { padding: 18px; border-radius: 10px; }
  .lead-gate-cta-title { font-size: 15px; }

  /* ── Carrinho ── */
  .cart-page { padding: 18px 0 80px; }
  .cart-title { font-size: 18px; margin-bottom: 16px; }
  .cart-item { grid-template-columns: 56px 1fr auto; gap: 10px; padding: 12px 14px; }
  .cart-item-cover img { width: 56px; height: 74px; }
  .cart-item-title { font-size: 13px; }
  .cart-summary-box { padding: 16px; }
  .cart-summary-box h3 { font-size: 15px; }
  .cart-total-price { font-size: 20px; }

  /* ── Checkout ── */
  .checkout-page { padding: 12px 0 60px; }
  .checkout-layout { gap: 14px; max-width: 100%; }
  .checkout-product-card { padding: 14px; }
  .checkout-product-single { grid-template-columns: 72px 1fr; gap: 12px; }
  .checkout-product-single img { width: 72px; }
  .checkout-form-wrap { padding: 16px; }
  .checkout-form-wrap h2 { font-size: 16px; margin-bottom: 14px; }
  .pix-copy-wrap { flex-direction: column; }
  .pix-qr { width: 180px; height: 180px; }

  /* ── Obrigado ── */
  .thanks-page { padding: 28px 16px; min-height: 50vh; padding-bottom: 40px; }
  .thanks-box h1 { font-size: 21px; }
  .thanks-icon { font-size: 44px; margin-bottom: 12px; }
  .thanks-box .btn { width: 100%; justify-content: center; }

  /* ── Auth ── */
  .auth-page { padding: 24px 0; align-items: flex-start; }
  .auth-box { padding: 24px 18px; border-radius: 12px; box-shadow: none; border: 1px solid var(--line); }
  .auth-box h1 { font-size: 20px; margin-bottom: 18px; }

  /* ── Conta / biblioteca ── */
  .account-page { padding: 14px 0 60px; }
  .account-nav {
    display: flex; flex-direction: row; overflow-x: auto; white-space: nowrap;
    gap: 4px; padding: 6px; border-radius: var(--radius); margin-bottom: 12px;
    scrollbar-width: none; -webkit-overflow-scrolling: touch;
  }
  .account-nav::-webkit-scrollbar { display: none; }
  .account-nav a { display: inline-flex; white-space: nowrap; padding: 8px 14px; font-size: 13px; flex-shrink: 0; }
  .account-header { flex-direction: column; align-items: flex-start; gap: 10px; margin-bottom: 16px; }
  .account-header h1 { font-size: 20px; margin-bottom: 0; }
  .account-greeting { font-size: 14px; margin-bottom: 20px; }
  .account-content h1 { font-size: 18px; margin-bottom: 14px; }
  .library-grid { grid-template-columns: repeat(2, 1fr); gap: 12px; }
  .library-card-body { padding: 10px; }
  .library-card-title { font-size: 12px; margin-bottom: 8px; }
  .library-upsell { flex-direction: column; align-items: flex-start; }

  /* ── Lead magnet ── */
  .lead-magnet-section { padding: 28px 0; }
  .lead-magnet-inner { grid-template-columns: 1fr; gap: 20px; }
  .lead-magnet-text h3 { font-size: 17px; }
  .lead-magnet-products { gap: 10px; }

  /* ── Trust section (home) ── */
  .trust-section { padding: 24px 0; }
  .trust-strip { grid-template-columns: 1fr 1fr; gap: 16px; }
  .trust-strip-item { gap: 10px; }
  .trust-strip-item svg { width: 22px; height: 22px; flex-shrink: 0; }
  .trust-strip-item strong { font-size: 13px; }
  .trust-strip-item span { font-size: 11px; }

  /* ── Footer ── */
  .site-footer { padding: 28px 0 16px; margin-top: 40px; }
  .footer-grid { grid-template-columns: 1fr; gap: 24px; margin-bottom: 24px; }
  .footer-grid > :first-child { grid-column: auto; }
  .footer-brand .logo-footer img { height: 30px; margin-bottom: 10px; }
  .footer-brand p { font-size: 12px; }
  .footer-col h4 { font-size: 13px; margin-bottom: 10px; }
  .footer-col ul { gap: 6px; }
  .footer-col ul li a { font-size: 13px; }
  .footer-bottom { flex-direction: column; align-items: flex-start; gap: 6px; padding-top: 14px; }
  .footer-bottom-trust { display: none; }

  /* ── Páginas estáticas ── */
  .static-page { padding: 16px 0 40px; }
  .static-page-body { padding: 18px 16px; border-radius: 10px; }
  .static-page-body h2 { font-size: 17px; margin: 22px 0 8px; }
  .lead { font-size: 14px; padding-left: 12px; }

  /* ── Admin ── */
  .admin-page { padding: 16px; }
  .stats-grid { grid-template-columns: 1fr 1fr; gap: 12px; }
  .stat-card { padding: 16px; }
  .stat-value { font-size: 24px; }
}

/* ── Telas muito pequenas (≤380px) ──────────────────────────────────── */
@media (max-width: 380px) {
  .hero h1 { font-size: 19px; }
  .products-grid { gap: 8px; }
  .product-card-title { font-size: 10px; }
  .trust-strip { grid-template-columns: 1fr; }
  .library-grid { grid-template-columns: 1fr 1fr; }
  .hero-actions .btn { padding: 12px 16px; font-size: 14px; }
}
