/* ============================================================
   1880 BRASA & UMI — CINEMATIC STYLES
   ============================================================ */

:root{
  --bg:        #0a0807;
  --bg-2:      #110d0b;
  --carvao:    #1a1411;
  --carvao-2:  #221a16;
  --gold:      #c9a14a;
  --gold-2:    #e3c27a;
  --gold-deep: #8a6a2a;
  --vinho:     #3a1418;
  --cream:     #f4ecdf;
  --white:     #ffffff;
  --muted:     #a89580;
  --line:      rgba(201,161,74,.18);

  --serif:  "DM Serif Display", "Fraunces", Georgia, serif;
  --serif2: "Fraunces", "DM Serif Display", Georgia, serif;
  --sans:   "Inter", system-ui, -apple-system, "Segoe UI", sans-serif;
  --display:"Bebas Neue", "Inter", sans-serif;

  --ease: cubic-bezier(.6,.05,.01,.99);
  --ease-out: cubic-bezier(.2,.7,.2,1);

  --max: 1440px;
  --pad: clamp(1.25rem, 4vw, 4rem);
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{background:var(--bg);color:var(--cream);font-family:var(--sans);font-weight:400;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;overflow-x:hidden}
html{scroll-behavior:smooth}
body{line-height:1.65;font-size:16px;letter-spacing:0;min-height:100vh;font-feature-settings:"cv11","ss01","ss03"}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;border:0;background:none;color:inherit;cursor:pointer}
em{font-family:var(--serif2);font-style:italic;font-weight:400}

::selection{background:var(--gold);color:var(--bg)}

/* ============== TYPE OVERRIDES (DM Serif Display has only 400) ============== */
.h2,
.hero__title,
.exp-card h3,
.esp-box h3,
.curso-pro__content h3,
.cinematic__quote p,
.historia__paragraphs strong{ font-weight:400 }

/* Bebas Neue on tags / chips / labels / micro-uppercase */
.eyebrow,
.hero__eyebrow,
.loader__year,
.footer__year,
.nav__links a,
.nav__cta,
.btn,
.mobile-menu__cta,
.curso-pro__role,
.curso-pro__chip,
.curso-pro__meta li,
.curso-pro__learn-title,
.curso-pro__btn,
.curso-pro__chef > span,
.esp-box__tag,
.esp-box__more,
.local__row span,
.local__map-caption,
.reserva__info span,
.footer__cols span,
.footer__bottom small,
.historia__caption,
.historia__stats small,
.cinematic__quote cite,
.hero__scroll{
  font-family: var(--display);
  font-weight: 400;
  letter-spacing: .22em;
}

/* Bebas is already condensed/tall, so reduce some letter-spacing to keep elegance */
.curso-pro__chip,
.esp-box__tag,
.curso-pro__chef > span,
.local__row span,
.reserva__info span,
.footer__cols span,
.historia__stats small{ letter-spacing:.28em }

/* Bebas in buttons looks better a bit smaller-ish on its tall axis */
.btn,
.nav__cta,
.curso-pro__btn,
.mobile-menu__cta{ letter-spacing:.32em; font-size:.88rem }
.btn--lg{ font-size:.95rem }

/* ============== LOADER ============== */
.loader{
  position:fixed;inset:0;background:var(--bg);z-index:9999;
  display:flex;align-items:center;justify-content:center;
  transition:opacity .8s var(--ease), visibility .8s var(--ease);
}
.loader.is-done{opacity:0;visibility:hidden;pointer-events:none}
.loader__inner{text-align:center}
.loader__brand{display:flex;flex-direction:column;gap:.6rem;margin-bottom:2.5rem}
.loader__year{font-family:var(--sans);letter-spacing:.5em;font-size:.7rem;color:var(--gold);text-transform:uppercase}
.loader__name{font-family:var(--serif);font-size:clamp(2rem,5vw,3.5rem);color:var(--cream)}
.loader__name em{color:var(--gold)}
.loader__bar{width:min(260px,40vw);height:1px;background:rgba(255,255,255,.08);margin:0 auto;overflow:hidden}
.loader__bar span{display:block;width:0;height:100%;background:var(--gold);animation:loadbar 1.6s var(--ease) forwards}
@keyframes loadbar{to{width:100%}}

/* ============== GRAIN ============== */
.grain{position:fixed;inset:0;pointer-events:none;z-index:8000;opacity:.05;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.6'/%3E%3C/svg%3E");
  animation:grainShift 8s steps(8) infinite}
@keyframes grainShift{0%{transform:translate(0,0)}25%{transform:translate(-2%,1%)}50%{transform:translate(1%,-2%)}75%{transform:translate(-1%,-1%)}100%{transform:translate(0,0)}}

