/* ==========================================================
   PARKTOWER IPTV — penthouse glass + brass
   ========================================================== */

:root{
  --bg-deep:#07091a;
  --bg-deeper:#04061a;
  --bg-card:#0f1227;
  --bg-elev:#161a35;
  --bg-glass:rgba(255,255,255,.04);
  --ink:#f5efe1;
  --ink-2:#d8d2c2;
  --ink-muted:#7e88a3;
  --line:rgba(245,239,225,.08);
  --line-strong:rgba(245,239,225,.18);
  --accent:#d4a574;
  --accent-hi:#e8c89b;
  --accent-glow:rgba(212,165,116,.35);
  --ice:#4ce5ff;
  --gold:#e6c46a;

  --radius-s:8px;
  --radius-m:18px;
  --radius-l:28px;

  --display:'Fraunces','Times New Roman',serif;
  --body:'DM Sans','Helvetica Neue',Arial,sans-serif;

  --container:1280px;
}

*,*::before,*::after{box-sizing:border-box}

html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;
  background:var(--bg-deep);
  color:var(--ink);
  font-family:var(--body);
  font-size:16px;
  line-height:1.55;
  font-weight:400;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;

  background-image:
    radial-gradient(circle at 100% 0%,rgba(212,165,116,.08) 0%,transparent 35%),
    radial-gradient(circle at 0% 100%,rgba(76,229,255,.06) 0%,transparent 40%);
  background-attachment:fixed;
}

img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
ul,ol{list-style:none;margin:0;padding:0}

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

/* GRAIN ATMOSFERA -------------------------------------- */
.grain{
  pointer-events:none;
  position:fixed;inset:0;
  z-index:9999;
  opacity:.05;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%' height='100%' filter='url(%23n)' opacity='0.9'/></svg>");
}

/* TORRE — linha vertical decorativa lateral ----------- */
.tower-rule{
  position:fixed;
  left:24px;top:0;bottom:0;
  width:1px;
  z-index:5;
  pointer-events:none;
  background:linear-gradient(180deg,
    transparent 0%,
    rgba(212,165,116,.4) 12%,
    rgba(212,165,116,.15) 50%,
    transparent 100%);
}
.tower-rule::before,
.tower-rule::after{
  content:'';position:absolute;left:-3px;
  width:7px;height:7px;border-radius:50%;
  background:var(--accent);
  box-shadow:0 0 12px var(--accent-glow);
}
.tower-rule::before{top:80px;animation:rise 3s ease-in-out infinite}
.tower-rule::after{bottom:80px;animation:rise 3s ease-in-out infinite reverse}
@keyframes rise{
  0%,100%{transform:translateY(0);opacity:.7}
  50%{transform:translateY(-12px);opacity:1}
}

/* TYPOGRAPHY UTILS ------------------------------------- */
.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--body);
  font-size:.74rem;font-weight:500;
  letter-spacing:.24em;text-transform:uppercase;
  color:var(--ink-2);
  padding:9px 18px;
  border:1px solid var(--line-strong);
  border-radius:999px;
  background:rgba(245,239,225,.02);
  backdrop-filter:blur(10px);
}
.eyebrow__pulse{
  width:8px;height:8px;border-radius:50%;
  background:var(--ice);
  box-shadow:0 0 0 0 rgba(76,229,255,.55);
  animation:pulse 1.8s infinite;
}
@keyframes pulse{
  0%{box-shadow:0 0 0 0 rgba(76,229,255,.55)}
  70%{box-shadow:0 0 0 12px rgba(76,229,255,0)}
  100%{box-shadow:0 0 0 0 rgba(76,229,255,0)}
}

/* FLOOR TAG (numeração de andares — motivo de marca) -- */
.floor__tag{
  display:inline-block;
  font-family:var(--display);
  font-size:.86rem;font-weight:500;
  font-variation-settings:"opsz" 11,"wght" 500,"SOFT" 100;
  letter-spacing:.32em;text-transform:uppercase;
  color:var(--accent);
  margin-bottom:22px;
  position:relative;padding-left:22px;
}
.floor__tag::before{
  content:'';position:absolute;
  left:0;top:50%;transform:translateY(-50%);
  width:14px;height:1px;
  background:var(--accent);
}
.floor__tag--center{padding-left:0;display:inline-block}
.floor__tag--center::before{display:none}

/* BUTTONS ---------------------------------------------- */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 24px;
  font-family:var(--body);
  font-size:.92rem;font-weight:600;letter-spacing:.02em;
  border-radius:999px;
  cursor:pointer;white-space:nowrap;
  transition:transform .25s ease,background .25s ease,border-color .25s ease,box-shadow .25s ease,color .25s ease;
  position:relative;
}
.btn--lg{padding:16px 30px;font-size:1rem}
.btn--block{width:100%;justify-content:center}

.btn--primary{
  background:linear-gradient(135deg,var(--accent),var(--accent-hi));
  color:#1a1108;
  box-shadow:0 12px 30px -10px var(--accent-glow),inset 0 1px 0 rgba(255,255,255,.3);
}
.btn--primary:hover{transform:translateY(-2px);box-shadow:0 18px 40px -12px var(--accent-glow)}

.btn--ghost{
  background:rgba(245,239,225,.04);
  color:var(--ink);
  border:1px solid var(--line-strong);
  backdrop-filter:blur(10px);
}
.btn--ghost:hover{background:rgba(245,239,225,.08);border-color:var(--accent)}

/* NAV -------------------------------------------------- */
.nav{
  position:fixed;
  top:0;left:0;right:0;
  z-index:100;
  padding:18px 0;
  transition:background .3s ease,backdrop-filter .3s ease,border-color .3s ease;
  border-bottom:1px solid transparent;
}
.nav.is-stuck{
  background:rgba(7,9,26,.78);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  border-bottom-color:var(--line);
}
.nav__inner{display:flex;align-items:center;justify-content:space-between;gap:24px}

.brand{display:inline-flex;align-items:center;gap:14px}
.brand__mark{
  display:inline-flex;flex-direction:column;gap:2px;
  width:14px;
}
.brand__mark span{
  display:block;
  height:3px;
  background:var(--accent);
  border-radius:1px;
}
.brand__mark span:nth-child(1){width:100%;height:5px;background:var(--accent-hi)}
.brand__mark span:nth-child(2){width:80%;margin-left:auto}
.brand__mark span:nth-child(3){width:65%;margin-left:auto}

.brand__name{
  font-family:var(--display);
  font-size:1.25rem;font-weight:700;letter-spacing:.16em;
  font-variation-settings:"opsz" 14,"wght" 700,"SOFT" 50;
}
.brand__name em{color:var(--accent);font-style:normal;font-weight:400}

.nav__menu{display:flex;align-items:center;gap:32px}
.nav__menu a{
  font-size:.92rem;font-weight:500;color:var(--ink-2);
  position:relative;transition:color .25s ease;
}
.nav__menu a:hover{color:var(--ink)}
.nav__menu a::after{
  content:'';position:absolute;left:0;right:0;bottom:-6px;
  height:1px;background:var(--accent);
  transform:scaleX(0);transform-origin:right;
  transition:transform .35s ease;
}
.nav__menu a:hover::after{transform:scaleX(1);transform-origin:left}

.nav__toggle{display:none;flex-direction:column;gap:5px;padding:10px}
.nav__toggle span{display:block;width:22px;height:2px;background:var(--ink);border-radius:2px;transition:transform .3s ease}

/* HERO ------------------------------------------------- */
.hero{
  position:relative;
  padding:170px 0 120px;
  overflow:hidden;
  isolation:isolate;
}
.hero__bg{position:absolute;inset:0;z-index:-1;overflow:hidden}
.hero__city{
  position:absolute;
  bottom:-40px;left:0;right:0;
  height:50%;
  background-image:
    linear-gradient(180deg,transparent 0%,rgba(7,9,26,.6) 70%,var(--bg-deep) 100%),
    repeating-linear-gradient(90deg,
      transparent 0,transparent 32px,
      rgba(212,165,116,.025) 32px,rgba(212,165,116,.025) 33px,
      transparent 33px,transparent 66px,
      rgba(212,165,116,.04) 66px,rgba(212,165,116,.04) 67px);
  opacity:.7;
}
.hero__beam{
  position:absolute;
  top:-30%;right:-10%;
  width:60%;height:130%;
  background:
    radial-gradient(ellipse at 50% 50%,rgba(212,165,116,.22) 0%,transparent 55%),
    radial-gradient(ellipse at 30% 80%,rgba(76,229,255,.1) 0%,transparent 60%);
  filter:blur(40px);
  transform:rotate(8deg);
  pointer-events:none;
}

