/* ========================================
   ERNANDE — Editor de Vídeo
   Cinema Noir Editorial Design System
   ======================================== */

/* ---- Tokens ---- */
:root {
  --black:   #060606;
  --bg:      #0A0A0A;
  --surface: #111111;
  --card:    #141414;
  --border:  #1E1E1E;
  --border2: #2A2A2A;
  --muted:   #444;
  --dim:     #666;
  --sub:     #999;
  --text:    #E8E8E8;
  --white:   #F5F5F5;

  --red:     #E63946;
  --red-dk:  #C22E3A;
  --red-g:   rgba(230,57,70,.12);
  --red-g2:  rgba(230,57,70,.25);

  --green:   #2D6A4F;
  --green-l: #52B788;
  --green-g: rgba(82,183,136,.12);

  --ff-display: 'Bebas Neue', system-ui, sans-serif;
  --ff-body:    'DM Sans', system-ui, sans-serif;
  --ff-mono:    'Space Mono', monospace;

  --ease: cubic-bezier(.16,1,.3,1);
  --nav-h: 64px;

  color-scheme: dark;
}

/* ---- Reset ---- */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:var(--nav-h);-webkit-font-smoothing:antialiased}
body{font-family:var(--ff-body);background:var(--bg);color:var(--text);line-height:1.6;overflow-x:hidden;}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%;height:auto}
/* Remove custom cursor fallback rules since it's totally gone now */
body{cursor:auto}
button,a{cursor:pointer;touch-action:manipulation}

/* ---- Film Grain ---- */
.grain{
  position:fixed;top:-50%;left:-50%;width:200vw;height:200vh;
  z-index:9998;pointer-events:none;opacity:.05;
  background-image:url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADIAAAAyBAMAAADsEZWCAAAAGFBMVEUAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA/X+D6AAAACHRSTlMAMwAAMwAAMwEEDpAAAAA2SURBVDjLY2AYBYM1EAExoEwBKAoXmKAyYIExYIEhYIEVYIE1YIE9YIFDYIFLYIFTYIE7YIEYAKt5V2Xb1qFfAAAAAElFTkSuQmCC");
  background-repeat:repeat;
  animation:grainShift 8s steps(10) infinite;
  will-change:transform;
}
@keyframes grainShift{
  0%,100%{transform:translate(0,0)}
  10%{transform:translate(-5%,-10%)}
  30%{transform:translate(3%,-15%)}
  50%{transform:translate(12%,9%)}
  70%{transform:translate(9%,4%)}
}
@media (prefers-reduced-motion: reduce) {
  .grain { animation: none; background-position: center; }
}

/* ---- Navigation ---- */
.nav{position:fixed;top:0;left:0;right:0;height:var(--nav-h);z-index:1000;transition:transform .5s var(--ease),background .3s}
.nav::after{content:'';position:absolute;inset:0;background:rgba(10,10,10,.75);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);z-index:-1;border-bottom:1px solid var(--border)}
.nav--up{transform:translateY(-100%)}
.nav__inner{max-width:1240px;margin:0 auto;height:100%;display:flex;align-items:center;justify-content:space-between;padding:0 clamp(20px,5vw,48px)}
.nav__logo{font-family:var(--ff-display);font-size:1.35rem;letter-spacing:.18em;display:flex}
.nav__logo-text{color:var(--white)}
.nav__logo-accent{color:var(--red)}
.nav__links{display:flex;align-items:center;gap:36px}
.nav__link{font-size:.8rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--sub);position:relative;padding:4px 0;transition:color .3s}
.nav__link::after{content:'';position:absolute;bottom:-2px;left:0;width:0;height:1px;background:var(--red);transition:width .45s var(--ease)}
.nav__link:hover{color:var(--white)}
.nav__link:hover::after{width:100%}
.nav__link--cta{display:inline-flex;align-items:center;gap:6px;color:var(--bg);background:var(--red);padding:8px 20px;border-radius:4px;font-weight:700;transition:background .3s,transform .3s,box-shadow .3s}
.nav__link--cta::after{display:none}
.nav__link--cta:hover{background:var(--red-dk);color:var(--bg);transform:translateY(-1px);box-shadow:0 6px 24px var(--red-g2)}

/* Burger */
.nav__burger{display:none;width:40px;height:40px;align-items:center;justify-content:center}
.nav__burger-lines{position:relative;width:22px;height:14px}
.nav__burger-lines span{position:absolute;left:0;width:100%;height:2px;background:var(--white);transition:transform .4s var(--ease),opacity .3s}
.nav__burger-lines span:first-child{top:0}
.nav__burger-lines span:last-child{bottom:0}
.nav__burger.active .nav__burger-lines span:first-child{transform:translateY(6px) rotate(45deg)}
.nav__burger.active .nav__burger-lines span:last-child{transform:translateY(-6px) rotate(-45deg)}