/* ============== NAV ============== */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:200;
  display:flex;align-items:center;justify-content:space-between;
  padding: 1.25rem var(--pad);
  transition:background .5s var(--ease), padding .5s var(--ease), border-color .5s;
  border-bottom:1px solid transparent;
}
.nav.is-scrolled{background:rgba(10,8,7,.78);backdrop-filter:blur(18px) saturate(140%);-webkit-backdrop-filter:blur(18px) saturate(140%);padding:.85rem var(--pad);border-bottom-color:var(--line)}
.nav__logo{display:flex;flex-direction:column;line-height:1;gap:.15rem}
.nav__logo-mark{font-family:var(--serif);font-size:1.35rem;color:var(--cream);letter-spacing:.04em}
.nav__logo-sub{font-family:var(--serif2);font-style:italic;font-size:.75rem;color:var(--gold);letter-spacing:.2em;text-transform:uppercase}
.nav__logo-sub em{color:var(--gold-2)}
.nav__links{display:flex;gap:2.5rem}
.nav__links a{position:relative;font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;color:var(--cream);opacity:.78;transition:opacity .3s}
.nav__links a:hover{opacity:1}
.nav__links a::after{content:"";position:absolute;left:0;bottom:-6px;width:0;height:1px;background:var(--gold);transition:width .5s var(--ease)}
.nav__links a:hover::after{width:100%}
.nav__cta{
  display:inline-flex;align-items:center;gap:.65rem;
  padding:.75rem 1.4rem;border:1px solid var(--gold);
  font-size:.72rem;letter-spacing:.25em;text-transform:uppercase;color:var(--gold);
  background:transparent;transition:all .5s var(--ease);position:relative;overflow:hidden;
}
.nav__cta::before{content:"";position:absolute;inset:0;background:var(--gold);transform:translateY(101%);transition:transform .5s var(--ease);z-index:-1}
.nav__cta:hover{color:var(--bg);border-color:var(--gold)}
.nav__cta:hover::before{transform:translateY(0)}
.nav__cta svg{width:14px;height:14px}
.nav__burger{display:none;width:34px;height:34px;flex-direction:column;gap:7px;align-items:center;justify-content:center}
.nav__burger span{width:22px;height:1px;background:var(--cream);transition:transform .4s,opacity .3s}
.nav__burger.is-open span:nth-child(1){transform:translateY(4px) rotate(45deg)}
.nav__burger.is-open span:nth-child(2){transform:translateY(-4px) rotate(-45deg)}

.mobile-menu{position:fixed;inset:0;background:var(--bg);z-index:150;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2.5rem;opacity:0;visibility:hidden;transition:opacity .5s var(--ease),visibility .5s}
.mobile-menu.is-open{opacity:1;visibility:visible}
.mobile-menu ul{list-style:none;display:flex;flex-direction:column;gap:1.5rem;text-align:center}
.mobile-menu li a{font-family:var(--serif);font-size:2rem;color:var(--cream)}
.mobile-menu__cta{margin-top:1rem;padding:1rem 2rem;border:1px solid var(--gold);color:var(--gold);letter-spacing:.2em;text-transform:uppercase;font-size:.75rem}

/* ============== TYPOGRAPHY ============== */
.h2{
  font-family:var(--serif);
  font-weight:500;
  font-size:clamp(2.2rem, 5.4vw, 5rem);
  line-height:1.02;
  letter-spacing:-.01em;
  color:var(--cream);
}
.h2 em{color:var(--gold);font-weight:400}
.eyebrow{display:inline-block;font-size:.72rem;letter-spacing:.35em;text-transform:uppercase;color:var(--gold);margin-bottom:1.5rem}
.section-head{max-width:var(--max);margin:0 auto;padding: 0 var(--pad);text-align:center;margin-bottom:5rem}
.section-sub{font-family:var(--sans);font-weight:400;font-size:1.05rem;line-height:1.65;color:var(--muted);max-width:600px;margin:1.5rem auto 0}

/* ============== BUTTONS ============== */
.btn{
  display:inline-flex;align-items:center;gap:.8rem;
  padding:1.1rem 2.2rem;
  font-size:.78rem;letter-spacing:.28em;text-transform:uppercase;
  position:relative;overflow:hidden;transition:color .5s var(--ease);
  border:1px solid currentColor;
}
.btn--lg{padding:1.3rem 2.8rem;font-size:.8rem}
.btn--gold{color:var(--bg);background:var(--gold);border-color:var(--gold)}
.btn--gold::before{content:"";position:absolute;inset:0;background:var(--gold-2);transform:translateY(101%);transition:transform .5s var(--ease);z-index:0}
.btn--gold span{position:relative;z-index:1}
.btn--gold:hover::before{transform:translateY(0)}
.btn--ghost{color:var(--cream);border-color:rgba(244,236,223,.4)}
.btn--ghost::before{content:"";position:absolute;inset:0;background:var(--cream);transform:translateY(101%);transition:transform .5s var(--ease);z-index:0}
.btn--ghost span{position:relative;z-index:1;transition:color .5s var(--ease)}
.btn--ghost:hover::before{transform:translateY(0)}
.btn--ghost:hover span{color:var(--bg)}

