/* ============== VANGUARD URBAN GROUP — TIJUCAS/SC · v2 ============== */
:root{
  --ink:#05080F; --abyss:#0A1322; --surf:#0F1D33; --surf2:#13243F;
  --blue:#2E8BFF; --green:#19C27E; --bone:#EAF1FB; --mist:#94A7C5; --dim:#5C6F8E;
  --line:rgba(138,160,192,.13);
  --grad:linear-gradient(118deg,#2E8BFF 0%,#1FB4C0 52%,#19C27E 100%);
  --display:'Space Grotesk',system-ui,sans-serif; --body:'Inter',system-ui,sans-serif;
  --pad:clamp(22px,5vw,84px); --maxw:1320px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{font-family:var(--body);background:var(--abyss);color:var(--bone);overflow-x:hidden;
  line-height:1.55;font-weight:300;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
img,video{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
::selection{background:rgba(46,139,255,.32);color:#fff}
.grad{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad)}

/* type */
.eyebrow{font-family:var(--body);font-weight:600;font-size:clamp(11px,1vw,12.5px);
  letter-spacing:.32em;text-transform:uppercase;color:var(--blue);display:inline-flex;align-items:center;gap:.7em}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--grad);display:inline-block}
.h-display{font-family:var(--display);font-weight:600;line-height:1;font-size:clamp(33px,6vw,88px);letter-spacing:-.02em}
.h-stage{font-family:var(--display);font-weight:600;line-height:1.05;font-size:clamp(27px,4.1vw,56px);letter-spacing:-.015em}
.h-sector{font-family:var(--display);font-weight:600;line-height:1.05;font-size:clamp(25px,3.4vw,48px);letter-spacing:-.015em;max-width:15ch}
.body{font-size:clamp(15px,1.2vw,17.5px);color:var(--mist);max-width:60ch;line-height:1.75;font-weight:300}
.lead{font-size:clamp(15px,1.4vw,20px);color:#C7D5EC;max-width:56ch;line-height:1.6;font-weight:300}
.idx{font-family:var(--display);font-weight:500;font-size:clamp(12px,1vw,14px);color:var(--green);
  letter-spacing:.16em;display:block;margin-bottom:18px}
.src{font-size:11.5px;color:var(--dim);letter-spacing:.02em;margin-top:22px;line-height:1.6}

/* loader */
.loader{position:fixed;inset:0;z-index:200;background:var(--ink);display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:26px;transition:opacity .7s,visibility .7s}
.loader.done{opacity:0;visibility:hidden;pointer-events:none}
.loader .vmark--lg{width:60px;height:60px;animation:pulse 2.4s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:.5;transform:translateY(0)}50%{opacity:1;transform:translateY(-4px)}}
.loader__bar{width:150px;height:2px;background:rgba(255,255,255,.1);border-radius:2px;overflow:hidden}
.loader__bar span{display:block;height:100%;width:0;background:var(--grad);transition:width .3s}
.loader__pct{font-family:var(--display);font-size:12px;letter-spacing:.3em;color:var(--dim)}

/* nav */
.nav{position:fixed;top:0;left:0;right:0;z-index:90;display:flex;align-items:center;justify-content:space-between;
  gap:24px;padding:20px var(--pad);transition:background .5s,padding .5s,border-color .5s;border-bottom:1px solid transparent}
.nav--solid{background:rgba(8,13,24,.8);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  padding-top:13px;padding-bottom:13px;border-color:var(--line)}
.nav__brand{display:flex;align-items:center;gap:12px}
.vmark{width:30px;height:30px;flex:none}.vmark--lg{width:52px;height:52px}
.nav__word{font-family:var(--display);font-weight:600;font-size:15px;letter-spacing:.02em;line-height:1}
.nav__word em{font-style:normal;color:var(--mist);font-weight:400}
.nav__links{display:flex;gap:28px;margin-left:auto}
.nav__links a{font-size:13px;color:var(--mist);font-weight:400;position:relative;transition:color .3s}
.nav__links a::after{content:"";position:absolute;left:0;bottom:-6px;width:0;height:1px;background:var(--grad);transition:width .35s}
.nav__links a:hover{color:var(--bone)}.nav__links a:hover::after{width:100%}
.nav__cta{font-size:13px;font-weight:500;padding:11px 20px;border:1px solid rgba(46,139,255,.5);
  border-radius:40px;color:var(--bone);transition:.35s;white-space:nowrap}
.nav__cta:hover{background:var(--blue);border-color:var(--blue);box-shadow:0 8px 30px -8px rgba(46,139,255,.6)}

/* rail — minimal ticks (calm) */
.rail{position:fixed;left:24px;top:50%;transform:translateY(-50%);z-index:80;display:flex;flex-direction:column;gap:16px}
.rail__item{display:flex;align-items:center;gap:11px}
.rail__item i{width:18px;height:1px;background:rgba(148,167,197,.4);flex:none;transition:.4s}
.rail__item span{font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--dim);
  opacity:0;transform:translateX(-6px);transition:.4s;white-space:nowrap}
.rail__item:hover span,.rail__item.active span{opacity:1;transform:none}
.rail__item.active i{width:30px;background:var(--grad)}
.rail__item.active span{color:var(--mist)}

/* hero (no particles) */
.hero{position:relative;height:100svh;min-height:600px;overflow:hidden;display:flex;flex-direction:column;justify-content:flex-end}
.hero__video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.hero__scrim{position:absolute;inset:0;z-index:2;background:
  radial-gradient(120% 80% at 50% 0%,transparent 42%,rgba(5,8,15,.45) 100%),
  linear-gradient(180deg,rgba(5,8,15,.5) 0%,transparent 26%,transparent 48%,rgba(5,8,15,.92) 100%)}
.hero__inner{position:relative;z-index:3;padding:0 var(--pad) clamp(64px,11vh,140px);max-width:var(--maxw);width:100%;margin:0 auto}
.hero__inner .eyebrow{margin-bottom:26px}
.hero h1{margin-bottom:28px;text-shadow:0 2px 40px rgba(0,0,0,.4)}
.cue{position:absolute;left:50%;bottom:28px;transform:translateX(-50%);z-index:4;display:flex;flex-direction:column;align-items:center;gap:9px;color:var(--mist)}
.cue span{font-size:10px;letter-spacing:.34em;text-transform:uppercase}
.cue i{width:1px;height:40px;background:linear-gradient(var(--blue),transparent);position:relative;overflow:hidden}
.cue i::after{content:"";position:absolute;top:0;left:0;width:100%;height:40%;background:var(--green);animation:cueRun 2s ease-in-out infinite}
@keyframes cueRun{0%{top:-40%}100%{top:120%}}
.hero__loc{position:absolute;right:var(--pad);bottom:32px;z-index:4;font-size:11px;letter-spacing:.18em;color:var(--dim);text-transform:uppercase}

/* MARKET / RANK */
.market{background:linear-gradient(180deg,var(--abyss),var(--ink));padding:clamp(90px,13vh,160px) 0}
.market .eyebrow{margin-bottom:24px}
.market .h-stage{margin-bottom:24px;max-width:20ch}
.market .body{margin-bottom:46px}
.rank{border-top:1px solid var(--line)}
.rank__row{display:grid;grid-template-columns:54px 1fr auto;align-items:center;gap:20px;
  padding:20px 0;border-bottom:1px solid var(--line)}
.rank__pos{font-family:var(--display);font-size:15px;font-weight:500;color:var(--dim);letter-spacing:.04em}
.rank__city{font-family:var(--display);font-weight:500;font-size:clamp(17px,1.7vw,23px);color:var(--bone)}
.rank__city em{font-style:normal;color:var(--mist);font-weight:400;font-size:.66em;font-family:var(--body)}
.rank__val{font-family:var(--display);font-weight:600;font-size:clamp(17px,1.7vw,23px);
  font-variant-numeric:tabular-nums;letter-spacing:.01em}
.rank__row--lead{padding:26px 0}
.rank__row--lead .rank__pos{color:var(--blue)}
.rank__row--lead .rank__city,.rank__row--lead .rank__val{font-size:clamp(20px,2.2vw,30px)}
.rank__row--lead .rank__val{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.rank__row--ref{opacity:.6}
.rank__row--ref .rank__val{color:var(--mist)}

/* GAP */
.gap{background:var(--ink);padding:clamp(90px,13vh,160px) 0;position:relative;overflow:hidden}
.gap::before{content:"";position:absolute;top:-20%;right:-10%;width:600px;height:600px;
  background:radial-gradient(circle,rgba(25,194,126,.09),transparent 65%);pointer-events:none}
.gap .eyebrow{margin-bottom:24px}
.gap .h-stage{margin-bottom:50px;max-width:22ch;position:relative}
.gapviz{position:relative;margin-bottom:54px}
.gapviz__row{display:grid;grid-template-columns:200px 1fr;align-items:center;gap:22px;margin-bottom:18px}
.gapviz__label b{font-family:var(--display);font-weight:600;font-size:clamp(15px,1.5vw,19px);display:block;line-height:1.2}
.gapviz__label span{font-size:12px;color:var(--dim);letter-spacing:.04em}
.gapviz__track{height:54px;background:rgba(255,255,255,.04);border-radius:8px;overflow:hidden;border:1px solid var(--line)}
.gapviz__fill{height:100%;width:0;border-radius:8px;display:flex;align-items:center;padding-left:18px;
  transition:width 1.4s cubic-bezier(.2,.7,.2,1);min-width:fit-content}
.gapviz__fill span{font-family:var(--display);font-weight:600;font-size:clamp(14px,1.4vw,18px);color:#fff;white-space:nowrap;font-variant-numeric:tabular-nums}
.gapviz__fill--here{background:linear-gradient(90deg,rgba(46,139,255,.4),rgba(46,139,255,.18))}
.gapviz__fill--bc{background:var(--grad)}
.gapviz__delta{display:flex;align-items:baseline;gap:16px;margin-top:32px;padding-top:28px;border-top:1px solid var(--line)}
.gapviz__delta b{font-family:var(--display);font-weight:600;font-size:clamp(42px,6vw,84px);line-height:1;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;font-variant-numeric:tabular-nums}
.gapviz__delta b::after{content:"%";font-size:.5em}
.gapviz__delta span{font-size:clamp(14px,1.3vw,17px);color:var(--mist);max-width:30ch;line-height:1.5}
.gapfacts{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.gapfact{padding:28px;background:rgba(255,255,255,.025);border:1px solid var(--line);border-radius:12px}
.gapfact b{font-family:var(--display);font-weight:600;font-size:clamp(20px,2vw,28px);display:block;margin-bottom:12px;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.gapfact span{font-size:13.5px;color:var(--mist);line-height:1.6}

/* LOCALIZAÇÃO */
.loc{position:relative;overflow:hidden;background:var(--abyss);padding:clamp(90px,12vh,150px) 0}
.loc__bgvid{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.18;z-index:0}
.loc__scrim{position:absolute;inset:0;z-index:1;background:radial-gradient(80% 80% at 72% 42%,transparent,rgba(5,8,15,.85)),linear-gradient(90deg,rgba(5,8,15,.9),transparent 62%)}
.loc__grid{position:relative;z-index:2;max-width:var(--maxw);margin:0 auto;padding:0 var(--pad);
  display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,80px);align-items:center}
.loc__copy .eyebrow{margin-bottom:22px}.loc__copy .h-stage{margin-bottom:22px}
.loc__list{list-style:none;margin:32px 0 8px;border-top:1px solid var(--line)}
.loc__list li{display:flex;justify-content:space-between;align-items:baseline;gap:18px;padding:14px 0;border-bottom:1px solid var(--line)}
.loc__city{font-family:var(--display);font-weight:500;font-size:clamp(15px,1.4vw,19px);color:var(--bone)}
.loc__city em{font-style:normal;color:var(--green);font-weight:400;font-size:.6em;font-family:var(--body);letter-spacing:.02em;display:block;margin-top:2px}
.loc__km{font-family:var(--display);font-weight:500;font-size:clamp(15px,1.3vw,18px);color:var(--mist);font-variant-numeric:tabular-nums;white-space:nowrap}
.loc__map{width:100%;height:auto;overflow:visible}.loc__mapwrap{position:relative}
.pin__core{fill:var(--blue)}.pin__core--hub{fill:url(#vg)}
.pin__name{font-family:var(--body);font-size:11px;fill:var(--mist);font-weight:500;letter-spacing:.03em;text-anchor:start}
.pin__name--hub{font-family:var(--display);font-size:15px;fill:#fff;font-weight:600;letter-spacing:.12em;text-anchor:middle}
.pin__sub{font-size:9px;fill:var(--green);letter-spacing:.26em;text-anchor:middle;text-transform:uppercase}
#links path{stroke:url(#vg);stroke-width:1.3;opacity:.45}

/* VISÃO + MASTERPLAN (calm hotspots) */
.vision{background:var(--ink);padding:clamp(80px,12vh,150px) 0;position:relative}
.vision__head{margin-bottom:46px}
.vision__head .eyebrow{margin-bottom:22px}.vision__head .h-stage{margin-bottom:22px;max-width:18ch}
.plan__frame{position:relative;border-radius:14px;overflow:hidden;border:1px solid var(--line);
  box-shadow:0 50px 120px -50px rgba(0,0,0,.9);aspect-ratio:16/9;background:#000;cursor:crosshair}
.plan__frame img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  transition:transform .4s cubic-bezier(.2,.7,.2,1);will-change:transform}
.plan__hotspots{position:absolute;inset:0;z-index:3}
.hotspot{position:absolute;width:32px;height:32px;transform:translate(-50%,-50%);border-radius:50%;
  border:1px solid rgba(234,241,251,.55);background:rgba(8,13,24,.5);backdrop-filter:blur(4px);
  -webkit-backdrop-filter:blur(4px);color:var(--bone);font-family:var(--display);font-size:13px;font-weight:600;
  cursor:pointer;display:grid;place-items:center;transition:.3s;padding:0}
.hotspot::before{content:attr(data-n)}
.hotspot:hover,.hotspot:focus-visible{background:var(--grad);border-color:transparent;
  transform:translate(-50%,-50%) scale(1.18);box-shadow:0 10px 28px -8px rgba(46,139,255,.7);outline:none}
.hotspot__tip{position:absolute;left:50%;bottom:142%;transform:translateX(-50%) translateY(6px);
  background:rgba(10,19,34,.97);border:1px solid var(--line);border-radius:10px;padding:9px 13px;
  min-width:max-content;opacity:0;pointer-events:none;transition:.26s;box-shadow:0 20px 50px -20px rgba(0,0,0,.9)}
.hotspot:hover .hotspot__tip,.hotspot:focus-visible .hotspot__tip{opacity:1;transform:translateX(-50%)}
.hotspot__tip b{display:block;font-family:var(--display);font-size:13px;font-weight:600;color:#fff}
.hotspot__tip span{font-size:11px;color:var(--green);letter-spacing:.03em}
.plan__hint{text-align:center;margin-top:22px;font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--dim)}

/* PROGRAMA */
.program-intro{background:var(--abyss);padding:clamp(80px,12vh,150px) 0}
.program-intro .eyebrow{margin-bottom:22px}
.program-intro .h-stage{margin-bottom:22px}.program-intro .body{margin-bottom:48px}
.prog{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);
  border:1px solid var(--line);border-radius:14px;overflow:hidden}
.prog__item{background:var(--abyss);padding:28px 24px;transition:background .35s}
.prog__item:hover{background:var(--surf)}
.prog__item b{font-family:var(--display);font-weight:600;font-size:clamp(16px,1.5vw,20px);display:block;margin-bottom:10px}
.prog__item span{font-size:13px;color:var(--mist);line-height:1.55}

/* SECTORS */
.sector{position:relative;min-height:100svh;display:flex;align-items:center;overflow:hidden}
.sector__bg{position:absolute;inset:0;z-index:0}
.sector__bg img,.sector__bgvid{width:100%;height:115%;object-fit:cover;will-change:transform}
.sector__bgvid{position:absolute;inset:0;height:100%}
.sector__scrim{position:absolute;inset:0;z-index:1;
  background:linear-gradient(90deg,rgba(5,8,15,.9) 0%,rgba(5,8,15,.42) 44%,transparent 80%),linear-gradient(0deg,rgba(5,8,15,.5),transparent 55%)}
.sector:has(.sector__content--r) .sector__scrim{
  background:linear-gradient(270deg,rgba(5,8,15,.9) 0%,rgba(5,8,15,.42) 44%,transparent 80%),linear-gradient(0deg,rgba(5,8,15,.5),transparent 55%)}
.sector__content{position:relative;z-index:2;padding:0 var(--pad);max-width:var(--maxw);margin:0 auto;width:100%}
.sector__content--r{text-align:right}
.sector__content--r .idx{color:var(--green)}
.sector__content--l .h-sector,.sector__content--l .body{margin-right:auto}
.sector__content--r .h-sector,.sector__content--r .body{margin-left:auto}
.sector__content .h-sector{margin-bottom:22px}

/* NÚMEROS */
.numbers{background:linear-gradient(180deg,var(--ink),var(--abyss));padding:clamp(90px,14vh,160px) 0;position:relative;overflow:hidden}
.numbers::before{content:"";position:absolute;top:-30%;left:50%;transform:translateX(-50%);width:700px;height:700px;
  background:radial-gradient(circle,rgba(46,139,255,.09),transparent 65%);pointer-events:none}
.numbers .eyebrow{margin-bottom:22px}.numbers .h-stage{margin-bottom:54px;max-width:22ch}
.nums{display:grid;grid-template-columns:repeat(4,1fr);gap:30px 24px;position:relative}
.nums--market{margin-top:42px;padding-top:42px;border-top:1px solid var(--line)}
.num b{font-family:var(--display);font-weight:600;font-size:clamp(34px,4.4vw,64px);line-height:1;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;display:block;
  font-variant-numeric:tabular-nums;letter-spacing:-.015em}
.nums--market .num b{font-size:clamp(28px,3.4vw,48px)}
.num span{display:block;margin-top:12px;font-size:12.5px;color:var(--mist);letter-spacing:.02em;line-height:1.45;max-width:24ch}

/* CONTATO */
.contact{position:relative;min-height:100svh;display:flex;align-items:center;justify-content:center;overflow:hidden;text-align:center}
.contact__bg{position:absolute;inset:0;z-index:0}.contact__bg img{width:100%;height:100%;object-fit:cover}
.contact__scrim{position:absolute;inset:0;z-index:1;background:radial-gradient(70% 70% at 50% 50%,rgba(5,8,15,.55),rgba(5,8,15,.92))}
.contact__inner{position:relative;z-index:2;padding:120px var(--pad);max-width:920px}
.contact__inner .vmark--lg{margin:0 auto 28px;width:58px;height:58px}
.contact__inner .h-display{margin-bottom:26px}
.contact__actions{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;margin:38px 0 28px}
.btn{font-family:var(--body);font-weight:500;font-size:15px;padding:16px 32px;border-radius:46px;transition:.35s;display:inline-flex;align-items:center;gap:10px}
.btn--primary{background:var(--grad);color:#fff;box-shadow:0 14px 44px -14px rgba(46,139,255,.7)}
.btn--primary:hover{transform:translateY(-2px);box-shadow:0 22px 60px -16px rgba(25,194,126,.7)}
.btn--ghost{border:1px solid var(--line);color:var(--mist)}.btn--ghost:hover{border-color:var(--blue);color:var(--bone)}
.contact__meta{display:flex;gap:32px;justify-content:center;flex-wrap:wrap;font-size:12px;color:var(--dim);margin-top:16px}

/* footer */
.footer{background:var(--ink);padding:54px var(--pad);border-top:1px solid var(--line);display:flex;flex-direction:column;align-items:center;gap:16px;text-align:center}
.footer__brand{display:flex;align-items:center;gap:12px}
.footer__brand span{font-family:var(--display);font-weight:600;font-size:14px;letter-spacing:.02em}
.footer__disc{max-width:74ch;font-size:11.5px;color:var(--dim);line-height:1.7}
.footer__cred{font-size:11px;color:var(--dim);letter-spacing:.06em}

/* responsive */
@media(max-width:1100px){
  .rail,.nav__links{display:none}
  .loc__grid{grid-template-columns:1fr}.loc__mapwrap{max-width:440px;margin:0 auto;order:-1}
  .prog{grid-template-columns:repeat(2,1fr)}
  .gapfacts{grid-template-columns:1fr}
}
@media(max-width:760px){
  .nav__word{font-size:13px}.nav__cta{padding:9px 15px;font-size:12px}
  .sector__content--r{text-align:left}
  .sector__content--r .h-sector,.sector__content--r .body{margin-left:0;margin-right:auto}
  .sector:has(.sector__content--r) .sector__scrim{background:linear-gradient(90deg,rgba(5,8,15,.92),rgba(5,8,15,.48) 50%,transparent 90%),linear-gradient(0deg,rgba(5,8,15,.55),transparent 55%)}
  .nums,.nums--market{grid-template-columns:repeat(2,1fr);gap:34px 18px}
  .prog{grid-template-columns:1fr}
  .rank__row{grid-template-columns:38px 1fr auto;gap:12px}
  .gapviz__row{grid-template-columns:1fr;gap:8px}
  .gapviz__track{height:46px}
  .plan__frame{aspect-ratio:3/4}
  .hero__loc{display:none}.contact__meta{flex-direction:column;gap:12px}
}
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}
  .stage__bg img,.sector__bg img{height:100%}
}