/* Mobile Menu */
.mmenu{position:fixed;inset:0;z-index:999;pointer-events:none}
.mmenu__bg{position:absolute;inset:0;background:var(--black);opacity:0;transition:opacity .5s var(--ease)}
.mmenu__content{position:absolute;inset:0;display:flex;flex-direction:column;align-items:flex-start;justify-content:center;padding:0 clamp(32px,8vw,80px);gap:8px;transform:translateY(20px);opacity:0;transition:transform .6s var(--ease),opacity .5s}
.mmenu.open{pointer-events:all}
.mmenu.open .mmenu__bg{opacity:.97}
.mmenu.open .mmenu__content{transform:translateY(0);opacity:1;transition-delay:.15s}
.mmenu__link{display:flex;align-items:baseline;gap:16px;padding:12px 0;transition:color .3s,transform .3s}
.mmenu__link-num{font-family:var(--ff-mono);font-size:.7rem;color:var(--muted);letter-spacing:.1em}
.mmenu__link-text{font-family:var(--ff-display);font-size:clamp(2.2rem,8vw,4rem);letter-spacing:.06em;color:var(--sub);transition:color .3s}
.mmenu__link:hover .mmenu__link-text{color:var(--red);transform:translateX(8px)}

/* ---- Hero ---- */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;overflow:hidden;padding:var(--nav-h) clamp(20px,5vw,48px) 40px}

/* Grid lines */
.hero__grid{position:absolute;inset:0;display:flex;justify-content:space-between;padding:0 clamp(20px,8vw,120px);pointer-events:none;opacity:.07}
.hero__grid span{width:1px;height:100%;background:linear-gradient(to bottom,transparent,var(--white) 20%,var(--white) 80%,transparent)}

/* Gradient mesh */
.hero__mesh{position:absolute;inset:0;overflow:hidden;pointer-events:none}
.hero__mesh-orb{position:absolute;border-radius:50%;filter:blur(120px);opacity:.3;will-change:transform}
.hero__mesh-orb--red{width:500px;height:500px;background:var(--red);top:-15%;right:-10%;animation:floatOrb1 12s ease-in-out infinite}
.hero__mesh-orb--green{width:400px;height:400px;background:var(--green);bottom:-10%;left:-5%;animation:floatOrb2 15s ease-in-out infinite}
.hero__mesh-orb--dark{width:600px;height:600px;background:var(--black);top:30%;left:30%;opacity:.6}

@keyframes floatOrb1{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(-40px,30px) scale(1.1)}}
@keyframes floatOrb2{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(30px,-20px) scale(1.08)}}

@media (prefers-reduced-motion: reduce) {
  .hero__mesh-orb { animation: none; transform: none !important; }
}

/* Hero content */
.hero__content{position:relative;z-index:2;text-align:center;max-width:960px}

.hero__eyebrow{display:inline-flex;align-items:center;gap:10px;padding:7px 18px 7px 14px;border:1px solid var(--green);border-radius:100px;margin-bottom:48px;font-size:.72rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--green-l)}
.hero__eyebrow-dot{width:7px;height:7px;border-radius:50%;background:var(--green-l);box-shadow:0 0 8px var(--green-l);animation:blink 2.5s ease-in-out infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}

.hero__title{margin-bottom:12px}
.hero__title-main{font-family:var(--ff-display);font-size:clamp(3.2rem,14vw,13rem);line-height:.9;letter-spacing:.04em;display:inline-flex}
.hero__char-wrap{display:inline-block;overflow:hidden}
.hero__char{display:inline-block;will-change:transform}

.hero__sub{display:flex;align-items:center;justify-content:center;gap:20px;margin-bottom:36px}
.hero__sub-line{height:1px;width:50px;background:var(--red);flex-shrink:0}
.hero__sub-text{font-family:var(--ff-display);font-size:clamp(1rem,3.2vw,2.2rem);letter-spacing:.4em;color:var(--red)}

.hero__desc{font-size:clamp(.9rem,1.4vw,1.08rem);color:var(--sub);max-width:500px;margin:0 auto 44px;line-height:1.75}