/* ============== HERO ============== */
.hero{
  position:relative;min-height:100vh;min-height:100svh;
  overflow:hidden;display:flex;align-items:center;
  padding: 8rem var(--pad) 6rem;
}
.hero__media{position:absolute;inset:0;z-index:0;overflow:hidden;will-change:transform}
.hero__img{
  width:100%;height:100%;object-fit:cover;
  transform:scale(1.18);
  filter:saturate(.85) contrast(1.08) brightness(.48);
  will-change:transform, filter;
}
.hero__veil{
  position:absolute;inset:0;
  background:
    radial-gradient(110% 80% at 50% 45%, rgba(10,8,7,.45) 0%, rgba(10,8,7,.75) 55%, rgba(10,8,7,.98) 100%),
    linear-gradient(to bottom, rgba(10,8,7,.7) 0%, rgba(10,8,7,.3) 35%, rgba(10,8,7,.55) 70%, rgba(10,8,7,.95) 100%);
}
.hero__content{position:relative;z-index:2;max-width:var(--max);margin:0 auto;width:100%;text-align:center;padding-top:4rem}
.hero__eyebrow{display:block;font-size:.72rem;letter-spacing:.5em;text-transform:uppercase;color:var(--gold);margin-bottom:2.2rem}
.hero__title{
  font-family:var(--serif);
  font-weight:500;
  font-size:clamp(2.8rem, 8vw, 7.4rem);
  line-height:.98;letter-spacing:-.02em;
  color:var(--cream);
}
.hero__title .line{display:block;overflow:hidden;padding:.04em 0}
.hero__title em{color:var(--gold);font-weight:400}
.hero__lede{
  font-family:var(--sans);font-weight:400;
  font-size:clamp(1.05rem, 1.4vw, 1.25rem);
  max-width:620px;margin:2.4rem auto 0;color:var(--cream);opacity:.92;line-height:1.6;
}
.hero__actions{display:flex;gap:1rem;justify-content:center;margin-top:3rem;flex-wrap:wrap}
.hero__scroll{position:absolute;bottom:5.5rem;right:var(--pad);z-index:2;display:flex;flex-direction:column;align-items:flex-end;gap:.8rem;font-size:.6rem;letter-spacing:.35em;text-transform:uppercase;color:var(--muted);pointer-events:none}
.hero__scroll > span{writing-mode:vertical-rl;transform:rotate(180deg);white-space:nowrap}
.hero__scroll-line{width:1px;height:54px;background:linear-gradient(to bottom, var(--gold), transparent);position:relative;overflow:hidden;margin-right:.2rem}
.hero__scroll-line::after{content:"";position:absolute;top:-100%;left:0;width:100%;height:50%;background:var(--gold-2);animation:scrollLine 2.4s var(--ease) infinite}
@keyframes scrollLine{to{top:100%}}
.hero__marquee{position:absolute;left:0;right:0;bottom:0;z-index:3;border-top:1px solid var(--line);background:rgba(10,8,7,.5);backdrop-filter:blur(8px);overflow:hidden;padding:1rem 0}
.marquee{display:flex;gap:2.5rem;white-space:nowrap;animation:marquee 40s linear infinite;width:max-content}
.marquee span{font-family:var(--serif2);font-style:italic;font-size:1rem;color:var(--cream);letter-spacing:.05em}
.marquee i{color:var(--gold);font-style:normal}
@keyframes marquee{to{transform:translateX(-50%)}}

