/* ═══════════════════════════════════════════════════════
   PEPÊ COLLAÇO — TEMA WORDPRESS
   css/main.css  |  v1.0.0
   ═══════════════════════════════════════════════════════ */

/* ── RESET & BASE ── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }

:root {
  --verde:    #0A4A2E;
  --verde2:   #0D5C38;
  --verde3:   #1a8f5c;
  --ouro:     #BFA14A;
  --ouro2:    #D4B86A;
  --branco:   #F5F3EE;
  --escuro:   #080C0A;
  --cinza:    rgba(255,255,255,0.55);
  --radius:   4px;
  --trans:    all .25s ease;
}

html { scroll-behavior: smooth; font-size: 16px; }

body.pepe-body {
  font-family: 'Barlow', 'Segoe UI', sans-serif;
  background: var(--escuro);
  color: var(--branco);
  overflow-x: hidden;
  cursor: none;
  -webkit-font-smoothing: antialiased;
}

img { max-width:100%; height:auto; display:block; }
a { color: inherit; text-decoration: none; }

/* ── CURSOR ── */
.cursor {
  position: fixed; width:12px; height:12px;
  background: var(--ouro); border-radius:50%;
  pointer-events:none; z-index:9999;
  transform:translate(-50%,-50%);
  transition: width .2s, height .2s, background .2s;
  mix-blend-mode: difference;
}
.cursor-ring {
  position:fixed; width:36px; height:36px;
  border:1.5px solid var(--ouro); border-radius:50%;
  pointer-events:none; z-index:9998;
  transform:translate(-50%,-50%);
  transition: all .12s ease-out;
  opacity:.6;
}
.cursor.big   { width:6px; height:6px; }
.cursor-ring.big { width:52px; height:52px; border-color:var(--ouro2); }

@media (pointer:coarse){ .cursor,.cursor-ring { display:none; } body.pepe-body { cursor:auto; } }

/* ── LOADER ── */
.page-loader {
  position:fixed; inset:0; background:var(--escuro); z-index:9000;
  display:flex; align-items:center; justify-content:center;
  transition: opacity .8s ease, visibility .8s;
}
.page-loader.done { opacity:0; visibility:hidden; pointer-events:none; }
.loader-text {
  font-family:'Barlow Condensed',sans-serif;
  font-size:1rem; letter-spacing:.4em; text-transform:uppercase;
  color:var(--ouro);
  animation: loaderPulse 2s ease forwards;
}
@keyframes loaderPulse {
  0%  { opacity:0; transform:translateY(10px); }
  40% { opacity:1; transform:translateY(0); }
  80% { opacity:1; }
  100%{ opacity:0; }
}

/* ── NAV ── */
.site-nav {
  position:fixed; top:0; width:100%; z-index:100;
  display:flex; align-items:center; justify-content:space-between;
  padding:24px 52px;
}
.site-nav::before {
  content:'';
  position:absolute; inset:0;
  background: linear-gradient(to bottom, rgba(0,0,0,.75) 0%, transparent 100%);
  pointer-events:none;
}
.nav-brand {
  position:relative;
  font-family:'Barlow Condensed',sans-serif;
  font-size:.78rem; letter-spacing:.25em; text-transform:uppercase;
  color:rgba(255,255,255,.7);
}
.nav-brand span { color:var(--ouro2); }
.nav-links {
  position:relative; list-style:none;
  display:flex; gap:2.8rem;
}
.nav-links a {
  font-family:'Barlow Condensed',sans-serif;
  font-size:.72rem; letter-spacing:.22em; text-transform:uppercase;
  color:rgba(255,255,255,.6);
  transition: color .25s;
}
.nav-links a:hover { color:var(--ouro2); }
.nav-toggle {
  display:none; background:none; border:none; cursor:pointer;
  flex-direction:column; gap:5px; padding:4px; position:relative; z-index:1;
}
.nav-toggle span {
  display:block; width:22px; height:1.5px;
  background:rgba(255,255,255,.7);
  transition:var(--trans);
}

