/* BRABA WORKS — core stylesheet (shared across pages) */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --lava:#FF5A1F;
  --preto:#0D0D0D;
  --branco:#F0EBE3;
  --azul:#1B3A5C;
  --cinza:#888888;
  --cinzaL:#C8C4BE;
  --sabbia:#D4B896;
}
html,body{background:var(--preto);color:var(--branco);font-family:'Helvetica Neue',Helvetica,Arial,sans-serif;-webkit-font-smoothing:antialiased;scroll-behavior:smooth}
body{cursor:none;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
::selection{background:var(--lava);color:var(--preto)}

/* Scroll progress */
.scroll-bar{position:fixed;top:0;left:0;height:2px;background:var(--lava);width:0%;z-index:9389;transition:width 0.05s linear}

/* Grain */
.grain{position:fixed;inset:0;z-index:9990;pointer-events:none;opacity:0.04;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-size:200px;animation:grainShift 0.5s steps(2) infinite}
@keyframes grainShift{0%{transform:translate(0,0)}25%{transform:translate(-2px,2px)}50%{transform:translate(2px,-1px)}75%{transform:translate(-1px,-2px)}100%{transform:translate(0,0)}}

/* Custom cursor */
.cursor{position:fixed;top:0;left:0;width:12px;height:12px;background:var(--lava);border-radius:50%;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);transition:width 0.2s,height 0.2s;will-change:transform}
.cursor-ring{position:fixed;top:0;left:0;width:40px;height:40px;border:1px solid rgba(255,90,31,0.5);border-radius:50%;pointer-events:none;z-index:9998;transform:translate(-50%,-50%);transition:width 0.3s,height 0.3s,border-color 0.3s;will-change:transform}
.cursor.hover{width:20px;height:20px}
.cursor-ring.hover{width:60px;height:60px;border-color:rgba(255,90,31,0.8)}
@media (hover:none){.cursor,.cursor-ring{display:none}body{cursor:auto}}

/* Container */
.container{max-width:1320px;margin:0 auto;padding:0 60px}

/* Navbar */
nav{position:fixed;top:0;left:0;right:0;z-index:1000;padding:28px 60px;display:flex;justify-content:space-between;align-items:center;transition:background 0.4s,padding 0.4s,backdrop-filter 0.4s}
nav.scrolled{background:rgba(13,13,13,0.92);backdrop-filter:blur(12px);padding:18px 60px}
.nav-logo{font-size:18px;font-weight:900;letter-spacing:0.12em;text-transform:uppercase;color:var(--branco);display:flex;align-items:center;gap:12px}
.nav-logo .mark{width:22px;height:33px;color:var(--lava);display:block;flex-shrink:0;transition:transform 0.5s cubic-bezier(.2,.8,.2,1)}
.nav-logo .mark svg{width:100%;height:100%;display:block}
.nav-logo .mark svg path{transition:transform 0.6s cubic-bezier(.3,.8,.2,1), fill 0.3s;transform-origin:center;fill:currentColor}
.nav-logo .mark svg path:nth-child(1){animation:markFloatA 5.5s ease-in-out infinite}
.nav-logo .mark svg path:nth-child(2){animation:markFloatB 5.5s ease-in-out infinite}
@keyframes markFloatA{0%,100%{transform:translateY(0) rotate(0)}50%{transform:translateY(-2px) rotate(-2deg)}}
@keyframes markFloatB{0%,100%{transform:translateY(0) rotate(0)}50%{transform:translateY(2px) rotate(2deg)}}
.nav-logo:hover .mark{transform:rotate(-8deg) scale(1.1)}
.nav-logo:hover .mark svg path:nth-child(1){transform:translateX(-3px)}
.nav-logo:hover .mark svg path:nth-child(2){transform:translateX(3px)}
.nav-logo span{color:var(--branco);font-size:22px;font-weight:700;letter-spacing:0.04em;transition:letter-spacing 0.4s}
.nav-logo:hover span{letter-spacing:0.1em}
.nav-links{display:flex;gap:36px;align-items:center}
.nav-links a{font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:var(--cinzaL);position:relative;transition:color 0.2s}
.nav-links a::after{content:'';position:absolute;left:0;bottom:-6px;width:0;height:1px;background:var(--lava);transition:width 0.3s}
.nav-links a:hover,.nav-links a.active{color:var(--branco)}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.nav-cta{font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:var(--preto);background:var(--lava);padding:10px 22px;font-weight:700;transition:background 0.2s,transform 0.2s}
.nav-cta:hover{background:var(--branco);transform:translateY(-1px)}