/* ============== HISTORIA ============== */
.historia{padding: 10rem var(--pad);max-width:var(--max);margin:0 auto;position:relative}
.historia__grid{display:grid;grid-template-columns:1.05fr 1fr;gap:clamp(2rem, 6vw, 6rem);align-items:center}
.historia__media{position:relative}
.parallax-img{position:relative;overflow:hidden;aspect-ratio:4/5;border-radius:2px}
.parallax-img img{width:100%;height:115%;object-fit:cover;transform:translateY(-7%);filter:saturate(.9) contrast(1.05)}
.historia__caption{display:block;margin-top:1.2rem;font-size:.7rem;letter-spacing:.35em;text-transform:uppercase;color:var(--gold)}
.historia__text .eyebrow{display:block}
.historia__paragraphs{margin-top:2.4rem;display:flex;flex-direction:column;gap:1.4rem}
.historia__paragraphs p{font-family:var(--sans);font-size:1.05rem;line-height:1.7;color:var(--cream);opacity:.88;font-weight:400}
.historia__paragraphs strong{color:var(--gold);font-weight:500}
.historia__paragraphs em{color:var(--gold-2);font-family:var(--serif2);font-style:italic;font-size:1.08em}
.historia__badges{
  display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;
  margin-top:3rem;
}
.historia__badges span{
  display:flex;align-items:center;justify-content:center;text-align:center;
  font-family:var(--display);font-weight:400;
  font-size:.9rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--cream);
  padding:1.1rem 1.2rem;
  border:1px solid var(--line);
  transition:border-color .5s var(--ease), color .3s, background .4s;
}
.historia__badges span:hover{border-color:var(--gold);color:var(--gold);background:rgba(201,161,74,.04)}

.historia__overlay{
  position:absolute;left:1.6rem;right:1.6rem;bottom:1.6rem;z-index:2;
  display:flex;flex-direction:column;gap:.5rem;
  pointer-events:none;
}
.historia__overlay-title{
  font-family:var(--display);font-weight:400;
  font-size:clamp(1.6rem, 3vw, 2.4rem);letter-spacing:.06em;
  color:var(--cream);line-height:1;text-transform:uppercase;
  text-shadow:0 4px 20px rgba(0,0,0,.6);
}
.historia__overlay-sub{
  font-family:var(--display);font-weight:400;
  font-size:.78rem;letter-spacing:.32em;text-transform:uppercase;
  color:var(--gold);
}
.parallax-img{position:relative}
.parallax-img::after{
  content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(180deg, rgba(10,8,7,0) 40%, rgba(10,8,7,.7) 100%);
}

/* ============== ESPECIALIDADES (4 BOXES) ============== */
.especialidades{padding: 8rem var(--pad) 10rem;background:var(--bg-2);position:relative}
.esp-grid{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:1.8rem;justify-content:center}
.esp-box{position:relative;overflow:hidden;background:var(--carvao);border:1px solid var(--line);min-height:480px;display:flex;align-items:flex-end;transition:transform .7s var(--ease), border-color .5s}
.esp-box:hover{border-color:var(--gold);transform:translateY(-8px)}
.esp-box__media{position:absolute;inset:0;z-index:0;overflow:hidden}
.esp-box__media img{width:100%;height:100%;object-fit:cover;transition:transform 1.4s var(--ease);filter:saturate(.85) contrast(1.05) brightness(.7)}
.esp-box:hover .esp-box__media img{transform:scale(1.08);filter:saturate(1) contrast(1.1) brightness(.6)}
.esp-box__veil{position:absolute;inset:0;background:linear-gradient(180deg, rgba(10,8,7,.15) 0%, rgba(10,8,7,.55) 50%, rgba(10,8,7,.95) 100%);transition:opacity .5s}
.esp-box__body{position:relative;z-index:2;padding:2.2rem 1.8rem 2.2rem;width:100%;display:flex;flex-direction:column;gap:.7rem}
.esp-box__num{font-family:var(--serif);font-size:2.4rem;color:var(--gold);line-height:1;opacity:.85}
.esp-box__tag{font-size:.66rem;letter-spacing:.32em;text-transform:uppercase;color:var(--gold);margin-top:-.4rem}
.esp-box h3{font-family:var(--serif);font-weight:500;font-size:2rem;color:var(--cream);line-height:1.05;margin:.3rem 0}
.esp-box p{font-family:var(--sans);font-size:.98rem;line-height:1.65;color:var(--cream);opacity:.88;max-height:0;overflow:hidden;transition:max-height .7s var(--ease), margin .5s, opacity .5s;font-weight:400}
.esp-box:hover p{max-height:180px;margin-top:.5rem;opacity:.9}
.esp-box__more{font-size:.68rem;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);margin-top:.8rem;display:inline-block;transition:transform .5s var(--ease), color .3s}
.esp-box:hover .esp-box__more{color:var(--gold-2);transform:translateX(6px)}