/* ── HELPER CLASSES ── */
.s-label {
  font-family:'Barlow Condensed',sans-serif;
  font-size:.68rem; letter-spacing:.35em; text-transform:uppercase;
  color:var(--ouro); margin-bottom:1.8rem; display:block;
}
.s-title {
  font-family:'Cormorant Garamond',serif;
  font-size: clamp(2.6rem,4vw,4.2rem);
  font-weight:300; line-height:1.1; margin-bottom:2.2rem;
}
.s-title strong { font-weight:700; color:var(--ouro2); }
.s-divider { width:40px; height:2px; background:var(--ouro); margin-bottom:2rem; }

/* ── ANIMAÇÕES REVEAL ── */
.reveal {
  opacity:0; transform:translateY(28px);
  transition: opacity .75s ease, transform .75s ease;
}
.reveal.in { opacity:1; transform:none; }
.reveal-d1 { transition-delay:.12s; }
.reveal-d2 { transition-delay:.24s; }
.reveal-d3 { transition-delay:.36s; }

/* ════════════════════════════════════
   HERO
════════════════════════════════════ */
.hero-section {
  position:relative; height:100vh; width:100%;
  display:flex; align-items:flex-end; overflow:hidden;
}
.hero-bg {
  position:absolute; inset:0;
  background: radial-gradient(ellipse at 60% 0%, #1a5c40 0%, #0A4A2E 35%, #050E08 70%, #000 100%);
}
.hero-bg-noise {
  position:absolute; inset:0; opacity:.04;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size:200px;
}
.hero-photo-wrap {
  position:absolute; right:8%; bottom:0;
  width:52vmin; max-width:520px; height:88vh;
  display:flex; align-items:flex-end; justify-content:center;
}
.hero-photo-img {
  height:100%; width:100%; object-fit:cover; object-position:center top;
  filter:grayscale(12%) contrast(1.06);
  -webkit-mask-image: linear-gradient(to top, transparent 0%, rgba(0,0,0,.15) 8%, black 22%, black 88%, transparent 100%),
                      linear-gradient(to right, transparent 0%, black 10%, black 90%, transparent 100%);
  mask-image: linear-gradient(to top, transparent 0%, rgba(0,0,0,.15) 8%, black 22%, black 88%, transparent 100%),
              linear-gradient(to right, transparent 0%, black 10%, black 90%, transparent 100%);
  -webkit-mask-composite:intersect; mask-composite:intersect;
}
.hero-photo-placeholder {
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:8px; color:rgba(255,255,255,.3); font-size:.8rem; height:100%;
}
.hero-photo-placeholder span { font-size:3rem; }
.hero-content {
  position:relative; z-index:5;
  padding:0 52px 7vh; width:55%;
}
.hero-eyebrow {
  font-family:'Barlow Condensed',sans-serif;
  font-size:.72rem; letter-spacing:.35em; text-transform:uppercase;
  color:var(--ouro); margin-bottom:1.2rem;
  opacity:0; animation: fadeUp .8s .9s forwards;
}
.hero-name {
  font-family:'Cormorant Garamond',serif;
  font-size: clamp(4.5rem,8vw,8.5rem);
  font-weight:700; line-height:.95; letter-spacing:-.01em;
  opacity:0; animation: fadeUp .9s 1.1s forwards;
}
.hero-name-first { display:block; }
.hero-name-first em { font-style:italic; font-weight:300; color:rgba(255,255,255,.65); }
.hero-name-last  { display:block; color:var(--ouro2); }
.hero-role {
  font-family:'Barlow Condensed',sans-serif;
  font-size:1rem; letter-spacing:.18em; text-transform:uppercase;
  color:rgba(255,255,255,.55);
  margin-top:1.4rem; margin-bottom:2.4rem;
  display:flex; align-items:center; gap:1rem;
  opacity:0; animation: fadeUp .8s 1.3s forwards;
}
.hero-role::before { content:''; display:inline-block; width:32px; height:1px; background:var(--ouro); }
.hero-scroll {
  display:flex; align-items:center; gap:12px;
  font-family:'Barlow Condensed',sans-serif;
  font-size:.68rem; letter-spacing:.3em; text-transform:uppercase;
  color:rgba(255,255,255,.35);
  opacity:0; animation: fadeUp .8s 1.6s forwards;
  transition: color .25s;
}
.hero-scroll:hover { color:var(--ouro); }
.scroll-line {
  display:inline-block; width:1px; height:42px;
  background:linear-gradient(to bottom, transparent, var(--ouro), transparent);
  animation: scrollAnim 2s infinite;
}
.hero-year {
  position:absolute; bottom:5vh; right:52px;
  font-family:'Barlow Condensed',sans-serif;
  font-size:.7rem; letter-spacing:.3em; text-transform:uppercase;
  color:rgba(255,255,255,.18); writing-mode:vertical-rl;
  opacity:0; animation: fadeUp .8s 1.8s forwards;
}
@keyframes fadeUp   { from{opacity:0;transform:translateY(22px)} to{opacity:1;transform:none} }
@keyframes scrollAnim { 0%,100%{opacity:.3;height:28px} 50%{opacity:1;height:48px} }

/* ════════════════════════════════════
   SOBRE
════════════════════════════════════ */
.sobre-section {
  display:grid; grid-template-columns:1fr 1fr; min-height:100vh;
}
.sobre-left {
  background:var(--verde); padding:10vh 8vw 10vh 52px;
  display:flex; flex-direction:column; justify-content:center;
  position:relative; overflow:hidden;
}
.sobre-left::before {
  content:''; position:absolute; top:0; right:0; bottom:0; width:1px;
  background:linear-gradient(to bottom, transparent, var(--ouro), transparent);
}
.sobre-left-deco {
  position:absolute; top:-60px; left:-60px; width:300px; height:300px;
  border-radius:50%;
  background:radial-gradient(circle, rgba(191,161,74,.07), transparent 70%);
}
.sobre-right {
  background:#0a0f0c; padding:10vh 52px 10vh 8vw;
  display:flex; flex-direction:column; justify-content:center;
}
.s-text {
  font-size:1rem; line-height:1.85; color:rgba(255,255,255,.65);
  max-width:460px;
}
.s-text + .s-text { margin-top:1.2rem; }
.stats-grid {
  display:grid; grid-template-columns:1fr 1fr; gap:2px; margin-top:4rem;
}
.stat-box {
  padding:2rem 1.8rem;
  background:rgba(255,255,255,.03); border:1px solid rgba(255,255,255,.06);
  transition:background .3s;
}
.stat-box:hover { background:rgba(191,161,74,.07); }
.stat-num {
  font-family:'Cormorant Garamond',serif;
  font-size:3rem; font-weight:700; color:var(--ouro2); line-height:1; margin-bottom:.3rem;
}
.stat-lbl {
  font-family:'Barlow Condensed',sans-serif;
  font-size:.7rem; letter-spacing:.2em; text-transform:uppercase;
  color:rgba(255,255,255,.4);
}
/* Timeline */
.timeline {
  border-left:1px solid rgba(191,161,74,.3);
  padding-left:2rem; margin-top:3rem;
  display:flex; flex-direction:column; gap:1.8rem;
}
.tl-item { position:relative; }
.tl-item::before {
  content:''; position:absolute; left:-2.55rem; top:5px;
  width:9px; height:9px; border-radius:50%;
  background:var(--ouro); box-shadow:0 0 12px var(--ouro);
}
.tl-yr {
  font-family:'Barlow Condensed',sans-serif;
  font-size:.68rem; letter-spacing:.2em; color:var(--ouro); text-transform:uppercase;
}
.tl-desc { font-size:.92rem; line-height:1.55; color:rgba(255,255,255,.6); margin-top:2px; }

/* ════════════════════════════════════
   PROJETOS DE LEI
════════════════════════════════════ */
.projetos-section {
  padding:10vh 52px;
  background:linear-gradient(180deg,#0a0f0c 0%,#050e08 100%);
  position:relative;
}
.projetos-section::before {
  content:'"'; position:absolute; top:-20px; left:40px;
  font-family:'Cormorant Garamond',serif; font-size:18rem;
  color:rgba(191,161,74,.04); line-height:1; pointer-events:none;
}
.proj-header {
  display:flex; align-items:flex-end; justify-content:space-between;
  margin-bottom:5rem;
}
.proj-title {
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(3rem,5vw,5.5rem); font-weight:300; line-height:1;
}
.proj-title strong { font-weight:700; color:var(--ouro2); display:block; }
.proj-count {
  font-family:'Cormorant Garamond',serif; font-size:5rem;
  color:rgba(255,255,255,.07); line-height:1;
}
.proj-filters { display:flex; gap:.6rem; flex-wrap:wrap; margin-bottom:3rem; }
.pf-btn {
  font-family:'Barlow Condensed',sans-serif;
  font-size:.7rem; letter-spacing:.2em; text-transform:uppercase;
  padding:8px 20px; border:1px solid rgba(255,255,255,.15);
  background:transparent; color:rgba(255,255,255,.5); cursor:pointer;
  transition:var(--trans);
}
.pf-btn.on, .pf-btn:hover { border-color:var(--ouro); color:var(--ouro); background:rgba(191,161,74,.06); }
.proj-list { display:flex; flex-direction:column; gap:0; }
.proj-item {
  display:grid; grid-template-columns:80px 1fr auto;
  align-items:center; gap:2.5rem; padding:2rem 0;
  border-bottom:1px solid rgba(255,255,255,.07);
  cursor:pointer; position:relative; overflow:hidden;
  transition: padding .3s ease;
}
.proj-item::before {
  content:''; position:absolute; left:0; top:0; bottom:0; width:0;
  background:rgba(191,161,74,.04); transition:width .3s;
}
.proj-item:hover::before { width:100%; }
.proj-item:hover { padding-left:1.5rem; padding-right:1.5rem; }
.proj-num {
  font-family:'Cormorant Garamond',serif; font-size:3rem; font-weight:700;
  color:rgba(191,161,74,.2); line-height:1;
}
.proj-tag {
  font-family:'Barlow Condensed',sans-serif;
  font-size:.65rem; letter-spacing:.22em; text-transform:uppercase;
  color:var(--ouro); margin-bottom:.4rem;
}
.proj-name {
  font-family:'Barlow Condensed',sans-serif;
  font-size:1.25rem; font-weight:600; letter-spacing:.02em; margin-bottom:.4rem;
}
.proj-desc { font-size:.88rem; color:rgba(255,255,255,.45); line-height:1.5; }
.proj-arrow {
  font-size:1.3rem; color:rgba(191,161,74,.4);
  transition:transform .25s, color .25s;
  text-decoration:none;
}
.proj-item:hover .proj-arrow { transform:translateX(6px); color:var(--ouro); }
.proj-status {
  display:inline-flex; align-items:center; gap:5px;
  font-size:.68rem; font-weight:600;
  font-family:'Barlow Condensed',sans-serif;
  letter-spacing:.1em; text-transform:uppercase; margin-top:.5rem;
}
.proj-status .dot { width:6px; height:6px; border-radius:50%; }
.st-ok  { color:#4caf6e; } .st-ok  .dot { background:#4caf6e; box-shadow:0 0 6px #4caf6e; }
.st-run { color:#f0b942; } .st-run .dot { background:#f0b942; box-shadow:0 0 6px #f0b942; }
.proj-cta { text-align:center; margin-top:4rem; }
.proj-cta-link {
  font-family:'Barlow Condensed',sans-serif;
  font-size:.75rem; letter-spacing:.28em; text-transform:uppercase;
  color:var(--ouro); border-bottom:1px solid rgba(191,161,74,.4);
  padding-bottom:4px; transition:var(--trans);
}
.proj-cta-link:hover { border-color:var(--ouro); letter-spacing:.32em; }

/* ════════════════════════════════════
   TRANSPARÊNCIA
════════════════════════════════════ */
.transp-section {
  background:var(--verde); padding:10vh 52px;
  position:relative; overflow:hidden;
}
.transp-section::after {
  content:''; position:absolute; inset:0;
  background:url("data:image/svg+xml,%3Csvg width='40' height='40' viewBox='0 0 40 40' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='20' cy='20' r='.5' fill='%23BFA14A' fill-opacity='.1'/%3E%3C/svg%3E");
  pointer-events:none;
}
.t-head {
  display:grid; grid-template-columns:1fr 1fr; gap:4rem;
  align-items:start; margin-bottom:5rem; position:relative; z-index:1;
}
.t-desc { font-size:.95rem; color:rgba(255,255,255,.5); line-height:1.7; margin-top:1.2rem; max-width:400px; }
.gastos-chart { margin-top:2rem; }
.g-row { display:flex; align-items:center; gap:1.5rem; margin-bottom:1.2rem; }
.g-label {
  font-family:'Barlow Condensed',sans-serif;
  font-size:.78rem; letter-spacing:.1em; text-transform:uppercase;
  color:rgba(255,255,255,.55); min-width:180px;
}
.g-bar-wrap { flex:1; height:6px; background:rgba(255,255,255,.1); border-radius:3px; }
.g-bar { height:6px; border-radius:3px; background:var(--ouro); transition:width 1.2s ease; width:0%; }
.g-val {
  font-family:'Cormorant Garamond',serif; font-size:1.1rem; font-weight:700;
  color:var(--ouro2); min-width:80px; text-align:right;
}
.t-disclaimer {
  font-size:.7rem; color:rgba(255,255,255,.25); margin-top:1rem;
  font-family:'Barlow Condensed',sans-serif; letter-spacing:.1em; text-transform:uppercase;
}
.t-links {
  display:grid; grid-template-columns:repeat(3,1fr); gap:2px;
  position:relative; z-index:1;
}
.t-link {
  background:rgba(0,0,0,.3); border:1px solid rgba(255,255,255,.1);
  padding:2rem 1.5rem; transition:var(--trans);
  display:flex; flex-direction:column; gap:.8rem;
}
.t-link:hover {
  background:rgba(0,0,0,.5); border-color:rgba(191,161,74,.4);
  transform:translateY(-4px);
}
.t-link-icon { font-size:1.6rem; }
.t-link-title {
  font-family:'Barlow Condensed',sans-serif;
  font-size:.9rem; letter-spacing:.1em; text-transform:uppercase; font-weight:600;
}
.t-link-url { font-size:.75rem; color:rgba(255,255,255,.4); }

/* ════════════════════════════════════
   CONTATO
════════════════════════════════════ */
.contato-section {
  background:#050e08; padding:10vh 52px;
  display:grid; grid-template-columns:1fr 1fr; gap:8vw; align-items:start;
}
.c-title {
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(3rem,5vw,5rem); font-weight:300; line-height:1.05; margin-bottom:3rem;
}
.c-title em { font-style:italic; color:var(--ouro2); }
.c-info { display:flex; flex-direction:column; gap:2rem; }
.c-item-lbl {
  font-family:'Barlow Condensed',sans-serif;
  font-size:.65rem; letter-spacing:.28em; text-transform:uppercase;
  color:var(--ouro); margin-bottom:.4rem;
}
.c-item-val { font-size:1.05rem; color:rgba(255,255,255,.7); line-height:1.6; }
.c-item-val a:hover { color:var(--ouro2); }
.c-social { display:flex; gap:1rem; margin-top:.5rem; }
.c-soc {
  width:42px; height:42px; border:1px solid rgba(255,255,255,.15);
  display:flex; align-items:center; justify-content:center;
  color:rgba(255,255,255,.5); font-family:'Barlow Condensed',sans-serif;
  font-size:.72rem; letter-spacing:.05em; font-weight:700;
  transition:var(--trans);
}
.c-soc:hover { border-color:var(--ouro); color:var(--ouro); transform:translateY(-3px); }
/* Form */
.c-form { display:flex; flex-direction:column; gap:0; }
.f-field {
  border-bottom:1px solid rgba(255,255,255,.12); padding:1.6rem 0;
  transition:border-color .25s;
}
.f-field:focus-within { border-color:var(--ouro); }
.f-label {
  font-family:'Barlow Condensed',sans-serif;
  font-size:.65rem; letter-spacing:.28em; text-transform:uppercase;
  color:rgba(255,255,255,.35); display:block; margin-bottom:.6rem;
  transition:color .25s;
}
.f-field:focus-within .f-label { color:var(--ouro); }
.f-input {
  width:100%; background:transparent; border:none; outline:none;
  font-size:1rem; color:var(--branco); font-family:'Barlow',sans-serif;
}
.f-input::placeholder { color:rgba(255,255,255,.2); }
textarea.f-input { resize:none; min-height:100px; }
.f-submit {
  margin-top:2.5rem; display:inline-flex; align-items:center; gap:1rem;
  font-family:'Barlow Condensed',sans-serif;
  font-size:.78rem; letter-spacing:.25em; text-transform:uppercase;
  background:var(--ouro); color:var(--escuro); font-weight:700;
  padding:15px 36px; border:none; cursor:pointer; transition:var(--trans);
}
.f-submit:hover { background:var(--ouro2); transform:translateX(6px); }
.cf-msg {
  padding:12px 16px; border-radius:var(--radius); margin-top:1rem;
  font-size:.9rem; font-family:'Barlow',sans-serif;
}
.cf-msg.ok  { background:rgba(76,175,110,.15); color:#4caf6e; border:1px solid rgba(76,175,110,.3); }
.cf-msg.err { background:rgba(220,53,69,.1);   color:#e57373; border:1px solid rgba(220,53,69,.3); }

/* ════════════════════════════════════
   FOOTER
════════════════════════════════════ */
.site-footer {
  background:var(--escuro); padding:2.5rem 52px;
  display:flex; align-items:center; justify-content:space-between;
  border-top:1px solid rgba(255,255,255,.06);
}
.f-copy {
  font-family:'Barlow Condensed',sans-serif;
  font-size:.68rem; letter-spacing:.18em; text-transform:uppercase;
  color:rgba(255,255,255,.25);
}
.f-links { display:flex; gap:2.5rem; }
.f-links a {
  font-family:'Barlow Condensed',sans-serif;
  font-size:.65rem; letter-spacing:.18em; text-transform:uppercase;
  color:rgba(255,255,255,.28); transition:color .25s;
}
.f-links a:hover { color:var(--ouro2); }

/* ════════════════════════════════════
   RESPONSIVO
════════════════════════════════════ */
@media (max-width:1024px){
  .t-links { grid-template-columns:1fr 1fr; }
}
@media (max-width:860px){
  .site-nav { padding:18px 24px; }
  .nav-toggle { display:flex; }
  .nav-links {
    display:none; flex-direction:column; gap:1.5rem;
    position:absolute; top:100%; right:0; left:0;
    background:rgba(8,12,10,.97); padding:2rem 24px;
    border-bottom:1px solid rgba(191,161,74,.2);
  }
  .nav-links.open { display:flex; }
  .hero-content { width:90%; padding:0 24px 9vh; }
  .hero-name { font-size:clamp(3.5rem,14vw,5.5rem); }
  .hero-photo-wrap { width:75vw; right:-5%; height:65vh; }
  .hero-year { right:16px; }
  .sobre-section { grid-template-columns:1fr; }
  .sobre-left, .sobre-right { padding:8vh 24px; }
  .stats-grid { grid-template-columns:1fr 1fr; }
  .projetos-section, .transp-section { padding:8vh 24px; }
  .proj-item { grid-template-columns:50px 1fr; }
  .proj-arrow { display:none; }
  .t-head { grid-template-columns:1fr; gap:3rem; }
  .t-links { grid-template-columns:1fr 1fr; }
  .g-label { min-width:120px; font-size:.7rem; }
  .contato-section { grid-template-columns:1fr; padding:8vh 24px; gap:4rem; }
  .site-footer { flex-direction:column; gap:1.5rem; text-align:center; padding:2rem 24px; }
}
@media (max-width:480px){
  .hero-name { font-size:clamp(3rem,15vw,4.5rem); }
  .t-links { grid-template-columns:1fr; }
  .proj-filters { gap:.4rem; }
  .pf-btn { padding:6px 14px; font-size:.65rem; }
}