.hero__ctas{display:flex;align-items:center;justify-content:center;gap:14px;flex-wrap:wrap}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:8px;padding:14px 32px;font-size:.82rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;border-radius:4px;transition:background .4s var(--ease), border-color .4s var(--ease), color .4s var(--ease), transform .4s var(--ease), box-shadow .4s var(--ease);position:relative;overflow:hidden}
.btn--primary{background:var(--red);color:var(--white);border:1px solid var(--red)}
.btn--primary::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,transparent 40%,rgba(255,255,255,.12) 50%,transparent 60%);transform:translateX(-100%);transition:transform .6s var(--ease)}
.btn--primary:hover::before{transform:translateX(100%)}
.btn--primary:hover{background:var(--red-dk);border-color:var(--red-dk);box-shadow:0 8px 32px var(--red-g2);transform:translateY(-2px)}
.btn--outline{background:transparent;color:var(--sub);border:1px solid var(--border2)}
.btn--outline:hover{color:var(--white);border-color:var(--sub);transform:translateY(-2px)}
.btn__arrow{transition:transform .3s var(--ease)}
.btn:hover .btn__arrow{transform:translateX(4px)}

/* Scroll cue */
.hero__scroll{position:absolute;bottom:32px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:10px}
.hero__scroll-text{font-family:var(--ff-mono);font-size:.6rem;letter-spacing:.25em;text-transform:uppercase;color:var(--muted);writing-mode:vertical-lr;margin-bottom:4px}
.hero__scroll-track{width:1px;height:48px;background:var(--border);position:relative;overflow:hidden}
.hero__scroll-thumb{position:absolute;top:-100%;left:0;width:100%;height:50%;background:var(--red);animation:scrollThumb 2s ease-in-out infinite}
@keyframes scrollThumb{0%{top:-50%}100%{top:100%}}

/* Corner decorations */
.hero__corner{position:absolute;width:40px;height:40px;pointer-events:none;opacity:.15}
.hero__corner--tl{top:clamp(80px,12vh,120px);left:clamp(20px,5vw,60px);border-top:1px solid var(--white);border-left:1px solid var(--white)}
.hero__corner--br{bottom:clamp(60px,10vh,100px);right:clamp(20px,5vw,60px);border-bottom:1px solid var(--white);border-right:1px solid var(--white)}

/* ---- Marquee Ticker ---- */
.ticker{width:100%;overflow:hidden;border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:18px 0;background:var(--black)}
.ticker__track{display:flex;gap:0;white-space:nowrap;animation:tickerScroll 25s linear infinite;width:max-content;will-change:transform;transform:translateZ(0)}
.ticker__item{font-family:var(--ff-display);font-size:clamp(1.1rem,3vw,1.8rem);letter-spacing:.12em;color:var(--sub);padding:0 24px}
.ticker__sep{color:var(--red);font-size:.8rem;padding:0 8px;display:inline-flex;align-items:center}
@keyframes tickerScroll{0%{transform:translate3d(0,0,0)}100%{transform:translate3d(-50%,0,0)}}

/* ---- Section Base ---- */
.section{padding:clamp(80px,12vw,160px) clamp(20px,5vw,48px);max-width:1240px;margin:0 auto}

.section__head{margin-bottom:clamp(48px,7vw,88px)}
.section__label{display:flex;align-items:center;gap:12px;margin-bottom:16px}
.section__num{font-family:var(--ff-mono);font-size:.7rem;letter-spacing:.15em;color:var(--red)}
.section__dash{width:24px;height:1px;background:var(--border2)}
.section__tag{font-size:.7rem;font-weight:600;letter-spacing:.15em;text-transform:uppercase;color:var(--muted)}
.section__title{font-family:var(--ff-display);font-size:clamp(2.6rem,6vw,5rem);line-height:1;letter-spacing:.04em}
.section__title em{font-style:normal;color:var(--red);-webkit-text-stroke:1px var(--red);-webkit-text-fill-color:transparent}

/* ---- Portfolio / Reel ---- */
.reel{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}

.reel__card{position:relative;border-radius:10px;overflow:hidden;background:var(--card);border:1px solid var(--border);transition:transform .55s var(--ease),border-color .4s,box-shadow .4s}
.reel__card:hover{transform:translateY(-6px) scale(1.01);border-color:var(--red);box-shadow:0 24px 64px rgba(0,0,0,.6),0 0 0 1px var(--red),0 0 48px var(--red-g)}

.reel__thumb{position:relative;aspect-ratio:9/16;overflow:hidden}
.reel__thumb img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease),filter .5s}
.reel__card:hover .reel__thumb img{transform:scale(1.06);filter:brightness(.55) saturate(1.2)}

.reel__overlay{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;opacity:0;transition:opacity .4s}
.reel__card:hover .reel__overlay{opacity:1}

