
/* ===================== ROOT & RESET ===================== */
:root {
  --bg:        #f4f1eb;
  --bg2:       #eceae3;
  --dark:      #1e2030;
  --dark2:     #2a2d42;
  --text:      #1e2030;
  --muted:     #7a7875;
  --muted2:    #a09d99;
  --border:    rgba(30,32,48,0.1);
  --border2:   rgba(30,32,48,0.06);
  --white:     #ffffff;
  --radius:    12px;
  --teal:      #2d7a6e;
  --teal-l:    #3d9a8c;
  --coral:     #d4685a;
  --blue-n:    #5ab5d4;
  --yellow-n:  #d9b840;
  --lavender:  #8878c0;
  --font:      -apple-system,'Helvetica Neue',Arial,sans-serif;
  --font-alt:  'Georgia','Times New Roman',serif;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;font-size:16px;}
body{
  font-family:var(--font);
  background:var(--bg);
  color:var(--text);
  overflow-x:hidden;
  line-height:1.6;
}
::-webkit-scrollbar{width:5px;}
::-webkit-scrollbar-track{background:var(--bg);}
::-webkit-scrollbar-thumb{background:var(--teal);border-radius:3px;opacity:0.5;}

img{display:block;max-width:100%;}
a{text-decoration:none;color:inherit;}
button{cursor:pointer;border:none;background:none;font-family:var(--font);}


/* Global: tight line-height em headings de seção */
section h2{line-height:1.08;}
/* ===================== LOADER ===================== */
.loader{
  position:fixed;inset:0;
  background:var(--dark);
  z-index:9999;
  display:flex;align-items:center;justify-content:center;
  transition:opacity 0.6s ease, visibility 0.6s ease;
}
.loader.done{opacity:0;visibility:hidden;}
.loader-count{
  font-size:clamp(3rem,10vw,8rem);
  font-weight:800;
  color:var(--bg);
  letter-spacing:-0.03em;
  font-variant-numeric:tabular-nums;
}

/* ===================== HEADER ===================== */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:100;
  padding:22px 40px;
  display:flex;align-items:center;justify-content:space-between;
  transition:background 0.3s ease, padding 0.3s ease, border-bottom 0.3s ease;
}
.site-header.scrolled{
  background:rgba(244,241,235,0.92);
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
  border-bottom:1px solid var(--border);
  padding:14px 40px;
}
.header-logo img{height:64px;width:auto;}
.header-right{display:flex;align-items:center;gap:20px;}
.header-social{display:flex;align-items:center;gap:10px;}
.header-social a{
  width:34px;height:34px;border-radius:50%;
  border:1px solid rgba(30,32,48,0.12);
  display:flex;align-items:center;justify-content:center;
  color:var(--muted);font-size:13px;
  transition:all 0.22s ease;
}
.header-social a:hover{
  border-color:var(--teal);
  color:var(--teal);
  background:rgba(45,122,110,0.06);
}

.header-cta{
  font-size:0.82rem;font-weight:600;
  letter-spacing:0.06em;text-transform:uppercase;
  color:var(--dark);
  border:1px solid var(--border2);
  padding:10px 20px;border-radius:999px;
  transition:all 0.25s ease;
}
.header-cta:hover{background:var(--dark);color:var(--bg);}

/* Hamburger */
.hamburger{
  display:flex;flex-direction:column;justify-content:center;
  gap:6px;width:36px;height:36px;padding:4px 0;
  cursor:pointer;position:relative;z-index:101;
}
.hamburger span{
  display:block;height:1.5px;background:var(--dark);
  border-radius:2px;
  transition:all 0.4s cubic-bezier(0.4,0,0.2,1);
  transform-origin:center;
}
.hamburger.open span:nth-child(1){transform:translateY(7.5px) rotate(45deg);}
.hamburger.open span:nth-child(2){opacity:0;transform:scaleX(0);}
.hamburger.open span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg);}

/* ===================== FULLSCREEN MENU ===================== */
.menu-overlay{
  position:fixed;inset:0;z-index:99;
  background:var(--dark);
  clip-path:circle(0% at calc(100% - 58px) 58px);
  transition:clip-path 0.7s cubic-bezier(0.4,0,0.2,1);
  pointer-events:none;
}
.menu-overlay.open{
  clip-path:circle(150% at calc(100% - 58px) 58px);
  pointer-events:all;
}
/* Logo clara quando menu aberto */
.menu-overlay.open ~ .site-header .header-logo img{
  filter:brightness(0) invert(1);
  transition:filter 0.3s ease;
}

.menu-inner{
  height:100%;
  overflow-y:auto;
  display:flex;
  padding:120px 60px 60px;
  gap:60px;
  opacity:0;transition:opacity 0.3s ease 0.2s;
}
.menu-overlay.open .menu-inner{opacity:1;}
.menu-nav{flex:1;}
.menu-nav ul{list-style:none;}
.menu-nav li{border-bottom:1px solid rgba(244,241,235,0.08);overflow:hidden;}
.menu-nav a{
  display:flex;align-items:center;justify-content:space-between;
  font-size:clamp(2rem,5vw,4rem);
  font-weight:700;letter-spacing:-0.02em;
  color:var(--bg);
  padding:20px 0;
  transition:color 0.2s ease;
  transform:translateY(100%);
  transition:transform 0.5s cubic-bezier(0.4,0,0.2,1), color 0.2s ease;
}
.menu-overlay.open .menu-nav a{transform:translateY(0);}
.menu-overlay.open .menu-nav li:nth-child(1) a{transition-delay:0.1s;}
.menu-overlay.open .menu-nav li:nth-child(2) a{transition-delay:0.15s;}
.menu-overlay.open .menu-nav li:nth-child(3) a{transition-delay:0.2s;}
.menu-overlay.open .menu-nav li:nth-child(4) a{transition-delay:0.25s;}
.menu-overlay.open .menu-nav li:nth-child(5) a{transition-delay:0.3s;}
.menu-overlay.open .menu-nav li:nth-child(6) a{transition-delay:0.35s;}
.menu-overlay.open .menu-nav li:nth-child(7) a{transition-delay:0.4s;}
.menu-overlay.open .menu-nav li:nth-child(8) a{transition-delay:0.45s;}
.menu-nav a:hover{color:var(--muted2);}
.menu-nav a .arr{font-size:0.5em;opacity:0.4;}
.menu-side{
  width:300px;
  display:flex;flex-direction:column;justify-content:space-between;
  color:var(--muted2);
  font-size:0.9rem;line-height:1.7;
}
.menu-side .tagline{font-style:italic;font-size:1.05rem;color:rgba(244,241,235,0.7);}
.menu-side .contacts a{color:var(--bg);font-weight:500;display:block;margin-top:8px;}
.menu-social{display:flex;gap:16px;margin-top:24px;}
.menu-social a{color:var(--muted2);font-size:0.8rem;font-weight:600;letter-spacing:0.06em;text-transform:uppercase;transition:color 0.2s;}
.menu-social a:hover{color:var(--bg);}

