/* =========================================================
   BUROFÁCIL — landing
   ========================================================= */

:root{
  --bg:        #1a1612;
  --bg-2:      #211c17;
  --bg-3:      #2a241e;
  --paper:     #fbf8f4;
  --paper-2:   #f3ede4;
  --ink:       #1a1612;
  --ink-2:     #4a423a;
  --ink-3:     #7a6f63;
  --line:      #e7dfd2;
  --line-dark: #36302a;
  --orange:    #ef5722;
  --orange-2:  #d94817;
  --orange-3:  #f4a07a;
  --orange-soft:#fcebe1;
  --radius:    14px;
  --radius-lg: 22px;

  --serif: "Newsreader", ui-serif, Georgia, serif;
  --sans:  "DM Sans", ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;

  --container: 1240px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--paper);
  font-size:16px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}

.container{
  width:100%;
  max-width:var(--container);
  margin:0 auto;
  padding:0 32px;
}

/* ---------- typography ---------- */
.h2{
  font-family:var(--serif);
  font-weight:500;
  font-size:clamp(28px, 3.1vw, 42px);
  line-height:1.08;
  letter-spacing:-0.015em;
  margin:0;
  color:var(--ink);
  text-wrap:balance;
}
.h2--light{color:var(--paper)}
.h3{
  font-family:var(--serif);
  font-weight:500;
  font-size:clamp(22px,2vw,28px);
  line-height:1.15;
  letter-spacing:-0.01em;
  margin:0;
}
.serif-em{font-style:italic; color:var(--orange-3); font-weight:400}