/* ============== CINEMATIC FULLSCREEN ============== */
.cinematic{position:relative;height:90vh;min-height:560px;overflow:hidden;display:flex;align-items:center;justify-content:center}
.cinematic__img{position:absolute;inset:-10%;background-size:cover;background-position:center;will-change:transform;filter:saturate(.85) brightness(.5)}
.cinematic__overlay{position:absolute;inset:0;background:radial-gradient(60% 60% at 50% 50%, rgba(10,8,7,.3), rgba(10,8,7,.9))}
.cinematic__quote{position:relative;z-index:2;text-align:center;padding:0 var(--pad);max-width:900px}
.cinematic__quote p{font-family:var(--serif);font-weight:400;font-size:clamp(1.8rem, 4.5vw, 4rem);line-height:1.15;color:var(--cream);letter-spacing:-.01em}
.cinematic__quote p em{color:var(--gold)}
.cinematic__quote cite{display:block;margin-top:2.5rem;font-style:normal;font-size:.75rem;letter-spacing:.4em;text-transform:uppercase;color:var(--gold)}

/* ============== CURSOS (com professor) ============== */
.cursos{padding: 10rem var(--pad);max-width:var(--max);margin:0 auto;position:relative}
.cursos__list{display:flex;flex-direction:column;gap:6rem}
.curso-pro{
  position:relative;display:grid;
  grid-template-columns:80px 1.05fr 1.4fr;
  gap:3rem;align-items:center;
  padding:3rem 0;
  border-top:1px solid var(--line);
}
.curso-pro:last-child{border-bottom:1px solid var(--line)}
.curso-pro--reverse{grid-template-columns:80px 1.4fr 1.05fr}
.curso-pro--reverse .curso-pro__photo{order:3}
.curso-pro--reverse .curso-pro__content{order:2}
.curso-pro__num{
  font-family:var(--serif);font-style:italic;font-weight:300;
  font-size:5rem;line-height:1;color:var(--gold);opacity:.5;
  align-self:flex-start;padding-top:1rem;
}
.curso-pro__photo{position:relative;overflow:hidden;aspect-ratio:4/5;background:var(--carvao)}
.curso-pro__photo img{
  width:100%;height:100%;object-fit:cover;
  object-position:center 18%;
  transform:scale(1.02);
  transition:transform 1.6s var(--ease), filter .8s;
  filter:saturate(.88) contrast(1.05) brightness(.92);
  will-change:transform;
}
.curso-pro:hover .curso-pro__photo img{transform:scale(1.06);filter:saturate(1) contrast(1.1) brightness(1)}
.curso-pro__chip{
  position:absolute;top:1.2rem;left:1.2rem;z-index:2;
  font-size:.66rem;letter-spacing:.32em;text-transform:uppercase;color:var(--gold);
  background:rgba(10,8,7,.65);backdrop-filter:blur(10px);padding:.55rem 1rem;
  border:1px solid rgba(201,161,74,.25);
}
.curso-pro__content{display:flex;flex-direction:column;gap:1rem}
.curso-pro__role{font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);margin-bottom:.4rem}
.curso-pro__content h3{font-family:var(--serif);font-weight:500;font-size:clamp(1.8rem, 3vw, 2.6rem);color:var(--cream);line-height:1.05;letter-spacing:-.01em}
.curso-pro__lede{font-family:var(--serif2);font-style:italic;font-size:1.35rem;line-height:1.4;color:var(--gold-2);margin-top:.2rem}
.curso-pro__story{font-family:var(--sans);font-size:1.02rem;line-height:1.7;color:var(--cream);opacity:.86;max-width:580px;font-weight:400}
.curso-pro__story em{color:var(--gold);opacity:1;font-family:var(--serif2);font-style:italic;font-size:1.08em}
.curso-pro__meta{list-style:none;display:flex;flex-wrap:wrap;gap:1.4rem;margin-top:.6rem;padding-top:1.4rem;border-top:1px solid var(--line)}
.curso-pro__meta li{font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;color:var(--cream);opacity:.75;position:relative;padding-left:1rem}
.curso-pro__meta li::before{content:"";position:absolute;left:0;top:50%;width:6px;height:1px;background:var(--gold)}

.curso-pro__learn{margin-top:.8rem;padding-top:1.6rem;border-top:1px solid var(--line)}
.curso-pro__learn-title{display:block;font-size:.68rem;letter-spacing:.32em;text-transform:uppercase;color:var(--gold);margin-bottom:1rem}
.curso-pro__learn ul{list-style:none;display:grid;grid-template-columns:repeat(2,1fr);gap:.7rem 1.6rem}
.curso-pro__learn li{
  font-family:var(--sans);font-size:.92rem;color:var(--cream);opacity:.88;
  position:relative;padding-left:1.4rem;line-height:1.4;
}
.curso-pro__learn li::before{
  content:"";position:absolute;left:0;top:.55rem;
  width:10px;height:1px;background:var(--gold);
}
.curso-pro__learn li::after{
  content:"";position:absolute;left:4px;top:calc(.55rem - 2px);
  width:5px;height:5px;border:1px solid var(--gold);transform:rotate(45deg);background:var(--bg)
}