/* Buttons */
.btn-primary{font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:var(--preto);background:var(--lava);padding:16px 36px;font-weight:700;transition:background 0.2s,transform 0.2s;display:inline-block;border:none;cursor:none}
.btn-primary:hover{background:var(--branco);transform:translateY(-2px)}
.btn-ghost{font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:var(--branco);display:inline-flex;align-items:center;gap:10px;transition:gap 0.3s,color 0.2s;padding:16px 0;cursor:none}
.btn-ghost::after{content:'→'}
.btn-ghost:hover{gap:18px;color:var(--lava)}
.btn-outline{font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:var(--branco);border:1px solid rgba(240,235,227,0.4);padding:15px 34px;font-weight:700;transition:border-color 0.2s,color 0.2s,background 0.2s;display:inline-block}
.btn-outline:hover{border-color:var(--lava);color:var(--lava)}

/* Tag */
.tag{display:inline-block;font-size:10px;letter-spacing:0.22em;text-transform:uppercase;color:var(--lava);border:1px solid rgba(255,90,31,0.4);padding:5px 12px}
.tag-ghost{color:rgba(240,235,227,0.7);border-color:rgba(240,235,227,0.3)}

/* Page Hero (internal pages) */
.phero{min-height:70vh;padding:180px 0 100px;position:relative;overflow:hidden;border-bottom:1px solid rgba(255,255,255,0.05)}
.phero-bg{position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.phero-bg svg{position:absolute;top:50%;left:50%;width:200%;height:auto;color:var(--lava);transform:translate(calc(-50% + var(--bgx,0px)), -50%);opacity:0.18;mix-blend-mode:screen;filter:drop-shadow(0 0 60px rgba(255,90,31,0.15));will-change:transform}
.phero-bg svg path{animation:shapeBreath 7s ease-in-out infinite}
.phero-bg svg path:nth-child(2n){animation-delay:-2.3s}
.phero-bg svg path:nth-child(3n){animation-delay:-4.6s}
@keyframes shapeBreath{0%,100%{opacity:0.85}50%{opacity:0.45}}
.phero-bg::after{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 30% 50%, transparent 0%, rgba(13,13,13,0.3) 55%, rgba(13,13,13,0.85) 100%)}
.phero-content{position:relative;z-index:2;max-width:920px}
.phero-eyebrow{font-size:10px;letter-spacing:0.25em;text-transform:uppercase;color:var(--lava);display:flex;align-items:center;gap:14px;margin-bottom:32px}
.phero-eyebrow::before{content:'';width:40px;height:1px;background:var(--lava)}
.phero-crumbs{font-size:10px;letter-spacing:0.25em;text-transform:uppercase;color:var(--cinza);margin-bottom:32px;display:flex;align-items:center;gap:12px}
.phero-crumbs a{color:var(--cinza);transition:color 0.2s}
.phero-crumbs a:hover{color:var(--lava)}
.phero-crumbs span{color:rgba(240,235,227,0.2)}
.phero-crumbs .cur{color:var(--branco)}
.phero-title{font-size:clamp(48px,7vw,120px);font-weight:900;text-transform:uppercase;letter-spacing:-0.03em;line-height:0.95;color:var(--branco);margin-bottom:40px}
.phero-title .lava{color:var(--lava)}
.phero-title .ghost{color:transparent;-webkit-text-stroke:1.5px rgba(240,235,227,0.25)}
.phero-title em{font-style:normal;color:var(--lava)}
.phero-sub{font-size:17px;line-height:1.7;color:var(--cinza);font-weight:300;max-width:680px;margin-bottom:40px}
.phero-sub strong{color:var(--branco);font-weight:400}
.phero-meta{display:flex;gap:48px;flex-wrap:wrap;padding-top:40px;border-top:1px solid rgba(255,255,255,0.08)}
.phero-meta-item{display:flex;flex-direction:column;gap:6px}
.phero-meta-k{font-size:9px;letter-spacing:0.28em;text-transform:uppercase;color:var(--lava)}
.phero-meta-v{font-size:14px;font-weight:500;color:var(--branco);letter-spacing:0.02em}