.eyebrow{
  font-family:var(--sans);
  font-size:11.5px;
  font-weight:600;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:var(--orange-3);
  margin:0 0 16px;
}
.eyebrow--dark{color:var(--orange-2)}
.eyebrow--light{color:var(--orange-3)}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:13px 22px;
  border-radius:6px;
  font-weight:600;
  font-size:14.5px;
  line-height:1;
  transition:transform .15s ease, background .2s, color .2s, border-color .2s, box-shadow .2s;
  white-space:nowrap;
  border:1px solid transparent;
}
.btn:active{transform:translateY(1px)}
.btn--primary{background:var(--orange);color:#fff;box-shadow:0 1px 0 rgba(0,0,0,.06), 0 8px 24px -10px rgba(225,106,59,.55)}
.btn--primary:hover{background:var(--orange-2)}
.btn--ghost-light{background:transparent;color:#fff;border-color:rgba(255,255,255,.35)}
.btn--ghost-light:hover{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.6)}
.btn--ghost-dark{background:transparent;color:#fff;border-color:rgba(255,255,255,.55)}
.btn--ghost-dark:hover{background:rgba(255,255,255,.10)}
.btn--white{background:#fff;color:var(--ink)}
.btn--white:hover{background:var(--paper-2)}
.btn--outline-ink{
  background:transparent;
  color:var(--ink);
  border:1px solid var(--ink);
}
.btn--outline-ink:hover{background:var(--ink);color:#fff}

/* ============================================================
   NAV — centered links
   ============================================================ */
.nav{
  position:absolute;
  top:0;left:0;right:0;
  z-index:30;
  padding:18px 0;
}
.nav__inner{
  display:grid;
  grid-template-columns:1fr auto 1fr;
  align-items:center;
  gap:16px;
}
.brand{
  display:inline-flex;
  align-items:center;
  line-height:1;
  color:#fff;
  justify-self:start;
}
.brand__logo{
  height:38px;
  width:auto;
  display:block;
}
.footer__logo{
  height:34px;
  width:auto;
  display:block;
}

.nav__links{
  display:flex;
  gap:4px;
  justify-self:center;
  position:relative;
}
.nav__item{position:relative;display:inline-flex}
.nav__link{
  color:#fff;
  opacity:.85;
  padding:9px 16px;
  border-radius:999px;
  font-size:14px;
  font-weight:500;
  display:inline-flex;
  align-items:center;
  gap:5px;
  transition:opacity .2s, background .2s;
}
.nav__link:hover{opacity:1;background:rgba(255,255,255,.06)}
.nav__caret{font-size:9px;opacity:.7;transform:translateY(1px)}
.nav__cta{justify-self:end}
.nav__burger{
  display:none;
  width:40px;height:40px;
  flex-direction:column;
  justify-content:center;
  gap:5px;
  align-items:center;
  justify-self:end;
}
.nav__burger span{
  display:block;
  width:22px;height:2px;
  background:#fff;
  border-radius:2px;
}

/* Light frosted nav for non-Home pages (sticky, off-white blur) */
.nav--light{
  position:sticky;
  top:0;
  background:rgba(251, 248, 244, 0.72);
  backdrop-filter:saturate(180%) blur(18px);
  -webkit-backdrop-filter:saturate(180%) blur(18px);
  border-bottom:1px solid rgba(26, 22, 18, 0.06);
  padding:14px 0;
  z-index:50;
}
.nav--light .nav__link{color:var(--ink);opacity:.78}
.nav--light .nav__link:hover{opacity:1;background:rgba(26,22,18,0.05)}
.nav--light .nav__caret{color:var(--ink-2)}
.nav--light .nav__burger span{background:var(--ink)}

/* ============================================================
   HERO — clean, no overflow
   ============================================================ */
.hero{
  position:relative;
  padding:140px 0 110px;
  background:var(--bg);
  color:#fff;
  overflow:hidden;
  isolation:isolate;
}
.hero__bg{
  position:absolute; inset:0;
  background-size:cover;
  background-position:center right;
  opacity:0;
  z-index:0;
  will-change:opacity;
}
.hero__bg.is-active{opacity:1}
.hero__bg[data-bg="auto"]{background-position:center center}
.hero__bg[data-bg="salary"]{background-position:center 25%}

.hero__scrim{
  position:absolute; inset:0;
  background:
    linear-gradient(90deg, rgba(20,16,12,.94) 0%, rgba(20,16,12,.82) 38%, rgba(20,16,12,.45) 62%, rgba(20,16,12,.20) 100%),
    linear-gradient(180deg, rgba(20,16,12,.55) 0%, rgba(20,16,12,0) 30%, rgba(20,16,12,0) 60%, rgba(20,16,12,.85) 100%);
  z-index:1;
}
.hero__content{position:relative;z-index:2}
.hero__copy{max-width:580px}
.hero__title{
  font-family:var(--serif);
  font-weight:500;
  font-size:clamp(32px, 3.8vw, 54px);
  line-height:1.05;
  letter-spacing:-0.02em;
  margin:0 0 20px;
  text-wrap:balance;
}
.hero__sub{
  font-size:16px;
  line-height:1.55;
  max-width:520px;
  margin:0 0 28px;
  color:rgba(255,255,255,.85);
}
.hero__ctas{display:flex;gap:12px;flex-wrap:wrap}

/* ============================================================
   CHOOSER BAND — own dark section between hero and stats
   ============================================================ */
.chooser-band{
  background:var(--bg);
  color:#fff;
  padding:48px 0 56px;
  border-top:1px solid rgba(255,255,255,.06);
  position:relative;
}
.chooser-band__head{
  display:flex;
  align-items:baseline;
  justify-content:space-between;
  gap:24px;
  margin-bottom:20px;
  flex-wrap:wrap;
}
.chooser-band__head .eyebrow{margin:0;color:var(--orange-3)}
.chooser-band__sub{
  margin:0;
  color:rgba(255,255,255,.6);
  font-size:13.5px;
}

.hero__chooser{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:14px;
}
.card-thumb{
  position:relative;
  display:flex;
  align-items:stretch;
  gap:14px;
  padding:14px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.10);
  border-radius:14px;
  color:#fff;
  text-align:left;
  transition:border-color .25s, background .25s, transform .15s;
  overflow:hidden;
}
.card-thumb:hover{border-color:rgba(255,255,255,.22);background:rgba(255,255,255,.07)}
.card-thumb.is-active{
  border-color:var(--orange);
  background:rgba(35,28,22,.95);
  box-shadow:0 0 0 1px var(--orange), 0 18px 40px -20px rgba(225,106,59,.55);
}
.card-thumb__img{
  width:72px; height:72px;
  flex:none;
  background-size:cover;
  background-position:center;
  border-radius:8px;
}
.card-thumb__body{
  display:flex;
  flex-direction:column;
  justify-content:center;
  gap:4px;
  min-width:0;
  flex:1;
}
.card-thumb__pill{
  display:inline-flex;
  align-items:center;
  gap:5px;
  font-size:9px;
  letter-spacing:0.14em;
  text-transform:uppercase;
  font-weight:600;
  color:var(--orange-3);
  width:fit-content;
}
.card-thumb__pill .dot{width:4px;height:4px;border-radius:50%;background:var(--orange);display:inline-block}
.card-thumb__title{
  font-family:var(--serif);
  font-weight:500;
  font-size:17px;
  line-height:1.1;
  letter-spacing:-0.01em;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.card-thumb__sub{
  font-size:12px;
  color:rgba(255,255,255,.62);
  line-height:1.35;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.card-thumb__arrow{
  align-self:center;
  margin-left:auto;
  width:32px;height:32px;
  display:flex;align-items:center;justify-content:center;
  border-radius:50%;
  background:rgba(255,255,255,.06);
  color:#fff;
  font-size:14px;
  transition:background .2s, color .2s, transform .2s;
  flex:none;
}
.card-thumb:hover .card-thumb__arrow{background:rgba(255,255,255,.14);transform:translateX(2px)}
.card-thumb.is-active .card-thumb__arrow{background:var(--orange);color:#fff}

/* ============================================================
   STATS BAR
   ============================================================ */
.stats{
  background:var(--bg);
  color:#fff;
  padding:32px 0 80px;
}
.stats__grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:32px;
  padding-top:32px;
  border-top:1px solid rgba(255,255,255,.08);
}
.stat{padding-right:24px;border-right:1px solid rgba(255,255,255,.08)}
.stat:last-child{border-right:0}
.stat__num{
  font-family:var(--serif);
  font-weight:500;
  font-size:clamp(28px,2.8vw,40px);
  line-height:1;
  letter-spacing:-0.02em;
  margin:0 0 8px;
  font-variant-numeric:tabular-nums;
}
.stat__num span{font-size:0.55em;color:var(--orange-3);font-style:italic;font-weight:400;margin-left:4px}
.stat__lbl{
  font-size:13px;
  color:rgba(255,255,255,.55);
  margin:0;
  letter-spacing:0.02em;
}

/* badge stat for "Parceiros BACEN" */
.stat--badge .stat__badge{
  margin:0 0 8px;
  font-size:13px;
  font-weight:600;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:#fff;
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 14px;
  border:1px solid rgba(255,255,255,.18);
  border-radius:999px;
  background:rgba(255,255,255,.04);
}
.stat--badge .stat__badge em{
  font-family:var(--serif);
  font-style:italic;
  font-weight:500;
  color:var(--orange-3);
  letter-spacing:0.02em;
  font-size:14px;
}

/* ============================================================
   GENERIC SECTION
   ============================================================ */
.section{padding:96px 0;background:var(--paper)}
.section--alt{background:var(--paper-2)}
.section__head{margin-bottom:48px}
.section__head-row{
  display:grid;
  grid-template-columns:1.05fr 1fr;
  gap:56px;
  align-items:end;
}
.section__lede{
  font-size:15.5px;
  line-height:1.65;
  color:var(--ink-2);
  margin:0;
  max-width:480px;
}

/* ============================================================
   FEATURE BLOCKS (Para Você — zigzag 50/50)
   ============================================================ */
.feature{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:48px;
  align-items:center;
  padding:24px 0;
}
.feature + .feature{
  margin-top:32px;
  padding-top:56px;
  border-top:1px solid var(--line);
}
.feature--reverse .feature__media{order:2}
.feature__media{
  aspect-ratio:5/4;
  background-size:cover;
  background-position:center;
  border-radius:var(--radius-lg);
  border:1px solid var(--line);
}
.feature__copy{
  display:flex;
  flex-direction:column;
  gap:14px;
  padding:0 8px;
}
.feature__title{
  font-family:var(--serif);
  font-weight:500;
  font-size:clamp(30px, 2.8vw, 42px);
  line-height:1.05;
  letter-spacing:-0.02em;
  margin:0;
}
.feature__sub{margin:0;color:var(--ink-3);font-size:14px}
.feature__lede{
  margin:0;
  color:var(--ink-2);
  font-size:15.5px;
  line-height:1.6;
  max-width:480px;
}
.feature__meta{
  list-style:none;
  margin:8px 0 0;
  padding:18px 0 0;
  border-top:1px dashed var(--line);
  display:flex;
  gap:28px;
  flex-wrap:wrap;
}
.feature__meta li{display:flex;flex-direction:column;gap:2px}
.feature__meta span{font-size:10.5px;letter-spacing:0.14em;text-transform:uppercase;color:var(--ink-3);font-weight:600}
.feature__meta strong{
  font-family:var(--serif);
  font-weight:500;
  font-size:26px;
  letter-spacing:-0.01em;
  color:var(--ink);
  font-variant-numeric:tabular-nums;
  line-height:1;
}
.feature__meta em{font-style:normal;font-size:11.5px;color:var(--ink-3);white-space:nowrap}
.feature__ctas{
  margin-top:14px;
  display:flex;
  align-items:center;
  gap:14px;
  flex-wrap:wrap;
}

.tag{
  display:inline-flex;
  align-items:center;
  gap:6px;
  font-size:10.5px;
  letter-spacing:0.16em;
  text-transform:uppercase;
  font-weight:600;
  padding:6px 10px;
  border-radius:6px;
  width:fit-content;
  white-space:nowrap;
}
.tag--orange{background:var(--orange-soft);color:var(--orange-2)}
.tag--orange .dot{width:5px;height:5px;border-radius:50%;background:var(--orange);display:inline-block}
.tag--outline{border:1px solid var(--line);color:var(--ink-2);background:#fff}

.link-arrow{
  font-weight:600;
  font-size:14px;
  color:var(--orange-2);
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 14px;
  border-radius:6px;
  background:transparent;
  transition:background .2s, gap .2s;
}
.link-arrow:hover{background:var(--orange-soft);gap:10px}
.link-arrow--sm{padding:6px 12px;font-size:13px;background:var(--orange-soft);white-space:nowrap;flex:none}
.link-arrow--sm:hover{background:#f8d9c4}

/* ============================================================
   PARA SUA EMPRESA cards
   ============================================================ */
.pe-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;
}
.biz-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  padding:28px;
  display:flex;
  flex-direction:column;
  gap:14px;
  transition:transform .25s, box-shadow .25s, border-color .25s;
}
.biz-card:hover{
  transform:translateY(-2px);
  box-shadow:0 24px 50px -32px rgba(26,22,18,.25);
  border-color:#dbcfb9;
}
.biz-card__icon{
  width:48px;height:48px;
  border-radius:12px;
  background:var(--orange-soft);
  color:var(--orange-2);
  display:flex;align-items:center;justify-content:center;
}
.biz-card__icon svg{width:28px;height:28px}
.biz-card__copy{
  margin:0;
  color:var(--ink-2);
  font-size:14.5px;
  line-height:1.6;
  flex:1;
}
.biz-card__meta{
  list-style:none;
  margin:0;
  padding:14px 0 0;
  border-top:1px dashed var(--line);
  display:flex;
  gap:20px;
}
.biz-card__meta li{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}
.biz-card__meta span{font-size:10.5px;letter-spacing:0.1em;text-transform:uppercase;color:var(--ink-3);font-weight:600}
.biz-card__meta strong{
  font-family:var(--serif);
  font-weight:500;
  font-size:22px;
  letter-spacing:-0.01em;
  color:var(--ink);
  font-variant-numeric:tabular-nums;
}
.biz-card__meta em{font-style:normal;font-size:11.5px;color:var(--ink-3)}
.biz-card__foot{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  padding-top:12px;
  flex-wrap:wrap;
}
.biz-card__price{
  font-size:11px;
  letter-spacing:0.14em;
  text-transform:uppercase;
  font-weight:600;
  color:var(--ink-3);
  line-height:1.3;
}

/* ============================================================
   PARTNERS
   ============================================================ */
.partners{
  position:relative;
  background:var(--bg);
  color:#fff;
  padding:96px 0;
  overflow:hidden;
}
.partners__bg{
  position:absolute;
  top:-1px;
  right:-200px;
  width:55%;
  bottom:-1px;
  background:radial-gradient(ellipse at right, rgba(225,106,59,.16), transparent 60%);
  pointer-events:none;
}
.partners__grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:64px;
  align-items:center;
  position:relative;
}
.partners__copy{max-width:560px}
.partners__title{
  font-size:clamp(28px, 3vw, 40px);
  line-height:1.15;
}
.partners__lede{
  font-size:15px;
  line-height:1.65;
  color:rgba(255,255,255,.72);
  margin:22px 0 30px;
}
.partners__ctas{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:28px}
.partners__pills{
  list-style:none;
  margin:0;padding:0;
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}
.partners__pills li{
  font-size:12.5px;
  padding:7px 14px;
  border:1px solid rgba(255,255,255,.18);
  border-radius:999px;
  color:rgba(255,255,255,.82);
  letter-spacing:0.04em;
}
.partners__media{position:relative}
.partners__photo{
  aspect-ratio:5/4;
  background-size:cover;
  background-position:center;
  border-radius:var(--radius-lg);
  border:1px solid rgba(255,255,255,.06);
}

/* ============================================================
   CTA FINAL — photo contained inside the card
   ============================================================ */
.cta-final{
  background:var(--bg);
  padding:80px 0;
}
.cta-final__card{
  background:var(--orange);
  color:#fff;
  border-radius:var(--radius-lg);
  overflow:hidden;
  display:grid;
  grid-template-columns:1fr 1fr;
  align-items:stretch;
  min-height:440px;
}
.cta-final__copy{
  padding:64px 56px;
  display:flex;
  flex-direction:column;
  justify-content:center;
}
.cta-final__lede{
  font-size:16px;
  line-height:1.6;
  color:rgba(255,255,255,.92);
  margin:14px 0 28px;
  max-width:420px;
}
.cta-final__ctas{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:24px}
.cta-final__hours{
  font-size:13px;
  color:rgba(255,255,255,.82);
  margin:0;
  letter-spacing:0.02em;
}
.cta-final__media{
  position:relative;
  min-height:360px;
}
.cta-final__photo{
  position:absolute;
  inset:0;
  background-size:cover;
  background-position:center;
}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{
  background:#0f0c09;
  color:rgba(255,255,255,.7);
  padding:72px 0 36px;
  font-size:14px;
}
.footer__top{
  display:grid;
  grid-template-columns:1.1fr 2fr;
  gap:56px;
  padding-bottom:48px;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.footer__brand{display:flex;flex-direction:column;align-items:flex-start}
.footer__about{
  max-width:280px;
  margin:16px 0 0;
  color:rgba(255,255,255,.55);
  font-size:13.5px;
  line-height:1.55;
}
.footer__cols{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:28px;
}
.footer__h{
  font-weight:600;
  color:#fff;
  margin:0 0 14px;
  font-size:13px;
  letter-spacing:0.04em;
}
.footer__col ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}
.footer__col a{color:rgba(255,255,255,.62);font-size:13.5px;transition:color .2s}
.footer__col a:hover{color:var(--orange-3)}
.footer__legal{padding-top:28px;display:flex;flex-direction:column;gap:18px}
.footer__legal p{margin:0;color:rgba(255,255,255,.45);font-size:12px;line-height:1.55;max-width:980px}
.footer__legal-meta{
  display:flex;
  flex-wrap:wrap;
  gap:24px;
  color:#ffffff;
  font-size:11.5px;
  letter-spacing:0.02em;
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 980px){
  .section__head-row{grid-template-columns:1fr;gap:20px}
  .partners__grid{grid-template-columns:1fr;gap:48px}
  .cta-final__card{grid-template-columns:1fr;min-height:0}
  .cta-final__copy{padding:56px 40px 32px}
  .cta-final__media{min-height:320px}
  .pe-grid{grid-template-columns:1fr 1fr}
  .feature{gap:32px}
  .feature__copy{padding:0}
}

@media (max-width: 760px){
  .container{padding:0 22px}
  .nav__inner{grid-template-columns:1fr auto}
  .nav__links, .nav__cta{display:none}
  .nav__burger{display:flex}
  .hero{padding:120px 0 72px}
  .hero__bg{background-position:center 30%}
  .hero__scrim{
    background:
      linear-gradient(180deg, rgba(20,16,12,.92) 0%, rgba(20,16,12,.55) 35%, rgba(20,16,12,.55) 70%, rgba(20,16,12,.96) 100%);
  }
  .chooser-band{padding:40px 0}
  .hero__chooser{grid-template-columns:1fr;gap:10px}
  .stats__grid{grid-template-columns:1fr 1fr;gap:24px}
  .stat{border-right:0;border-bottom:1px solid rgba(255,255,255,.08);padding:0 0 20px}
  .stat:nth-last-child(-n+2){border-bottom:0}
  .section{padding:72px 0}
  .feature{grid-template-columns:1fr;gap:24px;padding:16px 0}
  .feature + .feature{padding-top:40px;margin-top:24px}
  .feature--reverse .feature__media{order:0}
  .pe-grid{grid-template-columns:1fr}
  .biz-card{padding:24px}
  .footer__top{grid-template-columns:1fr;gap:36px}
  .footer__cols{grid-template-columns:1fr 1fr;gap:24px}
  .partners__photo{aspect-ratio:4/3}
  .cta-final__copy{padding:48px 28px 24px}
  .cta-final__media{min-height:260px}
  .card-thumb__img{width:72px;height:72px}
  .card-thumb__title{font-size:17px}
  .chooser-band__head{flex-direction:column;align-items:flex-start;gap:8px}
}

@media (max-width: 440px){
  .stats__grid{grid-template-columns:1fr}
  .stat{border-bottom:1px solid rgba(255,255,255,.08)!important}
  .stat:last-child{border-bottom:0!important}
  .footer__cols{grid-template-columns:1fr}
}

/* ============================================================
   MEGA MENU (injected by megamenu.js)
   ============================================================ */
.megamenu{
  position:fixed;
  top:0;
  left:0;
  width:638px;
  max-width:calc(100vw - 32px);
  background:#fff;
  border:1px solid var(--line);
  border-radius:20px;
  box-shadow:0 1px 0 rgba(0,0,0,.02), 0 28px 70px -28px rgba(26,22,18,.28);
  padding:18px;
  opacity:0;
  pointer-events:none;
  transition:opacity .18s ease;
  z-index:1000;
  isolation:isolate;
}
.megamenu.is-open{
  opacity:1;
  pointer-events:auto;
}
/* legacy hooks no longer used after detach to body */
.nav__item:last-child .megamenu{left:auto}

.megamenu__inner{
  display:grid;
  grid-template-columns:2fr 1fr;
  gap:16px;
}
.megamenu__list{
  list-style:none;
  margin:0;
  padding:0;
  display:flex;
  flex-direction:column;
  gap:4px;
}
.megamenu__link{
  display:block;
  padding:10px 14px;
  border-radius:10px;
  transition:background .15s ease, color .15s ease;
  color:var(--ink);
}
.megamenu__link:hover{background:var(--paper-2)}
.megamenu__title{
  display:flex;
  align-items:center;
  gap:7px;
  font-family:var(--serif);
  font-weight:500;
  font-size:19px;
  letter-spacing:-0.01em;
  line-height:1.1;
  color:var(--ink);
  margin-bottom:4px;
}
.megamenu__title svg{
  color:var(--orange-2);
  opacity:0;
  transform:translateX(-4px);
  transition:opacity .15s ease, transform .15s ease;
}
.megamenu__link:hover .megamenu__title svg{opacity:1;transform:translateX(0)}
.megamenu__desc{
  margin:0;
  font-size:13.5px;
  line-height:1.45;
  color:var(--ink-2);
}
.megamenu__art{
  aspect-ratio:9/16;
  max-height:286px;
  background:var(--paper-2);
  border-radius:13px;
  align-self:stretch;
  justify-self:end;
  width:100%;
  max-width:165px;
}

@media (max-width: 760px){
  .megamenu{display:none}
}

/* ============================================================
   SCROLL REVEAL (reveal.js) — animates content INSIDE each
   section, never the section itself. This keeps backgrounds
   stable so you don't see seams between blocks while scrolling.
   ============================================================ */
html.reveal-ready body > section > *:not(.hero__bg):not(.hero__scrim),
html.reveal-ready .he-hero > *,
html.reveal-ready .pc-hero > *,
html.reveal-ready .op-hero > *,
html.reveal-ready .ar-sim > *,
html.reveal-ready .as-split > *,
html.reveal-ready .pj-hero > *{
  opacity:0;
  transform:translateY(28px);
  transition:opacity .8s cubic-bezier(.2,.6,.2,1), transform .8s cubic-bezier(.2,.6,.2,1);
  will-change:opacity, transform;
}
html.reveal-ready body > section.is-revealed > *:not(.hero__bg):not(.hero__scrim),
html.reveal-ready .he-hero.is-revealed > *,
html.reveal-ready .pc-hero.is-revealed > *,
html.reveal-ready .op-hero.is-revealed > *,
html.reveal-ready .ar-sim.is-revealed > *,
html.reveal-ready .as-split.is-revealed > *,
html.reveal-ready .pj-hero.is-revealed > *{
  opacity:1;
  transform:none;
}
@media (prefers-reduced-motion: reduce){
  html.reveal-ready body > section > *:not(.hero__bg):not(.hero__scrim),
  html.reveal-ready .he-hero > *,
  html.reveal-ready .pc-hero > *,
  html.reveal-ready .op-hero > *,
  html.reveal-ready .ar-sim > *,
  html.reveal-ready .as-split > *,
  html.reveal-ready .pj-hero > *{
    opacity:1;
    transform:none;
    transition:none;
  }
}
