/* ============================================================
   HOUZZE IMOBILIÁRIA — Design System v2
   Editorial dark luxe · Syne + Instrument Serif + Hanken Grotesk
   Navy #0A0E18 · Blue #5B8CC7
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Syne:wght@500;600;700;800&family=Instrument+Serif:ital@0;1&family=Hanken+Grotesk:wght@300;400;500;600;700&display=swap');

:root{
  --bg:#0A0E18; --bg-2:#0E1424; --panel:#121B30; --panel-2:#172238;
  --blue:#5B8CC7; --blue-bright:#86B0E4; --blue-deep:#3E6CA0;
  --ink:#EAEFF7; --muted:#8C9BB4; --muted-2:#5E6C84; --faint:#2A3650;
  --line:rgba(255,255,255,0.08); --line-2:rgba(255,255,255,0.14);
  --white:#fff;
  --r:16px; --r-lg:26px;
  --disp:'Syne',sans-serif; --serif:'Instrument Serif',Georgia,serif; --sans:'Hanken Grotesk',sans-serif;
  --ease:cubic-bezier(0.22,1,0.36,1);
  --maxw:1320px;
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{font-family:var(--sans);background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased;line-height:1.6;overflow-x:hidden;}
body.nav-lock{overflow:hidden;}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
::selection{background:var(--blue);color:#fff;}

h1,h2,h3,h4{font-family:var(--disp);font-weight:700;line-height:1.02;letter-spacing:-0.02em;}
h1 em,h2 em,h3 em{font-family:var(--serif);font-style:italic;font-weight:400;letter-spacing:0;color:var(--blue-bright);}

.wrap{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 44px;}
.section{padding:120px 0;position:relative;}
.section.tight{padding:80px 0;}
.section.panel{background:var(--bg-2);}
.eyebrow{font-family:var(--sans);font-size:0.7rem;font-weight:600;letter-spacing:0.32em;text-transform:uppercase;color:var(--blue-bright);display:inline-flex;align-items:center;gap:14px;}
.eyebrow::before{content:'';width:30px;height:1px;background:var(--blue);}
.lead{color:var(--muted);font-size:1.1rem;max-width:56ch;font-weight:300;}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:11px;font-family:var(--sans);font-weight:600;font-size:0.82rem;letter-spacing:0.02em;padding:15px 26px;border-radius:100px;cursor:pointer;border:1px solid transparent;transition:all .4s var(--ease);white-space:nowrap;}
.btn svg{width:16px;height:16px;transition:transform .4s var(--ease);}
.btn:hover svg{transform:translateX(4px);}
.btn-blue{background:var(--blue);color:#06101f;font-weight:700;}
.btn-blue:hover{background:var(--blue-bright);transform:translateY(-3px);box-shadow:0 16px 34px rgba(91,140,199,0.34);}
.btn-line{background:transparent;border-color:var(--line-2);color:var(--ink);}
.btn-line:hover{border-color:var(--blue-bright);color:var(--blue-bright);}
.btn-light{background:var(--ink);color:var(--bg);font-weight:700;}
.btn-light:hover{transform:translateY(-3px);}
.btn-wa{background:#25D366;color:#06381b;font-weight:700;}
.btn-wa:hover{transform:translateY(-3px);box-shadow:0 14px 30px rgba(37,211,102,0.36);}
.btn-wa svg:hover{transform:none;}

/* ============================================================ HEADER */
.site-header{position:fixed;inset:0 0 auto 0;z-index:1000;padding:24px 0;transition:all .45s var(--ease);}
.site-header.scrolled{background:rgba(10,14,24,0.82);backdrop-filter:blur(18px);padding:13px 0;border-bottom:1px solid var(--line);}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:24px;}
.logo-link img{height:38px;width:auto;}
.nav{display:flex;align-items:center;gap:2px;}
.nav a{color:rgba(255,255,255,0.78);font-size:0.82rem;font-weight:500;padding:9px 14px;border-radius:100px;transition:.3s var(--ease);position:relative;}
.nav a:hover{color:#fff;}
.nav a.active{color:var(--blue-bright);}
.nav a.cta-link{background:var(--blue);color:#06101f;font-weight:700;margin-left:8px;}
.nav a.cta-link:hover{background:var(--blue-bright);}
.header-right{display:flex;align-items:center;gap:14px;}
.socials{display:flex;gap:8px;}
.socials a{width:36px;height:36px;border-radius:50%;display:grid;place-items:center;border:1px solid var(--line-2);color:rgba(255,255,255,0.8);transition:.3s var(--ease);}
.socials a:hover{background:var(--blue);border-color:var(--blue);color:#06101f;transform:translateY(-2px);}
.socials svg{width:15px;height:15px;fill:currentColor;}
.burger{display:none;width:44px;height:44px;border:1px solid var(--line-2);border-radius:12px;background:rgba(255,255,255,0.04);cursor:pointer;flex-direction:column;align-items:center;justify-content:center;gap:5px;}
.burger span{width:20px;height:2px;background:#fff;border-radius:2px;transition:.35s var(--ease);}
.burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.burger.open span:nth-child(2){opacity:0;}
.burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}

/* ============================================================ HERO */
.hero{position:relative;min-height:100vh;display:flex;align-items:flex-end;overflow:hidden;}
.hero-bg{position:absolute;inset:0;z-index:-2;}
.hero-bg .slide{position:absolute;inset:0;opacity:0;transition:opacity 1.5s var(--ease);}
.hero-bg .slide.active{opacity:1;animation:kb 9s ease forwards;}
.hero-bg .slide img{width:100%;height:100%;object-fit:cover;}
@keyframes kb{from{transform:scale(1.12);}to{transform:scale(1);}}
.hero-bg::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,14,24,0.55) 0%,rgba(10,14,24,0.35) 40%,rgba(10,14,24,0.96) 100%);}
.hero-noise{position:absolute;inset:0;z-index:-1;opacity:.5;pointer-events:none;background-image:radial-gradient(rgba(255,255,255,0.05) 1px,transparent 1px);background-size:3.5px 3.5px;}
.hero-inner{width:100%;padding-bottom:60px;padding-top:140px;}
.hero-top{display:flex;justify-content:space-between;align-items:flex-end;gap:30px;margin-bottom:30px;}
.hero-index{font-family:var(--disp);font-size:0.8rem;letter-spacing:0.3em;color:var(--muted);text-transform:uppercase;}
.hero-slogans{position:relative;min-height:clamp(230px,24vw,330px);padding-bottom:0;}
.hero-slogan{position:absolute;inset:0;opacity:0;transform:translateY(26px);transition:opacity .9s var(--ease),transform .9s var(--ease);pointer-events:none;}
.hero-slogan.active{opacity:1;transform:none;pointer-events:auto;}
.hero-slogan h1{font-size:clamp(2.7rem,7vw,6rem);font-weight:800;max-width:15ch;letter-spacing:-0.03em;}
.hero-slogan p{margin-top:18px;font-size:1.15rem;color:var(--muted);font-weight:300;max-width:42ch;}
.hero-dots{display:flex;gap:9px;margin-top:18px;position:relative;z-index:5;}
.hero-dots button{width:34px;height:3px;border-radius:4px;border:none;background:rgba(255,255,255,0.22);cursor:pointer;transition:.4s var(--ease);padding:0;}
.hero-dots button.active{background:var(--blue-bright);width:54px;}