.curso-pro__chef{
  font-family:var(--sans);font-style:normal;
  font-size:.98rem;line-height:1.65;color:var(--muted);
  padding:1.3rem 0 .2rem;border-top:1px dashed rgba(201,161,74,.18);
  margin-top:.4rem;font-weight:400;
}
.curso-pro__chef span{
  font-family:var(--sans);font-style:normal;
  font-size:.66rem;letter-spacing:.32em;text-transform:uppercase;color:var(--gold);
  margin-right:.4rem;
}
.curso-pro__chef em{color:var(--cream);font-family:var(--serif2)}
.curso-pro__foot{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;margin-top:1.6rem;flex-wrap:wrap}
.curso-pro__price{font-family:var(--serif);font-size:2.4rem;color:var(--gold);line-height:1;letter-spacing:-.01em}
.curso-pro__price small{font-size:1rem;color:var(--gold-deep)}
.curso-pro__btn{
  display:inline-flex;align-items:center;gap:.8rem;
  font-size:.74rem;letter-spacing:.28em;text-transform:uppercase;color:var(--bg);
  padding:1.05rem 1.8rem;background:var(--gold);border:1px solid var(--gold);
  position:relative;overflow:hidden;transition:color .5s var(--ease);
}
.curso-pro__btn::before{content:"";position:absolute;inset:0;background:var(--cream);transform:translateY(101%);transition:transform .5s var(--ease)}
.curso-pro__btn span,.curso-pro__btn svg{position:relative;z-index:1}
.curso-pro__btn svg{width:14px;height:14px;transition:transform .5s var(--ease)}
.curso-pro__btn:hover::before{transform:translateY(0)}
.curso-pro__btn:hover svg{transform:translateX(4px)}
.curso-pro--featured .curso-pro__num{opacity:.85}
.curso-pro--featured .curso-pro__photo::after{content:"";position:absolute;inset:0;border:1px solid var(--gold);pointer-events:none;z-index:2;opacity:.5}

/* ============== LOCALIZAÇÃO ============== */
.local{padding: 10rem var(--pad);max-width:var(--max);margin:0 auto;position:relative}
.local__grid{display:grid;grid-template-columns:1fr 1.05fr;gap:clamp(2.5rem, 6vw, 6rem);align-items:center}
.local__text{display:flex;flex-direction:column;gap:1.8rem}
.local__text .eyebrow{margin-bottom:0}
.local__text .h2{margin-top:-.4rem}
.local__lede{font-family:var(--sans);font-weight:400;font-size:1.05rem;line-height:1.7;color:var(--cream);opacity:.9;max-width:540px}
.local__info{display:grid;grid-template-columns:1fr 1fr;gap:1.6rem 2.4rem;margin-top:.4rem;border-top:1px solid var(--line);padding-top:2rem}
.local__row{display:flex;flex-direction:column;gap:.5rem}
.local__row span{font-size:.66rem;letter-spacing:.32em;text-transform:uppercase;color:var(--gold)}
.local__row p{font-family:var(--sans);font-size:.98rem;line-height:1.5;color:var(--cream);opacity:.92;font-weight:400}
.local__actions{display:flex;gap:1rem;margin-top:1.2rem;flex-wrap:wrap}

.local__map{position:relative}
.local__map-frame{
  position:relative;overflow:hidden;
  aspect-ratio:4/5;background:var(--carvao);
  border:1px solid var(--line);
  box-shadow: 0 30px 80px rgba(0,0,0,.45);
}
.local__map-frame iframe{
  position:absolute;inset:0;width:100%;height:100%;
  filter:grayscale(.45) contrast(1.05) brightness(.85) saturate(.9);
  transition:filter .6s var(--ease);
}
.local__map-frame:hover iframe{filter:grayscale(0) contrast(1) brightness(1) saturate(1)}
.local__map-veil{
  position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(180deg, rgba(10,8,7,.18) 0%, rgba(10,8,7,0) 30%, rgba(10,8,7,0) 70%, rgba(10,8,7,.35) 100%);
  transition:opacity .5s;
}
.local__map-frame:hover .local__map-veil{opacity:.4}
.local__map-caption{
  display:block;margin-top:1.1rem;
  font-size:.7rem;letter-spacing:.32em;text-transform:uppercase;color:var(--gold);
}

@media (max-width: 1024px){
  .local__grid{grid-template-columns:1fr;gap:3.5rem}
  .local__map-frame{aspect-ratio:16/11}
}
@media (max-width: 720px){
  .local{padding:6rem var(--pad)}
  .local__info{grid-template-columns:1fr;gap:1.4rem;padding-top:1.4rem}
  .local__actions{flex-direction:column;align-items:stretch}
  .local__actions .btn{justify-content:center}
}

