/* portfolio.html - estilos especificos desta pagina */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --gd:#0A2B1A;--gm:#0D4A28;--gb:#1A8A3C;
  --mg:#E8174E;--yw:#F5A623;--bl:#1A4FA0;
  --rd:#E31837;--rdk:#7A0020;--nv:#0D1E3A;
  --wh:#FFFFFF;
  --f:'Avenir Next',sans-serif;--fb:'Avenir Next',sans-serif;
}
body{font-family:var(--fb);background:var(--gd);color:var(--wh);overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
::-webkit-scrollbar{width:5px}
::-webkit-scrollbar-track{background:var(--gd)}
::-webkit-scrollbar-thumb{background:var(--mg);border-radius:3px}
nav{position:sticky;top:0;z-index:100;background:rgba(10,43,26,.93);backdrop-filter:blur(14px);border-bottom:2px solid rgba(232,23,78,.2)}
.nav-in{max-width:1400px;margin:0 auto;display:flex;align-items:center;padding:0 4vw;height:64px;gap:2rem}
.nav-logo img{height:36px;width:auto}
.nav-back{display:flex;align-items:center;gap:.4rem;font-family:var(--f);font-weight:700;font-size:.8rem;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.45);transition:color .2s}
.nav-back:hover{color:var(--wh)}
.nav-back svg{width:14px;height:14px;flex-shrink:0}
.top-cats{display:flex;gap:.2rem;margin-left:auto;flex-wrap:wrap}
.top-cats a{display:inline-flex;align-items:center;gap:.4rem;font-family:var(--f);font-weight:600;font-size:.95rem;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.85);padding:.5rem .9rem;border-radius:4px;transition:color .2s}
.top-cats a:hover{color:var(--yw)}
.nav-cta-pf{background:var(--mg);color:#fff!important;font-weight:700!important}
.top-cats a:hover{color:var(--wh);background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.15)}
.hero{background:var(--gd);padding:6rem 4vw 5rem;text-align:center;position:relative;overflow:hidden}
.hero::before{content:'PRODUTOS';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-family:var(--f);font-weight:900;font-size:clamp(5rem,16vw,18rem);text-transform:uppercase;color:rgba(255,255,255,.03);white-space:nowrap;pointer-events:none}
.hero-pill{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--f);font-weight:700;font-size:.78rem;letter-spacing:.2em;text-transform:uppercase;background:rgba(232,23,78,.12);border:1px solid rgba(232,23,78,.3);color:var(--mg);padding:.35rem .9rem;border-radius:50px;margin-bottom:1.25rem}
.hero-title{font-family:var(--f);font-weight:900;font-size:clamp(3rem,7vw,7rem);text-transform:uppercase;line-height:.92;margin-bottom:1rem}
.hero-title span{color:var(--yw)}
.hero-sub{font-size:1rem;color:rgba(255,255,255,.6);max-width:520px;margin:0 auto 2.5rem;line-height:1.65}
.hero-stats{display:inline-flex;border:1px solid rgba(255,255,255,.1);border-radius:8px;overflow:hidden}
.hs{padding:.9rem 2rem;border-right:1px solid rgba(255,255,255,.1)}
.hs:last-child{border-right:none}
.hs-n{font-family:var(--f);font-weight:900;font-size:2rem;color:var(--yw);line-height:1}
.hs-l{font-size:.7rem;color:rgba(255,255,255,.45);font-family:var(--f);text-transform:uppercase;letter-spacing:.1em;margin-top:.2rem}
.cns{position:sticky;top:64px;z-index:90;background:rgba(10,43,26,.96);border-bottom:1px solid rgba(255,255,255,.06);overflow-x:auto;scrollbar-width:none}
.cns::-webkit-scrollbar{display:none}
.cns-in{max-width:1400px;margin:0 auto;display:flex;padding:0 4vw;min-width:max-content}
.cnl{display:flex;align-items:center;gap:.55rem;padding:.85rem 1.4rem;font-family:var(--f);font-weight:700;font-size:.85rem;letter-spacing:.07em;text-transform:uppercase;color:rgba(255,255,255,.4);border-bottom:2px solid transparent;transition:all .2s;white-space:nowrap}
.cnl:hover,.cnl.active{color:var(--wh);border-bottom-color:var(--ca)}
.cnl-dot{width:8px;height:8px;border-radius:50%;background:var(--ca);flex-shrink:0}
.cat-sec{padding:6rem 4vw;position:relative;overflow:hidden}
.cat-in{max-width:1400px;margin:0 auto}
.cat-hd{display:flex;justify-content:space-between;align-items:flex-start;gap:2rem;flex-wrap:wrap;margin-bottom:3.5rem;padding-bottom:2.5rem;border-bottom:1px solid rgba(255,255,255,.07)}
.cat-hd-l{flex:1;min-width:260px}
.cat-hd-r{display:flex;flex-direction:column;align-items:flex-end;gap:1rem;flex-shrink:0}
.cat-pill{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--f);font-weight:700;font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;padding:.35rem .9rem;border-radius:50px;margin-bottom:.85rem}
.cat-title{font-family:var(--f);font-weight:900;font-size:clamp(2.5rem,4.5vw,5rem);text-transform:uppercase;line-height:.95;margin-bottom:.85rem;color:var(--wh)}
.cat-desc{font-size:.95rem;line-height:1.7;color:rgba(255,255,255,.58);max-width:520px}
.cat-meta{text-align:right;padding:1.1rem 1.5rem;border-radius:8px;border:1px solid}
.cat-weight{font-size:.75rem;color:rgba(255,255,255,.45);font-family:var(--f);text-transform:uppercase;letter-spacing:.07em}
.cat-cta{display:inline-flex;align-items:center;gap:.55rem;font-family:var(--f);font-weight:800;font-size:.95rem;letter-spacing:.1em;text-transform:uppercase;padding:.8rem 1.8rem;border-radius:4px;color:var(--wh);transition:filter .2s,transform .15s;white-space:nowrap}
.cat-cta:hover{filter:brightness(1.15);transform:translateY(-2px)}
.cat-div{height:1px;margin-top:0;opacity:.35}
.fc-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:1.25rem;margin-top:.5rem}
.fc{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07);border-radius:10px;overflow:hidden;display:flex;flex-direction:column;transition:transform .25s,border-color .25s,box-shadow .25s}
.fc:hover{transform:translateY(-6px);border-color:var(--ca);box-shadow:0 16px 48px rgba(0,0,0,.4),0 0 0 1px var(--ca)}
.fc-img-wrap{position:relative;aspect-ratio:3/4;background:transparent;overflow:hidden;display:flex;align-items:center;justify-content:center}
.fc-img{width:100%;height:100%;object-fit:contain;padding:.5rem;transition:transform .35s}
.fc:hover .fc-img{transform:scale(1.06)}
.badge-new{position:absolute;top:.55rem;right:.55rem;font-family:var(--f);font-weight:800;font-size:.65rem;letter-spacing:.12em;text-transform:uppercase;background:var(--mg);color:var(--wh);padding:.2rem .55rem;border-radius:3px;box-shadow:0 2px 8px rgba(232,23,78,.5)}
.fc-body{padding:1rem 1rem 1.1rem;flex:1;display:flex;flex-direction:column;border-top:2px solid var(--ca)}
.fc-name{font-family:var(--f);font-weight:800;font-size:1.1rem;text-transform:uppercase;line-height:1.1;margin-bottom:.5rem;color:var(--wh)}
.fc-desc{font-size:.8rem;line-height:1.5;color:rgba(255,255,255,.5);flex:1}
.ftcta{background:var(--mg);padding:6rem 4vw;text-align:center;position:relative;overflow:hidden}
.ftcta::before{content:'PALETEROS';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-family:var(--f);font-weight:900;font-size:clamp(5rem,14vw,16rem);text-transform:uppercase;color:rgba(255,255,255,.06);white-space:nowrap;pointer-events:none}
.ftcta-in{position:relative;z-index:1}
.ftcta h2{font-family:var(--f);font-weight:900;font-size:clamp(2.5rem,5.5vw,5.5rem);text-transform:uppercase;line-height:.95;margin-bottom:1rem}
.ftcta h2 span{color:var(--yw)}
.ftcta p{font-size:1rem;color:rgba(255,255,255,.8);margin-bottom:2.5rem;max-width:460px;margin-left:auto;margin-right:auto}
.ftcta-btns{display:flex;justify-content:center;gap:1rem;flex-wrap:wrap}
.btn-wh{display:inline-flex;align-items:center;gap:.5rem;background:var(--wh);color:var(--mg);font-family:var(--f);font-weight:800;font-size:1rem;letter-spacing:.1em;text-transform:uppercase;padding:.9rem 2.2rem;border-radius:4px;transition:background .2s,transform .15s}
.btn-wh:hover{background:#f0f0f0;transform:translateY(-2px)}
.btn-ol{display:inline-flex;align-items:center;gap:.5rem;background:transparent;color:var(--wh);border:2px solid rgba(255,255,255,.55);font-family:var(--f);font-weight:700;font-size:1rem;letter-spacing:.1em;text-transform:uppercase;padding:.9rem 2.2rem;border-radius:4px;transition:border-color .2s,transform .15s}
.btn-ol:hover{border-color:var(--wh);transform:translateY(-2px)}
footer{background:var(--gd);padding:2rem 4vw;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem;border-top:1px solid rgba(255,255,255,.06)}
.ft-logo img{height:30px;width:auto;opacity:.65}
.ft-copy{font-size:.75rem;color:rgba(255,255,255,.28);font-family:var(--f);text-transform:uppercase;letter-spacing:.05em}
.ft-links{display:flex;gap:1.5rem}
.ft-links a{font-size:.75rem;color:rgba(255,255,255,.28);font-family:var(--f);text-transform:uppercase;letter-spacing:.05em;transition:color .2s}
.ft-links a:hover{color:var(--wh)}
.reveal{opacity:0;transform:translateY(24px);transition:opacity .5s ease,transform .5s ease}
.reveal.vis{opacity:1;transform:none}
@media(max-width:1100px){.fc-grid{grid-template-columns:repeat(3,1fr)!important}}
@media(max-width:768px){
  .fc-grid{grid-template-columns:repeat(2,1fr)!important}
  .cat-hd{flex-direction:column}
  .cat-hd-r{align-items:flex-start;width:100%}
  .top-cats{display:none}
  .nav-in{gap:1rem}
  /* hero stats: allow wrap so they never overflow */
  .hero-stats{flex-wrap:wrap;border:none;gap:.6rem;justify-content:center}
  .hs{border:1px solid rgba(255,255,255,.1);border-radius:8px;flex:1 1 40%;min-width:120px}
  .cat-sec{padding:4rem 6vw}
  .hero{padding:4.5rem 6vw 3.5rem}
}
@media(max-width:480px){
  .fc-grid{grid-template-columns:1fr 1fr!important;gap:.8rem}
  .hero-title{font-size:clamp(2.4rem,13vw,3.5rem)}
  .cat-title{font-size:clamp(2rem,9vw,3rem)}
  .hs{flex:1 1 100%}
  .cat-cta{width:100%;justify-content:center}
  .cat-meta{width:100%;text-align:left}
  .fc-name{font-size:1rem}
  .fc-desc{font-size:.78rem}
}
@media(max-width:600px){h1,h2,h3,.hero-title,.sec-title,.tl-title,.feat-title,.fm-w{overflow-wrap:break-word;word-break:break-word}}
/* === MENU HAMBÚRGUER (mobile) === */
nav{position:relative}
.hb{display:none;background:none;border:0;cursor:pointer;padding:6px;margin-left:.4rem;flex-direction:column;gap:5px;align-items:center;justify-content:center}
.hb span{display:block;width:24px;height:2px;background:#fff;border-radius:2px;transition:transform .25s,opacity .2s}
.hb.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hb.open span:nth-child(2){opacity:0}
.hb.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.nav-cta-m{display:none;align-items:center;gap:.4rem;background:var(--mg);color:#fff!important;font-family:var(--f);font-weight:700;font-size:.82rem;letter-spacing:.06em;text-transform:uppercase;padding:.55rem 1rem;border-radius:5px;white-space:nowrap}
@media(max-width:768px){
  nav .nav-cta-m{display:inline-flex;margin-left:auto}
  nav .hb{display:flex}
  .nav-links,.top-cats{position:absolute!important;top:100%!important;left:0!important;right:0!important;width:auto!important;max-width:none!important;margin:0!important;flex-direction:column!important;align-items:stretch!important;flex-wrap:nowrap!important;gap:0!important;background:rgba(10,43,26,.98)!important;backdrop-filter:blur(14px);border-bottom:2px solid var(--mg);padding:0!important;max-height:0;overflow:hidden!important;transition:max-height .32s ease;display:flex!important}
  .nav-links.open,.top-cats.open{max-height:82vh;overflow:auto!important;padding:.3rem 0!important}
  .nav-links li{width:100%;list-style:none;margin:0}
  .nav-links a,.top-cats>a{display:block!important;width:100%;padding:.9rem 6vw!important;font-size:1.05rem!important;letter-spacing:.04em!important;border-bottom:1px solid rgba(255,255,255,.06)}
  .nav-links .nav-cta,.top-cats .nav-cta-pf{display:none!important}
}