.hero__inner{
  display:grid;
  grid-template-columns:80px 1.2fr .9fr;
  gap:50px 60px;
  align-items:center;
}

.floor{
  align-self:flex-start;
  display:flex;flex-direction:column;
  gap:6px;
  padding-top:80px;
  position:relative;
}
.floor::before{
  content:'';position:absolute;
  left:50%;top:0;width:1px;height:62px;
  background:linear-gradient(180deg,var(--accent),transparent);
}
.floor__num{
  font-family:var(--display);
  font-size:5.4rem;font-weight:300;line-height:.8;
  font-variation-settings:"opsz" 144,"wght" 300,"SOFT" 100;
  color:var(--accent);
  font-style:italic;
  letter-spacing:-.02em;
}
.floor__label{
  font-size:.72rem;letter-spacing:.32em;text-transform:uppercase;
  color:var(--ink-muted);
  writing-mode:vertical-rl;transform:rotate(180deg);
  margin-top:18px;
}

.hero__title{
  font-family:var(--display);
  font-size:clamp(3.6rem,8.6vw,7.8rem);
  font-weight:300;
  font-variation-settings:"opsz" 144,"wght" 300,"SOFT" 100;
  line-height:.95;letter-spacing:-.04em;
  margin:24px 0 26px;
}
.hero__title .line{display:block;opacity:0;transform:translateY(40px);animation:rise2 1s ease forwards}
.hero__title .line:nth-child(1){animation-delay:.1s}
.hero__title .line:nth-child(2){animation-delay:.25s}
.hero__title .line:nth-child(3){animation-delay:.4s}
.hero__title .line--accent{
  font-style:italic;
  font-variation-settings:"opsz" 144,"wght" 600,"SOFT" 50;
  font-weight:600;
  color:var(--accent);
}
.hero__title em{font-style:italic;color:var(--accent-hi);font-variation-settings:"opsz" 144,"wght" 700,"SOFT" 30}
@keyframes rise2{
  to{opacity:1;transform:translateY(0)}
}

.hero__lead{
  font-size:1.12rem;
  color:var(--ink-2);
  max-width:540px;
  margin:0 0 36px;
}
.hero__lead strong{color:var(--ink);font-weight:600}

.hero__ctas{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:38px}

.hero__chips{display:flex;flex-wrap:wrap;gap:10px}
.hero__chips li{
  font-size:.78rem;color:var(--ink-muted);
  padding:8px 14px;border:1px solid var(--line);border-radius:999px;
  background:rgba(245,239,225,.015);
  letter-spacing:.04em;
}
.hero__chips strong{color:var(--accent);font-weight:600}

