/* Central Artes — Catálogo. Base do protótipo aprovado + hero Higgsfield + animações. */
:root{
  --accent:#F26522; --ink:#404041; --ink2:#404041; --muted:#7A7A7A; --faint:#bcbcc0;
  --line:#e9e9ea; --line2:#f2f2f3; --panel:#f6f6f7; --bg:#ffffff;
  --mono:'JetBrains Mono',ui-monospace,monospace;
  --display:'Oswald',system-ui,sans-serif; --hand:'Caveat',cursive;
}
*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;scroll-behavior:smooth}
body{font-family:'Inter',system-ui,sans-serif;color:var(--ink);background:var(--bg);font-size:15px;line-height:1.55;font-weight:400}
a{color:inherit;text-decoration:none}
::selection{background:var(--accent);color:#fff}
.wrap{max-width:1280px;margin:0 auto;padding:0 40px}
.mono{font-family:var(--mono);font-feature-settings:"tnum"}
.kick{font-family:var(--mono);font-size:11px;letter-spacing:.04em;text-transform:uppercase;color:var(--muted);font-weight:400}

/* Header */
header{position:sticky;top:0;z-index:30;background:rgba(255,255,255,.94);backdrop-filter:saturate(180%) blur(12px);border-bottom:1px solid var(--line)}
header .wrap{display:flex;align-items:center;height:72px;gap:44px}
.brand{display:flex;align-items:center}
.brand .logo{height:42px;width:auto;display:block}
.flogo{height:78px;width:auto;display:block;margin-bottom:20px}
nav{display:flex;gap:32px;margin-left:6px}
nav a{font-size:13px;color:var(--ink2);letter-spacing:.01em;position:relative;padding:3px 0}
nav a::after{content:"";position:absolute;left:0;right:100%;bottom:-2px;height:1.5px;background:var(--accent);transition:right .25s}
nav a:hover::after,nav a.on::after{right:0}
.hr{flex:1;margin-left:auto;display:flex;align-items:center;justify-content:flex-end;gap:26px}
.search{position:relative;flex:1;max-width:420px;min-width:240px}
.search input{width:100%;border:none;border-bottom:1px solid var(--line);background:none;padding:7px 22px 7px 0;font-family:inherit;font-size:13px;outline:none;color:var(--ink);transition:.25s}
.search input::placeholder{color:var(--faint)}
.search input:focus{border-color:var(--ink)}
.search .ic{position:absolute;right:0;top:6px;color:var(--faint)}
.pbtn{display:flex;align-items:center;gap:10px;background:none;border:none;cursor:pointer;font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink)}
.pbtn .ct{min-width:21px;height:21px;border-radius:50%;border:1px solid var(--line);display:grid;place-items:center;font-size:10px;transition:.2s}
.pbtn .ct.has{background:var(--accent);border-color:var(--accent);color:#fff}
.pbtn.on{color:var(--accent)}
.pbtn.on .ct{border-color:var(--accent)}

/* ============ HERO — Vitrine Cinética Editorial ============ */
.hero{position:relative;overflow:hidden;border-bottom:1px solid var(--line);min-height:clamp(560px,82vh,780px);display:flex;flex-direction:column;justify-content:center}

/* Camada 0 — atmosfera */
.hero-ghost{position:absolute;right:-1.5%;bottom:-6%;z-index:0;font-weight:800;font-size:clamp(100px,15vw,250px);line-height:.8;letter-spacing:-.05em;color:transparent;-webkit-text-stroke:1.2px #f1f1f2;user-select:none;pointer-events:none;white-space:nowrap}
.hero-warm{position:absolute;inset:0;z-index:0;background:radial-gradient(58% 58% at 80% 72%,rgba(242,101,34,.10),transparent 72%);pointer-events:none}

/* Camada 1 — esteira (3 trilhas em contrafluxo) */
.esteira{position:absolute;top:0;right:0;bottom:0;left:44%;z-index:1;overflow:hidden;display:flex;flex-direction:column;justify-content:center;gap:22px}
.trilha{display:flex;gap:18px;width:max-content;will-change:transform}
.trilha-a{animation:slideL 60s linear infinite;opacity:.95}
.trilha-b{animation:slideR 80s linear infinite;opacity:.7}
.trilha-c{animation:slideL 96s linear infinite;opacity:.38;filter:blur(1.2px)}
.esteira:hover .trilha,.esteira:focus-within .trilha{animation-play-state:paused}
@keyframes slideL{from{transform:translate3d(0,0,0)}to{transform:translate3d(-50%,0,0)}}
@keyframes slideR{from{transform:translate3d(-50%,0,0)}to{transform:translate3d(0,0,0)}}
.ecard{flex:none;width:clamp(116px,12vw,154px);aspect-ratio:4/5;background:var(--panel);border:1px solid var(--line);border-radius:3px;position:relative;overflow:hidden;cursor:pointer;display:grid;place-items:center;transition:transform .25s,box-shadow .25s,border-color .25s}
.ecard>img{width:100%;height:100%;object-fit:contain}
.ecard .ph{width:40%;color:var(--faint)}
.ecard .eref{position:absolute;left:7px;bottom:6px;font-family:var(--mono);font-size:8.5px;letter-spacing:.04em;color:var(--muted);background:rgba(255,255,255,.72);padding:1px 4px;border-radius:2px}
.esteira:hover .ecard:hover{transform:scale(1.05);box-shadow:0 12px 30px rgba(0,0,0,.10);border-color:var(--accent);z-index:2}

/* Camada 2 — véu editorial (legibilidade) + reflexo de vidro */
.hero-veu{position:absolute;inset:0;z-index:2;pointer-events:none;background:linear-gradient(100deg,#fff 0%,#fff 36%,rgba(255,255,255,.72) 60%,rgba(255,255,255,.08) 100%)}
.hero-veu::after{content:"";position:absolute;top:0;bottom:0;left:42%;width:26%;background:linear-gradient(110deg,transparent,rgba(255,255,255,.5),transparent);transform:skewX(-12deg);animation:sweep 7.5s ease-in-out infinite}
@keyframes sweep{0%,100%{opacity:0;transform:translateX(-40%) skewX(-12deg)}50%{opacity:1;transform:translateX(70%) skewX(-12deg)}}

/* Camada 3 — protagonista (herói + SUA LOGO AQUI) */
.palco{position:absolute;z-index:3;right:6.5%;top:50%;transform:translateY(-50%);width:clamp(230px,25vw,350px);aspect-ratio:4/5;animation:floaty 7s ease-in-out infinite}
.palco .halo{position:absolute;inset:-16% -13%;z-index:-1;background:radial-gradient(circle at 50% 46%,rgba(242,101,34,.82),rgba(242,101,34,.16) 46%,transparent 68%);filter:blur(3px);animation:halo 9s ease-in-out infinite}
.heroi-card{width:100%;height:100%;background:#fff;border:1px solid var(--line);border-radius:4px;overflow:hidden;box-shadow:0 30px 60px -20px rgba(64,64,65,.30);display:grid;place-items:center;transform:rotate(-2deg);transition:transform .45s,box-shadow .45s;cursor:pointer}
.palco:hover .heroi-card{transform:rotate(0) scale(1.02);box-shadow:0 42px 80px -22px rgba(64,64,65,.36)}
.heroi-card>img{width:100%;height:100%;object-fit:contain}
.heroi-card .ph{width:42%;color:var(--faint)}
.zona-logo{position:absolute;left:50%;top:43%;transform:translate(-50%,-50%);width:44%;aspect-ratio:1;z-index:2;display:grid;place-items:center;border:1.5px dashed var(--accent);border-radius:3px;animation:pulselogo 2.4s ease-in-out infinite}
.zona-logo .tag{font-family:var(--mono);font-size:9px;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);background:rgba(255,255,255,.85);padding:2px 6px;border-radius:2px;transition:opacity .5s}
.zona-logo .applied{position:absolute;width:64%;opacity:0;transition:opacity .5s;mix-blend-mode:multiply}
.palco.logo-on .zona-logo .tag{opacity:0}
.palco.logo-on .zona-logo .applied{opacity:1}
.zona-logo::before,.zona-logo::after{content:"";position:absolute;width:8px;height:8px;border:1.5px solid var(--accent)}
.zona-logo::before{top:-2px;left:-2px;border-right:0;border-bottom:0}
.zona-logo::after{bottom:-2px;right:-2px;border-left:0;border-top:0}

/* Camada 4 — mensagem editorial */
.hero-msg{position:relative;z-index:4;width:100%;max-width:1280px;margin:0 auto;padding:40px}
.masthead{display:flex;align-items:center;gap:14px;font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink2);margin-bottom:30px}
.masthead i{height:1px;width:46px;background:var(--line);display:inline-block}
.masthead span:first-child{color:var(--accent)}
.masthead span:last-child{color:var(--muted)}
.hero-h1{font-family:var(--display);font-weight:700;font-size:clamp(48px,6.6vw,90px);line-height:.95;letter-spacing:-.02em;color:var(--ink)}
.hero-h1 span{display:block}
.hero-h1 .l1,.hero-h1 .l2,.hero-h1 .l3{animation:rise .8s cubic-bezier(.2,.7,.2,1) both}
.hero-h1 .l2{animation-delay:.07s}
.hero-h1 .l3{animation-delay:.14s}
.hero-h1 b{font-weight:700;font-style:normal}
.hero-h1 .o{color:var(--accent)}
.hero-sub{font-size:15.5px;font-weight:400;color:var(--muted);line-height:1.6;max-width:420px;margin:24px 0 0;animation:rise .8s .2s both}
.hero-cta{display:flex;gap:14px;margin-top:30px;animation:rise .8s .28s both}
.hero-cta a{font-family:var(--mono);font-size:11px;letter-spacing:.07em;text-transform:uppercase;padding:15px 26px;cursor:pointer;transition:.16s;display:inline-block}
.hero-cta .p{background:var(--accent);color:#fff}
.hero-cta .p:hover{background:#d4521a;transform:translateY(-1px);box-shadow:0 10px 24px -8px rgba(242,101,34,.5)}
.hero-cta .g{border:1px solid var(--ink);color:var(--ink)}
.hero-cta .g:hover{background:var(--ink);color:#fff}
.hero-assin{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-top:26px;animation:rise .8s .34s both}

/* Rodapé do hero — navegação por categoria */
.hero-strip{border-top:1px solid var(--line);position:relative;z-index:4;background:rgba(255,255,255,.78);backdrop-filter:blur(4px)}
.hero-strip .wrap{display:flex;gap:22px;padding:15px 40px;flex-wrap:wrap;align-items:center}
.hero-strip .lbl{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--accent)}
.hero-strip a{font-size:13px;color:var(--ink2);cursor:pointer;transition:.14s;position:relative;padding:2px 0}
.hero-strip a::after{content:"";position:absolute;left:0;right:100%;bottom:-2px;height:1.5px;background:var(--accent);transition:right .25s}
.hero-strip a:hover::after{right:0}
.hero-strip a:hover{color:var(--accent)}

@keyframes floaty{0%,100%{transform:translateY(-50%)}50%{transform:translateY(calc(-50% - 8px))}}
@keyframes halo{0%,100%{opacity:.82;transform:scale(1)}50%{opacity:1;transform:scale(1.05)}}
@keyframes pulselogo{0%,100%{opacity:.6}50%{opacity:1}}
@keyframes rise{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}

@media(max-width:900px){
  .hero{min-height:auto}
  .hero-veu,.palco,.trilha-b,.trilha-c{display:none}
  .esteira{position:relative;inset:auto;left:0;height:200px;order:2;padding:0 0 8px}
  .hero-ghost{font-size:30vw;bottom:auto;top:0;opacity:.7}
  .hero-msg{order:1;padding:34px 22px 18px}
  .hero-h1{font-size:clamp(40px,11vw,56px)}
  .hero-sub{max-width:none}
}
@media(prefers-reduced-motion:reduce){
  .trilha,.palco,.palco .halo,.zona-logo,.hero-veu::after,.hero-h1 span,.hero-sub,.hero-cta,.hero-assin{animation:none!important}
  .palco{transform:translateY(-50%)}
}

/* Layout */
.layout{display:grid;grid-template-columns:188px 1fr;gap:60px;padding:48px 0 90px}
.side{position:sticky;top:96px;align-self:start}
.side .kick{display:block;margin-bottom:20px;padding-bottom:14px;border-bottom:1px solid var(--line)}
.cats{list-style:none}
.cats li{margin-bottom:1px}
.cats button{width:100%;text-align:left;background:none;border:none;font-family:inherit;font-size:13px;color:var(--ink2);padding:8px 0;cursor:pointer;display:flex;align-items:baseline;gap:10px;transition:.16s;letter-spacing:.005em}
.cats button .ix{font-family:var(--mono);font-size:10px;color:var(--faint);width:18px;flex:none}
.cats button .tt{flex:1}
.cats button:hover{color:var(--ink)}
.cats button:hover .ix{color:var(--accent)}
.cats button.active{color:var(--accent)}
.cats button.active .ix{color:var(--accent)}
.chead{display:flex;justify-content:space-between;align-items:baseline;padding-bottom:20px;margin-bottom:34px;border-bottom:1px solid var(--line)}
.chead h2{font-family:var(--display);font-size:25px;font-weight:600;letter-spacing:-.01em;color:var(--ink)}
.chead .res{font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--faint)}

/* Grid */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:8px 28px}
.card{cursor:pointer;padding-bottom:8px;animation:fade .4s ease both}
@keyframes fade{from{opacity:0}to{opacity:1}}
.thumb{aspect-ratio:4/5;background:var(--panel);position:relative;overflow:hidden;display:grid;place-items:center}
.thumb>img{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;transition:transform .5s cubic-bezier(.2,.7,.2,1)}
.card:hover .thumb>img{transform:scale(1.04)}
.thumb .ic{width:38%;height:38%;color:var(--faint);transition:transform .5s cubic-bezier(.2,.7,.2,1),color .3s}
.card:hover .thumb .ic{transform:scale(1.06);color:#a8a8ad}
.thumb .ix{position:absolute;top:14px;left:14px;font-family:var(--mono);font-size:10px;color:var(--faint);z-index:2}
.thumb .eco{position:absolute;top:14px;right:14px;font-family:var(--mono);font-size:9px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);z-index:2}
.thumb .quick{position:absolute;left:0;right:0;bottom:0;background:linear-gradient(to top,rgba(255,255,255,.97),rgba(255,255,255,0));padding:30px 14px 14px;display:flex;gap:8px;opacity:0;transform:translateY(8px);transition:.28s cubic-bezier(.2,.7,.2,1);z-index:2}
.card:hover .quick{opacity:1;transform:translateY(0)}
.quick button{flex:1;font-family:var(--mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;padding:10px 6px;border:1px solid var(--ink);background:rgba(255,255,255,.6);cursor:pointer;color:var(--ink);transition:.15s}
.quick button.add{border-color:var(--accent);color:var(--accent)}
.quick button.add:hover{background:var(--accent);color:#fff}
.quick button.det:hover{background:var(--ink);color:#fff}
.meta{padding:15px 0 0}
.meta .ref{font-family:var(--mono);font-size:10px;letter-spacing:.06em;color:var(--faint);margin-bottom:6px}
.meta .name{font-size:14.5px;font-weight:500;line-height:1.35;letter-spacing:-.005em}
.meta .ct{font-size:13px;color:var(--muted);font-weight:300;margin-top:3px}
.pmeta{display:flex;align-items:center;gap:12px;margin-top:8px;flex-wrap:wrap}
.price{font-family:var(--mono);font-size:13px;font-weight:500;color:var(--ink)}
.stk{font-family:var(--mono);font-size:10px;letter-spacing:.05em;text-transform:uppercase}
.stk.ok{color:#2e8b57}.stk.no{color:var(--faint)}

/* Modal */
.ov{position:fixed;inset:0;background:rgba(31,31,33,.45);backdrop-filter:blur(3px);display:none;align-items:center;justify-content:center;z-index:50;padding:28px}
.ov.open{display:flex}
.modal{background:#fff;max-width:900px;width:100%;max-height:90vh;overflow:auto;display:grid;grid-template-columns:1.1fr 1fr;border-radius:2px}
.mimg{background:var(--panel);display:grid;place-items:center;min-height:440px;position:relative;overflow:hidden}
.mimg>img{width:100%;height:100%;object-fit:contain}
.mimg .ic{width:38%;height:38%;color:var(--faint)}
.mimg .ix{position:absolute;top:20px;left:20px;font-family:var(--mono);font-size:11px;color:var(--faint);z-index:2}
.mx{position:absolute;top:16px;right:16px;width:34px;height:34px;border:none;background:rgba(255,255,255,.7);cursor:pointer;color:var(--muted);font-size:20px;font-weight:300;z-index:3}
.minfo{padding:52px 46px}
.minfo .ref{font-family:var(--mono);font-size:11px;letter-spacing:.08em;color:var(--faint)}
.minfo h2{font-family:var(--display);font-size:30px;font-weight:600;letter-spacing:-.01em;margin:13px 0 7px;line-height:1.12;color:var(--ink)}
.minfo .ct{font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--accent);margin-bottom:24px}
.minfo p{font-size:14.5px;color:var(--muted);font-weight:300;line-height:1.7;margin-bottom:28px}
.blk{margin-bottom:26px}.blk .kick{display:block;margin-bottom:13px}
.spec{display:flex;flex-wrap:wrap;gap:8px}
.spec span{font-size:12px;color:var(--ink2);border:1px solid var(--line);padding:6px 13px;font-weight:400}
.colors{display:flex;gap:11px}
.sw{width:22px;height:22px;border-radius:50%;box-shadow:inset 0 0 0 1px rgba(0,0,0,.1)}
.acts{display:flex;gap:12px;margin-top:32px}
.btn{font-family:var(--mono);font-size:11px;font-weight:500;letter-spacing:.07em;text-transform:uppercase;padding:15px 26px;cursor:pointer;border:1px solid var(--ink);background:none;color:var(--ink);transition:.16s}
.btn:hover{background:var(--ink);color:#fff}
.btn.solid{background:var(--accent);border-color:var(--accent);color:#fff}
.btn.solid:hover{background:#d4521a;border-color:#d4521a}
.mvend{margin-bottom:18px}
.vend-row{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.price-lg{font-family:var(--mono);font-size:23px;font-weight:500;color:var(--ink)}
.vbadge{font-family:var(--mono);font-size:9px;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);border:1px solid var(--accent);padding:3px 8px}
.share{margin-top:28px;padding-top:22px;border-top:1px solid var(--line);display:flex;align-items:center;gap:12px}
.share .kick{flex:none}
.share code{font-family:var(--mono);font-size:12px;color:var(--muted);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.share button{border:none;background:none;color:var(--accent);font-family:var(--mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;cursor:pointer}

/* Drawer */
.dw{position:fixed;top:0;right:0;width:430px;max-width:94vw;height:100vh;background:#fff;border-left:1px solid var(--line);transform:translateX(100%);transition:.32s cubic-bezier(.4,0,.1,1);z-index:60;display:flex;flex-direction:column}
.dw.open{transform:translateX(0);box-shadow:-24px 0 70px rgba(0,0,0,.07)}
.dwh{padding:32px 32px 24px;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;align-items:flex-start}
.dwh h3{font-family:var(--display);font-size:20px;font-weight:600;letter-spacing:-.005em;color:var(--ink)}
.dwh .sub{font-family:var(--mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--faint);margin-top:6px}
.dwh button{border:none;background:none;font-family:var(--mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);cursor:pointer}
.dwb{flex:1;overflow:auto;padding:6px 32px}
.pit{display:flex;gap:16px;padding:22px 0;border-bottom:1px solid var(--line2);align-items:flex-start}
.pit .mn{width:56px;height:56px;background:var(--panel);display:grid;place-items:center;flex:none;overflow:hidden}
.pit .mn>img{width:100%;height:100%;object-fit:contain}
.pit .mn .ic{width:48%;height:48%;color:var(--faint)}
.pit .tx{flex:1}.pit .tx .n{font-size:14px;font-weight:500}
.pit .tx .r{font-family:var(--mono);font-size:10px;letter-spacing:.06em;color:var(--faint);margin-top:4px}
.qty{display:inline-flex;align-items:center;gap:16px;margin-top:12px}
.qty button{width:22px;height:22px;border:1px solid var(--line);background:none;border-radius:50%;cursor:pointer;color:var(--ink2);font-size:13px;display:grid;place-items:center;transition:.14s}
.qty button:hover{border-color:var(--ink)}
.qty span{font-family:var(--mono);font-size:12px;min-width:16px;text-align:center}
.pit .rm{border:none;background:none;color:var(--faint);font-size:17px;cursor:pointer;font-weight:300}
.pit .rm:hover{color:var(--accent)}
.pit .lineprice{font-family:var(--mono);font-size:11px;color:var(--muted);margin-top:7px}
.prop-total{display:flex;justify-content:space-between;align-items:baseline;padding:18px 0 4px;margin-top:6px;border-top:1px solid var(--line)}
.prop-total .l{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.prop-total .v{font-family:var(--mono);font-size:19px;color:var(--ink)}
.dwf{padding:28px 32px;border-top:1px solid var(--line)}
.dwf .btn{width:100%;text-align:center}
.dwf p{font-size:11.5px;color:var(--faint);font-weight:300;text-align:center;margin-top:15px;line-height:1.6}
.empty{text-align:center;padding:80px 24px;color:var(--faint)}
.empty .ic{width:36px;height:36px;margin-bottom:18px;color:var(--line)}
.empty p{font-size:13px;font-weight:300;line-height:1.7}

/* Footer */
footer{border-top:1px solid var(--line);padding:64px 0 44px}
footer .wrap{display:grid;grid-template-columns:1.7fr 1fr 1fr;gap:52px}
footer .slogan{font-size:22px;font-weight:300;letter-spacing:-.02em;margin-bottom:16px}
footer .slogan b{font-weight:600}
footer p{font-size:13.5px;color:var(--muted);font-weight:300;line-height:1.7;max-width:330px}
footer .fs{font-family:var(--mono);font-size:10.5px;color:var(--faint);margin-top:20px;line-height:1.9;letter-spacing:.02em}
footer h4{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--faint);margin-bottom:18px}
.fcol a{display:block;font-size:13.5px;color:var(--ink2);font-weight:300;margin-bottom:11px;transition:.14s}
.fcol a:hover{color:var(--accent)}
.fhr{display:block;font-family:var(--mono);font-size:11px;color:var(--faint);margin-top:4px}
.fbar{border-top:1px solid var(--line);margin-top:52px;padding-top:26px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px}
.fbar span{font-family:var(--mono);font-size:10.5px;color:var(--faint);letter-spacing:.04em}
.fbar .origem{font-family:var(--hand);font-size:17px;color:var(--accent);letter-spacing:0;text-transform:none}
.banner{font-family:var(--mono);font-size:11px;color:var(--muted);letter-spacing:.02em;border:1px solid var(--line);padding:13px 18px;margin-bottom:32px;background:var(--panel);line-height:1.6}
.banner b{color:var(--ink);font-weight:500}

/* Banner de categoria (fundo Higgsfield por categoria) */
/* Banner de categoria — vitrine de marca: tipografia Central Artes + produtos REAIS (sem render abstrato) */
.cathero{position:relative;display:none;align-items:stretch;justify-content:space-between;gap:26px;min-height:158px;margin-bottom:30px;border:1px solid var(--line);background:var(--bg);overflow:hidden;padding:26px 30px}
.cathero.show{display:flex;animation:fade .45s ease both}
.cathero::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--accent)}
.ch-info{display:flex;flex-direction:column;justify-content:center;gap:9px;flex:none;max-width:44%}
.ch-kick{font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);font-weight:500}
.ch-title{font-family:var(--display);font-size:clamp(26px,3.2vw,38px);font-weight:600;letter-spacing:-.01em;color:var(--ink);line-height:1.02}
.ch-count{font-family:var(--mono);font-size:11px;color:var(--muted);letter-spacing:.04em}
.ch-prods{display:flex;gap:14px;align-items:center;flex:1;justify-content:flex-end;overflow:hidden}
.ch-prods .cp{width:116px;height:116px;border:1px solid var(--line);background:#fff;display:grid;place-items:center;flex:none;padding:11px;transition:.2s}
.ch-prods .cp:hover{border-color:var(--accent)}
.ch-prods .cp img{max-width:100%;max-height:100%;object-fit:contain}
@media(max-width:820px){.ch-prods .cp:nth-child(n+3){display:none}.ch-info{max-width:58%}}
@media(max-width:560px){.ch-prods{display:none}.ch-info{max-width:100%}}

/* Login vendedor + toast */
.login{background:#fff;max-width:360px;width:100%;padding:40px 36px;border-radius:2px}
.login h3{font-size:20px;font-weight:400;margin-bottom:6px}
.login p{font-size:13px;color:var(--muted);font-weight:300;margin-bottom:22px}
.login input{width:100%;border:1px solid var(--line);padding:13px 14px;font-family:inherit;font-size:14px;outline:none;margin-bottom:14px}
.login input:focus{border-color:var(--ink)}
.login .err{color:var(--accent);font-size:12px;font-family:var(--mono);min-height:16px;margin-bottom:10px}
.toast{position:fixed;bottom:26px;left:50%;transform:translateX(-50%) translateY(20px);background:var(--ink);color:#fff;font-size:13px;padding:12px 22px;border-radius:2px;opacity:0;transition:.3s;z-index:100;pointer-events:none}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* Acessibilidade: foco visível na navegação por teclado */
:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:1px}

/* Produtos com fundo branco (foto inteira, sem corte) */
.thumb,.mimg,.ecard,.heroi-card{background:#fff}
.thumb>img,.ecard>img{padding:8px}
.mimg>img{padding:20px}
.heroi-card>img{padding:10px}
.mimg>img{transition:opacity .2s}

/* Swatches de cor clicáveis (troca a foto) */
.sw{width:24px;height:24px;border-radius:50%;border:none;padding:0;cursor:pointer;box-shadow:inset 0 0 0 1px rgba(0,0,0,.14);transition:transform .15s,box-shadow .15s}
.sw:hover{transform:scale(1.12)}
.sw.on{box-shadow:inset 0 0 0 1px rgba(0,0,0,.14),0 0 0 2px #fff,0 0 0 4px var(--accent)}
.corlabel{font-size:13.5px;color:var(--ink2);margin-bottom:13px}
.corlabel b{font-weight:600}
.cest{display:inline-block;font-family:var(--mono);font-size:10px;color:#2e8b57;margin-left:8px;border:1px solid #cfe6d6;background:#f2faf4;padding:3px 8px;border-radius:5px;letter-spacing:.02em;line-height:1.3}
.cest.no{color:var(--muted);border-color:var(--line);background:var(--panel)}

/* Bolinhas de cor no card */
.cdots{display:flex;align-items:center;gap:5px;margin-top:9px}
.cdot{width:12px;height:12px;border-radius:50%;box-shadow:inset 0 0 0 1px rgba(0,0,0,.16)}
.cmore{font-family:var(--mono);font-size:9px;color:var(--faint);margin-left:2px}

/* Tabela de preço por quantidade (vendedor) */
.ptab{display:flex;flex-wrap:wrap;gap:6px 16px;margin-top:14px;padding-top:13px;border-top:1px solid var(--line)}
.ptab-l{flex-basis:100%;font-family:var(--mono);font-size:9.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--faint);margin-bottom:2px}
.ptab-i{font-family:var(--mono);font-size:11.5px;color:var(--ink2)}
.ptab-i b{color:var(--accent);font-weight:600}

/* Formulário de lead (cliente público no carrinho) */
.leadform{display:flex;flex-direction:column;gap:8px;margin-bottom:14px}
.leadform input{border:1px solid var(--line);padding:11px 12px;font-family:inherit;font-size:14px;outline:none;width:100%}
.leadform input:focus{border-color:var(--ink)}
.pagbox{margin-bottom:12px}
.pagbox label{display:block;font-family:var(--mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);margin-bottom:6px}
.pagbox textarea,.pagbox input{width:100%;border:1px solid var(--line);padding:10px 12px;font-family:inherit;font-size:13px;outline:none;resize:vertical;line-height:1.5}
.pagbox textarea:focus,.pagbox input:focus{border-color:var(--accent)}
.lpx{width:64px;border:1px solid var(--line);padding:2px 5px;font-family:var(--mono);font-size:11px;text-align:right;color:var(--ink)}
.lpx:focus{outline:none;border-color:var(--accent)}

/* Modal: imagem do produto INTEIRA, centralizada (sem corte). O <img> vive dentro
   de #m-img (span), então o seletor precisa alcançá-lo aqui. */
#m-img{position:absolute;inset:0;display:grid;place-items:center;padding:26px;z-index:1}
#m-img img{max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain}

@media(max-width:900px){
  .wrap{padding:0 22px}
  nav,.search{display:none}
  .hero .wrap{grid-template-columns:1fr;padding:56px 22px 44px;gap:28px}
  .hero h1{font-size:38px}
  .layout{grid-template-columns:1fr;gap:32px}
  .side{position:static}
  .cats{display:flex;flex-wrap:wrap;gap:4px 18px}
  .cats button .ix{display:none}
  .modal{grid-template-columns:1fr}
  footer .wrap{grid-template-columns:1fr;gap:34px}
}