/* ===================== HERO ===================== */
.hero{
  min-height:100vh;
  padding:0;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  position:relative;
  overflow:hidden;
}
#particles-js{
  position:absolute;inset:0;
  width:100%;height:100%;
  z-index:0;
}
#particles-js canvas{
  position:absolute;inset:0;
  width:100% !important;
  height:100% !important;
}
.hero-inner{
  position:relative;z-index:2;
  padding:160px 40px 56px;
  width:100%;
}
.hero-top-bar{
  position:absolute;
  top:0;left:0;right:0;
  display:flex;align-items:center;
  padding:90px 40px 0;
  z-index:2;
}
.hero-top-tag{
  display:inline-flex;align-items:center;gap:10px;
  font-size:0.75rem;font-weight:600;
  letter-spacing:0.12em;text-transform:uppercase;
  color:var(--muted);
  border:1px solid var(--border);
  padding:8px 16px;border-radius:999px;
  background:rgba(244,241,235,0.6);backdrop-filter:blur(8px);
}
.hero-top-tag::before{
  content:'';display:block;
  width:6px;height:6px;border-radius:50%;
  background:var(--teal);
  animation:pulse 2s ease-in-out infinite;
}
@keyframes pulse{
  0%,100%{opacity:1;transform:scale(1);}
  50%{opacity:0.4;transform:scale(1.4);}
}
.hero-grid{
  display:grid;
  grid-template-columns:1fr 420px;
  gap:48px;
  align-items:end;
}
.hero-left{}
.hero-eyebrow{
  font-size:0.72rem;font-weight:700;
  letter-spacing:0.14em;text-transform:uppercase;
  color:var(--muted);margin-bottom:28px;
  display:flex;align-items:center;gap:12px;
}
.hero-eyebrow::before{content:'';display:block;width:24px;height:1px;background:var(--muted2);}
.hero-title{
  font-size:clamp(2.2rem,4.4vw,4.8rem);
  font-weight:800;
  line-height:1.1;
  letter-spacing:-0.03em;
  margin-bottom:28px;
  max-width:720px;
}
.hero-title .line-italic{
  font-style:italic;
  font-weight:700;
  color:var(--muted);
}
.hero-title .word-highlight{
  position:relative;
  display:inline-block;
  color:var(--dark);
}
.hero-title .word-highlight::after{
  content:'';
  position:absolute;
  bottom:0.05em;left:0;right:0;
  height:0.06em;
  background:var(--dark);
  border-radius:2px;
  transform:scaleX(0);
  transform-origin:left;
  animation:underlineIn 1s cubic-bezier(0.4,0,0.2,1) 1.6s forwards;
}
@keyframes underlineIn{to{transform:scaleX(1);}}
.hero-subtitle{
  font-size:1rem;
  color:var(--muted);
  line-height:1.7;
  max-width:480px;
  margin-bottom:32px;
}

.ico-btn{
  flex-shrink:0;width:34px;height:34px;border-radius:50%;
  background:var(--dark);color:var(--bg);
  display:flex;align-items:center;justify-content:center;
  transition:transform 0.25s ease, background 0.25s ease;
}
.ico-btn:hover{transform:rotate(45deg);background:var(--dark2);}
.btn-fill{
  display:inline-flex;align-items:center;gap:14px;
  font-size:0.75rem;font-weight:700;
  letter-spacing:0.1em;text-transform:uppercase;
  color:var(--bg);
  background:var(--dark);
  border:1.5px solid var(--dark);
  padding:13px 18px 13px 24px;border-radius:999px;
  transition:all 0.3s cubic-bezier(0.4,0,0.2,1);
  width:fit-content;
}
.btn-fill .ico-fill{
  width:30px;height:30px;border-radius:50%;
  background:rgba(255,255,255,0.15);
  display:flex;align-items:center;justify-content:center;
  transition:transform 0.3s ease, background 0.3s ease;
  flex-shrink:0;
}
.btn-fill:hover{background:var(--dark2);border-color:var(--dark2);}
.btn-fill:hover .ico-fill{background:rgba(255,255,255,0.25);transform:rotate(45deg);}

.hero-ctas{
  display:flex;align-items:center;gap:16px;flex-wrap:wrap;
}
/* Right panel */
.hero-right{
  display:flex;flex-direction:column;gap:16px;
  padding-bottom:4px;
}
.hero-card{
  background:rgba(30,32,48,0.05);
  border:1px solid var(--border);
  border-radius:var(--radius);
  backdrop-filter:blur(12px);
  padding:24px;
  transition:transform 0.3s ease,border-color 0.3s ease;
}
.hero-card:hover{
  transform:translateY(-2px);
  border-color:rgba(30,32,48,0.2);
}
.hero-card-label{
  font-size:0.7rem;font-weight:700;
  letter-spacing:0.12em;text-transform:uppercase;
  color:var(--muted);margin-bottom:12px;
}
.hero-card-main{
  font-size:1.1rem;font-weight:700;
  color:var(--dark);line-height:1.35;
  margin-bottom:10px;
}
.hero-card-sub{
  font-size:0.82rem;color:var(--muted);line-height:1.5;
}
.hero-card-row{
  display:flex;align-items:center;justify-content:space-between;
  gap:12px;
}
.hero-card-tags{
  display:flex;flex-wrap:wrap;gap:6px;margin-top:14px;
}
.hero-card-tag{
  font-size:0.7rem;font-weight:600;letter-spacing:0.06em;text-transform:uppercase;
  padding:4px 10px;border-radius:999px;
  border:1px solid rgba(45,122,110,0.2);
  color:var(--teal);
  background:rgba(45,122,110,0.06);
}
.hero-scroll-hint{
  display:flex;align-items:center;gap:10px;
  font-size:0.72rem;font-weight:600;
  letter-spacing:0.1em;text-transform:uppercase;
  color:var(--muted2);
  padding-top:12px;
}
.hero-scroll-line{
  flex:1;height:1px;background:var(--border);
}
.hero-scroll-dot{
  width:8px;height:8px;border-radius:50%;
  border:1.5px solid var(--muted2);
  animation:scrollBounce 1.8s ease-in-out infinite;
}
@keyframes scrollBounce{
  0%,100%{transform:translateY(0);}
  50%{transform:translateY(3px);}
}

/* Reveal animation for hero content */
.hero-inner .reveal-fast{
  opacity:0;transform:translateY(24px);
  animation:revealFast 0.9s cubic-bezier(0.4,0,0.2,1) forwards;
}
.hero-inner .d1{animation-delay:0.8s;}
.hero-inner .d2{animation-delay:1.0s;}
.hero-inner .d3{animation-delay:1.2s;}
.hero-inner .d4{animation-delay:1.35s;}
.hero-inner .d5{animation-delay:1.5s;}
@keyframes revealFast{to{opacity:1;transform:translateY(0);}}