/* Footer */
footer{background:#050505;padding:100px 0 40px;border-top:1px solid rgba(255,255,255,0.04)}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:60px;margin-bottom:60px}
.footer-brand-logo{font-size:32px;font-weight:900;letter-spacing:0.04em;color:var(--branco);margin-bottom:18px;display:flex;align-items:center;gap:14px}
.footer-brand-logo .mark{width:32px;height:48px;color:var(--lava);flex-shrink:0}
.footer-brand-logo .mark svg{width:100%;height:100%}
.footer-brand-logo .mark svg path{fill:currentColor;transform-origin:center}
.footer-brand-logo .mark svg path:nth-child(1){animation:markFloatA 5.5s ease-in-out infinite}
.footer-brand-logo .mark svg path:nth-child(2){animation:markFloatB 5.5s ease-in-out infinite}
.footer-brand-logo span{color:var(--lava)}

/* Section-divider mark — drops between major sections */
.mark-divider{display:flex;justify-content:center;padding:60px 0;position:relative}
.mark-divider::before,.mark-divider::after{content:'';flex:1;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,0.1),transparent);align-self:center;margin:0 32px}
.mark-divider .mark{width:24px;height:36px;color:var(--lava);opacity:0.7;animation:markSpin 22s linear infinite}
.mark-divider .mark svg{width:100%;height:100%}
.mark-divider .mark svg path{fill:currentColor}
@keyframes markSpin{from{transform:rotate(0)}to{transform:rotate(360deg)}}

/* Floating mark — corner accent */
.mark-float{position:fixed;bottom:32px;left:32px;width:36px;height:54px;color:var(--lava);z-index:90;pointer-events:none;opacity:0;transition:opacity 0.6s}
.mark-float.on{opacity:0.35}
.mark-float svg{width:100%;height:100%}
.mark-float svg path{fill:currentColor;transform-origin:center}
.mark-float svg path:nth-child(1){animation:markFloatA 6s ease-in-out infinite}
.mark-float svg path:nth-child(2){animation:markFloatB 6s ease-in-out infinite}
@media (max-width:900px){.mark-float{display:none}}
.footer-brand-tag{font-size:13px;line-height:1.7;color:var(--cinza);max-width:320px;font-weight:300}
.footer-col-title{font-size:10px;letter-spacing:0.22em;text-transform:uppercase;color:var(--lava);margin-bottom:20px;font-weight:700}
.footer-col a{display:block;font-size:13px;color:var(--cinzaL);padding:6px 0;transition:color 0.2s,padding-left 0.2s}
.footer-col a:hover{color:var(--branco);padding-left:6px}
.footer-bottom{padding-top:32px;border-top:1px solid rgba(255,255,255,0.06);display:flex;justify-content:space-between;font-size:10px;letter-spacing:0.22em;text-transform:uppercase;color:var(--cinza);flex-wrap:wrap;gap:20px}

/* Reveal utility */
.reveal,.reveal-left,.reveal-right{opacity:0;transition:opacity 0.9s ease,transform 0.9s ease}
.reveal{transform:translateY(30px)}
.reveal-left{transform:translateX(-40px)}
.reveal-right{transform:translateX(40px)}
.reveal.visible,.reveal-left.visible,.reveal-right.visible{opacity:1;transform:translate(0,0)}

/* Responsive */
@media (max-width:900px){
  nav{padding:20px 24px}
  nav.scrolled{padding:14px 24px}
  .nav-links{display:none}
  .container{padding:0 24px}
  .phero{padding:140px 0 70px}
  .phero-meta{gap:24px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:40px}
}
