/* =========================================================
   Escopo Filmes — design tokens
   Verde profundo da marca + laranja de destaque único.
   Tipografia condensada/bold ecoando os cortes retos do logo.
========================================================= */

:root{
  --bg:        #0a3530;
  --bg-deep:   #062420;
  --orange:    #ff5a1f;
  --cream:     #f4ede1;
  --line:      rgba(244,237,225,0.14);

  --font-display: "Archivo Black", "Archivo", sans-serif;
  --font-body:    "Archivo", sans-serif;

  --maxw: 1180px;
}

*{ margin:0; padding:0; box-sizing:border-box; }

html{ scroll-behavior:smooth; }

body{
  background:var(--bg);
  color:var(--cream);
  font-family:var(--font-body);
  line-height:1.5;
  overflow-x:hidden;
}

a{ color:inherit; text-decoration:none; }

img{ display:block; max-width:100%; }

/* subtle film-grain texture overlay */
.grain{
  position:fixed; inset:0; pointer-events:none; z-index:50;
  opacity:0.035; mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

@media (prefers-reduced-motion: reduce){
  html{ scroll-behavior:auto; }
  *{ animation-duration:0.001ms !important; transition-duration:0.001ms !important; }
}

:focus-visible{
  outline:2px solid var(--orange);
  outline-offset:3px;
}

/* ---------- topbar ---------- */

.topbar{
  position:sticky; top:0; z-index:40;
  background:rgba(10,53,48,0.92);
  backdrop-filter:blur(6px);
  border-bottom:1px solid var(--line);
}

.topbar__inner{
  max-width:var(--maxw);
  margin:0 auto;
  padding:14px 24px;
  display:flex;
  align-items:center;
  justify-content:space-between;
}

.topbar__logo{
  height:30px;
  width:auto;
  object-fit:contain;
}

.topbar__nav{
  display:flex;
  align-items:center;
  gap:28px;
  font-size:0.95rem;
  font-weight:500;
}

.topbar__nav a{ opacity:0.85; transition:opacity 0.2s; }
.topbar__nav a:hover{ opacity:1; }

.topbar__cta{
  background:var(--orange);
  color:var(--bg-deep);
  font-weight:700;
  padding:9px 18px;
  border-radius:2px;
  opacity:1 !important;
}
.topbar__cta:hover{ filter:brightness(1.08); }

/* ---------- hero ---------- */

.hero{
  position:relative;
  max-width:var(--maxw);
  margin:0 auto;
  padding:120px 24px 140px;
}

.hero__bars{
  position:absolute;
  top:60px; right:24px;
  display:flex;
  flex-direction:column;
  gap:10px;
  z-index:0;
}
.hero__bars span{
  display:block;
  height:22px;
  background:var(--orange);
  animation:slide-in 0.7s cubic-bezier(.2,.8,.2,1) backwards;
}
.hero__bars span:nth-child(1){ width:120px; animation-delay:0.05s; }
.hero__bars span:nth-child(2){ width:78px;  animation-delay:0.18s; }
.hero__bars span:nth-child(3){ width:50px;  animation-delay:0.31s; }

@keyframes slide-in{
  from{ transform:translateX(40px); opacity:0; }
  to{ transform:translateX(0); opacity:1; }
}

.hero__title{
  position:relative;
  font-family:var(--font-display);
  font-size:clamp(2.6rem, 7vw, 5.2rem);
  line-height:1.04;
  letter-spacing:-0.01em;
  max-width:780px;
  animation:rise 0.6s ease backwards;
  animation-delay:0.1s;
}

.hero__sub{
  margin-top:28px;
  max-width:480px;
  font-size:1.08rem;
  color:rgba(244,237,225,0.78);
  animation:rise 0.6s ease backwards;
  animation-delay:0.25s;
}

.hero__link{
  display:inline-block;
  margin-top:40px;
  font-weight:700;
  font-size:1.05rem;
  color:var(--orange);
  border-bottom:2px solid var(--orange);
  padding-bottom:4px;
  animation:rise 0.6s ease backwards;
  animation-delay:0.35s;
  transition:letter-spacing 0.25s;
}
.hero__link:hover{ letter-spacing:0.02em; }

@keyframes rise{
  from{ transform:translateY(16px); opacity:0; }
  to{ transform:translateY(0); opacity:1; }
}

/* ---------- serviços ---------- */

.servicos{
  max-width:var(--maxw);
  margin:0 auto;
  padding:0 24px 120px;
}

.servicos__title{
  font-family:var(--font-display);
  font-size:clamp(1.6rem, 3.4vw, 2.2rem);
  margin-bottom:48px;
}

.servicos__list{
  list-style:none;
  border-top:1px solid var(--line);
}

.servicos__item{
  position:relative;
  display:grid;
  grid-template-columns:28px 1fr 1.4fr;
  gap:28px;
  align-items:start;
  padding:28px 0;
  border-bottom:1px solid var(--line);
  transition:padding-left 0.25s;
}

.servicos__item:hover{ padding-left:10px; }

.servicos__bar{
  width:14px; height:14px;
  margin-top:6px;
  background:var(--orange);
  flex-shrink:0;
}

.servicos__item h3{
  font-family:var(--font-display);
  font-size:1.25rem;
  font-weight:400;
}

.servicos__item p{
  color:rgba(244,237,225,0.7);
  font-size:1rem;
  max-width:480px;
}

@media (max-width:640px){
  .servicos__item{
    grid-template-columns:14px 1fr;
  }
  .servicos__item h3{ grid-column:2; }
  .servicos__item p{ grid-column:2; margin-top:8px; }
}

/* ---------- trabalhos ---------- */

.trabalhos{
  max-width:var(--maxw);
  margin:0 auto;
  padding:0 24px 130px;
}

.trabalhos__title{
  font-family:var(--font-display);
  font-size:clamp(1.6rem, 3.4vw, 2.2rem);
  margin-bottom:48px;
}

.trabalhos__grid{
  display:grid;
  grid-template-columns:repeat(2, 1fr);
  gap:24px;
}

@media (max-width:720px){
  .trabalhos__grid{ grid-template-columns:1fr; }
}

.card{
  position:relative;
  display:block;
}

.card__frame{
  position:relative;
  aspect-ratio:16/10;
  background:
    linear-gradient(135deg, rgba(255,90,31,0.16), transparent 60%),
    var(--bg-deep);
  border:1px solid var(--line);
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
  transition:border-color 0.25s;
}

.card:hover .card__frame{ border-color:var(--orange); }

.card__play{
  width:0; height:0;
  border-style:solid;
  border-width:13px 0 13px 20px;
  border-color:transparent transparent transparent rgba(244,237,225,0.55);
  transition:border-color 0.25s, transform 0.25s;
}
.card:hover .card__play{
  border-color:transparent transparent transparent var(--orange);
  transform:scale(1.12);
}

.card__tag{
  display:inline-block;
  margin-top:16px;
  font-size:0.8rem;
  font-weight:700;
  letter-spacing:0.04em;
  text-transform:uppercase;
  color:var(--orange);
}

.card__name{
  font-family:var(--font-display);
  font-size:1.15rem;
  font-weight:400;
  margin-top:4px;
  color:rgba(244,237,225,0.55);
}

/* ---------- contato ---------- */

.contato{
  max-width:var(--maxw);
  margin:0 auto;
  padding:0 24px 140px;
}

.contato__title{
  font-family:var(--font-display);
  font-size:clamp(2rem, 5.5vw, 3.4rem);
  line-height:1.08;
  margin-bottom:48px;
}

.contato__links{
  display:flex;
  flex-wrap:wrap;
  gap:18px 40px;
}

.contato__link{
  font-size:clamp(1.1rem, 2.4vw, 1.5rem);
  font-weight:700;
  border-bottom:2px solid transparent;
  transition:border-color 0.25s, color 0.25s;
}

.contato__link:hover{
  color:var(--orange);
  border-color:var(--orange);
}

/* ---------- footer ---------- */

.footer{
  border-top:1px solid var(--line);
  padding:32px 24px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  max-width:var(--maxw);
  margin:0 auto;
  gap:16px;
  flex-wrap:wrap;
}

.footer__logo{
  height:40px;
  opacity:0.85;
}

.footer p{
  font-size:0.85rem;
  color:rgba(244,237,225,0.55);
}