.reel__play{width:56px;height:56px;border-radius:50%;background:var(--red);display:flex;align-items:center;justify-content:center;box-shadow:0 4px 24px var(--red-g2);transform:scale(.7);transition:transform .5s var(--ease)}
.reel__card:hover .reel__play{transform:scale(1)}
.reel__play svg{width:20px;height:20px;color:var(--white);margin-left:2px}

.reel__watch{font-size:.7rem;font-weight:600;letter-spacing:.15em;text-transform:uppercase;color:var(--white)}

.reel__meta{padding:14px 16px;display:flex;align-items:center;gap:8px}
.reel__label{font-size:.7rem;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--dim)}
.reel__dot{font-size:4px;color:var(--border2)}

/* ---- Modal ---- */
.modal{position:fixed;inset:0;z-index:10000;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .4s var(--ease)}
.modal.open{opacity:1;pointer-events:all}
.modal__backdrop{position:absolute;inset:0;background:rgba(0,0,0,.92);backdrop-filter:blur(12px)}
.modal__shell{position:relative;z-index:1;width:min(380px,88vw);transform:scale(.88) translateY(24px);transition:transform .6s var(--ease)}
.modal.open .modal__shell{transform:scale(1) translateY(0)}
.modal__close{position:absolute;top:-52px;right:0;width:40px;height:40px;display:flex;align-items:center;justify-content:center;color:var(--sub);transition:color .3s,transform .4s var(--ease)}
.modal__close svg{width:22px;height:22px}
.modal__close:hover{color:var(--white);transform:rotate(90deg)}
.modal__frame{aspect-ratio:9/16;border-radius:14px;overflow:hidden;background:var(--card);box-shadow:0 40px 100px rgba(0,0,0,.7),0 0 60px var(--red-g)}
.modal__frame iframe{width:100%;height:100%;border:0}

/* ---- Clients ---- */
.clients{display:flex;flex-direction:column;gap:0;margin-bottom:56px;border-top:1px solid var(--border)}

.clients__item{display:flex;align-items:center;justify-content:space-between;padding:20px clamp(12px,3vw,32px);border-bottom:1px solid var(--border);transition:background .35s,padding-left .4s var(--ease)}
.clients__item:hover{background:var(--card);padding-left:clamp(20px,4vw,44px)}

.clients__item--highlight{border-left:3px solid var(--red);background:linear-gradient(90deg,rgba(230,57,70,.04),transparent 40%)}
.clients__item--highlight:hover{background:linear-gradient(90deg,rgba(230,57,70,.08),transparent 40%)}

.clients__row{display:flex;align-items:center;gap:16px}
.clients__name{font-size:clamp(.95rem,1.8vw,1.15rem);font-weight:600;letter-spacing:.01em;transition:color .3s}
.clients__item:hover .clients__name{color:var(--white)}