/* ============== RESERVA ============== */
.reserva{position:relative;padding: 10rem var(--pad);overflow:hidden;text-align:center}
.reserva__bg{position:absolute;inset:-10%;background-size:cover;background-position:center;will-change:transform;filter:saturate(.8) brightness(.4)}
.reserva__overlay{position:absolute;inset:0;background:radial-gradient(70% 60% at 50% 50%, rgba(10,8,7,.55), rgba(10,8,7,.95))}
.reserva__inner{position:relative;z-index:2;max-width:780px;margin:0 auto}
.reserva__inner p{font-family:var(--sans);font-size:1.05rem;line-height:1.65;color:var(--cream);opacity:.9;margin:1.6rem auto 0;max-width:600px;font-weight:400}
.reserva__actions{display:flex;gap:1rem;justify-content:center;margin-top:3rem;flex-wrap:wrap}
.reserva__info{margin-top:5rem;display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;border-top:1px solid var(--line);padding-top:3rem}
.reserva__info > div{display:flex;flex-direction:column;gap:.4rem}
.reserva__info span{font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;color:var(--gold)}
.reserva__info p{font-family:var(--serif);font-size:1.1rem;color:var(--cream);margin:0;opacity:1}

/* ============== FOOTER ============== */
.footer{background:var(--bg);border-top:1px solid var(--line);padding: 5rem var(--pad) 2rem}
.footer__top{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:1fr 1.4fr;gap:4rem;padding-bottom:4rem;border-bottom:1px solid var(--line)}
.footer__brand{display:flex;flex-direction:column;gap:.4rem}
.footer__year{font-size:.7rem;letter-spacing:.5em;color:var(--gold);text-transform:uppercase}
.footer__name{font-family:var(--serif);font-size:2rem;color:var(--cream)}
.footer__name em{color:var(--gold)}
.footer__brand p{font-family:var(--serif2);font-style:italic;color:var(--muted);margin-top:.6rem}
.footer__cols{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}
.footer__cols > div{display:flex;flex-direction:column;gap:.6rem}
.footer__cols span{font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);margin-bottom:.4rem}
.footer__cols a{font-size:.92rem;color:var(--cream);opacity:.7;transition:opacity .3s, color .3s}
.footer__cols a:hover{opacity:1;color:var(--gold)}
.footer__bottom{max-width:var(--max);margin:2rem auto 0;display:flex;justify-content:space-between;font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}

/* ============== WHATSAPP ============== */
.wa-float{position:fixed;right:1.6rem;bottom:1.6rem;width:56px;height:56px;background:var(--gold);color:var(--bg);display:flex;align-items:center;justify-content:center;border-radius:50%;z-index:300;box-shadow:0 14px 40px rgba(201,161,74,.25), 0 0 0 0 rgba(201,161,74,.4);transition:transform .4s var(--ease), box-shadow .4s;animation:waPulse 2.6s var(--ease) infinite}
.wa-float:hover{transform:translateY(-4px) scale(1.05)}
.wa-float svg{width:26px;height:26px}
@keyframes waPulse{0%,100%{box-shadow:0 14px 40px rgba(201,161,74,.25), 0 0 0 0 rgba(201,161,74,.45)}50%{box-shadow:0 14px 40px rgba(201,161,74,.25), 0 0 0 18px rgba(201,161,74,0)}}

/* ============== REVEAL ANIMATIONS ============== */
[data-reveal]{opacity:0;transform:translateY(40px);transition:opacity 1.2s var(--ease), transform 1.2s var(--ease)}
[data-reveal].is-in{opacity:1;transform:translateY(0)}

/* esp-box: stagger via nth-child delay */
.esp-box[data-reveal]{transform:translateY(60px) scale(.98)}
.esp-box[data-reveal].is-in{transform:translateY(0) scale(1)}
.esp-box:nth-child(1)[data-reveal]{transition-delay:0s}
.esp-box:nth-child(2)[data-reveal]{transition-delay:.1s}
.esp-box:nth-child(3)[data-reveal]{transition-delay:.2s}
.esp-box:nth-child(4)[data-reveal]{transition-delay:.3s}

