:root {
  --bg: #050403;
  --bg-soft: #0f0a05;
  --card: rgba(19, 12, 5, 0.78);
  --card-strong: rgba(24, 15, 6, 0.94);
  --line: rgba(245, 198, 91, 0.20);
  --line-strong: rgba(245, 198, 91, 0.42);
  --text: #fff7e8;
  --muted: #c5ad7c;
  --green: #f5c65b;
  --green-deep: #b98626;
  --gold: #ffe08a;
  --orange: #d99b36;
  --danger: #ff6473;
  --shadow: 0 30px 90px rgba(0, 0, 0, 0.42);
  --radius-xl: 34px;
  --radius-lg: 24px;
  --radius-md: 16px;
  --max: 1220px;
  color-scheme: dark;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  background: radial-gradient(circle at 15% 0%, rgba(245, 198, 91, 0.16), transparent 35%), var(--bg);
  color: var(--text);
  min-height: 100vh;
  overflow-x: hidden;
}
body.drawer-open { overflow: hidden; }
a { color: inherit; text-decoration: none; }
button, input, textarea, select { font: inherit; }
button { cursor: pointer; }
img { max-width: 100%; display: block; }

.site-bg { position: fixed; inset: 0; z-index: -3; overflow: hidden; }
.orb { position: absolute; width: 44vw; height: 44vw; border-radius: 999px; filter: blur(68px); opacity: .25; }
.orb-a { left: -15vw; top: 8vh; background: #d19b33; }
.orb-b { right: -18vw; bottom: -8vw; background: #ffcc4d; opacity: .17; }
.grid-light {
  position: absolute;
  inset: 0;
  background-image: linear-gradient(rgba(255,255,255,.035) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.035) 1px, transparent 1px);
  background-size: 72px 72px;
  mask-image: radial-gradient(circle at center, black, transparent 75%);
}

.neon-progress { position: fixed; top: 0; left: 0; right: 0; height: 3px; z-index: 100; background: rgba(255,255,255,.04); }
.neon-progress span { display: block; width: 0; height: 100%; background: linear-gradient(90deg, transparent, var(--green), var(--gold)); box-shadow: 0 0 24px rgba(245,198,91,.9); }

.top-shell { position: sticky; top: 0; z-index: 90; backdrop-filter: blur(22px); background: rgba(7, 17, 12, .72); border-bottom: 1px solid var(--line); }
.utility-bar, .navbar { width: min(var(--max), calc(100% - 32px)); margin: 0 auto; }
.utility-bar { min-height: 38px; display: flex; align-items: center; justify-content: space-between; gap: 16px; color: var(--muted); font-size: 13px; }
.utility-left, .utility-actions { display: flex; align-items: center; gap: 12px; }
.utility-actions a { color: #dffff0; opacity: .88; transition: .25s; }
.utility-actions a:hover { color: var(--green); }
.live-dot { width: 8px; height: 8px; border-radius: 999px; background: var(--green); box-shadow: 0 0 18px var(--green); }

.navbar { min-height: 80px; display: flex; align-items: center; justify-content: space-between; gap: 22px; }
.brand img { width: 212px; height: auto; }
.nav-links { display: flex; align-items: center; gap: 18px; color: #dbeee0; font-size: 14px; }
.nav-links a { position: relative; opacity: .86; }
.nav-links a::after { content: ""; position: absolute; left: 0; right: 0; bottom: -9px; height: 2px; border-radius: 10px; background: var(--green); transform: scaleX(0); transform-origin: left; transition: .25s; }
.nav-links a:hover::after { transform: scaleX(1); }
.nav-toggle { display: none; width: 44px; height: 44px; border: 1px solid var(--line); background: rgba(255,255,255,.04); border-radius: 14px; }
.nav-toggle span { display: block; width: 18px; height: 2px; background: var(--text); margin: 4px auto; border-radius: 9px; }
.language-switcher { display: flex; gap: 5px; padding: 4px; border: 1px solid var(--line); border-radius: 999px; background: rgba(255,255,255,.04); }
.language-switcher button { border: 0; background: transparent; width: 31px; height: 31px; border-radius: 999px; font-size: 16px; opacity: .55; transition: .25s; }
.language-switcher button.active, .language-switcher button:hover { opacity: 1; background: rgba(245,198,91,.12); box-shadow: inset 0 0 0 1px rgba(245,198,91,.24); }

.section-pad { width: min(var(--max), calc(100% - 32px)); margin: 0 auto; padding: 88px 0; }
.hero { display: grid; grid-template-columns: 1.03fr .97fr; gap: 54px; align-items: center; min-height: calc(100vh - 118px); padding-top: 72px; }
.eyebrow { display: inline-flex; align-items: center; gap: 10px; padding: 8px 10px; border: 1px solid var(--line); border-radius: 999px; background: rgba(255,255,255,.045); color: var(--muted); font-size: 13px; }
.eyebrow span { color: var(--green); letter-spacing: .12em; font-size: 11px; font-weight: 800; }
h1, h2, h3, p { margin-top: 0; }
h1 { margin: 26px 0 20px; font-size: clamp(44px, 6vw, 82px); line-height: .91; letter-spacing: -.06em; max-width: 920px; }
.hero-copy p { max-width: 700px; color: #cae0d0; font-size: 18px; line-height: 1.7; }
.hero-actions { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 30px; }
.primary-btn, .secondary-btn, .ghost-btn, .danger-btn { border: 0; border-radius: 999px; min-height: 50px; padding: 0 22px; display: inline-flex; align-items: center; justify-content: center; gap: 8px; font-weight: 800; transition: transform .25s, box-shadow .25s, background .25s; }
.primary-btn { color: #041008; background: linear-gradient(135deg, var(--green), var(--gold)); box-shadow: 0 18px 44px rgba(245,198,91,.23); }
.primary-btn:hover, .secondary-btn:hover, .ghost-btn:hover { transform: translateY(-2px); }
.secondary-btn { background: rgba(255,255,255,.07); color: var(--text); border: 1px solid var(--line-strong); }
.ghost-btn { background: rgba(255,255,255,.045); color: var(--text); border: 1px solid var(--line); }
.ghost-btn.compact { min-height: 38px; padding: 0 14px; font-size: 13px; }
.danger-btn { background: rgba(255,100,115,.12); color: #ffd9de; border: 1px solid rgba(255,100,115,.28); }
.full { width: 100%; }
.trust-row { display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 12px; margin-top: 38px; }
.trust-row div { border: 1px solid var(--line); border-radius: 20px; padding: 16px; background: rgba(255,255,255,.035); }
.trust-row strong { display: block; color: var(--green); font-size: 18px; }
.trust-row span { color: var(--muted); font-size: 13px; }

.hero-visual { min-height: 580px; display: grid; place-items: center; perspective: 1100px; }
.glass-card { border: 1px solid var(--line); background: linear-gradient(155deg, rgba(255,255,255,.1), rgba(255,255,255,.025)); box-shadow: var(--shadow); backdrop-filter: blur(22px); }
.holo-card { width: min(500px, 100%); height: 560px; border-radius: 42px; padding: 30px; position: relative; overflow: hidden; transform: rotateX(6deg) rotateY(-10deg); }
.holo-card::before { content: ""; position: absolute; inset: -2px; background: linear-gradient(120deg, transparent, rgba(245,198,91,.20), transparent); transform: translateX(-70%); animation: scan 5s infinite; }
@keyframes scan { 50%, 100% { transform: translateX(70%); } }
.product-orbit { position: absolute; inset: 40px 18px 90px; display: grid; place-items: center; }
.orbit-ring { position: absolute; width: 88%; aspect-ratio: 1; border-radius: 50%; border: 1px solid rgba(255,204,102,.22); transform: rotateX(70deg); }
.ring-one { animation: spin 12s linear infinite; box-shadow: 0 0 42px rgba(245,198,91,.1); }
.ring-two { width: 65%; transform: rotateX(72deg) rotateZ(24deg); animation: spin 8s linear infinite reverse; border-color: rgba(255,224,138,.28); }
@keyframes spin { to { rotate: 360deg; } }
.supplement-tower { position: relative; width: 180px; height: 290px; border-radius: 35px 35px 28px 28px; background: linear-gradient(110deg, #fff3cc 0%, #f2c15c 18%, #2a1a08 52%, #080604 100%); box-shadow: inset -26px 0 50px rgba(0,0,0,.44), 0 42px 80px rgba(0,0,0,.48), 0 0 70px rgba(245,198,91,.26); transform: translateY(12px); }
.supplement-tower .lid { position: absolute; top: -28px; left: 16px; right: 16px; height: 54px; border-radius: 28px 28px 18px 18px; background: linear-gradient(90deg, #fff1c4, #f5c65b, #2f210b); box-shadow: inset -22px 0 25px rgba(0,0,0,.28); }
.label-band { position: absolute; left: 0; right: 0; top: 105px; padding: 18px 0; text-align: center; color: #051109; background: linear-gradient(90deg, var(--green), var(--gold)); font-weight: 950; letter-spacing: .18em; }
.shine { position: absolute; inset: 20px auto 20px 25px; width: 28px; border-radius: 999px; background: linear-gradient(transparent, rgba(255,255,255,.62), transparent); opacity: .52; filter: blur(2px); }
.capsule { position: absolute; width: 76px; height: 28px; border-radius: 999px; background: linear-gradient(90deg, var(--gold) 0 50%, #eaffef 50% 100%); box-shadow: 0 0 30px rgba(255,224,138,.35); }
.capsule-a { left: 62px; top: 122px; rotate: -24deg; animation: float 5s ease-in-out infinite; }
.capsule-b { right: 56px; top: 190px; rotate: 22deg; animation: float 4.2s ease-in-out infinite reverse; }
.capsule-c { left: 128px; bottom: 58px; rotate: 12deg; animation: float 5.7s ease-in-out infinite; }
@keyframes float { 50% { transform: translateY(-18px); } }
.holo-info { position: absolute; left: 26px; right: 26px; bottom: 26px; display: flex; align-items: center; justify-content: space-between; border-radius: 24px; padding: 18px 20px; background: rgba(3, 9, 6, .68); border: 1px solid var(--line); }
.holo-info span { color: var(--muted); font-size: 13px; }
.holo-info strong { color: var(--green); font-size: 28px; }

.feature-strip { width: min(var(--max), calc(100% - 32px)); margin: -20px auto 0; display: grid; grid-template-columns: repeat(4, minmax(0,1fr)); gap: 14px; }
.feature-strip article { min-height: 170px; padding: 22px; border: 1px solid var(--line); border-radius: 24px; background: rgba(255,255,255,.035); }
.feature-strip span { color: var(--green); font-weight: 950; font-size: 12px; letter-spacing: .16em; }
.feature-strip strong { display: block; margin: 18px 0 8px; font-size: 18px; }
.feature-strip p { color: var(--muted); line-height: 1.55; margin: 0; font-size: 14px; }

.section-heading { display: grid; grid-template-columns: .45fr 1fr; gap: 28px; align-items: end; margin-bottom: 34px; }
.section-heading.slim { grid-template-columns: 1fr; max-width: 720px; }
.section-heading span, .delivery-banner span, .panel-kicker { color: var(--green); text-transform: uppercase; letter-spacing: .16em; font-size: 12px; font-weight: 950; }
.section-heading h2, .delivery-banner h2 { margin: 0; font-size: clamp(30px, 4.2vw, 58px); line-height: .98; letter-spacing: -.045em; }
.section-heading p, .delivery-banner p { color: var(--muted); line-height: 1.7; margin: 0; max-width: 720px; }
.finder-panel { border-radius: 30px; padding: 20px; display: grid; grid-template-columns: minmax(240px, 420px) 1fr; gap: 16px; align-items: end; }
.searchbox span, .drawer-note span, .owner-box label span { display: block; color: var(--muted); margin-bottom: 8px; font-size: 13px; }
.searchbox input, .drawer-note input, .owner-box input, .owner-box textarea, .owner-box select, .chat-form input { width: 100%; border: 1px solid var(--line); background: rgba(0,0,0,.24); color: var(--text); border-radius: 16px; min-height: 50px; padding: 0 14px; outline: none; transition: .25s; }
.owner-box textarea { min-height: 95px; padding: 14px; resize: vertical; }
.searchbox input:focus, .drawer-note input:focus, .owner-box input:focus, .owner-box textarea:focus, .owner-box select:focus, .chat-form input:focus { border-color: rgba(245,198,91,.55); box-shadow: 0 0 0 4px rgba(245,198,91,.08); }
.chips { display: flex; flex-wrap: wrap; gap: 8px; }
.chips button { border: 1px solid var(--line); background: rgba(255,255,255,.045); color: var(--text); border-radius: 999px; min-height: 42px; padding: 0 14px; }
.chips button.active { background: rgba(245,198,91,.15); border-color: rgba(245,198,91,.42); color: var(--green); }

.product-section.alt { width: 100%; max-width: none; padding-left: max(16px, calc((100% - var(--max))/2)); padding-right: max(16px, calc((100% - var(--max))/2)); background: linear-gradient(90deg, rgba(245,198,91,.055), rgba(255,224,138,.035)); border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.product-grid { display: grid; grid-template-columns: repeat(4, minmax(0,1fr)); gap: 18px; }
.product-card { position: relative; overflow: hidden; border: 1px solid var(--line); background: linear-gradient(165deg, rgba(255,255,255,.075), rgba(255,255,255,.024)); border-radius: 28px; padding: 16px; min-height: 460px; display: flex; flex-direction: column; transition: transform .25s, border-color .25s, box-shadow .25s; }
.product-card:hover { transform: translateY(-6px); border-color: rgba(245,198,91,.46); box-shadow: 0 24px 60px rgba(0,0,0,.26); }
.product-media { height: 210px; border-radius: 22px; display: grid; place-items: center; overflow: hidden; background: radial-gradient(circle at 50% 28%, rgba(245,198,91,.2), rgba(255,255,255,.035) 54%, rgba(0,0,0,.2)); }
.product-media img { width: 100%; height: 100%; object-fit: cover; }
.product-media .fallback { width: 118px; height: 170px; border-radius: 25px 25px 18px 18px; background: linear-gradient(120deg, #fff4d1, #f5c65b 32%, #1b1206 78%); box-shadow: 0 30px 50px rgba(0,0,0,.32); position: relative; }
.product-media .fallback::before { content: "PROTA"; position: absolute; left: 0; right: 0; top: 68px; padding: 10px 0; text-align: center; color: #06110a; font-weight: 950; background: linear-gradient(90deg, var(--green), var(--gold)); font-size: 16px; letter-spacing: .1em; }
.product-tag { position: absolute; top: 28px; left: 28px; color: #051109; background: linear-gradient(90deg, var(--gold), var(--green)); padding: 8px 11px; border-radius: 999px; font-weight: 900; font-size: 11px; letter-spacing: .06em; text-transform: uppercase; }
.product-card h3 { margin: 18px 0 8px; font-size: 20px; line-height: 1.15; }
.product-card p { color: var(--muted); line-height: 1.5; font-size: 14px; flex: 1; }
.price-row { display: flex; align-items: baseline; gap: 10px; margin-bottom: 16px; }
.price-row strong { font-size: 26px; color: var(--green); }
.price-row del { color: #7c9283; }
.card-actions { display: grid; grid-template-columns: 1fr 48px; gap: 10px; }
.card-actions button, .card-actions a { border: 0; min-height: 48px; border-radius: 16px; display: inline-flex; align-items: center; justify-content: center; font-weight: 900; }
.card-actions button { background: linear-gradient(135deg, var(--green), var(--gold)); color: #041008; }
.card-actions a { background: rgba(255,255,255,.06); border: 1px solid var(--line); }
.empty-state { grid-column: 1 / -1; border: 1px dashed var(--line-strong); border-radius: 24px; padding: 38px; text-align: center; color: var(--muted); }

.delivery-banner { width: min(var(--max), calc(100% - 32px)); margin: 34px auto; border-radius: 38px; padding: 46px; border: 1px solid rgba(245,198,91,.24); background: linear-gradient(135deg, rgba(245,198,91,.13), rgba(255,224,138,.06)), rgba(255,255,255,.035); display: flex; align-items: center; justify-content: space-between; gap: 28px; box-shadow: var(--shadow); }
.delivery-banner div { max-width: 760px; }
.delivery-banner h2 { margin: 13px 0 16px; }

.faq-links { display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 14px; }
.faq-links a { padding: 22px; border-radius: 24px; border: 1px solid var(--line); background: rgba(255,255,255,.035); min-height: 135px; transition: .25s; }
.faq-links a:hover { transform: translateY(-4px); border-color: rgba(245,198,91,.45); }
.faq-links strong { display: block; font-size: 20px; margin-bottom: 10px; }
.faq-links span { display: block; color: var(--muted); line-height: 1.5; }
.accordion { margin-top: 22px; display: grid; gap: 10px; }
details { border: 1px solid var(--line); border-radius: 20px; background: rgba(255,255,255,.035); padding: 0 18px; }
summary { min-height: 58px; display: flex; align-items: center; justify-content: space-between; font-weight: 850; cursor: pointer; }
details p { color: var(--muted); line-height: 1.65; margin-bottom: 18px; }

.footer { width: min(var(--max), calc(100% - 32px)); margin: 0 auto; padding: 50px 0 44px; display: grid; grid-template-columns: 1fr auto auto; gap: 32px; align-items: end; border-top: 1px solid var(--line); }
.footer-brand img { width: 190px; margin-bottom: 16px; }
.footer-brand p { color: var(--muted); max-width: 430px; line-height: 1.6; }
.footer-links { display: flex; flex-direction: column; gap: 10px; color: #e4f8e9; }
.pixeleco-credit { display: flex; align-items: center; gap: 9px; color: var(--muted); font-size: 12px; opacity: .78; }
.pixeleco-credit img { width: 112px; }

.cart-fab, .back-top, .chatbot-fab { position: fixed; z-index: 80; border: 1px solid var(--line); box-shadow: 0 18px 44px rgba(0,0,0,.28); }
.cart-fab { right: 24px; bottom: 104px; width: 58px; height: 58px; border-radius: 20px; background: linear-gradient(135deg, var(--green), var(--gold)); color: #051109; display: grid; place-items: center; font-weight: 950; }
.cart-fab strong { position: absolute; top: -8px; right: -8px; min-width: 24px; height: 24px; display: grid; place-items: center; border-radius: 999px; background: #050403; color: var(--green); font-size: 12px; border: 1px solid var(--line); }
.back-top { right: 24px; bottom: 34px; width: 52px; height: 52px; border-radius: 18px; background: rgba(7,17,12,.78); color: var(--green); opacity: 0; pointer-events: none; transform: translateY(15px); transition: .25s; }
.back-top.visible { opacity: 1; pointer-events: auto; transform: translateY(0); }
.cart-drawer { position: fixed; top: 0; right: 0; width: min(420px, 100vw); height: 100vh; z-index: 110; background: rgba(7,17,12,.95); border-left: 1px solid var(--line); backdrop-filter: blur(24px); transform: translateX(103%); transition: transform .28s; padding: 22px; display: flex; flex-direction: column; gap: 16px; }
.cart-drawer.open { transform: translateX(0); }
.drawer-head { display: flex; justify-content: space-between; align-items: center; }
.drawer-head span { color: var(--green); text-transform: uppercase; letter-spacing: .14em; font-size: 12px; font-weight: 950; }
.drawer-head strong { display: block; font-size: 28px; }
.icon-btn { width: 40px; height: 40px; border-radius: 14px; border: 1px solid var(--line); background: rgba(255,255,255,.05); color: var(--text); font-size: 22px; }
.cart-items { flex: 1; overflow-y: auto; display: grid; gap: 10px; align-content: start; padding-right: 3px; }
.cart-line { border: 1px solid var(--line); border-radius: 18px; padding: 12px; display: grid; gap: 8px; background: rgba(255,255,255,.035); }
.cart-line-head { display: flex; justify-content: space-between; gap: 12px; }
.cart-line small { color: var(--muted); }
.qty-row { display: flex; align-items: center; justify-content: space-between; }
.qty-controls { display: flex; align-items: center; gap: 8px; }
.qty-controls button { width: 30px; height: 30px; border-radius: 10px; border: 1px solid var(--line); background: rgba(255,255,255,.05); color: var(--text); }
.cart-total { border-top: 1px solid var(--line); padding-top: 16px; display: flex; justify-content: space-between; align-items: baseline; }
.cart-total span { color: var(--muted); }
.cart-total strong { color: var(--green); font-size: 26px; }

.chatbot { position: fixed; left: 24px; bottom: 24px; z-index: 88; }
.chatbot-fab { position: static; width: 64px; height: 64px; border-radius: 24px; background: linear-gradient(135deg, rgba(245,198,91,.95), rgba(255,224,138,.98)); color: #051109; font-weight: 1000; font-size: 18px; }
.chat-window { position: absolute; left: 0; bottom: 78px; width: min(390px, calc(100vw - 36px)); max-height: 640px; background: rgba(7,17,12,.96); border: 1px solid var(--line); border-radius: 28px; box-shadow: var(--shadow); overflow: hidden; transform: translateY(12px) scale(.98); opacity: 0; pointer-events: none; transition: .25s; }
.chat-window.open { opacity: 1; pointer-events: auto; transform: translateY(0) scale(1); }
.chat-head { min-height: 72px; padding: 16px; display: flex; align-items: center; justify-content: space-between; border-bottom: 1px solid var(--line); background: linear-gradient(90deg, rgba(245,198,91,.12), rgba(255,255,255,.02)); }
.chat-head strong { display: block; font-size: 20px; }
.chat-head span { color: var(--green); font-size: 12px; }
.chat-body { padding: 16px; max-height: 280px; overflow-y: auto; display: flex; flex-direction: column; gap: 10px; }
.msg { max-width: 86%; padding: 12px 14px; border-radius: 18px; line-height: 1.45; font-size: 14px; }
.msg.bot { background: rgba(255,255,255,.06); border: 1px solid var(--line); border-bottom-left-radius: 6px; }
.msg.user { margin-left: auto; background: linear-gradient(135deg, rgba(245,198,91,.9), rgba(255,224,138,.9)); color: #06110a; border-bottom-right-radius: 6px; font-weight: 700; }
.quick-questions { padding: 0 16px 14px; display: flex; flex-wrap: wrap; gap: 8px; }
.quick-questions button { border: 1px solid var(--line); border-radius: 999px; min-height: 34px; padding: 0 11px; background: rgba(255,255,255,.045); color: var(--text); font-size: 12px; }
.chat-form { display: grid; grid-template-columns: 1fr 46px; gap: 8px; padding: 14px 16px; border-top: 1px solid var(--line); }
.chat-form input { min-height: 46px; border-radius: 14px; }
.chat-form button { border: 0; border-radius: 14px; background: var(--green); color: #06110a; font-weight: 950; }
.chat-disclaimer { color: var(--muted); font-size: 11px; line-height: 1.4; margin: 0; padding: 0 16px 16px; }

.owner-dialog { border: 0; padding: 0; background: transparent; width: min(980px, calc(100vw - 24px)); }
.owner-dialog::backdrop { background: rgba(0,0,0,.72); backdrop-filter: blur(8px); }
.owner-box { position: relative; margin: 0; padding: 28px; border: 1px solid var(--line); background: rgba(7,17,12,.97); border-radius: 30px; color: var(--text); box-shadow: var(--shadow); }
.close-dialog { position: absolute; top: 18px; right: 18px; }
.owner-login { max-width: 460px; margin: 0 auto; padding: 32px 0; }
.owner-login h2, .owner-panel h2 { font-size: 36px; letter-spacing: -.04em; margin: 10px 0 12px; }
.owner-login p { color: var(--muted); line-height: 1.65; }
.owner-login small { display: block; color: var(--muted); margin-top: 12px; }
.owner-grid-form { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 14px; }
.owner-grid-form .wide { grid-column: 1 / -1; }
.owner-actions { display: flex; flex-wrap: wrap; gap: 10px; margin: 18px 0; }
.file-ghost { position: relative; overflow: hidden; }
.file-ghost input { position: absolute; inset: 0; opacity: 0; cursor: pointer; }
.owner-list { display: grid; gap: 8px; max-height: 250px; overflow-y: auto; padding-right: 4px; }
.owner-item { display: grid; grid-template-columns: 1fr auto; gap: 12px; align-items: center; border: 1px solid var(--line); border-radius: 16px; padding: 12px; background: rgba(255,255,255,.035); }
.owner-item small { color: var(--muted); }
.owner-item button { border: 0; border-radius: 12px; min-height: 36px; padding: 0 12px; background: rgba(255,100,115,.14); color: #ffd7dc; }

.reveal { opacity: 0; transform: translateY(24px); transition: opacity .7s ease, transform .7s ease; }
.reveal.in-view { opacity: 1; transform: translateY(0); }

.faq-page main { width: min(920px, calc(100% - 32px)); margin: 0 auto; padding: 76px 0; }
.faq-hero { border: 1px solid var(--line); border-radius: 34px; padding: 42px; background: linear-gradient(155deg, rgba(245,198,91,.12), rgba(255,255,255,.035)); margin-bottom: 22px; }
.faq-hero a { color: var(--green); font-weight: 850; }
.faq-hero h1 { font-size: clamp(36px, 7vw, 64px); }
.answer-card { border: 1px solid var(--line); border-radius: 24px; padding: 24px; background: rgba(255,255,255,.035); margin-bottom: 12px; }
.answer-card h2 { margin-bottom: 12px; font-size: 24px; }
.answer-card p, .answer-card li { color: var(--muted); line-height: 1.72; }
.answer-card ul { padding-left: 20px; }

@media (max-width: 1080px) {
  .hero { grid-template-columns: 1fr; min-height: auto; }
  .hero-visual { min-height: 480px; }
  .holo-card { height: 480px; transform: none; }
  .feature-strip, .product-grid { grid-template-columns: repeat(2, minmax(0,1fr)); }
  .section-heading, .finder-panel { grid-template-columns: 1fr; }
  .delivery-banner { flex-direction: column; align-items: flex-start; }
}

@media (max-width: 820px) {
  .utility-bar { display: none; }
  .navbar { min-height: 70px; }
  .brand img { width: 176px; }
  .nav-toggle { display: block; }
  .nav-links { position: fixed; left: 16px; right: 16px; top: 78px; padding: 18px; display: grid; gap: 14px; border-radius: 24px; border: 1px solid var(--line); background: rgba(7,17,12,.97); box-shadow: var(--shadow); opacity: 0; pointer-events: none; transform: translateY(-10px); transition: .25s; }
  .nav-links.open { opacity: 1; pointer-events: auto; transform: translateY(0); }
  .language-switcher { width: max-content; }
  .section-pad { padding: 62px 0; }
  h1 { font-size: clamp(42px, 14vw, 68px); }
  .hero-copy p { font-size: 16px; }
  .trust-row, .feature-strip, .product-grid, .faq-links, .footer { grid-template-columns: 1fr; }
  .hero-visual { min-height: 430px; }
  .holo-card { height: 430px; border-radius: 30px; }
  .supplement-tower { width: 140px; height: 235px; }
  .label-band { top: 88px; }
  .product-orbit { inset: 32px 12px 78px; }
  .product-media { height: 190px; }
  .product-card { min-height: auto; }
  .owner-grid-form { grid-template-columns: 1fr; }
  .footer { align-items: start; }
  .chatbot { left: 16px; bottom: 16px; }
  .cart-fab { right: 16px; bottom: 92px; }
  .back-top { right: 16px; bottom: 24px; }
}

@media (max-width: 520px) {
  .hero-actions .primary-btn, .hero-actions .secondary-btn { width: 100%; }
  .feature-strip article { min-height: auto; }
  .delivery-banner { padding: 30px 22px; border-radius: 28px; }
  .faq-hero { padding: 28px; }
  .owner-box { padding: 22px; }
  .chat-window { width: calc(100vw - 32px); }
}


/* PROTA v3: abertura cinematográfica e hero com imagem principal */
body.intro-playing { overflow: hidden; }
.intro-loader {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: grid;
  place-items: center;
  background:
    radial-gradient(circle at 50% 58%, rgba(245,198,91,.18), transparent 26%),
    linear-gradient(180deg, #000 0%, #050403 55%, #000 100%);
  overflow: hidden;
  opacity: 1;
  visibility: visible;
  transition: opacity .65s ease, visibility .65s ease;
}
.intro-loader.hidden { opacity: 0; visibility: hidden; pointer-events: none; }
.intro-stage {
  position: relative;
  width: min(1120px, 92vw);
  aspect-ratio: 16 / 9;
  display: grid;
  place-items: center;
  transform: translateY(8px) scale(.96);
  animation: introStage 3.7s cubic-bezier(.18,.72,.16,1) forwards;
}
.intro-stage img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  filter: drop-shadow(0 0 38px rgba(245,198,91,.22));
}
.intro-stage::before,
.intro-stage::after {
  content: "";
  position: absolute;
  left: 8%;
  right: 8%;
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg, transparent, rgba(245,198,91,.95), rgba(255,232,166,.95), transparent);
  filter: blur(.2px) drop-shadow(0 0 18px rgba(245,198,91,.8));
  opacity: .85;
}
.intro-stage::before { bottom: 23%; animation: introLine 2.4s ease-in-out .25s both; }
.intro-stage::after { top: 26%; animation: introLine 2.5s ease-in-out .45s both reverse; opacity: .38; }
.intro-scan {
  position: absolute;
  inset: 0;
  background: linear-gradient(115deg, transparent 0 42%, rgba(255,232,166,.24) 48%, transparent 56% 100%);
  transform: translateX(-82%);
  mix-blend-mode: screen;
  animation: introScan 2.9s ease .15s both;
}
.intro-glow {
  position: absolute;
  width: 42%;
  height: 42%;
  border-radius: 999px;
  background: rgba(245,198,91,.20);
  filter: blur(70px);
  opacity: .65;
  z-index: -1;
  animation: introPulse 2.6s ease-in-out infinite;
}
.intro-beam {
  position: absolute;
  width: 58vw;
  height: 2px;
  background: linear-gradient(90deg, transparent, rgba(245,198,91,.95), transparent);
  box-shadow: 0 0 26px rgba(245,198,91,.8);
  opacity: .75;
}
.intro-beam-left { left: -18vw; bottom: 28vh; transform: rotate(18deg); animation: beamLeft 3s ease both; }
.intro-beam-right { right: -18vw; top: 27vh; transform: rotate(-16deg); animation: beamRight 3s ease .25s both; }
.intro-skip {
  position: absolute;
  right: 28px;
  bottom: 26px;
  min-height: 42px;
  padding: 0 18px;
  border-radius: 999px;
  border: 1px solid rgba(245,198,91,.38);
  color: #ffe8a6;
  background: rgba(0,0,0,.42);
  backdrop-filter: blur(12px);
  font-size: 13px;
  font-weight: 800;
}
@keyframes introStage {
  0% { opacity: 0; transform: translateY(26px) scale(.90); filter: blur(8px); }
  18% { opacity: 1; filter: blur(0); }
  72% { transform: translateY(0) scale(1.015); }
  100% { opacity: 1; transform: translateY(0) scale(1); }
}
@keyframes introLine { 0% { transform: scaleX(0); opacity: 0; } 30%, 82% { opacity: .9; } 100% { transform: scaleX(1); opacity: .55; } }
@keyframes introScan { 0% { transform: translateX(-82%); } 70%, 100% { transform: translateX(82%); } }
@keyframes introPulse { 50% { transform: scale(1.16); opacity: .9; } }
@keyframes beamLeft { 0% { transform: translateX(-40%) rotate(18deg); opacity: 0; } 35%, 85% { opacity: .75; } 100% { transform: translateX(35%) rotate(18deg); opacity: .15; } }
@keyframes beamRight { 0% { transform: translateX(40%) rotate(-16deg); opacity: 0; } 35%, 85% { opacity: .75; } 100% { transform: translateX(-35%) rotate(-16deg); opacity: .15; } }

.hero-showcase {
  display: grid;
  grid-template-columns: 1fr;
  gap: 30px;
  min-height: auto;
  padding-top: 42px;
}
.hero-main-photo {
  margin: 0;
  width: 100%;
  border-radius: 36px;
  overflow: hidden;
  border: 1px solid rgba(245,198,91,.32);
  background: #000;
  box-shadow: 0 38px 100px rgba(0,0,0,.56), 0 0 85px rgba(245,198,91,.12);
  position: relative;
}
.hero-main-photo::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  box-shadow: inset 0 0 0 1px rgba(255,232,166,.08), inset 0 -80px 120px rgba(0,0,0,.20);
}
.hero-main-photo img {
  width: 100%;
  height: auto;
  aspect-ratio: 16 / 9;
  object-fit: cover;
}
.hero-panel {
  max-width: 1000px;
  padding: 28px 0 0;
}
.hero-panel h1 { max-width: 1040px; color: #fff3d5; text-shadow: 0 0 34px rgba(245,198,91,.08); }
.hero-panel p { color: #d6c39a; }
.hero-panel .eyebrow { border-color: rgba(245,198,91,.28); background: rgba(245,198,91,.07); }
.hero-panel .eyebrow span { color: #ffe08a; }

.primary-btn { background: linear-gradient(135deg, #f1b741, #ffe08a 58%, #bf8126); color: #070503; box-shadow: 0 20px 54px rgba(245,198,91,.24); }
.secondary-btn, .ghost-btn { border-color: rgba(245,198,91,.30); }
.feature-strip article, .product-card, .finder-panel, .faq-links a, .accordion details, .delivery-banner, .owner-box, .cart-drawer, .chat-window { box-shadow: 0 24px 70px rgba(0,0,0,.36); }
.chatbot-fab, .cart-fab { background: linear-gradient(135deg, #f1b741, #ffe08a); color: #090603; }
.chat-form button { background: linear-gradient(135deg, #f1b741, #ffe08a); color: #090603; }

@media (max-width: 820px) {
  .intro-stage { width: min(760px, 96vw); }
  .intro-skip { right: 16px; bottom: 16px; }
  .hero-showcase { padding-top: 24px; gap: 22px; }
  .hero-main-photo { border-radius: 24px; }
  .hero-panel { padding-top: 10px; }
}
@media (max-width: 520px) {
  .hero-main-photo img { min-height: 260px; object-fit: cover; object-position: center; }
  .intro-stage { width: 112vw; }
}
@media (prefers-reduced-motion: reduce) {
  .intro-stage, .intro-stage::before, .intro-stage::after, .intro-scan, .intro-glow, .intro-beam { animation: none !important; }
}

/* PROTA v4 corrigido: imagens oficiais aplicadas no site */
:root {
  --bg: #030201;
  --bg-soft: #090604;
  --card: rgba(18, 11, 4, 0.82);
  --card-strong: rgba(22, 13, 4, 0.96);
  --line: rgba(246, 191, 73, 0.24);
  --line-strong: rgba(255, 220, 132, 0.46);
  --text: #fff5dc;
  --muted: #d1b16a;
  --green: #f2bb3d;
  --green-deep: #a66b14;
  --gold: #ffe08a;
  --orange: #d29024;
}
body {
  background:
    radial-gradient(circle at 50% -10%, rgba(246,191,73,.13), transparent 34%),
    radial-gradient(circle at 0% 20%, rgba(166,107,20,.11), transparent 28%),
    #030201;
}
.neon-progress span { background: linear-gradient(90deg, #c77a12, #ffe08a, #f2bb3d); }
.intro-loader {
  background:
    radial-gradient(circle at 50% 54%, rgba(246,191,73,.25), transparent 31%),
    radial-gradient(circle at 50% 100%, rgba(198,118,19,.16), transparent 42%),
    #000;
}
.intro-stage {
  width: min(1180px, 90vw);
  aspect-ratio: 16 / 9;
}
.intro-stage img {
  object-fit: contain;
  transform-origin: center;
  animation: introImageFloat 4.15s cubic-bezier(.18,.7,.16,1) forwards;
}
.intro-loader::before,
.intro-loader::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
}
.intro-loader::before {
  background:
    linear-gradient(115deg, transparent 0 44%, rgba(255,224,138,.18) 48%, transparent 54% 100%),
    radial-gradient(circle at 50% 50%, transparent 0 34%, rgba(246,191,73,.11) 35%, transparent 36% 100%);
  mix-blend-mode: screen;
  animation: introLightSweep 3.4s ease both;
}
.intro-loader::after {
  background-image:
    radial-gradient(circle, rgba(255,224,138,.45) 0 1px, transparent 1.4px),
    radial-gradient(circle, rgba(242,187,61,.28) 0 1px, transparent 1.4px);
  background-size: 120px 120px, 190px 190px;
  opacity: .18;
  animation: introParticles 4s ease both;
}
@keyframes introImageFloat {
  0% { opacity: 0; transform: translateY(26px) scale(.92); filter: blur(9px) brightness(.82); }
  20% { opacity: 1; filter: blur(0) brightness(1); }
  70% { transform: translateY(0) scale(1.018); }
  100% { transform: translateY(0) scale(1); filter: blur(0) brightness(1.03); }
}
@keyframes introLightSweep {
  0% { transform: translateX(-55%); opacity: 0; }
  20%, 72% { opacity: 1; }
  100% { transform: translateX(55%); opacity: 0; }
}
@keyframes introParticles {
  0% { transform: translateY(18px); opacity: 0; }
  25%, 80% { opacity: .18; }
  100% { transform: translateY(-10px); opacity: 0; }
}
.hero-showcase {
  width: min(1480px, calc(100% - 28px));
  padding-top: 28px;
  padding-bottom: 16px;
  min-height: auto;
  display: grid;
  grid-template-columns: 1fr;
}
.hero-main-photo {
  border-radius: 0;
  border: 0;
  overflow: hidden;
  box-shadow: 0 42px 110px rgba(0,0,0,.56), 0 0 90px rgba(242,187,61,.10);
  background: #000;
}
.hero-main-photo.image-only::after { display: none; }
.hero-main-photo img {
  width: 100%;
  height: auto;
  aspect-ratio: 16 / 9;
  object-fit: cover;
  object-position: center;
}
.hero-command {
  padding-top: 14px;
  padding-bottom: 42px;
}
.hero-command .hero-panel {
  max-width: 1180px;
  margin: 0 auto;
  padding: 28px;
  border: 1px solid rgba(246,191,73,.22);
  border-radius: 28px;
  background: linear-gradient(135deg, rgba(246,191,73,.08), rgba(255,255,255,.025));
  box-shadow: 0 24px 80px rgba(0,0,0,.34);
}
.hero-command h1 { font-size: clamp(36px, 6vw, 78px); color: #fff1c8; }
.hero-command p { color: #d7bc75; }
.hero-command .trust-row { margin-top: 24px; }
.navbar,
.feature-strip article,
.product-card,
.finder-panel,
.faq-links a,
.accordion details,
.delivery-banner,
.owner-box,
.cart-drawer,
.chat-window {
  border-color: rgba(246,191,73,.22);
  background-color: rgba(10,6,2,.70);
}
.brand img { filter: drop-shadow(0 0 18px rgba(246,191,73,.20)); }
.nav-links a:hover,
.utility-actions a:hover { color: #ffe08a; }
.primary-btn,
.chatbot-fab,
.cart-fab,
.chat-form button {
  background: linear-gradient(135deg, #c77a12 0%, #f2bb3d 42%, #ffe08a 72%, #a76510 100%);
  color: #070400;
}
.secondary-btn,
.ghost-btn {
  color: #ffe8a6;
  border-color: rgba(246,191,73,.36);
  background: rgba(246,191,73,.06);
}
.back-top { right: 24px; bottom: 24px; }
.cart-fab { right: 24px; bottom: 104px; }
.chatbot { left: 24px; bottom: 24px; }
@media (max-width: 820px) {
  .hero-showcase { width: calc(100% - 18px); padding-top: 18px; }
  .hero-command .hero-panel { padding: 20px; border-radius: 22px; }
  .intro-stage { width: min(900px, 108vw); }
}
@media (max-width: 520px) {
  .hero-main-photo img { min-height: auto; object-fit: cover; }
  .intro-stage { width: 122vw; }
  .cart-fab { right: 16px; bottom: 92px; }
  .back-top { right: 16px; bottom: 22px; }
  .chatbot { left: 16px; bottom: 16px; }
}