/* PENTHOUSE DEVICE MOCK -------------------------------- */
.hero__device{position:relative;perspective:1800px}
.penthouse{
  transform:rotateY(-7deg) rotateX(4deg);
  position:relative;
}
.penthouse__frame{
  background:linear-gradient(135deg,#1d1f3a,#0a0c20);
  padding:18px;
  border-radius:24px;
  border:1px solid var(--line-strong);
  box-shadow:
    0 60px 120px -40px rgba(0,0,0,.7),
    0 0 0 1px rgba(212,165,116,.08),
    inset 0 1px 0 rgba(255,255,255,.05);
}
.penthouse__screen{
  background:linear-gradient(180deg,#181a35 0%,#0c0e1f 100%);
  border-radius:14px;
  padding:18px;
  min-height:430px;
  position:relative;
  overflow:hidden;
}
.penthouse__screen::before{
  content:'';position:absolute;inset:0;
  background:
    radial-gradient(circle at 20% 20%,rgba(212,165,116,.18) 0%,transparent 45%),
    radial-gradient(circle at 80% 90%,rgba(76,229,255,.12) 0%,transparent 50%);
  pointer-events:none;
}
.penthouse__bar{
  display:flex;justify-content:space-between;align-items:center;
  font-size:.72rem;color:var(--ink-muted);letter-spacing:.1em;text-transform:uppercase;
  margin-bottom:18px;position:relative;z-index:1;
}
.penthouse__signal{display:inline-flex;gap:3px;align-items:flex-end}
.penthouse__signal i{display:block;width:3px;background:var(--accent);border-radius:1px}
.penthouse__signal i:nth-child(1){height:5px}
.penthouse__signal i:nth-child(2){height:8px}
.penthouse__signal i:nth-child(3){height:11px}
.penthouse__signal i:nth-child(4){height:14px}

.penthouse__poster{
  position:relative;
  border-radius:12px;
  height:240px;
  background:
    linear-gradient(135deg,rgba(212,165,116,.5),rgba(76,229,255,.3)),
    linear-gradient(180deg,#2a1a08,#0a0c20);
  padding:22px;
  display:flex;flex-direction:column;justify-content:flex-end;
  overflow:hidden;
  z-index:1;
}
.penthouse__poster::after{
  content:'';position:absolute;inset:0;
  background:radial-gradient(circle at 70% 30%,rgba(255,255,255,.18),transparent 50%);
}
.poster__title{
  font-family:var(--display);
  font-weight:300;font-style:italic;
  font-size:2.4rem;
  font-variation-settings:"opsz" 144,"wght" 300,"SOFT" 100;
  line-height:.95;
  letter-spacing:-.02em;
  position:relative;z-index:1;
  color:var(--ink);
}
.poster__title em{color:var(--accent-hi);font-weight:600;font-variation-settings:"opsz" 144,"wght" 600,"SOFT" 30}
.poster__meta{
  font-size:.72rem;letter-spacing:.2em;color:var(--ink-2);
  margin-top:8px;position:relative;z-index:1;
}
.poster__play{
  position:absolute;top:18px;right:18px;
  width:54px;height:54px;border-radius:50%;
  display:grid;place-items:center;
  background:rgba(245,239,225,.95);color:#1a1108;
  z-index:2;
  animation:pulsePlay 2.4s ease infinite;
}
@keyframes pulsePlay{
  0%,100%{box-shadow:0 0 0 0 rgba(212,165,116,.5)}
  50%{box-shadow:0 0 0 16px rgba(212,165,116,0)}
}

.penthouse__rail{margin-top:18px;position:relative;z-index:1}
.rail__head{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-muted);margin-bottom:10px}
.rail__items{display:flex;gap:8px}
.rail__items span{
  flex:1;height:54px;
  display:grid;place-items:center;
  background:rgba(245,239,225,.04);
  border:1px solid var(--line);
  border-radius:8px;
  font-family:var(--display);font-weight:600;font-size:1.1rem;letter-spacing:.04em;
  font-variation-settings:"opsz" 14,"wght" 600;
  color:var(--accent);
  transition:all .25s ease;
}
.rail__items span:hover{background:var(--accent);color:#1a1108;border-color:var(--accent);transform:translateY(-2px)}

.penthouse__caption{
  margin-top:14px;
  text-align:center;
  font-size:.72rem;letter-spacing:.32em;text-transform:uppercase;color:var(--ink-muted);
}

/* SKYLINE MARQUEE ------------------------------------- */
.skyline{
  border-block:1px solid var(--line);
  background:var(--bg-deeper);
  padding:24px 0;overflow:hidden;white-space:nowrap;
}
.skyline__track{display:flex;gap:34px;animation:slide 40s linear infinite;width:max-content}
.skyline__group{display:flex;gap:34px;align-items:center;flex-shrink:0}
.skyline__group span{
  font-family:var(--display);
  font-weight:500;font-size:1.4rem;letter-spacing:.18em;
  font-variation-settings:"opsz" 18,"wght" 500;
  color:var(--ink-muted);text-transform:uppercase;
}
.skyline__group span:nth-child(2n+1){color:var(--ink)}
.skyline__group span:nth-child(2n){color:var(--accent);font-size:1.1rem}
@keyframes slide{
  from{transform:translateX(0)}
  to{transform:translateX(-50%)}
}

/* STATS ----------------------------------------------- */
.stats{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:0;padding:90px 24px;
  border-bottom:1px solid var(--line);
}
.stat{padding:0 32px;border-right:1px solid var(--line)}
.stat:last-child{border-right:none}
.stat__num{
  font-family:var(--display);
  font-weight:300;font-style:italic;
  font-variation-settings:"opsz" 144,"wght" 300,"SOFT" 100;
  font-size:clamp(3.2rem,5.2vw,5rem);
  line-height:1;letter-spacing:-.04em;
  color:var(--ink);
}
.stat__num em{color:var(--accent);font-style:italic;font-size:.5em;font-weight:600;font-variation-settings:"opsz" 72,"wght" 600;margin-left:2px}
.stat__label{
  margin-top:14px;font-size:.78rem;
  color:var(--ink-muted);text-transform:uppercase;letter-spacing:.2em;
  line-height:1.4;
}

/* SECTIONS GENERIC ------------------------------------- */
.section{padding:140px 0;position:relative}
.section__head{margin-bottom:64px;max-width:760px}
.section__head--center{margin-inline:auto;text-align:center}
.section__head--split{
  max-width:none;
  display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:end;
}
.section__head--split .section__lead{margin:0}
.section__head--center .floor__tag{padding-left:0}
.section__head--center .floor__tag::before{display:none}

.section__title{
  font-family:var(--display);
  font-weight:300;
  font-variation-settings:"opsz" 144,"wght" 300,"SOFT" 100;
  font-size:clamp(2.8rem,6vw,5.4rem);
  line-height:.96;letter-spacing:-.04em;
  margin:0 0 26px;
}
.section__title em{
  font-style:italic;color:var(--accent);
  font-variation-settings:"opsz" 144,"wght" 500,"SOFT" 50;
  font-weight:500;
}
.section__lead{font-size:1.05rem;color:var(--ink-2);max-width:560px;margin:0;line-height:1.65}
.section__lead strong{color:var(--ink);font-weight:600}

/* TRIAL ------------------------------------------------ */
.trial{padding:30px 0 80px}
.trial__panel{
  display:grid;grid-template-columns:1.4fr 1fr;
  border:1px solid var(--line-strong);
  border-radius:var(--radius-l);
  overflow:hidden;
  background:linear-gradient(135deg,#171a3a 0%,var(--bg-card) 70%);
  position:relative;
}
.trial__panel::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(circle at 90% 0%,rgba(212,165,116,.25),transparent 55%);
  pointer-events:none;
}
.trial__copy{padding:60px;position:relative;z-index:1}
.trial__title{
  font-family:var(--display);
  font-weight:300;
  font-variation-settings:"opsz" 144,"wght" 300,"SOFT" 100;
  font-size:clamp(2.6rem,5.6vw,4.6rem);
  line-height:.94;letter-spacing:-.04em;
  margin:18px 0 24px;
}
.trial__title em{
  color:var(--accent);font-style:italic;
  font-variation-settings:"opsz" 144,"wght" 600,"SOFT" 30;
  font-weight:600;
}
.trial__lead{font-size:1.05rem;color:var(--ink-2);margin:0 0 28px;max-width:520px}
.trial__lead strong{color:var(--ink);font-weight:600}
.trial__list{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:0 0 32px}
.trial__list li{
  display:flex;align-items:flex-start;gap:10px;
  font-size:.92rem;color:var(--ink-2);
}
.trial__list span{
  color:var(--accent);font-size:.9rem;flex-shrink:0;
  margin-top:2px;
}
.trial__list strong{color:var(--ink);font-weight:600}

.trial__elev{
  background:rgba(0,0,0,.4);
  border-left:1px solid var(--line);
  padding:60px 44px;
  display:flex;flex-direction:column;justify-content:center;
  position:relative;z-index:1;
  text-align:center;
}
.elev__head{
  font-size:.74rem;letter-spacing:.32em;text-transform:uppercase;color:var(--ink-muted);
  margin-bottom:24px;
  position:relative;
}
.elev__head::after{
  content:'';display:block;
  width:24px;height:1px;
  background:var(--accent);
  margin:8px auto 0;
}
.elev__chrono{margin-bottom:24px}
.elev__floor{
  display:block;
  font-family:var(--display);
  font-weight:300;font-style:italic;
  font-variation-settings:"opsz" 144,"wght" 300,"SOFT" 100;
  font-size:7rem;line-height:1;letter-spacing:-.04em;
  color:var(--accent);
}
.elev__sub{font-size:.82rem;color:var(--ink-muted);letter-spacing:.06em}

.elev__bar{
  height:2px;border-radius:999px;
  background:rgba(245,239,225,.06);
  margin:24px 0;position:relative;overflow:hidden;
}
.elev__bar span{
  position:absolute;left:0;top:0;bottom:0;width:30%;
  background:linear-gradient(90deg,var(--accent),var(--ice));
  border-radius:999px;
  animation:elevSlide 2.4s ease-in-out infinite;
}
@keyframes elevSlide{
  0%,100%{margin-left:0;width:30%}
  50%{margin-left:35%;width:50%}
}

.elev__list{display:flex;flex-direction:column;gap:10px;text-align:left;font-size:.92rem;color:var(--ink-2)}
.elev__list b{color:var(--accent);font-family:var(--display);margin-right:6px;font-weight:600}
.elev__list em{color:var(--ink);font-style:italic;font-weight:600}

/* PROGRAMAÇÃO · CATS ---------------------------------- */
.cats{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:14px;
}
.cat{
  position:relative;
  padding:32px 28px;
  background:var(--bg-card);
  border:1px solid var(--line);
  border-radius:var(--radius-m);
  transition:transform .35s ease,border-color .35s ease,background .35s ease;
  overflow:hidden;
  display:flex;flex-direction:column;
}
.cat::before{
  content:'';position:absolute;left:0;top:0;bottom:0;
  width:3px;
  background:linear-gradient(180deg,var(--accent),transparent);
  opacity:.4;transition:opacity .35s ease;
}
.cat:hover{transform:translateY(-4px);border-color:var(--line-strong);background:var(--bg-elev)}
.cat:hover::before{opacity:1}
.cat__floor{
  position:absolute;top:18px;right:22px;
  font-family:var(--display);
  font-weight:300;font-style:italic;
  font-variation-settings:"opsz" 96,"wght" 300,"SOFT" 100;
  font-size:1.6rem;color:var(--ink-muted);letter-spacing:-.02em;
}
.cat h3{
  font-family:var(--display);
  font-weight:400;
  font-variation-settings:"opsz" 36,"wght" 400,"SOFT" 50;
  font-size:1.5rem;letter-spacing:-.01em;
  margin:32px 0 8px;
  color:var(--ink);
}
.cat p{color:var(--ink-muted);font-size:.92rem;margin:0 0 22px;flex:1}
.cat__count{
  display:inline-block;align-self:flex-start;
  font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--accent);font-weight:600;
  padding:6px 12px;border:1px solid rgba(212,165,116,.3);border-radius:999px;
  background:rgba(212,165,116,.06);
}
.cat--xl{
  grid-column:span 2;grid-row:span 2;
  padding:50px;
  background:linear-gradient(140deg,#1a1530 0%,var(--bg-card) 65%);
  border-color:rgba(212,165,116,.2);
}
.cat--xl .cat__floor{font-size:2.6rem}
.cat--xl h3{font-size:2.4rem;margin-top:48px}
.cat--xl p{font-size:1.05rem;color:var(--ink-2)}

/* SUITES (planos) ------------------------------------- */
.suite-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:20px;align-items:stretch;
}
.suite{
  position:relative;
  padding:40px 32px;
  background:var(--bg-card);
  border:1px solid var(--line);
  border-radius:var(--radius-l);
  display:flex;flex-direction:column;
  transition:all .35s ease;
}
.suite:hover{transform:translateY(-4px);border-color:var(--line-strong)}

.suite__head{
  display:flex;justify-content:space-between;align-items:baseline;
  margin-bottom:24px;
  padding-bottom:18px;
  border-bottom:1px solid var(--line);
}
.suite h3{
  font-family:var(--display);
  font-weight:400;
  font-variation-settings:"opsz" 48,"wght" 400,"SOFT" 50;
  font-size:1.8rem;letter-spacing:-.01em;
  margin:0;
}
.suite__floor{
  font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--accent);
}
.suite__price{
  display:flex;align-items:baseline;gap:4px;
  font-family:var(--display);
  margin-bottom:6px;
}
.suite__price span{font-size:1.3rem;color:var(--ink-2);font-weight:300;font-variation-settings:"opsz" 24,"wght" 300}
.suite__price strong{
  font-size:4.6rem;line-height:1;letter-spacing:-.04em;
  font-weight:300;font-style:italic;
  font-variation-settings:"opsz" 144,"wght" 300,"SOFT" 100;
  color:var(--ink);
}
.suite__price strong em{font-size:.55em;font-weight:400;color:var(--ink-2);font-variation-settings:"opsz" 72,"wght" 400}
.suite__price small{font-size:1rem;color:var(--ink-muted);margin-left:6px;font-family:var(--body);font-weight:500}
.suite__total{font-size:.82rem;color:var(--ink-muted);margin:0 0 24px;letter-spacing:.04em}
.suite ul{display:flex;flex-direction:column;gap:12px;margin:24px 0 32px;flex:1}
.suite li{
  display:flex;align-items:flex-start;gap:10px;
  font-size:.92rem;color:var(--ink-2);
  padding-left:22px;position:relative;
}
.suite li::before{
  content:'';position:absolute;left:0;top:7px;
  width:10px;height:10px;
  border:1px solid var(--accent);
  border-radius:50%;
  background:transparent;
  transition:background .25s ease;
}
.suite li::after{
  content:'';position:absolute;left:3px;top:10px;
  width:4px;height:4px;border-radius:50%;
  background:var(--accent);
}

.suite--featured{
  background:linear-gradient(160deg,#1f1a35 0%,var(--bg-card) 70%);
  border-color:var(--accent);
  box-shadow:0 30px 80px -30px var(--accent-glow);
  transform:translateY(-12px);
}
.suite--featured:hover{transform:translateY(-16px)}
.suite__ribbon{
  position:absolute;top:-1px;left:50%;transform:translateX(-50%);
  font-size:.7rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;
  background:var(--accent);color:#1a1108;
  padding:8px 18px;border-radius:0 0 12px 12px;
  white-space:nowrap;
}

.suites__legal{
  margin-top:32px;text-align:center;font-size:.82rem;color:var(--ink-muted);
}

/* DEVICES (acesso) ----------------------------------- */
.dev-grid{
  display:grid;grid-template-columns:repeat(6,1fr);gap:14px;
}
.dev{
  background:var(--bg-card);
  border:1px solid var(--line);
  border-radius:var(--radius-m);
  padding:32px 22px;
  text-align:center;
  transition:all .35s ease;
}
.dev:hover{transform:translateY(-3px);border-color:var(--accent);background:var(--bg-elev)}
.dev__sym{
  font-family:var(--display);font-weight:300;
  font-size:2.4rem;color:var(--accent);
  margin-bottom:14px;line-height:1;
}
.dev h4{
  font-family:var(--display);
  font-weight:400;
  font-variation-settings:"opsz" 24,"wght" 400;
  font-size:1.15rem;letter-spacing:-.01em;
  margin:0 0 6px;
}
.dev span{font-size:.75rem;color:var(--ink-muted);letter-spacing:.04em}

/* ENGENHARIA ------------------------------------------ */
.eng-grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:0;
  border-top:1px solid var(--line);
  border-left:1px solid var(--line);
}
.eng{
  padding:48px 36px;
  border-bottom:1px solid var(--line);
  border-right:1px solid var(--line);
  position:relative;
  transition:background .35s ease;
}
.eng:hover{background:var(--bg-card)}
.eng__num{
  display:block;
  font-family:var(--display);
  font-weight:300;font-style:italic;
  font-variation-settings:"opsz" 96,"wght" 300,"SOFT" 100;
  font-size:2.4rem;
  color:var(--accent);margin-bottom:18px;letter-spacing:-.02em;
}
.eng h3{
  font-family:var(--display);
  font-weight:400;
  font-variation-settings:"opsz" 36,"wght" 400,"SOFT" 50;
  font-size:1.6rem;letter-spacing:-.01em;
  margin:0 0 14px;
}
.eng p{color:var(--ink-muted);font-size:.95rem;margin:0;line-height:1.65}

/* RESIDENTES (depoimentos) ---------------------------- */
.testi-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:20px;
}
.testi{
  margin:0;
  padding:38px 32px;
  background:var(--bg-card);
  border:1px solid var(--line);
  border-radius:var(--radius-m);
  position:relative;
}
.testi::before{
  content:'';position:absolute;top:0;left:32px;
  width:36px;height:2px;background:var(--accent);
}
.testi blockquote{
  margin:0 0 24px;padding:0;
  font-family:var(--display);
  font-weight:300;font-style:italic;
  font-variation-settings:"opsz" 18,"wght" 300,"SOFT" 80;
  font-size:1.15rem;line-height:1.5;color:var(--ink);
}
.testi figcaption{font-size:.82rem;line-height:1.6;color:var(--ink-muted)}
.testi figcaption strong{color:var(--ink);font-weight:600;letter-spacing:.04em}