.clients__icons{display:flex;align-items:center;gap:8px}
.clients__platform{font-family:var(--ff-mono);font-size:.6rem;font-weight:700;letter-spacing:.05em;color:var(--muted);padding:3px 8px;border:1px solid var(--border);border-radius:3px;transition:border-color .3s,color .3s}
.clients__item:hover .clients__platform{border-color:#E1306C;color:#E1306C} /* Default hover (Instagram pink) */
.clients__item:hover .clients__platform--yt,
.clients__platform--yt:hover{border-color:#FF0000;color:#FF0000} /* Specific hover (YouTube red) */
.clients__star{color:var(--red);font-size:.75rem}

.clients__arrow{width:14px;height:14px;color:var(--white);transition:color .3s,transform .4s var(--ease);flex-shrink:0}
.clients__arrow-link{display:inline-flex;align-items:center;flex-shrink:0}
.clients__item:hover .clients__arrow{color:var(--red);transform:translate(4px,-4px)}

/* Featured */
.featured{padding-top:8px}
.featured__heading{font-family:var(--ff-mono);font-size:.7rem;letter-spacing:.15em;text-transform:uppercase;color:var(--muted);margin-bottom:20px}
.featured__row{display:flex;flex-direction:column;gap:0}
.featured__link{display:flex;align-items:center;justify-content:space-between;padding:16px 0;border-bottom:1px solid var(--border);font-size:.95rem;font-weight:500;color:var(--sub);transition:color .3s,padding-left .4s var(--ease)}
.featured__link:hover{color:var(--white);padding-left:12px}
.featured__cta{display:inline-flex;align-items:center;gap:6px;font-size:.75rem;color:var(--red);font-weight:600;letter-spacing:.04em;white-space:nowrap}

/* ---- About ---- */
.about{display:grid;grid-template-columns:1.6fr 1fr;gap:clamp(40px,6vw,80px);align-items:start}
.about__body p{color:var(--sub);font-size:1.02rem;line-height:1.8;margin-bottom:20px}
.about__body p:last-child{margin-bottom:0}
.about__lead{font-size:1.1rem !important;color:var(--text) !important}
.about__body strong{color:var(--white);font-weight:600}

.about__metrics{display:flex;flex-direction:column;gap:36px;padding-top:4px}
.about__metric{padding-left:20px;border-left:2px solid var(--red);display:flex;flex-direction:column;gap:2px}
.about__metric-val{font-family:var(--ff-display);font-size:3.2rem;line-height:1;color:var(--white)}
.about__metric-plus{font-family:var(--ff-display);font-size:2rem;color:var(--red)}
.about__metric-lbl{font-size:.75rem;letter-spacing:.1em;text-transform:uppercase;color:var(--dim);font-weight:500}

/* ---- CTA Block ---- */
.cta-block{position:relative;text-align:center;padding:clamp(64px,10vw,120px) clamp(24px,5vw,64px);background:var(--card);border:1px solid var(--border);border-radius:16px;overflow:hidden}

.cta-block__mesh{position:absolute;inset:0;pointer-events:none;overflow:hidden}
.cta-block__orb{position:absolute;border-radius:50%;filter:blur(100px);opacity:.25}
.cta-block__orb--1{width:350px;height:350px;background:var(--red);top:-20%;right:-10%;animation:floatOrb1 10s ease-in-out infinite}
.cta-block__orb--2{width:280px;height:280px;background:var(--green);bottom:-20%;left:-5%;animation:floatOrb2 13s ease-in-out infinite}

.cta-block__eyebrow{display:block;font-family:var(--ff-mono);font-size:.65rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin-bottom:24px;position:relative;z-index:1}
.cta-block__title{font-family:var(--ff-display);font-size:clamp(2.6rem,6vw,5.5rem);line-height:1;letter-spacing:.03em;margin-bottom:20px;position:relative;z-index:1}
.cta-block__q{color:var(--red)}
.cta-block__desc{font-size:1.02rem;color:var(--sub);max-width:400px;margin:0 auto 44px;line-height:1.7;position:relative;z-index:1}

.cta-block__links{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px;max-width:640px;margin:0 auto;position:relative;z-index:1}
.cta-block__link{display:flex;flex-direction:column;gap:4px;padding:18px 20px;border:1px solid var(--border);border-radius:8px;text-align:left;transition:background .4s var(--ease), border-color .4s var(--ease), transform .4s var(--ease)}
.cta-block__link:hover{border-color:var(--red);background:var(--red-g);transform:translateY(-2px)}
.cta-block__link-label{font-size:.65rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.cta-block__link-val{font-size:.9rem;font-weight:500;color:var(--text)}

/* ---- Footer ---- */
.footer{border-top:1px solid var(--border);padding:28px clamp(20px,5vw,48px)}
.footer__inner{max-width:1240px;margin:0 auto;display:flex;align-items:center;justify-content:center;gap:12px;font-size:.72rem;color:var(--muted);letter-spacing:.06em}
.footer__sep{opacity:.3}

/* ---- Selection ---- */
::selection{background:var(--red);color:var(--white)}

/* ---- Scrollbar ---- */
::-webkit-scrollbar{width:5px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:var(--border2);border-radius:4px}
::-webkit-scrollbar-thumb:hover{background:var(--muted)}

/* ---- Responsive ---- */
@media(max-width:1024px){
  .reel{grid-template-columns:repeat(2,1fr)}
  .hero__mesh-orb{filter:blur(80px);opacity:.2}
}

@media(max-width:768px){
  .nav__links{display:none}
  .nav__burger{display:flex}
  .reel{grid-template-columns:repeat(2,1fr);gap:14px}
  .about{grid-template-columns:1fr}
  .about__metrics{flex-direction:row;gap:28px;flex-wrap:wrap}
  .section{padding:clamp(64px,10vw,100px) clamp(16px,4vw,32px)}
  .section__title{font-size:clamp(2.2rem,8vw,3.5rem)}
  .hero__mesh-orb{width:300px;height:300px}
}

@media(max-width:520px){
  .reel{grid-template-columns:repeat(2,1fr);gap:14px}
  .reel__meta{padding:12px 10px}
  .cta-block__links{grid-template-columns:1fr}
  .hero__corner{display:none}
  .hero{padding-top:calc(var(--nav-h) + 20px)}
  .hero__sub{flex-direction:column;gap:12px}
  .hero__sub-line{width:30px;height:2px}
  .clients__item{padding:16px 16px}
  .clients__row{flex-wrap:wrap;gap:8px}
  .clients__arrow{width:12px;height:12px}
}