/* curso-pro: cinematic alternating slide */
.curso-pro[data-reveal]{opacity:0;transform:translateY(60px)}
.curso-pro[data-reveal].is-in{opacity:1;transform:translateY(0)}
.curso-pro[data-reveal] .curso-pro__photo{opacity:0;transform:translateX(-50px);transition:opacity 1.4s var(--ease) .15s, transform 1.4s var(--ease) .15s}
.curso-pro--reverse[data-reveal] .curso-pro__photo{transform:translateX(50px)}
.curso-pro[data-reveal].is-in .curso-pro__photo{opacity:1;transform:translateX(0)}
.curso-pro[data-reveal] .curso-pro__content > *{opacity:0;transform:translateY(20px);transition:opacity .9s var(--ease), transform .9s var(--ease)}
.curso-pro[data-reveal].is-in .curso-pro__content > *{opacity:1;transform:translateY(0)}
.curso-pro[data-reveal].is-in .curso-pro__content > *:nth-child(1){transition-delay:.3s}
.curso-pro[data-reveal].is-in .curso-pro__content > *:nth-child(2){transition-delay:.4s}
.curso-pro[data-reveal].is-in .curso-pro__content > *:nth-child(3){transition-delay:.5s}
.curso-pro[data-reveal].is-in .curso-pro__content > *:nth-child(4){transition-delay:.6s}
.curso-pro[data-reveal].is-in .curso-pro__content > *:nth-child(5){transition-delay:.7s}
.curso-pro[data-reveal].is-in .curso-pro__content > *:nth-child(6){transition-delay:.8s}
.curso-pro[data-reveal].is-in .curso-pro__content > *:nth-child(7){transition-delay:.9s}
.curso-pro[data-reveal] .curso-pro__num{opacity:0;transform:translateY(-20px);transition:opacity 1.6s var(--ease) .5s, transform 1.6s var(--ease) .5s}
.curso-pro[data-reveal].is-in .curso-pro__num{opacity:.5;transform:translateY(0)}
.curso-pro--featured[data-reveal].is-in .curso-pro__num{opacity:.85}
[data-split]{display:inline-block;transform:translateY(110%);transition:transform 1.2s var(--ease)}
.line.is-in [data-split]{transform:translateY(0)}
.hero__title .line:nth-child(1) [data-split]{transition-delay:.2s}
.hero__title .line:nth-child(2) [data-split]{transition-delay:.35s}
.hero__title .line:nth-child(3) [data-split]{transition-delay:.5s}

/* ============== RESPONSIVE ============== */
@media (max-width: 900px){
  .esp-grid{grid-template-columns:repeat(2,1fr);max-width:720px}
}
@media (max-width: 1024px){
  .nav__links{display:none}
  .nav__cta{display:none}
  .nav__burger{display:flex}
  .historia__grid{grid-template-columns:1fr;gap:3rem}
  .curso-pro,.curso-pro--reverse{grid-template-columns:60px 1fr;gap:1.8rem}
  .curso-pro__photo,.curso-pro--reverse .curso-pro__photo{order:initial;grid-column:2;aspect-ratio:16/10}
  .curso-pro__content,.curso-pro--reverse .curso-pro__content{order:initial;grid-column:2}
  .curso-pro__num{grid-row:span 2}
  .footer__top{grid-template-columns:1fr;gap:3rem}
}
@media (max-width: 720px){
  body{font-size:14px}
  .hero{padding:7rem 1.25rem 5rem}
  .hero__scroll{display:none}
  .hero__title{font-size:14vw}
  .historia,.especialidades,.cursos,.reserva{padding-top:6rem;padding-bottom:6rem}
  .section-head{margin-bottom:3rem}
  .esp-grid{grid-template-columns:1fr;gap:1rem}
  .esp-box{min-height:380px}
  .esp-box p{max-height:none;margin-top:.5rem;opacity:.85}
  .cursos__list{gap:3rem}
  .curso-pro,.curso-pro--reverse{grid-template-columns:1fr;gap:1.4rem;padding:2.5rem 0}
  .curso-pro__num{font-size:3.5rem;padding-top:0}
  .curso-pro__photo,.curso-pro--reverse .curso-pro__photo{grid-column:1;aspect-ratio:4/3}
  .curso-pro__content,.curso-pro--reverse .curso-pro__content{grid-column:1}
  .curso-pro__foot{flex-direction:column;align-items:stretch;gap:1.2rem}
  .curso-pro__btn{justify-content:center}
  .reserva__info{grid-template-columns:1fr;text-align:center}
  .footer__cols{grid-template-columns:1fr 1fr}
  .footer__bottom{flex-direction:column;gap:.6rem;text-align:center}
  .wa-float{width:50px;height:50px;right:1.1rem;bottom:1.1rem}
  .grain{opacity:.03}
}

/* ============== A11Y ============== */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.001s!important;transition-duration:.001s!important;animation-iteration-count:1!important}
  [data-reveal]{opacity:1;transform:none}
  [data-split]{transform:none}
  .hero__img{transform:none}
}