/* RECEPÇÃO · FAQ -------------------------------------- */
.faq-list{display:flex;flex-direction:column;gap:8px;max-width:920px}
.faq-item{
  border:1px solid var(--line);
  border-radius:var(--radius-m);
  background:var(--bg-card);
  overflow:hidden;
  transition:border-color .25s ease,background .25s ease;
}
.faq-item[open]{border-color:var(--accent);background:var(--bg-elev)}
.faq-item summary{
  list-style:none;cursor:pointer;
  padding:24px 30px;
  font-weight:500;font-size:1.05rem;
  display:flex;justify-content:space-between;align-items:center;gap:24px;
  font-family:var(--display);
  font-variation-settings:"opsz" 18,"wght" 500,"SOFT" 30;
  letter-spacing:-.01em;
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{
  content:'';width:14px;height:14px;flex-shrink:0;
  background:
    linear-gradient(currentColor,currentColor) center/100% 1.5px no-repeat,
    linear-gradient(currentColor,currentColor) center/1.5px 100% no-repeat;
  transition:transform .3s ease;
  color:var(--accent);
}
.faq-item[open] summary::after{transform:rotate(45deg)}
.faq-item p{padding:0 30px 26px;margin:0;color:var(--ink-2);font-size:.95rem;line-height:1.7}
.faq-item p strong{color:var(--ink);font-weight:600}

/* FINALE (CTA final) ---------------------------------- */
.finale__box{
  position:relative;overflow:hidden;
  padding:90px 60px;
  border-radius:var(--radius-l);
  background:
    radial-gradient(circle at 80% 30%,rgba(212,165,116,.4),transparent 50%),
    radial-gradient(circle at 10% 80%,rgba(76,229,255,.2),transparent 60%),
    linear-gradient(135deg,#1a1530,#0a0c20);
  border:1px solid var(--line-strong);
  text-align:center;
}
.finale__box h2{
  font-family:var(--display);
  font-weight:300;
  font-variation-settings:"opsz" 144,"wght" 300,"SOFT" 100;
  font-size:clamp(2.6rem,5.6vw,4.8rem);
  line-height:.96;letter-spacing:-.04em;
  margin:18px 0 22px;
}
.finale__box h2 em{
  color:var(--accent);font-style:italic;
  font-variation-settings:"opsz" 144,"wght" 600,"SOFT" 30;
  font-weight:600;
}
.finale__box p{font-size:1.1rem;color:var(--ink-2);margin:0 0 36px}
.finale__btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* FOOTER ---------------------------------------------- */
.footer{
  padding:90px 0 30px;
  border-top:1px solid var(--line);
  background:var(--bg-deeper);
}
.footer__inner{
  display:grid;
  grid-template-columns:2fr 1fr 1fr 1fr;
  gap:50px;
  padding-bottom:60px;
  border-bottom:1px solid var(--line);
}
.footer__brand p{color:var(--ink-muted);max-width:340px;margin:18px 0 0;font-size:.92rem}
.footer__col h5{
  font-family:var(--display);
  font-size:.95rem;letter-spacing:.2em;
  font-variation-settings:"opsz" 14,"wght" 600;
  text-transform:uppercase;font-weight:600;
  color:var(--accent);margin:0 0 18px;
}
.footer__col{display:flex;flex-direction:column;gap:10px}
.footer__col a{font-size:.92rem;color:var(--ink-muted);transition:color .25s ease}
.footer__col a:hover{color:var(--ink)}

.footer__bottom{
  display:flex;justify-content:space-between;align-items:center;
  padding-top:28px;
  font-size:.82rem;color:var(--ink-muted);letter-spacing:.04em;
}

/* WHATSAPP FLOAT -------------------------------------- */
.wa-float{
  position:fixed;
  bottom:24px;right:24px;z-index:90;
  width:62px;height:62px;border-radius:50%;
  display:grid;place-items:center;
  background:#25D366;color:#fff;
  box-shadow:0 14px 40px -10px rgba(37,211,102,.55),0 0 0 1px rgba(0,0,0,.1);
  transition:transform .25s ease;
}
.wa-float:hover{transform:scale(1.08)}

/* NAV HIGHLIGHT (Teste grátis em destaque) ------------ */
.nav__highlight{
  color:var(--accent) !important;
  font-weight:600 !important;
  position:relative;
}
.nav__highlight::before{
  content:'';
  display:inline-block;
  width:6px;height:6px;border-radius:50%;
  background:var(--accent);
  margin-right:8px;vertical-align:middle;
  box-shadow:0 0 12px var(--accent-glow);
  animation:pulse 1.8s infinite;
}

/* HERO TEST VARIANT ----------------------------------- */
.hero--test .hero__inner--test{
  grid-template-columns:80px 1.05fr .85fr;
  gap:50px 60px;
}

/* TRIAL CARD (sidebar do hero) ------------------------ */
.trial-card{
  position:relative;
  background:linear-gradient(160deg,#1a1a3a 0%,var(--bg-card) 75%);
  border:1px solid var(--line-strong);
  border-radius:var(--radius-l);
  padding:34px 30px;
  box-shadow:0 30px 80px -30px var(--accent-glow);
  align-self:flex-start;
  margin-top:60px;
}
.trial-card__top{display:flex;align-items:center;gap:14px;margin-bottom:22px}
.trial-card__pulse{
  width:46px;height:46px;border-radius:50%;
  background:rgba(76,229,255,.12);
  display:grid;place-items:center;flex-shrink:0;
}
.trial-card__pulse span{
  width:14px;height:14px;border-radius:50%;
  background:var(--ice);
  animation:pulse 1.8s infinite;
}
.trial-card__title{
  font-family:var(--display);
  font-size:1.05rem;font-weight:500;
  font-variation-settings:"opsz" 14,"wght" 500,"SOFT" 30;
  letter-spacing:.04em;
}
.trial-card__sub{font-size:.78rem;color:var(--ink-muted);letter-spacing:.06em;margin-top:2px}
.trial-card__sub span{color:var(--accent);font-weight:600}

.trial-card__progress{margin-bottom:22px}
.trial-card__bar{
  position:relative;
  height:5px;border-radius:999px;
  background:rgba(245,239,225,.06);
  overflow:hidden;margin-bottom:10px;
}
.trial-card__bar span{
  position:absolute;left:0;top:0;bottom:0;width:78%;
  background:linear-gradient(90deg,var(--accent),var(--ice));
  border-radius:999px;
  animation:cardBar 2.4s ease-in-out infinite;
}
@keyframes cardBar{
  0%,100%{width:74%}
  50%{width:88%}
}
.trial-card__counter{font-size:.78rem;color:var(--ink-muted);text-align:right;letter-spacing:.04em}
.trial-card__counter span{color:var(--ink);font-weight:600}

.trial-card__divider{height:1px;background:var(--line);margin:0 0 22px}
.trial-card__h3{
  font-family:var(--display);
  font-weight:400;
  font-variation-settings:"opsz" 18,"wght" 400,"SOFT" 30;
  font-size:1.2rem;letter-spacing:-.01em;
  margin:0 0 16px;
}
.trial-card__steps{display:flex;flex-direction:column;gap:12px;margin:0 0 24px}
.trial-card__steps li{
  display:flex;align-items:center;gap:12px;
  font-size:.95rem;color:var(--ink-2);
}
.trial-card__steps b{
  display:grid;place-items:center;
  width:26px;height:26px;border-radius:50%;
  background:rgba(212,165,116,.14);color:var(--accent);
  font-family:var(--display);font-size:.95rem;
  font-variation-settings:"opsz" 14,"wght" 600;
  flex-shrink:0;
}
.trial-card__steps em{color:var(--ink);font-style:italic;font-weight:500;font-family:var(--display);font-variation-settings:"opsz" 14,"wght" 500,"SOFT" 60}
.trial-card__legal{
  margin:14px 0 0;
  font-size:.74rem;color:var(--ink-muted);text-align:center;line-height:1.5;
}

/* PROOF BAR ------------------------------------------- */
.proof{
  display:grid;grid-template-columns:repeat(4,1fr);gap:0;
  padding:48px 24px;margin-top:40px;
  border-block:1px solid var(--line);
  background:var(--bg-deeper);
}
.proof__item{padding:0 24px;border-right:1px solid var(--line);text-align:center}
.proof__item:last-child{border-right:none}
.proof__item strong{
  display:block;
  font-family:var(--display);
  font-weight:300;font-style:italic;
  font-variation-settings:"opsz" 96,"wght" 300,"SOFT" 100;
  font-size:2.6rem;line-height:1;color:var(--accent);
  margin-bottom:8px;letter-spacing:-.02em;
}
.proof__item span{font-size:.78rem;letter-spacing:.1em;color:var(--ink-muted)}

/* STEPS (como pegar) ---------------------------------- */
.steps{
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;
}
.step{
  position:relative;
  padding:48px 36px;
  background:var(--bg-card);
  border:1px solid var(--line);
  border-radius:var(--radius-l);
  overflow:hidden;
}
.step::before{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,var(--accent),transparent);
}
.step__num{
  display:block;
  font-family:var(--display);
  font-weight:300;font-style:italic;
  font-variation-settings:"opsz" 144,"wght" 300,"SOFT" 100;
  font-size:5rem;line-height:1;letter-spacing:-.04em;
  color:var(--accent);margin-bottom:22px;
}
.step h3{
  font-family:var(--display);
  font-weight:400;
  font-variation-settings:"opsz" 36,"wght" 400,"SOFT" 50;
  font-size:1.6rem;letter-spacing:-.01em;
  margin:0 0 12px;
}
.step p{color:var(--ink-muted);font-size:.95rem;margin:0;line-height:1.65}
.step strong{color:var(--ink);font-weight:600}

/* CONTATO --------------------------------------------- */
.contato__grid{
  display:grid;grid-template-columns:1fr 1.05fr;
  gap:60px;align-items:start;
}
.contato__list{margin-top:40px;display:flex;flex-direction:column;gap:14px}
.contato__list li{
  display:flex;align-items:center;gap:18px;
  padding:18px 22px;
  border:1px solid var(--line);
  border-radius:var(--radius-m);
  background:var(--bg-card);
  transition:border-color .25s ease,background .25s ease;
}
.contato__list li:hover{border-color:var(--line-strong);background:var(--bg-elev)}
.contato__ico{
  width:46px;height:46px;flex-shrink:0;
  display:grid;place-items:center;
  font-size:1.3rem;
  background:rgba(212,165,116,.1);
  border-radius:12px;
}
.contato__list h4{
  font-family:var(--display);
  font-size:1.05rem;letter-spacing:-.01em;
  font-weight:500;
  font-variation-settings:"opsz" 14,"wght" 500,"SOFT" 30;
  margin:0 0 2px;color:var(--ink);
}
.contato__list a{font-size:.95rem;color:var(--ink-muted);transition:color .25s ease}
.contato__list a:hover{color:var(--accent)}

.contato__form{
  background:linear-gradient(160deg,#1a1a3a 0%,var(--bg-card) 75%);
  border:1px solid var(--line-strong);
  border-radius:var(--radius-l);
  padding:42px 38px;
  box-shadow:0 30px 80px -30px var(--accent-glow);
}
.contato__form-title{
  font-family:var(--display);
  font-weight:400;
  font-variation-settings:"opsz" 36,"wght" 400,"SOFT" 50;
  font-size:1.7rem;letter-spacing:-.01em;
  margin:0 0 28px;
}
.field{margin-bottom:18px;display:flex;flex-direction:column;gap:8px}
.field label{
  font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--ink-2);font-weight:600;
}
.field label span{color:var(--ink-muted);font-weight:400;text-transform:none;letter-spacing:0;font-size:.8rem;margin-left:4px}
.field input,
.field select,
.field textarea{
  width:100%;
  padding:14px 16px;
  font-family:var(--body);font-size:.95rem;
  background:rgba(0,0,0,.35);
  border:1px solid var(--line);
  border-radius:12px;
  color:var(--ink);
  transition:border-color .25s ease,background .25s ease,box-shadow .25s ease;
  outline:none;
}
.field input::placeholder,
.field textarea::placeholder{color:var(--ink-muted)}
.field input:focus,
.field select:focus,
.field textarea:focus{
  border-color:var(--accent);
  background:rgba(0,0,0,.55);
  box-shadow:0 0 0 4px rgba(212,165,116,.12);
}
.field input:invalid:not(:placeholder-shown),
.field select:invalid:not(:focus){
  border-color:rgba(212,165,116,.45);
}
.field select{
  appearance:none;
  background-image:linear-gradient(45deg,transparent 50%,var(--ink-muted) 50%),linear-gradient(135deg,var(--ink-muted) 50%,transparent 50%);
  background-position:calc(100% - 22px) 50%,calc(100% - 16px) 50%;
  background-size:6px 6px,6px 6px;
  background-repeat:no-repeat;
  padding-right:44px;
}
.field select option{background:var(--bg-deep);color:var(--ink)}
.field textarea{resize:vertical;min-height:80px;font-family:var(--body)}

.checkbox{
  display:flex;gap:10px;align-items:flex-start;
  margin:8px 0 22px;
  font-size:.85rem;color:var(--ink-2);line-height:1.5;cursor:pointer;
}
.checkbox input{
  appearance:none;
  width:18px;height:18px;flex-shrink:0;
  border:1px solid var(--line-strong);
  border-radius:4px;
  background:rgba(0,0,0,.35);
  cursor:pointer;
  transition:all .2s ease;
  margin-top:1px;
}
.checkbox input:checked{
  background:var(--accent);border-color:var(--accent);
  background-image:linear-gradient(45deg,transparent 60%,#1a1108 60%,#1a1108 65%,transparent 65%),linear-gradient(135deg,transparent 35%,#1a1108 35%,#1a1108 40%,transparent 40%);
}

.contato__legal{
  margin:14px 0 0;
  font-size:.74rem;color:var(--ink-muted);text-align:center;line-height:1.5;
}

/* LEGAL PAGES ---------------------------------------- */
.legal-hero{
  position:relative;
  padding:170px 0 60px;
  border-bottom:1px solid var(--line);
  overflow:hidden;
  isolation:isolate;
}
.legal-hero::before{
  content:'';position:absolute;inset:0;z-index:-1;
  background:radial-gradient(circle at 80% 20%,rgba(212,165,116,.18),transparent 55%);
}
.legal-hero h1{
  font-family:var(--display);
  font-weight:300;
  font-variation-settings:"opsz" 144,"wght" 300,"SOFT" 100;
  font-size:clamp(2.8rem,6vw,5rem);
  line-height:.96;letter-spacing:-.04em;
  margin:0 0 18px;
}
.legal-hero h1 em{
  color:var(--accent);font-style:italic;
  font-variation-settings:"opsz" 144,"wght" 600,"SOFT" 30;
  font-weight:600;
}
.legal-hero p{
  color:var(--ink-muted);font-size:.95rem;
  letter-spacing:.04em;
  max-width:680px;margin:0;
}

.legal{
  padding:80px 0 120px;
  display:grid;
  grid-template-columns:240px 1fr;
  gap:80px;
  align-items:start;
}
.legal__toc{
  position:sticky;top:100px;
  border-left:1px solid var(--line);
  padding-left:22px;
}
.legal__toc h5{
  font-family:var(--display);
  font-size:.85rem;letter-spacing:.2em;
  font-variation-settings:"opsz" 14,"wght" 600;
  text-transform:uppercase;font-weight:600;
  color:var(--accent);margin:0 0 16px;
}
.legal__toc ol{display:flex;flex-direction:column;gap:8px;counter-reset:toc}
.legal__toc li{counter-increment:toc;font-size:.88rem;line-height:1.5}
.legal__toc li::before{
  content:counter(toc,decimal-leading-zero) ' · ';
  color:var(--accent);font-weight:500;font-family:var(--display);
}
.legal__toc a{color:var(--ink-muted);transition:color .25s ease}
.legal__toc a:hover{color:var(--ink)}

.legal__body{max-width:780px}
.legal__body h2{
  font-family:var(--display);
  font-weight:400;
  font-variation-settings:"opsz" 36,"wght" 400,"SOFT" 50;
  font-size:1.9rem;letter-spacing:-.01em;
  margin:54px 0 16px;padding-top:28px;
  border-top:1px solid var(--line);
}
.legal__body h2:first-child{margin-top:0;padding-top:0;border-top:none}
.legal__body h3{
  font-family:var(--display);
  font-weight:500;
  font-variation-settings:"opsz" 18,"wght" 500,"SOFT" 30;
  font-size:1.15rem;letter-spacing:0;
  margin:28px 0 10px;color:var(--ink);
}
.legal__body p,.legal__body li{
  color:var(--ink-2);font-size:.98rem;line-height:1.75;
  margin:0 0 14px;
}
.legal__body strong{color:var(--ink);font-weight:600}
.legal__body ul,.legal__body ol{
  margin:0 0 18px;padding-left:24px;list-style:disc;
}
.legal__body ol{list-style:decimal}
.legal__body li{padding-left:6px;margin-bottom:8px}
.legal__body a{color:var(--accent);text-decoration:underline;text-underline-offset:3px}
.legal__body a:hover{color:var(--accent-hi)}

.legal__callout{
  background:linear-gradient(135deg,rgba(212,165,116,.08),rgba(212,165,116,.02));
  border:1px solid rgba(212,165,116,.25);
  border-radius:var(--radius-m);
  padding:24px 28px;margin:24px 0;
}
.legal__callout p:last-child{margin-bottom:0}

/* BLOG INDEX ------------------------------------------ */
.blog-hero{
  padding:160px 0 60px;border-bottom:1px solid var(--line);
  position:relative;overflow:hidden;isolation:isolate;
}
.blog-hero::before{
  content:'';position:absolute;inset:0;z-index:-1;
  background:radial-gradient(circle at 70% 30%,rgba(212,165,116,.15),transparent 55%);
}
.blog-hero h1{
  font-family:var(--display);
  font-weight:300;
  font-variation-settings:"opsz" 144,"wght" 300,"SOFT" 100;
  font-size:clamp(3rem,7vw,5.6rem);
  line-height:.95;letter-spacing:-.04em;
  margin:0 0 22px;
}
.blog-hero h1 em{
  color:var(--accent);font-style:italic;
  font-variation-settings:"opsz" 144,"wght" 600,"SOFT" 30;
  font-weight:600;
}
.blog-hero p{font-size:1.1rem;color:var(--ink-muted);max-width:620px;margin:0}

.blog-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:24px;
  padding:80px 0 120px;
}
.blog-card{
  background:var(--bg-card);
  border:1px solid var(--line);
  border-radius:var(--radius-m);
  padding:32px 28px;
  display:flex;flex-direction:column;
  transition:transform .35s ease,border-color .35s ease,background .35s ease;
}
.blog-card:hover{transform:translateY(-4px);border-color:var(--line-strong);background:var(--bg-elev)}
.blog-card__cat{
  font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--accent);margin-bottom:18px;font-weight:600;
}
.blog-card h2{
  font-family:var(--display);
  font-weight:400;
  font-variation-settings:"opsz" 36,"wght" 400,"SOFT" 50;
  font-size:1.45rem;line-height:1.15;letter-spacing:-.01em;
  margin:0 0 14px;color:var(--ink);
}
.blog-card p{color:var(--ink-muted);font-size:.92rem;line-height:1.6;margin:0 0 22px;flex:1}
.blog-card__meta{
  display:flex;justify-content:space-between;align-items:center;
  font-size:.78rem;color:var(--ink-muted);
  padding-top:18px;border-top:1px solid var(--line);
}
.blog-card__meta strong{color:var(--accent);font-weight:600;letter-spacing:.04em}

/* BLOG POST ------------------------------------------- */
.post-hero{
  padding:160px 0 60px;
  border-bottom:1px solid var(--line);
  position:relative;overflow:hidden;isolation:isolate;
}
.post-hero::before{
  content:'';position:absolute;inset:0;z-index:-1;
  background:radial-gradient(circle at 80% 20%,rgba(212,165,116,.12),transparent 55%);
}
.post-meta{
  display:flex;gap:14px;align-items:center;flex-wrap:wrap;
  font-size:.82rem;color:var(--ink-muted);
  margin-bottom:28px;
}
.post-meta__cat{
  color:var(--accent);font-weight:600;letter-spacing:.16em;
  text-transform:uppercase;
}
.post-meta__sep{color:var(--line-strong)}
.post-hero h1{
  font-family:var(--display);
  font-weight:400;
  font-variation-settings:"opsz" 144,"wght" 400,"SOFT" 60;
  font-size:clamp(2.4rem,5.6vw,4.4rem);
  line-height:1.05;letter-spacing:-.02em;
  margin:0 0 22px;max-width:880px;
}
.post-hero h1 em{
  color:var(--accent);font-style:italic;
  font-variation-settings:"opsz" 144,"wght" 600,"SOFT" 30;
  font-weight:600;
}
.post-hero p{font-size:1.1rem;color:var(--ink-2);max-width:680px;margin:0;line-height:1.55}

.post{padding:70px 0 120px}
.post__body{max-width:780px;margin-inline:auto}
.post__body p,.post__body li{
  color:var(--ink-2);font-size:1.05rem;line-height:1.8;
  margin:0 0 18px;
}
.post__body p:first-child{
  font-size:1.18rem;color:var(--ink);
  font-family:var(--body);font-weight:400;
}
.post__body h2{
  font-family:var(--display);
  font-weight:400;
  font-variation-settings:"opsz" 48,"wght" 400,"SOFT" 50;
  font-size:2rem;letter-spacing:-.01em;
  margin:54px 0 18px;line-height:1.15;
}
.post__body h2 em{
  color:var(--accent);font-style:italic;
  font-variation-settings:"opsz" 48,"wght" 600,"SOFT" 30;
  font-weight:600;
}
.post__body h3{
  font-family:var(--display);
  font-weight:500;
  font-variation-settings:"opsz" 24,"wght" 500,"SOFT" 30;
  font-size:1.35rem;letter-spacing:-.01em;
  margin:36px 0 12px;color:var(--ink);
}
.post__body strong{color:var(--ink);font-weight:600}
.post__body ul,.post__body ol{margin:0 0 22px;padding-left:24px}
.post__body ul{list-style:disc}
.post__body ol{list-style:decimal}
.post__body li{margin-bottom:10px;padding-left:6px}
.post__body a{color:var(--accent);text-decoration:underline;text-underline-offset:3px}
.post__body a:hover{color:var(--accent-hi)}
.post__body blockquote{
  margin:32px 0;padding:22px 28px;
  border-left:3px solid var(--accent);
  background:rgba(212,165,116,.04);
  border-radius:0 12px 12px 0;
  font-family:var(--display);
  font-style:italic;font-weight:400;
  font-variation-settings:"opsz" 18,"wght" 400,"SOFT" 80;
  font-size:1.1rem;line-height:1.55;
  color:var(--ink);
}
.post__body code{
  background:rgba(212,165,116,.1);
  border:1px solid rgba(212,165,116,.2);
  border-radius:6px;padding:2px 8px;
  font-family:'DM Mono','Fira Code',monospace;
  font-size:.92rem;color:var(--accent-hi);
}
.post__cta{
  margin:50px 0;padding:36px;
  background:linear-gradient(135deg,#1a1a3a,var(--bg-card));
  border:1px solid var(--line-strong);
  border-radius:var(--radius-m);
  text-align:center;
}
.post__cta h3{
  font-family:var(--display);
  font-weight:400;
  font-variation-settings:"opsz" 36,"wght" 400,"SOFT" 50;
  font-size:1.6rem;margin:0 0 10px;
}
.post__cta h3 em{color:var(--accent);font-style:italic}
.post__cta p{color:var(--ink-muted);margin:0 0 22px;font-size:.95rem}

.post-related{
  border-top:1px solid var(--line);
  padding:60px 0;background:var(--bg-deeper);
}
.post-related h3{
  font-family:var(--display);
  font-size:.92rem;letter-spacing:.2em;
  font-variation-settings:"opsz" 14,"wght" 600;
  text-transform:uppercase;font-weight:600;
  color:var(--accent);margin:0 0 28px;
}
.post-related__grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:18px;
}

/* RESPONSIVE legal/blog ------------------------------ */
@media (max-width:1180px){
  .blog-grid{grid-template-columns:repeat(2,1fr)}
  .post-related__grid{grid-template-columns:1fr 1fr}
}
@media (max-width:820px){
  .legal{grid-template-columns:1fr;gap:40px}
  .legal__toc{position:static;border-left:none;border-top:1px solid var(--line);padding:24px 0 0}
  .legal-hero{padding:130px 0 50px}
  .blog-hero{padding:130px 0 50px}
  .blog-grid{grid-template-columns:1fr}
  .post-hero{padding:130px 0 50px}
  .post-related__grid{grid-template-columns:1fr}
}

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

/* RESPONSIVE ----------------------------------------- */
@media (max-width:1180px){
  .hero__inner{grid-template-columns:60px 1fr;gap:40px;align-items:flex-start}
  .hero__device{grid-column:span 2;margin-top:40px;max-width:560px;margin-inline:auto}
  .hero--test .hero__inner--test{grid-template-columns:60px 1fr;gap:40px}
  .trial-card{grid-column:span 2;margin-top:30px;max-width:520px;width:100%;margin-inline:auto}
  .floor{padding-top:60px}
  .floor__num{font-size:4.4rem}

  .cats{grid-template-columns:repeat(3,1fr)}
  .cat--xl{grid-column:span 3;grid-row:span 1}

  .dev-grid{grid-template-columns:repeat(3,1fr)}
  .testi-grid{grid-template-columns:1fr 1fr}
  .footer__inner{grid-template-columns:1fr 1fr}
}
@media (max-width:820px){
  .nav__menu{display:none}
  .nav__menu.is-open{
    display:flex;flex-direction:column;gap:0;
    position:absolute;top:100%;left:0;right:0;
    background:rgba(7,9,26,.96);backdrop-filter:blur(20px);
    border-block:1px solid var(--line);padding:18px 24px;
  }
  .nav__menu.is-open a{padding:14px 0;border-bottom:1px solid var(--line)}
  .nav__menu.is-open a:last-child{border-bottom:none}
  .nav__menu.is-open a::after{display:none}
  .nav__cta{display:none}
  .nav__toggle{display:flex}
  .tower-rule{display:none}

  .hero{padding:140px 0 80px}
  .hero__inner{grid-template-columns:1fr;gap:30px}
  .floor{flex-direction:row;align-items:center;padding-top:0}
  .floor::before{display:none}
  .floor__num{font-size:2.8rem}
  .floor__label{writing-mode:initial;transform:none;margin:0 0 0 16px}

  .section{padding:90px 0}
  .stats{grid-template-columns:repeat(2,1fr);padding:50px 24px}
  .stat{padding:24px;border-right:none}
  .stat:nth-child(odd){border-right:1px solid var(--line)}
  .stat:nth-child(-n+2){border-bottom:1px solid var(--line)}

  .section__head--split{grid-template-columns:1fr;gap:20px;align-items:start}

  .trial__panel{grid-template-columns:1fr}
  .trial__copy{padding:40px 28px}
  .trial__list{grid-template-columns:1fr}
  .trial__elev{padding:40px 28px;border-left:none;border-top:1px solid var(--line)}

  .cats{grid-template-columns:1fr 1fr}
  .cat--xl{grid-column:span 2;padding:34px}
  .cat--xl h3{font-size:1.9rem}

  .dev-grid{grid-template-columns:1fr 1fr}
  .suite-grid{grid-template-columns:1fr}
  .suite--featured{transform:none}
  .suite--featured:hover{transform:translateY(-4px)}

  .eng-grid{grid-template-columns:1fr}
  .testi-grid{grid-template-columns:1fr}

  .hero--test .hero__inner--test{grid-template-columns:1fr;gap:30px}
  .proof{grid-template-columns:1fr 1fr;gap:0;padding:24px}
  .proof__item{padding:18px 0;border-right:none}
  .proof__item:nth-child(odd){border-right:1px solid var(--line)}
  .proof__item:nth-child(-n+2){border-bottom:1px solid var(--line)}
  .steps{grid-template-columns:1fr;gap:14px}
  .step{padding:36px 28px}
  .contato__grid{grid-template-columns:1fr;gap:40px}
  .contato__form{padding:32px 24px}

  .finale__box{padding:48px 28px}
  .footer__inner{grid-template-columns:1fr 1fr;gap:32px}
  .footer__bottom{flex-direction:column;gap:8px}
}
@media (max-width:480px){
  .cats{grid-template-columns:1fr}
  .cat--xl{grid-column:span 1;padding:30px}
  .dev-grid{grid-template-columns:1fr 1fr}
  .footer__inner{grid-template-columns:1fr}
  .hero__title{font-size:3.6rem}
  .penthouse__poster{height:200px}
  .poster__title{font-size:1.8rem}
}

/* ==========================================================
   MOBILE OPTIMIZATION
   ========================================================== */

/* iOS safe-area insets (notch/home-indicator) ---------- */
@supports (padding: max(0px)) {
  .nav__inner{
    padding-left:max(24px,env(safe-area-inset-left));
    padding-right:max(24px,env(safe-area-inset-right));
  }
  .container{
    padding-left:max(24px,env(safe-area-inset-left));
    padding-right:max(24px,env(safe-area-inset-right));
  }
  .wa-float{
    bottom:max(24px,env(safe-area-inset-bottom));
    right:max(24px,env(safe-area-inset-right));
  }
  .mobile-cta{
    padding-bottom:max(12px,env(safe-area-inset-bottom));
  }
}

/* Tap-highlight cor da marca em vez de cinza padrão --- */
*{-webkit-tap-highlight-color:rgba(212,165,116,.12)}

/* Hover apenas em dispositivos com hover real --------- */
@media (hover:none){
  .cat:hover,.suite:hover,.blog-card:hover,.dev:hover,
  .step:hover,.testi:hover,.eng:hover,
  .contato__list li:hover,.faq-item[open]{
    transform:none;
  }
  .btn:hover{transform:none}
}

/* Prevent iOS zoom on input focus (sempre ≥16px) ------ */
@media (max-width:820px){
  .field input,
  .field select,
  .field textarea{
    font-size:16px;
  }
}

/* Mobile · refinamentos visuais ------------------------ */
@media (max-width:820px){
  /* === HERO MOBILE === */
  .hero{
    padding:110px 0 50px;
    min-height:auto;
    overflow:hidden;
  }
  .hero__inner{
    display:flex !important;          /* sai do grid · fica como flex column simples */
    flex-direction:column;
    align-items:flex-start;            /* tudo alinhado à esquerda */
    justify-content:flex-start;
    gap:0;
    width:100%;
    grid-template-columns:none;
  }

  /* esconde mockup TV e decoração de fundo no mobile */
  .hero__device{display:none !important}
  .hero__beam{display:none}
  .hero__city{height:30%;opacity:.35}

  /* floor virou pílula brass-leve compacta */
  .floor{
    display:inline-flex;flex-direction:row;align-items:center;
    padding:7px 14px;margin:0 0 20px;
    background:rgba(212,165,116,.08);
    border:1px solid rgba(212,165,116,.22);
    border-radius:999px;
    width:auto;max-width:none;
    flex-shrink:0;
  }
  .floor::before{display:none}
  .floor__num{
    font-size:.95rem;font-style:italic;font-weight:600;
    color:var(--accent);
    font-variation-settings:"opsz" 14,"wght" 600,"SOFT" 30;
    line-height:1;letter-spacing:.04em;
  }
  .floor__label{
    writing-mode:initial;transform:none;
    margin:0 0 0 10px;
    font-size:.68rem;letter-spacing:.18em;
    color:var(--ink-muted);
    line-height:1;
  }

  /* copy ocupa largura total e alinhado à esquerda */
  .hero__copy{
    width:100%;
    max-width:100%;
    text-align:left;
  }
  .hero__title{
    font-size:clamp(2.6rem,9.5vw,3.8rem);
    margin:18px 0 20px;
    line-height:1;
    text-align:left;
    word-break:break-word;
  }
  .hero__title .line{display:block;text-align:left}
  .hero__lead{
    font-size:1rem;line-height:1.55;
    margin:0 0 26px;max-width:100%;text-align:left;
  }
  .hero__ctas{justify-content:flex-start}
  .hero__chips{gap:8px;justify-content:flex-start}
  .hero__chips li{padding:7px 12px;font-size:.74rem}

  .hero__chips{gap:8px}
  .hero__chips li{padding:7px 12px;font-size:.74rem}

  /* sections mais enxutas */
  .section{padding:70px 0}
  .section__head{margin-bottom:44px}
  .section__title{font-size:clamp(2.2rem,7.5vw,3.4rem)}
  .section__lead{font-size:.98rem}

  /* trial panel mais compacto */
  .trial__title{font-size:clamp(2rem,7vw,2.8rem)}
  .elev__floor{font-size:5rem}

  /* legal/blog headings */
  .legal-hero h1{font-size:clamp(2.2rem,8vw,3.4rem)}
  .blog-hero h1{font-size:clamp(2.4rem,8vw,3.6rem)}
  .post-hero h1{font-size:clamp(2rem,7vw,3.2rem)}
  .post__body p,.post__body li{font-size:1rem}
  .post__body h2{font-size:1.65rem;margin:40px 0 14px}

  /* finale */
  .finale__box h2{font-size:clamp(2.2rem,7.5vw,3.4rem)}
  .finale__box p{font-size:1rem}

  /* stats num menor */
  .stat__num{font-size:clamp(2.4rem,9vw,3.6rem)}
}

/* Tap targets ≥48px ----------------------------------- */
/* trial-card no /teste-iptv/ mobile (flex column) ----- */
@media (max-width:820px){
  .trial-card{
    width:100%;max-width:100%;
    margin-top:30px;
    align-self:stretch;
  }
}

@media (max-width:820px){
  .btn{min-height:48px}
  .btn--lg{min-height:54px}
  .nav__menu.is-open a{padding:16px 0;min-height:48px;display:flex;align-items:center}
  .nav__toggle{padding:14px;min-width:48px;min-height:48px;display:flex;justify-content:center;align-items:center}
  .faq-item summary{padding:22px 24px;min-height:64px}
  .footer__col a{padding:6px 0;min-height:32px;display:inline-flex;align-items:center}
  .blog-card{padding:26px 22px}
  .post-meta{font-size:.78rem;flex-wrap:wrap}
}

/* WhatsApp float maior em mobile ---------------------- */
@media (max-width:820px){
  .wa-float{
    width:60px;height:60px;
    bottom:90px;right:18px;
    box-shadow:0 16px 50px -10px rgba(37,211,102,.65),0 0 0 1px rgba(0,0,0,.1);
  }
  .wa-float svg{width:32px;height:32px}
}

/* Mobile sticky CTA bar (só no mobile) ----------------- */
.mobile-cta{
  display:none;
  position:fixed;
  left:0;right:0;bottom:0;
  z-index:95;
  padding:12px 16px;
  background:rgba(7,9,26,.92);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  border-top:1px solid var(--line-strong);
  box-shadow:0 -10px 30px rgba(0,0,0,.4);
}
.mobile-cta__btn{
  display:flex;align-items:center;justify-content:center;gap:10px;
  width:100%;
  padding:14px 20px;
  background:linear-gradient(135deg,var(--accent),var(--accent-hi));
  color:#1a1108;
  font-family:var(--body);
  font-size:.95rem;font-weight:700;letter-spacing:.02em;
  border-radius:999px;
  box-shadow:0 8px 24px -6px var(--accent-glow);
  min-height:50px;
}
.mobile-cta__btn svg{flex-shrink:0}
@media (max-width:820px){
  .mobile-cta{display:block}
  /* padding extra no body para o CTA não cobrir conteúdo */
  body{padding-bottom:74px}
  .footer__bottom{margin-bottom:6px}
}

/* Smaller phones (≤480px) ----------------------------- */
@media (max-width:480px){
  .hero{padding:110px 0 50px}
  .hero__title{font-size:2.6rem}
  .hero__lead{font-size:.95rem;margin-bottom:24px}
  .hero__ctas{flex-direction:column;gap:10px;width:100%;align-items:stretch}
  .hero__ctas .btn{justify-content:center;width:100%}

  .section{padding:60px 0}
  .section__head{margin-bottom:36px}
  .container{padding-inline:18px}

  .penthouse__screen{min-height:300px;padding:14px}
  .penthouse__poster{height:170px;padding:18px}
  .poster__title{font-size:1.6rem}
  .rail__items span{height:42px;font-size:.95rem}

  .stat{padding:18px}
  .stat__num{font-size:2.6rem}
  .stat__label{font-size:.7rem;letter-spacing:.14em}

  .trial__copy{padding:32px 22px}
  .trial__elev{padding:32px 22px}
  .elev__floor{font-size:4.6rem}

  .cat,.dev,.suite,.blog-card,.testi,.step,.eng{padding:24px 20px}
  .cat--xl{padding:28px 22px}

  .suite__price strong{font-size:3.6rem}
  .finale__box{padding:40px 22px}
  .finale__btns{flex-direction:column;width:100%}
  .finale__btns .btn{width:100%;justify-content:center}

  .legal-hero{padding:110px 0 36px}
  .blog-hero{padding:110px 0 36px}
  .post-hero{padding:110px 0 36px}
  .post{padding:50px 0 80px}
  .legal__body h2{font-size:1.6rem;margin:40px 0 12px;padding-top:22px}
  .post__body h2{font-size:1.55rem}
  .post__body blockquote{padding:18px 20px;font-size:1rem}

  .footer{padding:60px 0 24px}
  .footer__inner{padding-bottom:36px;gap:24px}
  .footer__col h5{margin-bottom:12px}

  /* mobile-cta menor em telas muito pequenas */
  .mobile-cta{padding:10px 14px}
  .mobile-cta__btn{padding:12px 18px;font-size:.9rem}
  body{padding-bottom:68px}
}

/* Performance: content-visibility (offscreen sections)  */
@media (min-width:0px){
  .programacao,.suites,.acesso,.engenharia,.residentes,
  .recepcao,.finale,.contato,.post-related{
    content-visibility:auto;
    contain-intrinsic-size:auto 600px;
  }
}

/* Touch pointer: scrollbar-gutter para evitar layout-shift */
@media (pointer:coarse){
  html{scrollbar-gutter:stable}
}

/* Landscape orientação curta (smartphone deitado) ----- */
@media (max-height:500px) and (orientation:landscape){
  .hero{padding:100px 0 40px}
  .nav{padding:10px 0}
  .wa-float{display:none}
  .mobile-cta{display:none !important}
}

/* REDUCED MOTION -------------------------------------- */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:.01ms !important;
    animation-iteration-count:1 !important;
    transition-duration:.01ms !important;
  }
  .skyline__track{animation:none}
}