/* search dock */
.search-bar{margin-top:42px;background:rgba(18,27,48,0.6);backdrop-filter:blur(22px);border:1px solid var(--line-2);border-radius:20px;padding:12px;display:grid;grid-template-columns:1.2fr 1fr auto;gap:10px;max-width:780px;box-shadow:0 30px 70px rgba(0,0,0,0.45);}
.search-field{display:flex;flex-direction:column;gap:3px;padding:10px 18px;border-radius:13px;transition:background .3s;}
.search-field:hover{background:rgba(255,255,255,0.04);}
.search-field label{font-size:0.6rem;letter-spacing:0.2em;text-transform:uppercase;color:var(--muted);font-weight:700;}
.search-field select{background:transparent;border:none;color:#fff;font-family:var(--sans);font-size:1rem;font-weight:600;outline:none;cursor:pointer;appearance:none;padding-right:20px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='11' height='7'%3E%3Cpath fill='%2386B0E4' d='M5.5 7 0 0h11z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right center;}
.search-field select option{background:var(--bg-2);color:#fff;}
.search-bar .btn{align-self:stretch;}

/* ============================================================ SECTION HEAD */
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:30px;margin-bottom:60px;flex-wrap:wrap;}
.sec-head-left{max-width:680px;}
.sec-head h2{font-size:clamp(2rem,4.4vw,3.6rem);margin-top:18px;}
.sec-head .lead{margin-top:14px;}

/* ============================================================ CARDS */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;}
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;display:flex;flex-direction:column;transition:transform .55s var(--ease),border-color .55s var(--ease);}
.card:hover{transform:translateY(-8px);border-color:var(--line-2);}
.card-media{position:relative;display:block;aspect-ratio:4/3;overflow:hidden;}
.card-media img{width:100%;height:100%;object-fit:cover;transition:transform 1.1s var(--ease);}
.card:hover .card-media img{transform:scale(1.08);}
.card-media::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(10,14,24,0.5),transparent 45%);}
.card-num{position:absolute;top:16px;left:18px;z-index:2;font-family:var(--disp);font-weight:800;font-size:1rem;color:#fff;opacity:.85;}
.card-zone{position:absolute;top:16px;right:16px;z-index:2;background:rgba(10,14,24,0.55);backdrop-filter:blur(6px);border:1px solid var(--line-2);color:#fff;font-size:0.62rem;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;padding:7px 12px;border-radius:100px;}
.card-go{position:absolute;bottom:16px;right:16px;z-index:2;width:42px;height:42px;border-radius:50%;background:var(--blue);display:grid;place-items:center;transform:translateY(8px);opacity:0;transition:.45s var(--ease);}
.card:hover .card-go{transform:none;opacity:1;}
.card-go svg{width:17px;height:17px;stroke:#06101f;}
.card-body{padding:26px;display:flex;flex-direction:column;flex:1;}
.card-loc{font-size:0.78rem;color:var(--muted);display:flex;align-items:center;gap:7px;margin-bottom:12px;}
.card-loc svg{width:13px;height:13px;stroke:var(--blue);}
.card-body h3{font-size:1.5rem;line-height:1.05;margin-bottom:14px;}
.card-body h3 a:hover{color:var(--blue-bright);}
.card-specs{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:16px;}
.card-specs span{font-size:0.7rem;font-weight:600;color:var(--blue-bright);background:rgba(91,140,199,0.12);border:1px solid rgba(91,140,199,0.18);padding:6px 11px;border-radius:8px;}
.card-desc{font-size:0.9rem;color:var(--muted);flex:1;margin-bottom:22px;}
.card-foot{display:flex;align-items:center;justify-content:space-between;gap:12px;padding-top:18px;border-top:1px solid var(--line);}
.card-foot .link{font-weight:700;font-size:0.82rem;color:var(--blue-bright);display:inline-flex;align-items:center;gap:7px;transition:gap .3s;}
.card-foot .link:hover{gap:12px;}
.card-foot .link svg{width:15px;height:15px;}
.card-wa{width:40px;height:40px;border-radius:50%;background:#25D366;display:grid;place-items:center;transition:transform .3s;flex-shrink:0;}
.card-wa:hover{transform:scale(1.1);}
.card-wa svg{width:19px;height:19px;fill:#06381b;}

/* ============================================================ ZONE STRIP (accordion) */
.zstrip{display:flex;gap:14px;height:460px;}
.zitem{position:relative;flex:1;border-radius:var(--r-lg);overflow:hidden;cursor:pointer;transition:flex .7s var(--ease);display:flex;align-items:flex-end;color:#fff;text-decoration:none;}
.zitem:hover{flex:2.6;}
.zitem img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform 1s var(--ease);filter:brightness(.7);}
.zitem:hover img{transform:scale(1.06);filter:brightness(.85);}
.zitem::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(10,14,24,0.9),transparent 60%);}
.zitem .zc{position:relative;z-index:2;padding:26px;width:100%;}
.zitem .zc small{font-size:0.62rem;letter-spacing:0.22em;text-transform:uppercase;color:var(--blue-bright);font-weight:700;}
.zitem .zc h3{font-size:clamp(1.3rem,2vw,1.9rem);margin-top:6px;writing-mode:vertical-rl;transform:rotate(180deg);transition:.5s var(--ease);height:170px;}
.zitem:hover .zc h3{writing-mode:horizontal-tb;transform:none;height:auto;}
.zitem .zc .zmeta{max-height:0;opacity:0;overflow:hidden;transition:.5s var(--ease);}
.zitem:hover .zc .zmeta{max-height:80px;opacity:1;margin-top:8px;}
.zitem .zc .zmeta span{display:inline-flex;align-items:center;gap:8px;font-size:0.85rem;color:var(--muted);}

/* ============================================================ INTERESTS */
.interests{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.interest{position:relative;border-radius:var(--r-lg);overflow:hidden;min-height:380px;display:flex;align-items:flex-end;color:#fff;}
.interest img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform 1s var(--ease);filter:brightness(.72);}
.interest::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(10,14,24,0.92),transparent 60%);}
.interest:hover img{transform:scale(1.07);}
.interest .it{position:relative;z-index:2;padding:34px;}
.interest .it h3{font-size:1.8rem;}
.interest .it p{font-size:0.9rem;color:var(--muted);margin-top:6px;}
.interest .it .more{display:inline-flex;align-items:center;gap:8px;margin-top:16px;font-size:0.8rem;font-weight:700;color:var(--blue-bright);}

/* ============================================================ SPLIT / ABOUT */
.split{display:grid;grid-template-columns:1fr 1fr;gap:70px;align-items:center;}
.split-media{position:relative;}
.split-media img{border-radius:var(--r-lg);aspect-ratio:4/5;object-fit:cover;width:100%;}
.split-media .badge{position:absolute;bottom:-24px;right:-24px;background:var(--blue);color:#06101f;border-radius:var(--r);padding:22px 26px;text-align:center;box-shadow:0 24px 50px rgba(0,0,0,.4);}
.split-media .badge strong{font-family:var(--disp);font-size:2.2rem;display:block;line-height:1;}
.split-media .badge span{font-size:0.7rem;letter-spacing:0.1em;text-transform:uppercase;font-weight:600;}
.split-body h2{font-size:clamp(2rem,3.6vw,3rem);margin:18px 0 22px;}
.split-body p{color:var(--muted);margin-bottom:16px;}
.split-body p strong{color:var(--ink);font-weight:600;}
.stats{display:flex;gap:42px;margin:30px 0;flex-wrap:wrap;}
.stat strong{font-family:var(--disp);font-size:2.6rem;color:var(--blue-bright);display:block;line-height:1;}
.stat span{font-size:0.78rem;color:var(--muted);}

/* value cards (sobre) */
.vcards{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.vcard{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-lg);padding:40px 34px;transition:.5s var(--ease);}
.vcard:hover{border-color:var(--line-2);transform:translateY(-6px);}
.vcard .vn{font-family:var(--disp);font-size:0.8rem;color:var(--blue);letter-spacing:0.2em;}
.vcard h3{font-size:1.6rem;margin:18px 0 10px;}
.vcard p{color:var(--muted);font-size:0.92rem;}

/* ============================================================ PAGE TOP + FILTER */
.page-top{padding:180px 0 70px;position:relative;overflow:hidden;}
.page-top::before{content:'';position:absolute;right:-8%;top:-30%;width:620px;height:620px;border-radius:50%;background:radial-gradient(circle,rgba(91,140,199,0.22),transparent 65%);}
.breadcrumb{font-size:0.78rem;color:var(--muted);margin-bottom:20px;position:relative;}
.breadcrumb a:hover{color:var(--blue-bright);}
.page-top h1{font-size:clamp(2.6rem,6vw,4.6rem);position:relative;}
.page-top p{margin-top:14px;color:var(--muted);max-width:54ch;position:relative;}
.filter-dock{background:var(--panel);border:1px solid var(--line);border-radius:var(--r);padding:14px;display:grid;grid-template-columns:repeat(3,1fr) auto;gap:8px;margin-top:-44px;position:relative;z-index:5;box-shadow:0 30px 60px rgba(0,0,0,.35);}
.filter-dock .ff{display:flex;flex-direction:column;gap:3px;padding:9px 18px;border-right:1px solid var(--line);}
.filter-dock .ff:nth-child(3){border-right:none;}
.filter-dock label{font-size:0.6rem;letter-spacing:0.18em;text-transform:uppercase;color:var(--muted);font-weight:700;}
.filter-dock select,.filter-dock input{border:none;outline:none;background:transparent;font-family:var(--sans);font-size:0.96rem;font-weight:600;color:var(--ink);appearance:none;}
.filter-dock select{cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='11' height='7'%3E%3Cpath fill='%2386B0E4' d='M5.5 7 0 0h11z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right center;}
.filter-dock select option{background:var(--bg-2);}
.filter-dock input::placeholder{color:var(--muted-2);}
.results-meta{display:flex;justify-content:space-between;align-items:center;margin:46px 0 30px;flex-wrap:wrap;gap:16px;}
.results-meta .count{font-size:0.9rem;color:var(--muted);}
.results-meta .count b{color:var(--ink);font-family:var(--disp);}
.chips{display:flex;gap:8px;flex-wrap:wrap;}
.chip{font-size:0.74rem;font-weight:600;padding:8px 15px;border-radius:100px;background:var(--panel);border:1px solid var(--line);color:var(--muted);cursor:pointer;transition:.3s;}
.chip:hover{border-color:var(--line-2);color:var(--ink);}
.chip.active{background:var(--blue);border-color:var(--blue);color:#06101f;}
.empty-state{text-align:center;padding:80px 20px;color:var(--muted);}
.empty-state svg{width:52px;height:52px;stroke:var(--blue);margin-bottom:16px;}
.empty-state h3{font-size:1.7rem;color:var(--ink);margin-bottom:8px;}

/* ============================================================ DETAIL */
.detail-hero{position:relative;min-height:88vh;display:flex;align-items:flex-end;overflow:hidden;}
.detail-hero .bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:-2;}
.detail-hero::after{content:'';position:absolute;inset:0;z-index:-1;background:linear-gradient(to top,rgba(10,14,24,0.95),rgba(10,14,24,0.25) 60%);}
.detail-hero .dh-inner{padding-bottom:64px;padding-top:150px;}
.detail-hero .badge-zone{display:inline-flex;align-items:center;gap:8px;background:rgba(91,140,199,0.18);border:1px solid rgba(91,140,199,0.3);backdrop-filter:blur(8px);color:#fff;font-size:0.74rem;font-weight:600;padding:9px 15px;border-radius:100px;margin-bottom:18px;}
.detail-hero .badge-zone svg{width:14px;height:14px;stroke:var(--blue-bright);}
.detail-hero h1{font-size:clamp(2.6rem,6.5vw,5.2rem);}
.detail-hero .dh-tags{display:flex;flex-wrap:wrap;gap:9px;margin-top:22px;}
.detail-hero .dh-tags span{background:rgba(255,255,255,0.1);border:1px solid var(--line-2);backdrop-filter:blur(8px);padding:9px 15px;border-radius:100px;font-size:0.82rem;font-weight:600;}
.detail-grid{display:grid;grid-template-columns:1.6fr 1fr;gap:60px;align-items:start;}
.detail-body h2{font-size:2.1rem;margin:16px 0 18px;}
.detail-body p{color:var(--muted);margin-bottom:18px;font-size:1.04rem;}
.feature-list{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:28px;}
.feature-list li{list-style:none;display:flex;align-items:center;gap:12px;font-weight:500;color:var(--ink);}
.feature-list li svg{width:18px;height:18px;stroke:var(--blue-bright);flex-shrink:0;}
.detail-aside{position:sticky;top:100px;background:var(--panel);border:1px solid var(--line);border-radius:var(--r-lg);padding:34px;}
.detail-aside h3{font-size:1.5rem;margin-bottom:6px;}
.detail-aside p{color:var(--muted);font-size:0.92rem;margin-bottom:22px;}
.detail-aside .btn{width:100%;margin-bottom:12px;}
.detail-aside .aside-contact{margin-top:22px;padding-top:20px;border-top:1px solid var(--line);font-size:0.88rem;color:var(--muted);}
.detail-aside .aside-contact a{color:var(--ink);font-weight:600;}

/* ============================================================ FORMS */
.form-card{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-lg);padding:46px;}
.form-card h2{font-size:1.9rem;margin-bottom:6px;}
.form-card .sub{color:var(--muted);margin-bottom:30px;font-size:0.95rem;}
.field{margin-bottom:20px;}
.field label{display:block;font-size:0.64rem;letter-spacing:0.14em;text-transform:uppercase;color:var(--muted);font-weight:700;margin-bottom:8px;}
.field label .req{color:var(--blue-bright);}
.field input,.field select,.field textarea{width:100%;padding:14px 16px;border:1px solid var(--line-2);border-radius:12px;font-family:var(--sans);font-size:0.96rem;color:var(--ink);background:var(--bg-2);outline:none;transition:.3s;}
.field textarea{min-height:130px;resize:vertical;}
.field select{appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='11' height='7'%3E%3Cpath fill='%2386B0E4' d='M5.5 7 0 0h11z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center;}
.field select option{background:var(--bg-2);}
.field input::placeholder,.field textarea::placeholder{color:var(--muted-2);}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--blue);box-shadow:0 0 0 4px rgba(91,140,199,0.14);}
.field.err input,.field.err select,.field.err textarea{border-color:#e2574c;}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.form-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:6px;}
.form-note{font-size:0.78rem;color:var(--muted);margin-top:16px;}
.info-stack{display:flex;flex-direction:column;gap:14px;}
.info-row{display:flex;align-items:center;gap:18px;padding:22px 24px;background:var(--panel);border:1px solid var(--line);border-radius:var(--r);transition:.4s var(--ease);}
.info-row:hover{transform:translateX(6px);border-color:var(--line-2);}
.info-ico{width:48px;height:48px;border-radius:14px;background:rgba(91,140,199,0.12);display:grid;place-items:center;flex-shrink:0;}
.info-ico svg{width:21px;height:21px;stroke:var(--blue-bright);fill:none;stroke-width:1.8;}
.info-row small{display:block;font-size:0.64rem;letter-spacing:0.12em;text-transform:uppercase;color:var(--muted);font-weight:700;}
.info-row .v{font-weight:700;color:var(--ink);}

/* ============================================================ SIM */
.sim-grid{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:start;}
.sim-result{background:linear-gradient(150deg,var(--panel),var(--panel-2));border:1px solid var(--line);border-radius:var(--r-lg);padding:44px;position:sticky;top:100px;overflow:hidden;}
.sim-result::before{content:'';position:absolute;right:-30%;top:-30%;width:340px;height:340px;border-radius:50%;background:radial-gradient(circle,rgba(91,140,199,0.3),transparent 65%);}
.sim-amount{font-family:var(--disp);font-weight:800;font-size:clamp(2.6rem,6vw,3.8rem);margin:12px 0 4px;position:relative;}
.sim-amount small{font-size:1rem;color:var(--muted);font-family:var(--sans);font-weight:400;}
.sim-lines{margin-top:26px;position:relative;}
.sim-line{display:flex;justify-content:space-between;padding:13px 0;border-bottom:1px solid var(--line);font-size:0.92rem;}
.sim-line span{color:var(--muted);}
.range-field .rv{font-family:var(--disp);font-size:1.3rem;color:var(--blue-bright);}
.range-field input[type=range]{width:100%;accent-color:var(--blue);margin-top:8px;}

/* ============================================================ CTA */
.cta-band{background:linear-gradient(135deg,var(--panel),var(--panel-2));border:1px solid var(--line);border-radius:var(--r-lg);padding:72px;text-align:center;position:relative;overflow:hidden;}
.cta-band::before,.cta-band::after{content:'';position:absolute;border-radius:50%;background:radial-gradient(circle,rgba(91,140,199,0.28),transparent 65%);}
.cta-band::before{width:380px;height:380px;left:-8%;bottom:-55%;}
.cta-band::after{width:320px;height:320px;right:-5%;top:-50%;}
.cta-band h2{font-size:clamp(2rem,4.4vw,3.4rem);max-width:20ch;margin:0 auto 14px;position:relative;}
.cta-band p{color:var(--muted);position:relative;margin-bottom:30px;}
.cta-band .btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;position:relative;}

/* ============================================================ FOOTER */
.footer{background:var(--bg-2);border-top:1px solid var(--line);padding:80px 0 36px;}
.footer-top{display:grid;grid-template-columns:1.6fr 1fr 1.2fr;gap:60px;padding-bottom:50px;border-bottom:1px solid var(--line);}
.footer-brand img{height:40px;margin-bottom:22px;}
.footer-brand p{color:var(--muted);font-size:0.94rem;max-width:38ch;}
.footer-col h4{font-family:var(--sans);font-size:0.7rem;letter-spacing:0.18em;text-transform:uppercase;color:var(--blue-bright);margin-bottom:20px;font-weight:700;}
.footer-col ul{list-style:none;}
.footer-col li{margin-bottom:12px;}
.footer-col a{color:var(--muted);font-size:0.92rem;transition:.3s;}
.footer-col a:hover{color:#fff;padding-left:5px;}
.footer-col p{color:var(--muted);font-size:0.92rem;margin-bottom:10px;}
.footer-col p a{color:#fff;font-weight:600;}
.footer-socials{display:flex;gap:10px;margin-top:18px;}
.footer-socials a{width:40px;height:40px;border-radius:50%;border:1px solid var(--line);display:grid;place-items:center;color:var(--muted);transition:.3s;}
.footer-socials a:hover{background:var(--blue);border-color:var(--blue);color:#06101f;transform:translateY(-3px);}
.footer-socials svg{width:16px;height:16px;fill:currentColor;}
.footer-bottom{padding-top:28px;display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;}
.footer-bottom p{font-size:0.78rem;color:var(--muted-2);}
.footer-bottom .mini{display:flex;gap:22px;}
.footer-bottom .mini a{font-size:0.78rem;color:var(--muted);}

/* ============================================================ REVEAL */
.reveal{opacity:0;transform:translateY(34px);transition:opacity 1s var(--ease),transform 1s var(--ease);}
.reveal.in{opacity:1;transform:none;}
.reveal.d1{transition-delay:.08s;}.reveal.d2{transition-delay:.16s;}.reveal.d3{transition-delay:.24s;}

/* ============================================================ RESPONSIVE */
@media(max-width:1080px){
  .cards,.interests,.vcards{grid-template-columns:repeat(2,1fr);}
  .split,.detail-grid,.sim-grid{grid-template-columns:1fr;gap:44px;}
  .detail-aside,.sim-result{position:relative;top:auto;}
  .zstrip{height:auto;flex-direction:column;}
  .zitem{flex:none;height:130px;}
  .zitem:hover{flex:none;}
  .zitem .zc h3{writing-mode:horizontal-tb;transform:none;height:auto;}
  .zitem .zc .zmeta{max-height:none;opacity:1;}
}
@media(max-width:860px){
  .hero-slogans{min-height:clamp(280px,58vw,390px);padding-bottom:0;}
  .nav,.header-right .socials{display:none;}
  .burger{display:flex;}
  .nav.open{display:flex;position:fixed;inset:74px 16px auto 16px;flex-direction:column;align-items:stretch;background:rgba(14,20,36,0.98);backdrop-filter:blur(18px);border:1px solid var(--line-2);border-radius:18px;padding:14px;gap:4px;box-shadow:0 30px 70px rgba(0,0,0,.5);}
  .nav.open a{padding:14px 16px;}
  .nav.open a.cta-link{margin:6px 0 0;text-align:center;}
  .search-bar,.filter-dock{grid-template-columns:1fr;}
  .filter-dock .ff{border-right:none;border-bottom:1px solid var(--line);}
  .frow,.feature-list{grid-template-columns:1fr;}
}
@media(max-width:620px){
  .hero-slogans{min-height:clamp(310px,88vw,430px);padding-bottom:0;}
  .wrap{padding:0 22px;}
  .section{padding:72px 0;}
  .cards,.interests,.vcards{grid-template-columns:1fr;}
  .cta-band,.form-card,.sim-result{padding:34px 24px;}
  .footer-top{grid-template-columns:1fr;gap:36px;}
  .split-media .badge{right:12px;}
}


/* ============================================================
   SCROLL LATERAL COM SOBREPOSICAO APENAS ENTRE "ENCONTRE POR ZONA" E "QUAL O SEU INTERESSE"
   O site desce normal ate a section anterior. "Encontre por zona" aparece primeiro,
   "Qual o seu interesse" entra pela direita e sobrepoe. Depois disso, volta ao scroll vertical normal.
   No mobile, tudo volta ao scroll vertical normal.
   ============================================================ */
@media (min-width:901px){
  .overlay-scroll{
    position:relative;
    background:transparent;
  }

  .overlay-stage{
    position:sticky;
    top:0;
    width:100%;
    height:100vh;
    overflow:hidden;
    background:transparent;
  }

  .overlay-panel{
    position:absolute;
    inset:0;
    width:100%;
    height:100vh;
    min-height:100vh;
    overflow-y:auto;
    overflow-x:hidden;
    transform:translateX(100%);
    transition:transform .06s linear;
    will-change:transform;
    box-shadow:-34px 0 70px rgba(0,0,0,.34);
    background:var(--bg);
  }

  .overlay-panel.panel{
    background:var(--bg-2);
  }

  .overlay-panel.footer{
    background:var(--bg-2);
  }

  .overlay-panel:first-child{transform:translateX(0);}

  .overlay-panel:nth-child(1){z-index:1;}
  .overlay-panel:nth-child(2){z-index:2;}
  .overlay-panel:nth-child(3){z-index:3;}
  .overlay-panel:nth-child(4){z-index:4;}
  .overlay-panel:nth-child(5){z-index:5;}

  .overlay-panel.section{
    padding:90px 0 70px;
  }

  .overlay-panel.footer{
    padding:90px 0 36px;
  }

  .overlay-panel .sec-head{
    margin-bottom:44px;
  }

  .overlay-panel .zstrip{
    height:430px;
  }

  .overlay-panel .interest{
    min-height:360px;
  }

  .overlay-panel .split{
    min-height:calc(100vh - 180px);
  }
}

@media (max-width:900px){
  .overlay-scroll,
  .overlay-stage{
    position:relative;
    height:auto !important;
    overflow:visible;
  }

  .overlay-panel{
    position:relative;
    inset:auto;
    width:auto;
    height:auto;
    min-height:0;
    overflow:visible;
    transform:none !important;
    box-shadow:none;
  }
}

/* ============================================================
   AJUSTES FINAIS MOBILE
   Mantem o efeito lateral apenas no desktop e evita cortes no celular.
   ============================================================ */
@media (max-width:900px){
  html, body{
    width:100%;
    max-width:100%;
    overflow-x:hidden;
  }

  .site-header{
    padding:14px 0;
  }

  .site-header.scrolled{
    padding:10px 0;
  }

  .header-inner{
    gap:12px;
  }

  .logo-link img{
    height:30px;
  }

  .burger{
    width:40px;
    height:40px;
    flex-shrink:0;
  }

  .nav.open{
    inset:64px 14px auto 14px;
    max-height:calc(100vh - 84px);
    overflow-y:auto;
  }

  .hero{
    min-height:auto;
    align-items:flex-end;
  }

  .hero-inner{
    padding-top:112px;
    padding-bottom:38px;
  }

  .hero-top{
    display:block;
    margin-bottom:18px;
  }

  .hero-index{
    display:none;
  }

  .eyebrow{
    font-size:.62rem;
    letter-spacing:.22em;
    gap:10px;
  }

  .eyebrow::before{
    width:24px;
  }

  .hero-slogans{
    min-height:clamp(270px,76vw,390px);
  }

  .hero-slogan h1{
    max-width:100%;
    font-size:clamp(2.25rem,13.5vw,4.7rem);
    line-height:.95;
    overflow-wrap:normal;
  }

  .hero-slogan p{
    margin-top:14px;
    font-size:1rem;
    max-width:28ch;
  }

  .hero-dots{
    margin-top:14px;
  }

  .search-bar{
    margin-top:24px;
    max-width:100%;
    border-radius:16px;
    padding:10px;
  }

  .search-field{
    padding:10px 14px;
  }

  .search-bar .btn{
    width:100%;
    min-height:50px;
  }

  .section,
  .section.tight,
  .overlay-panel.section{
    padding:68px 0;
  }

  .sec-head{
    display:block;
    margin-bottom:32px;
  }

  .sec-head-left{
    max-width:100%;
  }

  .sec-head h2{
    font-size:clamp(2rem,10vw,3rem);
    line-height:1;
    max-width:100%;
  }

  .sec-head .btn,
  .sec-head > .btn{
    margin-top:22px;
  }

  .cards,
  .interests,
  .vcards{
    grid-template-columns:1fr;
    gap:18px;
  }

  .card-body{
    padding:22px;
  }

  .card-body h3{
    font-size:1.35rem;
  }

  .zstrip,
  .overlay-panel .zstrip{
    height:auto;
    flex-direction:column;
    gap:14px;
  }

  .zitem,
  .overlay-panel .zitem{
    height:190px;
    min-height:190px;
    flex:none;
  }

  .zitem:hover,
  .overlay-panel .zitem:hover{
    flex:none;
  }

  .zitem .zc{
    padding:22px;
  }

  .zitem .zc h3{
    writing-mode:horizontal-tb;
    transform:none;
    height:auto;
    font-size:1.55rem;
  }

  .zitem .zc .zmeta{
    max-height:none;
    opacity:1;
    margin-top:8px;
  }

  .interest,
  .overlay-panel .interest{
    min-height:330px;
  }

  .interest .it{
    padding:26px;
  }

  .interest .it h3{
    font-size:1.55rem;
  }

  .split{
    grid-template-columns:1fr;
    gap:34px;
  }

  .split-media img{
    aspect-ratio:4/3;
  }

  .split-media .badge{
    right:12px;
    bottom:12px;
    padding:16px 18px;
  }

  .split-media .badge strong{
    font-size:1.8rem;
  }

  .stats{
    gap:22px;
  }

  .stat strong{
    font-size:2rem;
  }

  .cta-band{
    padding:38px 22px;
    text-align:left;
  }

  .cta-band h2{
    margin:0 0 12px;
    max-width:100%;
  }

  .cta-band .btns{
    justify-content:flex-start;
  }

  .cta-band .btns .btn{
    width:100%;
  }

  .footer{
    padding:60px 0 30px;
  }

  .footer-top{
    grid-template-columns:1fr;
    gap:30px;
  }

  .footer-bottom{
    align-items:flex-start;
    flex-direction:column;
  }

  .footer-bottom .mini{
    flex-wrap:wrap;
    gap:14px;
  }

  .overlay-scroll,
  .overlay-stage{
    position:relative !important;
    height:auto !important;
    min-height:0 !important;
    overflow:visible !important;
  }

  .overlay-panel,
  .overlay-panel:first-child{
    position:relative !important;
    inset:auto !important;
    width:100% !important;
    height:auto !important;
    min-height:0 !important;
    overflow:visible !important;
    transform:none !important;
    box-shadow:none !important;
  }
}

@media (max-width:480px){
  .wrap{
    padding:0 18px;
  }

  .hero-inner{
    padding-top:100px;
  }

  .hero-slogans{
    min-height:clamp(250px,82vw,350px);
  }

  .hero-slogan h1{
    font-size:clamp(2rem,12.5vw,3.4rem);
  }

  .hero-slogan p{
    font-size:.96rem;
  }

  .btn{
    width:100%;
    padding:14px 18px;
  }

  .sec-head h2{
    font-size:clamp(1.85rem,10.5vw,2.6rem);
  }

  .card-media{
    aspect-ratio:1/1;
  }

  .zitem,
  .overlay-panel .zitem{
    height:170px;
    min-height:170px;
  }

  .interest,
  .overlay-panel .interest{
    min-height:300px;
  }
}

/* ============================================================
   AJUSTE FINAL MOBILE - HERO SEM CORTAR FRASES
   Mantem o desktop igual e corrige apenas telas pequenas.
   ============================================================ */
@media (max-width: 620px){
  html,
  body{
    width:100%;
    max-width:100%;
    overflow-x:hidden;
  }

  .hero{
    min-height:100svh;
    align-items:flex-end;
  }

  .hero-inner{
    padding-top:112px;
    padding-bottom:26px;
  }

  .hero-top{
    display:block;
    margin-bottom:22px;
  }

  .hero-index{
    display:none;
  }

  .hero-slogans{
    min-height:245px;
    width:100%;
    overflow:visible;
  }

  .hero-slogan{
    width:100%;
    max-width:100%;
    overflow:visible;
  }

  .hero-slogan h1{
    max-width:100%;
    width:100%;
    font-size:clamp(2.35rem, 10.2vw, 3.05rem);
    line-height:.96;
    letter-spacing:-0.045em;
    overflow-wrap:normal;
    word-break:normal;
  }

  .hero-slogan h1 em{
    display:inline;
  }

  .hero-slogan p{
    margin-top:16px;
    max-width:100%;
    font-size:1rem;
    line-height:1.35;
  }

  .hero-dots{
    margin-top:18px;
  }

  .search-bar{
    margin-top:28px;
  }
}

@media (max-width: 430px){
  .hero-slogan h1{
    font-size:clamp(2.2rem, 9.8vw, 2.75rem);
    line-height:.98;
  }

  .hero-slogans{
    min-height:230px;
  }
}

@media (max-width: 375px){
  .hero-slogan h1{
    font-size:2.05rem;
  }

  .hero-slogans{
    min-height:220px;
  }
}


/* ============================================================
   SECOES UAU HOUZZE
   Conteudo extra com efeitos visuais sem alterar o fluxo existente.
   ============================================================ */
.wow-ribbon{
  position:relative;
  overflow:hidden;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  background:linear-gradient(90deg,rgba(91,140,199,.18),rgba(10,14,24,.95),rgba(91,140,199,.16));
  padding:18px 0;
}
.wow-ribbon::before,
.wow-ribbon::after{
  content:'';
  position:absolute;
  top:0;
  width:160px;
  height:100%;
  z-index:2;
  pointer-events:none;
}
.wow-ribbon::before{left:0;background:linear-gradient(90deg,var(--bg),transparent);}
.wow-ribbon::after{right:0;background:linear-gradient(270deg,var(--bg),transparent);}
.ribbon-track{
  display:flex;
  align-items:center;
  gap:26px;
  width:max-content;
  animation:ribbonMove 24s linear infinite;
}
.ribbon-track span{
  font-family:var(--disp);
  font-size:clamp(1rem,2vw,1.35rem);
  font-weight:800;
  color:rgba(234,239,247,.9);
  letter-spacing:.08em;
  text-transform:uppercase;
  white-space:nowrap;
}
.ribbon-track i{
  width:8px;
  height:8px;
  border-radius:50%;
  background:var(--blue-bright);
  box-shadow:0 0 22px rgba(134,176,228,.85);
  flex:0 0 auto;
}
@keyframes ribbonMove{from{transform:translateX(0);}to{transform:translateX(-50%);}}

.experience-lab{
  overflow:hidden;
  background:
    radial-gradient(circle at 12% 18%,rgba(91,140,199,.20),transparent 30%),
    radial-gradient(circle at 88% 78%,rgba(134,176,228,.15),transparent 28%),
    var(--bg);
}
.wow-grid{
  display:grid;
  grid-template-columns:1fr 1.25fr 1fr;
  gap:22px;
  align-items:stretch;
}
.magnetic-card{
  --mx:50%;
  --my:50%;
  position:relative;
  overflow:hidden;
  isolation:isolate;
}
.magnetic-card::before{
  content:'';
  position:absolute;
  inset:0;
  z-index:-1;
  opacity:0;
  transition:opacity .35s var(--ease);
  background:radial-gradient(circle at var(--mx) var(--my),rgba(134,176,228,.28),transparent 34%);
}
.magnetic-card:hover::before{opacity:1;}
.wow-card{
  min-height:360px;
  padding:34px;
  border-radius:var(--r-lg);
  border:1px solid var(--line);
  background:linear-gradient(145deg,rgba(18,27,48,.92),rgba(14,20,36,.72));
  box-shadow:0 34px 80px rgba(0,0,0,.28);
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  transition:transform .55s var(--ease),border-color .55s var(--ease),box-shadow .55s var(--ease);
}
.wow-card:hover{
  transform:translateY(-10px);
  border-color:rgba(134,176,228,.36);
  box-shadow:0 42px 100px rgba(0,0,0,.42);
}
.wow-number{
  position:absolute;
  top:28px;
  left:30px;
  font-family:var(--disp);
  font-weight:800;
  color:rgba(134,176,228,.85);
  letter-spacing:.12em;
}
.wow-card h3{
  font-size:clamp(1.45rem,2.4vw,2.25rem);
  max-width:12ch;
  margin-bottom:14px;
}
.wow-card p{
  color:var(--muted);
  font-size:.96rem;
  max-width:34ch;
}
.featured-wow{
  min-height:430px;
  background:
    linear-gradient(to top,rgba(10,14,24,.92),rgba(10,14,24,.28)),
    url('https://images.unsplash.com/photo-1600566753190-17f0baa2a6c3?auto=format&fit=crop&q=80&w=1200') center/cover;
}
.orb{
  position:absolute;
  border-radius:50%;
  filter:blur(1px);
  opacity:.8;
  pointer-events:none;
}
.orb-one{
  width:150px;
  height:150px;
  right:22px;
  top:28px;
  background:radial-gradient(circle,rgba(134,176,228,.5),transparent 68%);
  animation:floatOrb 7s ease-in-out infinite;
}
.orb-two{
  width:90px;
  height:90px;
  right:150px;
  bottom:82px;
  background:radial-gradient(circle,rgba(255,255,255,.28),transparent 68%);
  animation:floatOrb 8s ease-in-out infinite reverse;
}
@keyframes floatOrb{0%,100%{transform:translate3d(0,0,0);}50%{transform:translate3d(-18px,22px,0);}}

.journey-showcase{
  overflow:hidden;
}
.journey-wrap{
  display:grid;
  grid-template-columns:.9fr 1.1fr;
  gap:70px;
  align-items:center;
}
.journey-copy{
  position:relative;
}
.journey-copy h2{
  font-size:clamp(2.1rem,4.6vw,4.4rem);
  margin:18px 0 18px;
}
.journey-copy p{
  color:var(--muted);
  max-width:46ch;
  margin-bottom:28px;
}
.journey-steps{
  position:relative;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:18px;
}
.journey-steps::before{
  content:'';
  position:absolute;
  inset:10% auto 10% 50%;
  width:1px;
  background:linear-gradient(to bottom,transparent,var(--blue-bright),transparent);
  opacity:.5;
}
.journey-step{
  min-height:230px;
  padding:28px;
  border-radius:24px;
  border:1px solid var(--line);
  background:rgba(10,14,24,.46);
  backdrop-filter:blur(18px);
  box-shadow:0 24px 70px rgba(0,0,0,.25);
  transition:transform .5s var(--ease),border-color .5s var(--ease);
}
.journey-step:nth-child(even){transform:translateY(38px);}
.journey-step:hover{
  transform:translateY(-6px) scale(1.02);
  border-color:rgba(134,176,228,.34);
}
.journey-step:nth-child(even):hover{transform:translateY(28px) scale(1.02);}
.journey-step strong{
  font-family:var(--disp);
  color:var(--blue-bright);
  letter-spacing:.18em;
}
.journey-step h3{
  margin:34px 0 10px;
  font-size:1.45rem;
}
.journey-step p{
  color:var(--muted);
  font-size:.92rem;
}

.dream-board{
  overflow:hidden;
}
.dream-panel{
  position:relative;
  min-height:560px;
  border-radius:34px;
  overflow:hidden;
  border:1px solid var(--line-2);
  background:var(--panel);
  box-shadow:0 45px 120px rgba(0,0,0,.34);
}
.dream-bg{
  position:absolute;
  inset:0;
  background:
    linear-gradient(90deg,rgba(10,14,24,.92),rgba(10,14,24,.42),rgba(10,14,24,.86)),
    url('https://images.unsplash.com/photo-1600607687920-4e2a09cf159d?auto=format&fit=crop&q=80&w=1600') center/cover;
  transform:scale(1.05);
  animation:dreamZoom 12s ease-in-out infinite alternate;
}
@keyframes dreamZoom{from{transform:scale(1.04);}to{transform:scale(1.12);}}
.dream-content{
  position:relative;
  z-index:2;
  padding:72px;
  max-width:720px;
}
.dream-content h2{
  font-size:clamp(2.2rem,5vw,4.8rem);
  margin:18px 0 18px;
}
.dream-content p{
  color:var(--muted);
  max-width:50ch;
  font-size:1.08rem;
}
.dream-pills{
  position:absolute;
  inset:0;
  z-index:3;
  pointer-events:none;
}
.pill{
  position:absolute;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:48px;
  padding:0 22px;
  border-radius:999px;
  background:rgba(234,239,247,.12);
  border:1px solid rgba(255,255,255,.22);
  backdrop-filter:blur(18px);
  color:#fff;
  font-weight:700;
  box-shadow:0 20px 60px rgba(0,0,0,.28);
  animation:floatPill 8s ease-in-out infinite;
}
.p1{right:10%;top:18%;}
.p2{right:7%;bottom:22%;animation-delay:.7s;}
.p3{left:48%;top:52%;animation-delay:1.2s;}
.p4{right:26%;top:38%;animation-delay:1.8s;}
.p5{left:8%;bottom:14%;animation-delay:2.4s;}
@keyframes floatPill{0%,100%{transform:translateY(0);}50%{transform:translateY(-18px);}}

@media(max-width:1080px){
  .wow-grid,
  .journey-wrap{
    grid-template-columns:1fr;
  }
  .wow-card,
  .featured-wow{
    min-height:310px;
  }
  .journey-steps{
    margin-top:10px;
  }
}

@media(max-width:760px){
  .wow-ribbon{
    padding:14px 0;
  }
  .ribbon-track span{
    font-size:.9rem;
  }
  .wow-grid,
  .journey-steps{
    grid-template-columns:1fr;
  }
  .wow-card,
  .featured-wow{
    min-height:280px;
    padding:26px;
  }
  .journey-steps::before{
    display:none;
  }
  .journey-step,
  .journey-step:nth-child(even),
  .journey-step:hover,
  .journey-step:nth-child(even):hover{
    transform:none;
  }
  .dream-panel{
    min-height:auto;
    border-radius:24px;
  }
  .dream-content{
    padding:42px 24px 220px;
  }
  .dream-content h2{
    font-size:clamp(2rem,10vw,3rem);
  }
  .dream-pills{
    position:absolute;
    display:flex;
    flex-wrap:wrap;
    gap:10px;
    align-content:flex-end;
    padding:0 22px 28px;
  }
  .pill{
    position:relative;
    inset:auto !important;
    min-height:40px;
    padding:0 14px;
    font-size:.82rem;
    animation:none;
  }
}

/* ============================================================
   AJUSTES FINOS SOLICITADOS
   1) faixa animada mais delicada
   2) imagem em todos os cards da experiencia
   ============================================================ */
.wow-ribbon{
  background:linear-gradient(90deg,rgba(91,140,199,.08),rgba(10,14,24,.98),rgba(91,140,199,.08));
  padding:10px 0;
}
.wow-ribbon::before,
.wow-ribbon::after{
  width:110px;
}
.ribbon-track{
  gap:18px;
  animation:ribbonMove 34s linear infinite;
}
.ribbon-track span{
  font-size:clamp(.82rem,1.3vw,1rem);
  font-weight:700;
  color:rgba(234,239,247,.76);
  letter-spacing:.12em;
}
.ribbon-track i{
  width:5px;
  height:5px;
  background:rgba(134,176,228,.85);
  box-shadow:0 0 10px rgba(134,176,228,.45);
  opacity:.85;
}

.wow-grid .wow-card:nth-child(1){
  background:
    linear-gradient(to top,rgba(10,14,24,.94),rgba(10,14,24,.50)),
    url('https://images.unsplash.com/photo-1560518883-ce09059eeffa?auto=format&fit=crop&q=80&w=1200') center/cover;
}

.wow-grid .wow-card:nth-child(3){
  background:
    linear-gradient(to top,rgba(10,14,24,.94),rgba(10,14,24,.42)),
    url('https://images.unsplash.com/photo-1554224154-22dec7ec8818?auto=format&fit=crop&q=80&w=1200') center/cover;
}

.wow-grid .wow-card:nth-child(1) p,
.wow-grid .wow-card:nth-child(3) p,
.wow-grid .wow-card:nth-child(1) h3,
.wow-grid .wow-card:nth-child(3) h3{
  position:relative;
  z-index:1;
}

@media(max-width:900px){
  .wow-ribbon{
    padding:8px 0;
  }

  .ribbon-track{
    gap:14px;
    animation-duration:28s;
  }

  .ribbon-track span{
    font-size:.78rem;
    letter-spacing:.10em;
  }

  .ribbon-track i{
    width:4px;
    height:4px;
  }
}


/* ============================================================
   MAPA DE POSSIBILIDADES ENTRA PELA LATERAL APOS "DO CLIQUE AS CHAVES"
   Depois dele, o fluxo volta ao scroll vertical normal.
   ============================================================ */
@media (min-width:901px){
  .dream-side-scroll{
    position:relative;
    background:var(--bg);
  }

  .dream-side-stage{
    position:sticky;
    top:0;
    height:100vh;
    overflow:hidden;
    background:var(--bg);
  }

  .dream-side-panel{
    position:absolute;
    inset:0;
    width:100%;
    height:100vh;
    min-height:100vh;
    display:flex;
    align-items:center;
    overflow:hidden;
    transform:translateX(100%);
    transition:transform .06s linear;
    will-change:transform;
    box-shadow:-34px 0 70px rgba(0,0,0,.34);
  }

  .dream-side-panel.section{
    padding:70px 0;
  }

  .dream-side-panel .dream-panel{
    width:100%;
  }
}

@media (max-width:900px){
  .dream-side-scroll,
  .dream-side-stage{
    position:relative;
    height:auto !important;
    overflow:visible;
  }

  .dream-side-panel{
    position:relative;
    inset:auto;
    width:auto;
    height:auto;
    min-height:0;
    display:block;
    overflow:visible;
    transform:none !important;
    box-shadow:none;
  }
}


/* ============================================================
   CORRECAO DO VAZIO ANTES DO MAPA
   Mantem "Do clique as chaves" como base visivel enquanto
   "Mapa de possibilidades" entra pela lateral por cima.
   ============================================================ */
@media (min-width:901px){
  .dream-side-scroll{
    position:relative;
    background:transparent !important;
  }

  .dream-side-stage{
    position:sticky;
    top:0;
    width:100%;
    height:100vh;
    overflow:hidden;
    background:var(--bg-2) !important;
  }

  .dream-base-panel,
  .dream-side-panel{
    position:absolute !important;
    inset:0;
    width:100%;
    height:100vh;
    min-height:100vh;
    overflow-y:auto;
    overflow-x:hidden;
  }

  .dream-base-panel{
    z-index:1;
    transform:none !important;
  }

  .dream-side-panel{
    z-index:2;
    transform:translateX(100%);
    will-change:transform;
    background:var(--bg) !important;
    box-shadow:-34px 0 70px rgba(0,0,0,.34);
  }

  .dream-base-panel.section,
  .dream-side-panel.section{
    padding:70px 0;
  }

  .dream-base-panel .journey-wrap{
    min-height:calc(100vh - 140px);
  }
}

@media (max-width:900px){
  .dream-base-panel,
  .dream-side-panel{
    position:relative !important;
    height:auto;
    min-height:0;
    overflow:visible;
    transform:none !important;
    box-shadow:none;
  }
}