@media(max-width:900px){
  .hero-top-bar{padding:80px 20px 0;}
  .hero-inner{padding:0 20px 48px;}
  .hero-grid{grid-template-columns:1fr;}
  .hero-right{display:none;}
  .hero-title{font-size:clamp(2.2rem,8vw,4rem);}
}
/* ===================== MARQUEE TEXT ===================== */
.marquee-strip{
  background:linear-gradient(135deg, #2d7a6e 0%, #1e4a44 100%);
  color:var(--bg);
  padding:24px 0;
  overflow:hidden;
  white-space:nowrap;
}
.marquee-track{
  display:inline-flex;align-items:center;gap:0;
  animation:marquee-left 18s linear infinite;
  will-change:transform;
}
@keyframes marquee-left{
  0%{transform:translateX(0);}
  100%{transform:translateX(-50%);}
}
.marquee-item{
  display:inline-flex;align-items:center;gap:20px;
  font-size:clamp(0.8rem,1.5vw,1rem);
  font-weight:600;letter-spacing:0.12em;text-transform:uppercase;
  padding:0 32px;
}
.marquee-dot{
  width:5px;height:5px;border-radius:50%;
  background:rgba(244,241,235,0.3);
  flex-shrink:0;
}
.marquee-strip-light{
  background:var(--bg2);
  padding:18px 0;
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
}
.marquee-strip-light .marquee-track{animation-direction:reverse;animation-duration:22s;}
.marquee-strip-light .marquee-item{
  color:var(--muted);
  font-size:0.75rem;
}
.marquee-strip-light .marquee-dot{background:var(--border);}

/* ===================== MANIFESTO ===================== */
/* ===================== MANIFESTO / ORIGEM ===================== */
.manifesto{
  background:var(--bg);
  padding:0 40px 100px;
}
.manifesto-rule-top{
  border:none;border-top:1px solid var(--border);
  margin:0 0 72px;
}
.manifesto-cols{
  display:grid;
  grid-template-columns:220px 1fr 200px;
  gap:60px;
  align-items:start;
  max-width:1200px;
  margin:0 auto;
}
/* LEFT col: logo badge + label */
.manifesto-left-col{
  display:flex;flex-direction:column;gap:20px;
  padding-top:8px;
}
.manifesto-logo-wrap{
  display:flex;align-items:center;gap:12px;
}
.manifesto-logo-wrap img{
  width:62px;height:62px;object-fit:contain;
  opacity:0.85;
}
.manifesto-logo-name{
  font-size:0.72rem;font-weight:700;
  letter-spacing:0.1em;text-transform:uppercase;
  color:var(--muted);line-height:1.3;
}
.manifesto-year-tag{
  display:inline-block;
  font-size:0.68rem;font-weight:700;
  letter-spacing:0.12em;text-transform:uppercase;
  color:var(--teal);
  border:1px solid rgba(45,122,110,0.25);
  background:rgba(45,122,110,0.06);
  padding:5px 12px;border-radius:999px;
  width:fit-content;
}
.manifesto-left-line{
  width:1px;height:64px;
  background:linear-gradient(to bottom, var(--border), transparent);
  margin-left:20px;
}
/* CENTER col: big text */
.manifesto-center-col{}
.manifesto-big-text{
  font-size:clamp(2rem,3.6vw,3.4rem);
  font-weight:800;
  line-height:1.1;
  letter-spacing:-0.03em;
  color:var(--text);
  margin-bottom:32px;
}
.manifesto-big-text .txt-italic{
  font-style:italic;
  font-weight:300;
  color:var(--muted);
}
.manifesto-big-text .txt-teal{
  color:var(--teal);
  position:relative;
  display:inline-block;
}
.manifesto-big-text .txt-teal::after{
  content:'';
  position:absolute;bottom:-4px;left:0;right:0;
  height:2px;background:var(--teal);opacity:0.4;
  border-radius:2px;
}
.manifesto-body-text{
  font-size:1.05rem;
  line-height:1.7;
  color:var(--muted);
  max-width:560px;
}
/* RIGHT col: meta + cta */
.manifesto-right-col{
  display:flex;flex-direction:column;
  gap:24px;align-items:flex-end;
  padding-top:8px;
}
.manifesto-loc-pill{
  display:inline-flex;align-items:center;gap:8px;
  font-size:0.68rem;font-weight:600;
  letter-spacing:0.1em;text-transform:uppercase;
  color:var(--muted);
  border:1px solid var(--border);
  border-radius:999px;padding:7px 14px;
  text-align:right;line-height:1.5;
  background:var(--bg2);
}
.manifesto-loc-pill::before{
  content:'';display:block;
  width:5px;height:5px;flex-shrink:0;border-radius:50%;
  background:var(--teal);
  animation:pulse 2.5s ease-in-out infinite;
}
.manifesto-link{
  display:inline-flex;align-items:center;gap:8px;
  font-size:0.78rem;font-weight:700;
  letter-spacing:0.08em;text-transform:uppercase;
  color:var(--text);
  text-decoration:none;
  transition:color 0.2s;
}
.manifesto-link:hover{color:var(--teal);}
.manifesto-link svg{transition:transform 0.2s;}
.manifesto-link:hover svg{transform:translateX(4px);}
@media(max-width:1024px){
  .manifesto-cols{grid-template-columns:1fr;gap:40px;}
  .manifesto-right-col{align-items:flex-start;}
  .manifesto-big-text{font-size:clamp(2rem,7vw,3rem);}
}
@media(max-width:768px){
  .manifesto{padding:0 20px 72px;}
  .manifesto-big-text{font-size:2rem;}
}

/* ===================== DIVIDER IMAGE ===================== */
.section-divider-blob{
  position:absolute;
  border-radius:50%;
  filter:blur(60px);
  pointer-events:none;
  z-index:0;
  opacity:0.35;
}
.section-divider{
  margin:0 40px;
  border-radius:16px;
  overflow:hidden;
  height:460px;
  position:relative;
}
.divider-bg{
  width:100%;height:100%;
  background:linear-gradient(120deg,#c5c1b5 0%,#9a9690 40%,#b8b4a9 100%);
  display:flex;align-items:center;justify-content:center;
  position:relative;
}
.divider-label{
  position:absolute;bottom:32px;left:32px;right:32px;
  display:flex;align-items:flex-end;justify-content:space-between;
}
.divider-label p{
  color:rgba(255,255,255,0.9);
  font-size:0.8rem;font-weight:500;letter-spacing:0.06em;text-transform:uppercase;
}

/* ===================== MODULES (PINNED SCROLL) ===================== */
.modules{
  padding:100px 40px;
  max-width:1200px;margin:0 auto;
}
.modules-header{
  display:flex;align-items:flex-end;justify-content:space-between;
  margin-bottom:60px;padding-bottom:32px;
  border-bottom:1px solid var(--border);
}
.modules-header h2{
  font-size:clamp(2rem,5vw,4rem);
  font-weight:800;letter-spacing:-0.03em;
  line-height:1.08;
}
.modules-header p{color:var(--muted);max-width:380px;line-height:1.65;}
.module-list{display:flex;flex-direction:column;}
.module-item{
  display:grid;grid-template-columns:80px 1fr 1fr;
  gap:40px;align-items:start;
  padding:40px 0;
  border-bottom:1px solid var(--border);
  cursor:default;
  transition:background 0.2s ease;
}
.module-item:hover{background:var(--bg2);margin:0 -40px;padding:40px;}
.module-num{
  font-size:0.78rem;font-weight:700;
  color:var(--teal);letter-spacing:0.08em;
  padding-top:6px;
}
.module-name{
  font-size:clamp(1.6rem,3vw,2.8rem);
  font-weight:800;letter-spacing:-0.02em;
  line-height:1.05;
}
.module-right{
  display:flex;flex-direction:column;gap:20px;
  padding-top:6px;
}
.module-desc{color:var(--muted);font-size:0.92rem;line-height:1.7;max-width:380px;}
.module-tags{display:flex;flex-wrap:wrap;gap:8px;}
.module-tag{
  font-size:0.72rem;font-weight:600;
  letter-spacing:0.06em;text-transform:uppercase;
  border:1px solid rgba(45,122,110,0.18);
  padding:6px 14px;border-radius:999px;
  color:var(--teal);
  background:rgba(45,122,110,0.05);
  transition:all 0.2s ease;
}
.module-item:hover .module-tag{border-color:rgba(45,122,110,0.4);background:rgba(45,122,110,0.1);}

/* ===================== SPACES GRID ===================== */
.spaces-section{
  padding:100px 40px;
  background:linear-gradient(160deg, #112e2a 0%, #1a3d38 40%, #1e2030 100%);
  position:relative;
  overflow:hidden;
}
.spaces-section::before{
  content:'';
  position:absolute;
  top:-100px;right:-100px;
  width:500px;height:500px;
  background:radial-gradient(circle, #2d7a6e40 0%, transparent 70%);
  pointer-events:none;
}
.spaces-section::after{
  content:'';
  position:absolute;
  bottom:-80px;left:10%;
  width:400px;height:400px;
  background:radial-gradient(circle, #d4685a25 0%, transparent 70%);
  pointer-events:none;
}
.spaces-section .section-header{
  display:flex;align-items:flex-end;justify-content:space-between;
  margin-bottom:48px;
}
.spaces-section .section-header h2{
  font-size:clamp(2rem,4vw,3.5rem);
  line-height:1.08;
  font-weight:800;letter-spacing:-0.03em;
  color:var(--bg);
}
.spaces-section .section-header p{color:rgba(244,241,235,0.5);max-width:340px;}
.spaces-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:20px;
}
.space-card{border-radius:16px;overflow:hidden;background:rgba(244,241,235,0.04);border:1px solid rgba(244,241,235,0.08);transition:all 0.3s ease;}
.space-card:hover{border-color:rgba(244,241,235,0.2);transform:translateY(-4px);}
.space-card-img{height:220px;position:relative;}
.sc-img-1{background:linear-gradient(135deg,#6b6357 0%,#3d3933 100%);}
.sc-img-2{background:linear-gradient(135deg,#4a5568 0%,#2d3748 100%);}
.sc-img-3{background:linear-gradient(135deg,#5a4e44 0%,#2d2520 100%);}
.space-card-badge{
  position:absolute;top:16px;left:16px;
  font-size:0.7rem;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;
  color:var(--dark);background:var(--bg);
  padding:5px 12px;border-radius:999px;
}
.space-card-body{padding:24px;}
.space-card-name{font-size:1.1rem;font-weight:700;color:var(--bg);margin-bottom:8px;}
.space-card-desc{font-size:0.85rem;color:rgba(244,241,235,0.5);line-height:1.6;margin-bottom:20px;}
.space-card-footer{display:flex;align-items:center;justify-content:space-between;}
.space-price{font-size:1rem;font-weight:700;color:var(--bg);}
.space-price span{font-size:0.75rem;font-weight:400;color:rgba(244,241,235,0.4);}
.btn-ghost{
  font-size:0.75rem;font-weight:600;
  letter-spacing:0.06em;text-transform:uppercase;
  color:var(--dark);
  border:1px solid rgba(244,241,235,0.15);
  padding:9px 18px;border-radius:999px;
  transition:all 0.25s;
}
.btn-ghost:hover{color:var(--dark);background:var(--bg);border-color:var(--bg);}

/* ===================== NEWS + EVENTS ===================== */
.news-section{
  padding:100px 40px;
  max-width:1200px;margin:0 auto;
}
.section-header-inline{
  display:flex;align-items:baseline;gap:40px;
  margin-bottom:48px;padding-bottom:24px;
  border-bottom:1px solid var(--border);
}
.section-header-inline h2{
  font-size:clamp(1.8rem,3.5vw,3rem);
  font-weight:800;letter-spacing:-0.03em;
  line-height:1.08;
  flex-shrink:0;
}
.section-header-inline p{color:var(--muted);font-size:0.9rem;line-height:1.6;max-width:400px;}
.section-header-inline .btn-arrow{margin-left:auto;flex-shrink:0;}
.news-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:32px;
}
.news-card{cursor:pointer;}
.news-card-img{
  border-radius:12px;overflow:hidden;
  aspect-ratio:4/3;
  margin-bottom:20px;
  position:relative;
}
.nc-img-1{background:linear-gradient(135deg,#c5c1b5 0%,#9a9690 100%);}
.nc-img-2{background:linear-gradient(135deg,#b5c1c5 0%,#8a9aa0 100%);}
.nc-img-3{background:linear-gradient(135deg,#c5b5b5 0%,#a08a8a 100%);}
.nc-img-4{background:linear-gradient(135deg,#b5c5b5 0%,#8aa08a 100%);}
.nc-img-5{background:linear-gradient(135deg,#c5c5b5 0%,#a0a08a 100%);}
.nc-img-6{background:linear-gradient(135deg,#b5b5c5 0%,#8a8aa0 100%);}
.news-card-img::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(to top,rgba(30,32,48,0.5) 0%,transparent 60%);
}
.news-card-tags{display:flex;gap:8px;margin-bottom:14px;}
.news-card-tag{
  font-size:0.7rem;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;
  padding:5px 12px;border-radius:999px;
  border:1px solid rgba(45,122,110,0.25);
  color:var(--teal);
  background:rgba(45,122,110,0.07);
}
.news-card:nth-child(2) .news-card-tag{
  border-color:rgba(212,104,90,0.25);
  color:#d4685a;background:rgba(212,104,90,0.07);
}
.news-card:nth-child(3) .news-card-tag{
  border-color:rgba(90,181,212,0.25);
  color:#5ab5d4;background:rgba(90,181,212,0.07);
}
.news-card-title{
  font-size:1.1rem;font-weight:700;line-height:1.3;
  margin-bottom:12px;
  transition:color 0.2s;
}
.news-card:hover .news-card-title{color:var(--muted);}
.news-card-meta{font-size:0.78rem;color:var(--muted2);}

/* ===================== EVENTS LIST ===================== */
.events-section{
  padding:0 40px 100px;
  max-width:1200px;margin:0 auto;
}
.events-list{display:flex;flex-direction:column;gap:0;}
.event-row{
  display:flex;align-items:center;gap:32px;
  padding:24px 0;
  border-bottom:1px solid var(--border);
  cursor:pointer;
  transition:background 0.2s;
  position:relative;
}
.event-row:hover{background:var(--bg2);margin:0 -40px;padding:24px 40px;}
.event-date{
  min-width:80px;
  text-align:center;
}
.event-day{font-size:2rem;font-weight:800;letter-spacing:-0.03em;line-height:1;}
.event-month{font-size:0.7rem;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;color:var(--muted);}
.event-info{flex:1;}
.event-partner{font-size:0.72rem;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;color:var(--muted);margin-bottom:6px;}
.event-name{font-size:1.15rem;font-weight:700;margin-bottom:4px;}
.event-location{font-size:0.82rem;color:var(--muted2);}
.event-tags{display:flex;gap:8px;}
.event-tag{
  font-size:0.7rem;font-weight:600;letter-spacing:0.06em;text-transform:uppercase;
  padding:5px 12px;border-radius:999px;
  border:1px solid var(--border);color:var(--muted);
}
.event-arr{
  width:36px;height:36px;border-radius:50%;
  border:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;
  font-size:1rem;color:var(--muted);
  transition:all 0.2s;
  flex-shrink:0;
}
.event-row:hover .event-arr{background:var(--dark);color:var(--bg);border-color:var(--dark);}

/* ===================== CTA ===================== */
.cta-section{
  margin:40px;
  border-radius:20px;
  background:linear-gradient(145deg, #0e2e28 0%, #2d7a6e 50%, #1e2030 100%);
  padding:120px 80px;
  position:relative;overflow:hidden;
}
.cta-label{
  font-size:0.78rem;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;
  color:rgba(244,241,235,0.4);
  margin-bottom:28px;
  display:flex;align-items:center;gap:12px;
}
.cta-label::before{content:'';display:block;width:24px;height:1px;background:rgba(244,241,235,0.3);}
.cta-title{
  font-size:clamp(2.5rem,7vw,6.5rem);
  font-weight:800;letter-spacing:-0.03em;line-height:1.0;
  color:var(--bg);
  margin-bottom:48px;
  max-width:800px;
}
.cta-actions{display:flex;align-items:center;gap:16px;flex-wrap:wrap;}
.btn-light{
  display:inline-flex;align-items:center;gap:10px;
  font-size:0.85rem;font-weight:600;
  letter-spacing:0.06em;text-transform:uppercase;
  color:var(--dark);
  background:var(--bg);
  padding:16px 28px;border-radius:999px;
  transition:all 0.25s ease;
}
.btn-light .ico{
  width:28px;height:28px;border-radius:50%;
  background:var(--dark);color:var(--bg);
  display:flex;align-items:center;justify-content:center;
  transition:transform 0.25s;
}
.btn-light:hover .ico{transform:rotate(45deg);}
.btn-outline-light{
  display:inline-flex;align-items:center;gap:10px;
  font-size:0.85rem;font-weight:600;
  letter-spacing:0.06em;text-transform:uppercase;
  color:rgba(244,241,235,0.6);
  border:1px solid rgba(244,241,235,0.15);
  padding:16px 28px;border-radius:999px;
  transition:all 0.25s ease;
}
.btn-outline-light:hover{color:var(--dark);background:var(--bg);border-color:var(--bg);}
.cta-deco{
  position:absolute;right:-80px;bottom:-80px;
  width:400px;height:400px;border-radius:50%;
  border:1px solid rgba(244,241,235,0.06);
}
.cta-deco::before{
  content:'';position:absolute;
  inset:40px;border-radius:50%;
  border:1px solid rgba(244,241,235,0.06);
}
.cta-deco::after{
  content:'';position:absolute;
  inset:80px;border-radius:50%;
  border:1px solid rgba(244,241,235,0.06);
}

/* ===================== FORUM + OPORTUNIDADES ===================== */
.forum-section{
  padding:100px 40px;
  max-width:1200px;margin:0 auto;
}
.forum-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:80px;align-items:start;}
.forum-topics{display:flex;flex-direction:column;gap:0;}
.forum-topic{
  padding:24px 0;
  border-bottom:1px solid var(--border);
  cursor:pointer;
}
.forum-topic:hover .ft-title{color:var(--muted);}
.ft-num{font-size:0.7rem;color:var(--muted2);font-weight:600;letter-spacing:0.08em;text-transform:uppercase;margin-bottom:10px;}
.ft-title{font-size:1.05rem;font-weight:700;margin-bottom:8px;line-height:1.35;transition:color 0.2s;}
.ft-meta{font-size:0.78rem;color:var(--muted2);display:flex;align-items:center;gap:16px;}
.forum-side{}
.forum-side h3{
  font-size:clamp(1.5rem,3vw,2.4rem);
  font-weight:800;letter-spacing:-0.02em;
  margin-bottom:20px;line-height:1.1;
}
.forum-side p{color:var(--muted);line-height:1.7;margin-bottom:32px;font-size:0.92rem;}
.oport-grid{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:16px;margin-top:40px;
}
.oport-card{
  border-radius:14px;
  background:var(--bg2);
  border:1px solid var(--border);
  padding:28px;
  cursor:pointer;
  transition:all 0.25s ease;
}
.oport-card:hover{background:var(--dark);border-color:var(--dark);color:var(--bg);}
.oport-card:hover .oport-count{color:rgba(244,241,235,0.5);}
.oport-icon{font-size:1.8rem;margin-bottom:16px;}
.oport-name{font-size:0.95rem;font-weight:700;margin-bottom:4px;}
.oport-count{font-size:0.78rem;color:var(--muted);transition:color 0.25s;}

/* ===================== FOOTER ===================== */
footer{
  background:var(--dark);
  padding:80px 40px 40px;
}
.footer-top{
  border-bottom:1px solid rgba(244,241,235,0.08);
  padding-bottom:60px;
  margin-bottom:48px;
  padding-top:0;
}

.footer-grid{
  display:grid;
  grid-template-columns:2fr 1fr 1fr 1fr;
  gap:60px;
  margin-top:0;
  padding-top:0;
}
.footer-brand img{height:48px;filter:invert(1);margin-bottom:20px;opacity:0.92;}
.footer-brand::before{
  content:'';display:block;
  width:40px;height:3px;
  background:var(--teal);
  border-radius:2px;
  margin-bottom:28px;
}
.footer-brand p{color:rgba(244,241,235,0.4);font-size:0.85rem;line-height:1.7;max-width:260px;margin-bottom:24px;}
.footer-social{display:flex;gap:12px;}
.fsoc{
  width:40px;height:40px;border-radius:50%;
  border:1px solid rgba(244,241,235,0.15);
  display:flex;align-items:center;justify-content:center;
  color:rgba(244,241,235,0.45);
  font-size:15px;
  transition:all 0.25s ease;
}
.fsoc:hover{
  border-color:rgba(244,241,235,0.5);
  color:var(--bg);
  background:rgba(244,241,235,0.07);
  transform:translateY(-2px);
}
.footer-col h5{
  font-size:0.72rem;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;
  color:rgba(244,241,235,0.3);margin-bottom:20px;
}
.footer-col ul{list-style:none;}
.footer-col li{margin-bottom:12px;}
.footer-col a{
  color:rgba(244,241,235,0.5);font-size:0.88rem;
  transition:color 0.2s;
}
.footer-col a:hover{color:var(--bg);}
.footer-bottom{
  display:flex;align-items:center;justify-content:space-between;
  flex-wrap:wrap;gap:12px;
}
.footer-copy{color:rgba(244,241,235,0.25);font-size:0.78rem;}
.footer-made{color:rgba(244,241,235,0.25);font-size:0.78rem;}

/* ===================== REVEAL ANIMATION ===================== */
.reveal{opacity:0;transform:translateY(28px);transition:opacity 0.75s ease,transform 0.75s ease;}
.reveal.in{opacity:1;transform:none;}
.reveal-d1{transition-delay:0.08s;}
.reveal-d2{transition-delay:0.16s;}
.reveal-d3{transition-delay:0.24s;}
.reveal-d4{transition-delay:0.32s;}

/* ===================== CONTACT SECTION ===================== */
.contact-section{
  padding:80px 40px;
  max-width:1200px;margin:0 auto;
  display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start;
}
.contact-info h2{
  font-size:clamp(2rem,4vw,3.5rem);
  font-weight:800;letter-spacing:-0.03em;
  margin-bottom:24px;line-height:1.1;
}
.contact-info p{color:var(--muted);line-height:1.7;margin-bottom:40px;font-size:0.95rem;}
.contact-item{display:flex;gap:16px;align-items:flex-start;margin-bottom:24px;}
.ci-ico{
  width:40px;height:40px;border-radius:10px;
  border:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;
  font-size:1rem;flex-shrink:0;
  color:var(--muted);
}
.ci-text small{display:block;font-size:0.72rem;color:var(--muted2);letter-spacing:0.06em;text-transform:uppercase;margin-bottom:4px;}
.ci-text strong{font-size:0.92rem;font-weight:600;}
.contact-form{background:var(--bg2);border-radius:20px;padding:40px;}
.form-group{margin-bottom:20px;}
.form-group label{display:block;font-size:0.72rem;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;color:var(--muted);margin-bottom:10px;}
.form-group input,.form-group textarea{
  width:100%;padding:14px 18px;
  background:var(--white);
  border:1px solid var(--border);
  border-radius:10px;
  font-family:var(--font);font-size:0.9rem;
  color:var(--text);
  outline:none;
  transition:border-color 0.2s;
}
/* ===================== RESPONSIVE ===================== */
@media(max-width:1024px){
  .hero-bottom,.modules-grid,.forum-grid,.contact-section{grid-template-columns:1fr;}
  .footer-grid{grid-template-columns:1fr 1fr;}
  .spaces-grid,.news-grid{grid-template-columns:repeat(2,1fr);}
}
@media(max-width:768px){
  .site-header{padding:16px 20px;}
  .site-header.scrolled{padding:12px 20px;}
  .hero{padding:120px 20px 60px;}
  .hero-title{font-size:clamp(2.5rem,10vw,5rem);}
  .hero-bottom{grid-template-columns:1fr;}
  .manifesto{padding:60px 20px;}
  .manifesto-inner{grid-template-columns:1fr;}
  .section-divider-blob{
  position:absolute;
  border-radius:50%;
  filter:blur(60px);
  pointer-events:none;
  z-index:0;
  opacity:0.35;
}
.section-divider{margin:0 20px;height:280px;}
  .modules{padding:60px 20px;}
  .module-item{grid-template-columns:50px 1fr;gap:20px;}
  .module-right{display:none;}
  .module-item:hover{margin:0;padding:40px 20px;}
  .spaces-section,.forum-section,.news-section,.events-section{padding:60px 20px;}
  .spaces-grid,.news-grid{grid-template-columns:1fr;}
  .cta-section{margin:20px;padding:60px 32px;}
  .cta-title{font-size:clamp(2rem,8vw,4rem);}
  .footer-grid{grid-template-columns:1fr;}
  footer{padding:60px 20px 32px;}
  .header-cta{display:none;}
  .header-social{display:none;}
  .menu-inner{flex-direction:column;padding:100px 32px 40px;}
  .menu-nav a{font-size:clamp(1.8rem,8vw,3.5rem);}
  .menu-side{width:100%;}
  .contact-section{padding:60px 20px;gap:48px;}
  .marquee-strip{display:none;}
  .oport-grid{grid-template-columns:1fr;}
}

.module-item:nth-child(1) .module-num { color:#2d7a6e; }
.module-item:nth-child(2) .module-num { color:#d4685a; }
.module-item:nth-child(3) .module-num { color:#5ab5d4; }
.module-item:nth-child(4) .module-num { color:#d9b840; }
.module-item:nth-child(5) .module-num { color:#8878c0; }
.module-item:nth-child(6) .module-num { color:#7ec8a0; }
.module-item:nth-child(7) .module-num { color:#2d7a6e; }
.module-item:nth-child(1) .module-name { border-left:3px solid #2d7a6e; padding-left:16px; }
.module-item:nth-child(2) .module-name { border-left:3px solid #d4685a; padding-left:16px; }
.module-item:nth-child(3) .module-name { border-left:3px solid #5ab5d4; padding-left:16px; }
.module-item:nth-child(4) .module-name { border-left:3px solid #d9b840; padding-left:16px; }
.module-item:nth-child(5) .module-name { border-left:3px solid #8878c0; padding-left:16px; }
.module-item:nth-child(6) .module-name { border-left:3px solid #7ec8a0; padding-left:16px; }
.module-item:nth-child(7) .module-name { border-left:3px solid #2d7a6e; padding-left:16px; }


.oport-card:nth-child(1) .oport-icon { color:#2d7a6e; background:rgba(45,122,110,0.1); }
.oport-card:nth-child(2) .oport-icon { color:#d4685a; background:rgba(212,104,90,0.1); }
.oport-card:nth-child(3) .oport-icon { color:#d9b840; background:rgba(217,184,64,0.1); }
.oport-card:nth-child(4) .oport-icon { color:#8878c0; background:rgba(136,120,192,0.1); }


/* ===================== PAGES SYSTEM ===================== */
.page { display:none; min-height:100vh; padding-top:90px; }
.page.active { display:block; }
#page-home { padding-top:0; }

.page-hero {
  background:var(--bg2);
  padding:140px 40px 60px;
  border-bottom:1px solid var(--border);
}
.page-hero .ph-eyebrow {
  font-size:0.72rem;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;
  color:var(--teal);margin-bottom:16px;display:flex;align-items:center;gap:10px;
}
.page-hero .ph-eyebrow::before{content:'';width:20px;height:1.5px;background:var(--teal);display:block;}
.page-hero h1 {
  font-size:clamp(2rem,4vw,3.8rem);font-weight:800;letter-spacing:-0.03em;line-height:1.08;
  margin-bottom:16px;
}
.page-hero p { font-size:1rem;color:var(--muted);max-width:560px;line-height:1.7; }
.page-inner { max-width:1200px;margin:0 auto;padding:64px 40px; }

/* Back button */
.btn-back {
  display:inline-flex;align-items:center;gap:8px;
  font-size:0.75rem;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;
  color:var(--muted);margin-bottom:40px;
  transition:color 0.2s;
}
.btn-back:hover{color:var(--teal);}
.btn-back svg{transition:transform 0.2s;}
.btn-back:hover svg{transform:translateX(-3px);}

/* Grid cards */
.cards-grid { display:grid;grid-template-columns:repeat(3,1fr);gap:28px; }
.cards-grid-2 { display:grid;grid-template-columns:repeat(2,1fr);gap:28px; }
.cards-grid-4 { display:grid;grid-template-columns:repeat(4,1fr);gap:24px; }

/* Generic card */
.g-card {
  background:var(--white);
  border:1px solid var(--border);
  border-radius:var(--radius);
  overflow:hidden;
  transition:transform 0.25s,box-shadow 0.25s,border-color 0.25s;
  cursor:pointer;
}
.g-card:hover{transform:translateY(-4px);box-shadow:0 12px 40px rgba(30,32,48,0.08);border-color:rgba(30,32,48,0.15);}
.g-card-img {
  aspect-ratio:16/9;
  background:linear-gradient(135deg,#c8c4b8,#a8a49a);
  position:relative;overflow:hidden;
}
.g-card-img.teal-grad{background:linear-gradient(135deg,#2d7a6e,#1a4a44);}
.g-card-img.coral-grad{background:linear-gradient(135deg,#d4685a,#8a3530);}
.g-card-img.blue-grad{background:linear-gradient(135deg,#5ab5d4,#2a6a8a);}
.g-card-img.yellow-grad{background:linear-gradient(135deg,#d9b840,#8a7020);}
.g-card-img.lav-grad{background:linear-gradient(135deg,#8878c0,#4a3a80);}
.g-card-body { padding:20px; }
.g-card-tag {
  font-size:0.68rem;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;
  color:var(--teal);background:rgba(45,122,110,0.08);
  border:1px solid rgba(45,122,110,0.2);
  padding:3px 10px;border-radius:999px;
  display:inline-block;margin-bottom:10px;
}
.g-card-title{font-size:1rem;font-weight:700;line-height:1.3;margin-bottom:8px;}
.g-card-meta{font-size:0.8rem;color:var(--muted);}
.g-card-foot{
  padding:14px 20px;
  border-top:1px solid var(--border2);
  display:flex;align-items:center;justify-content:space-between;
}
.g-card-foot span{font-size:0.8rem;color:var(--muted);}

/* Capacity badge */
.cap-badge{
  display:inline-flex;align-items:center;gap:6px;
  font-size:0.75rem;font-weight:600;color:var(--muted);
}

/* ── DETAIL PAGE ── */
.detail-layout{display:grid;grid-template-columns:1fr 380px;gap:48px;align-items:start;}
.detail-gallery{}
.detail-main-img{
  border-radius:var(--radius);overflow:hidden;
  aspect-ratio:16/9;
  background:linear-gradient(135deg,#c8c4b8,#9a9690);
  margin-bottom:12px;
}
.detail-thumbs{display:flex;gap:10px;}
.detail-thumb{
  width:80px;height:56px;border-radius:8px;
  background:linear-gradient(135deg,#b8b4a8,#8a8680);
  cursor:pointer;opacity:0.6;transition:opacity 0.2s;flex-shrink:0;
}
.detail-thumb:hover,.detail-thumb.active{opacity:1;}
.detail-info h1{font-size:clamp(1.6rem,3vw,2.6rem);font-weight:800;letter-spacing:-0.02em;line-height:1.1;margin-bottom:8px;}
.detail-price{font-size:1.4rem;font-weight:800;color:var(--teal);margin-bottom:20px;}
.detail-price small{font-size:0.85rem;font-weight:500;color:var(--muted);}
.detail-specs{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:24px;}
.detail-spec{
  display:flex;align-items:center;gap:8px;
  font-size:0.82rem;color:var(--muted);
  padding:8px 14px;border-radius:999px;
  border:1px solid var(--border);background:var(--white);
}
.detail-desc{font-size:0.95rem;color:var(--text);line-height:1.75;margin-bottom:28px;}
.detail-sidebar{}
.sidebar-box{
  background:var(--white);border:1px solid var(--border);
  border-radius:var(--radius);padding:24px;margin-bottom:16px;
}
.sidebar-box h3{font-size:0.85rem;font-weight:700;letter-spacing:0.06em;text-transform:uppercase;color:var(--muted);margin-bottom:16px;}

/* Calendar mini */
.mini-cal{width:100%;}
.mini-cal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;}
.mini-cal-header button{background:none;border:1px solid var(--border);width:28px;height:28px;border-radius:6px;cursor:pointer;font-size:0.8rem;display:flex;align-items:center;justify-content:center;}
.mini-cal-header span{font-size:0.85rem;font-weight:700;}
.mini-cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;text-align:center;}
.mini-cal-day-head{font-size:0.65rem;font-weight:700;color:var(--muted2);padding:4px 0;}
.mini-cal-day{font-size:0.75rem;padding:6px 2px;border-radius:6px;cursor:pointer;transition:all 0.15s;}
.mini-cal-day.available{background:rgba(45,122,110,0.1);color:var(--teal);font-weight:600;}
.mini-cal-day.available:hover{background:var(--teal);color:white;}
.mini-cal-day.unavailable{color:var(--muted2);text-decoration:line-through;}
.mini-cal-day.selected{background:var(--teal);color:white;font-weight:700;}
.mini-cal-day.empty{visibility:hidden;}

/* ── FORUM ── */
.forum-list{display:flex;flex-direction:column;gap:0;}
.forum-topic{
  display:grid;grid-template-columns:1fr auto;gap:24px;align-items:center;
  padding:24px 0;border-bottom:1px solid var(--border2);
  cursor:pointer;transition:background 0.15s;
}
.forum-topic:hover .ft-title{color:var(--teal);}
.ft-title{font-size:1rem;font-weight:700;margin-bottom:6px;transition:color 0.2s;}
.ft-meta{font-size:0.78rem;color:var(--muted);}
.ft-badge{
  display:flex;flex-direction:column;align-items:center;
  font-size:0.7rem;color:var(--muted);gap:2px;
}
.ft-badge strong{font-size:1.1rem;font-weight:800;color:var(--text);}
.ft-status{
  display:inline-block;font-size:0.65rem;font-weight:700;letter-spacing:0.08em;
  text-transform:uppercase;padding:2px 8px;border-radius:999px;
  background:rgba(45,122,110,0.1);color:var(--teal);margin-right:8px;
}

/* ── NEWS ARTICLE ── */
.article-layout{display:grid;grid-template-columns:1fr 300px;gap:64px;}
.article-content h2{font-size:1.4rem;font-weight:700;margin:32px 0 12px;line-height:1.2;}
.article-content p{font-size:1rem;line-height:1.8;color:var(--text);margin-bottom:20px;}
.article-content blockquote{
  border-left:3px solid var(--teal);
  padding:12px 20px;margin:24px 0;
  background:rgba(45,122,110,0.05);border-radius:0 8px 8px 0;
  font-style:italic;color:var(--muted);
}
.article-cover{
  border-radius:var(--radius);overflow:hidden;
  aspect-ratio:16/8;margin-bottom:40px;
}
.author-box{
  display:flex;align-items:center;gap:16px;
  padding:20px;background:var(--bg2);border-radius:var(--radius);margin-top:40px;
}
.author-avatar{
  width:48px;height:48px;border-radius:50%;
  background:linear-gradient(135deg,var(--teal),#1a4a44);flex-shrink:0;
}
.author-name{font-size:0.9rem;font-weight:700;}
.author-role{font-size:0.8rem;color:var(--muted);}

/* Sidebar sticky */
.article-sidebar{position:sticky;top:100px;}
.aside-box{
  background:var(--white);border:1px solid var(--border);
  border-radius:var(--radius);padding:20px;margin-bottom:16px;
}
.aside-box h4{font-size:0.72rem;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;color:var(--muted);margin-bottom:14px;}

/* Comments */
.comments-section{margin-top:60px;padding-top:40px;border-top:1px solid var(--border);}
.comments-section h3{font-size:1.1rem;font-weight:700;margin-bottom:24px;}
.comment{display:flex;gap:14px;margin-bottom:24px;}
.comment-avatar{width:36px;height:36px;border-radius:50%;background:var(--bg2);flex-shrink:0;}
.comment-body{flex:1;}
.comment-meta{font-size:0.78rem;color:var(--muted);margin-bottom:6px;}
.comment-meta strong{color:var(--text);}
.comment-text{font-size:0.9rem;line-height:1.6;}

/* ── FEED ── */
.feed-layout{display:grid;grid-template-columns:1fr 300px;gap:32px;max-width:1100px;margin:0 auto;}
.feed-card{
  background:var(--white);border:1px solid var(--border);
  border-radius:var(--radius);overflow:hidden;margin-bottom:20px;
}
.feed-card-header{display:flex;align-items:center;gap:12px;padding:16px 20px;}
.feed-avatar{width:36px;height:36px;border-radius:50%;background:var(--bg2);flex-shrink:0;}
.feed-author{font-size:0.85rem;font-weight:700;}
.feed-time{font-size:0.75rem;color:var(--muted);}
.feed-type-badge{
  margin-left:auto;font-size:0.65rem;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;
  padding:3px 10px;border-radius:999px;
}
.feed-type-news{background:rgba(45,122,110,0.1);color:var(--teal);}
.feed-type-event{background:rgba(90,181,212,0.1);color:#5ab5d4;}
.feed-type-forum{background:rgba(136,120,192,0.1);color:#8878c0;}
.feed-type-oport{background:rgba(212,104,90,0.1);color:#d4685a;}
.feed-card-img{aspect-ratio:16/7;background:linear-gradient(135deg,#c8c4b8,#9a9690);}
.feed-card-body{padding:16px 20px;}
.feed-card-title{font-size:1rem;font-weight:700;margin-bottom:8px;line-height:1.3;}
.feed-card-text{font-size:0.88rem;color:var(--muted);line-height:1.6;margin-bottom:0;}
.feed-card-foot{
  padding:12px 20px;border-top:1px solid var(--border2);
  display:flex;align-items:center;gap:20px;
}
.feed-action{
  display:flex;align-items:center;gap:6px;
  font-size:0.78rem;color:var(--muted);
  cursor:pointer;transition:color 0.2s;
}
.feed-action:hover{color:var(--teal);}
.feed-action svg{width:16px;height:16px;}

/* ── OPORTUNIDADES ── */
.oport-cats{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:48px;}
.oport-cat-card{
  border-radius:var(--radius);overflow:hidden;cursor:pointer;
  border:1px solid var(--border);background:var(--white);
  transition:transform 0.25s,box-shadow 0.25s;
  text-align:center;padding:32px 20px;
}
.oport-cat-card:hover{transform:translateY(-4px);box-shadow:0 12px 32px rgba(30,32,48,0.08);}
.oport-cat-icon{
  width:56px;height:56px;border-radius:14px;
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 16px;font-size:22px;
}
.oport-cat-name{font-size:0.9rem;font-weight:700;margin-bottom:4px;}
.oport-cat-count{font-size:0.78rem;color:var(--muted);}

/* ── LOGIN/REGISTER ── */
.auth-page{
  min-height:100vh;display:flex;align-items:center;justify-content:center;
  padding:100px 20px 40px;background:var(--bg);
}
.auth-box{
  width:100%;max-width:420px;
  background:var(--white);border:1px solid var(--border);
  border-radius:16px;padding:40px;
}
.auth-logo{display:flex;justify-content:center;margin-bottom:32px;}
.auth-logo img{height:40px;}
.auth-tabs{display:flex;gap:0;margin-bottom:28px;border-bottom:1px solid var(--border);}
.auth-tab{
  flex:1;text-align:center;padding:10px;
  font-size:0.78rem;font-weight:700;letter-spacing:0.06em;text-transform:uppercase;
  color:var(--muted);cursor:pointer;border-bottom:2px solid transparent;
  transition:all 0.2s;margin-bottom:-1px;
}
.auth-tab.active{color:var(--teal);border-bottom-color:var(--teal);}
.auth-form-panel{display:none;}
.auth-form-panel.active{display:block;}
.auth-forgot{font-size:0.78rem;color:var(--muted);text-align:right;margin-top:-8px;margin-bottom:16px;display:block;}
.auth-forgot:hover{color:var(--teal);}
.auth-divider{text-align:center;font-size:0.78rem;color:var(--muted2);margin:20px 0;position:relative;}
.auth-divider::before,.auth-divider::after{content:'';position:absolute;top:50%;width:42%;height:1px;background:var(--border);}
.auth-divider::before{left:0;}
.auth-divider::after{right:0;}
.auth-social{
  display:flex;gap:10px;
}
.auth-social-btn{
  flex:1;padding:10px;border:1px solid var(--border);border-radius:8px;
  display:flex;align-items:center;justify-content:center;gap:8px;
  font-size:0.8rem;font-weight:600;cursor:pointer;
  background:var(--white);transition:border-color 0.2s;
}
.auth-social-btn:hover{border-color:var(--teal);}

/* Pill filter bar */
.filter-bar{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:36px;}
.filter-pill{
  padding:8px 18px;border-radius:999px;border:1.5px solid var(--border);
  font-size:0.75rem;font-weight:700;letter-spacing:0.06em;text-transform:uppercase;
  color:var(--muted);cursor:pointer;transition:all 0.2s;background:transparent;
}
.filter-pill.active,.filter-pill:hover{border-color:var(--teal);color:var(--teal);background:rgba(45,122,110,0.06);}

/* Pagination */
.pagination{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:48px;}
.page-btn{
  width:36px;height:36px;border-radius:8px;border:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;
  font-size:0.82rem;font-weight:600;cursor:pointer;transition:all 0.2s;
}
.page-btn.active,.page-btn:hover{background:var(--teal);color:white;border-color:var(--teal);}

@media(max-width:900px){
  .detail-layout,.article-layout,.feed-layout{grid-template-columns:1fr;}
  .cards-grid{grid-template-columns:repeat(2,1fr);}
  .cards-grid-4,.oport-cats{grid-template-columns:repeat(2,1fr);}
  .article-sidebar{display:none;}
  .page-inner{padding:40px 20px;}
}




  .contato-row { grid-template-columns: 1fr; }
  .contato-form-wrap { padding: 28px 20px; }
}



/* ═══════════════ PAGE: CONTATO ═══════════════ */
.contato-wrap {
  max-width: 1100px;
  margin: 0 auto;
  padding: 64px 40px 100px;
}
/* 4 boxes lado a lado */
/* ── CONTATO ── */
.ctt-info-bar {
  display:grid;grid-template-columns:repeat(4,1fr);
  margin-bottom:56px;
}
.ctt-info-item {
  padding:28px 28px;border-right:1px solid var(--border);
}
.ctt-info-item:last-child{border-right:none;}
.ctt-info-lbl {
  font-size:0.67rem;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;
  color:var(--teal);margin-bottom:10px;display:flex;align-items:center;gap:9px;
}
.ctt-info-lbl svg{flex-shrink:0;opacity:0.7;}
.ctt-info-val {font-size:0.9rem;color:var(--text);line-height:1.65;}
.ctt-info-val a{color:var(--text);}
.ctt-info-val a:hover{color:var(--teal);}
.ctt-info-val small{display:block;font-size:0.78rem;color:var(--muted);margin-top:2px;}

.ctt-layout {
  display:grid;grid-template-columns:1fr 300px;gap:32px;align-items:start;margin-bottom:48px;
}

.ctt-soc-grid{display:flex;flex-wrap:wrap;gap:10px;margin-top:12px;}
.ctt-soc-btn{
  height:44px;border-radius:10px;
  border:1px solid var(--border);background:var(--bg);
  display:flex;align-items:center;justify-content: flex-start;
  color:var(--muted);transition:all 0.2s;text-decoration:none;
}
.ctt-soc-btn:hover{border-color:var(--teal);color:var(--teal);background:rgba(45,122,110,0.06);}

.ctt-map-block {
  border-radius:var(--radius);overflow:hidden;
  border:1px solid var(--border);height:320px;
  background:var(--bg2);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:10px;color:var(--muted);font-size:0.85rem;text-align:center;
}

@media(max-width:1024px){
  .ctt-info-bar{grid-template-columns:repeat(2,1fr);}
  .ctt-info-item:nth-child(2){border-right:none;}
  .ctt-info-item:nth-child(3){border-top:1px solid var(--border);}
  .ctt-info-item:nth-child(4){border-top:1px solid var(--border);}
  .ctt-layout{grid-template-columns:1fr;}
}
@media(max-width:640px){
  .ctt-info-bar{grid-template-columns:1fr;}
  .ctt-info-item{border-right:none!important;border-top:1px solid var(--border);}
  .ctt-info-item:first-child{border-top:none;}
}


/* ── SOBRE / PARCEIROS / SEJA PARCEIRO ── */
.sobre-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start;margin-bottom:56px;}
.sobre-stat-row{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;margin-bottom:56px;}
.sobre-stat{background:var(--white);padding:28px 24px;}
.sobre-stat-num{font-size:2.2rem;font-weight:800;letter-spacing:-0.03em;color:var(--teal);line-height:1;}
.sobre-stat-lbl{font-size:0.75rem;color:var(--muted);margin-top:6px;line-height:1.4;}
.sobre-values{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;}
.sobre-value-item{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:22px 24px;}
.sobre-value-icon{font-size:1.4rem;margin-bottom:10px;}
.sobre-value-title{font-size:0.85rem;font-weight:700;margin-bottom:6px;}
.sobre-value-text{font-size:0.82rem;color:var(--muted);line-height:1.6;}

.parceiros-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.parceiro-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:28px;transition:transform 0.2s,box-shadow 0.2s;}
.parceiro-card:hover{transform:translateY(-3px);box-shadow:0 10px 32px rgba(30,32,48,0.07);}
.parceiro-logo{width:56px;height:56px;border-radius:10px;background:var(--bg2);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;margin-bottom:16px;font-size:1.4rem;}
.parceiro-name{font-size:1rem;font-weight:700;margin-bottom:6px;}
.parceiro-desc{font-size:0.82rem;color:var(--muted);line-height:1.65;margin-bottom:16px;}
.parceiro-tag{font-size:0.65rem;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;color:var(--teal);background:rgba(45,122,110,0.08);border:1px solid rgba(45,122,110,0.2);padding:3px 10px;border-radius:999px;display:inline-block;}

.seja-layout{display:grid;grid-template-columns:1fr 360px;gap:40px;align-items:start;}
