/* ════════════════════════════════════════
   RESET & TOKENS
════════════════════════════════════════ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }

:root {
  --black:    #0a0a0a;
  --white-bg: #f5f5f0;
  --white:    #f0f0f0;
  --ink-lt:   #f0f0f0;
  --ink-mid:  #777777;
  --yellow:   #ffff00;

  --col-data: #a20ddd;
  --col-ux:   #0cbbf0;
  --col-code: #f00c2e;
  --col-arch: #08d504;
  --col-xr:   #f88f05;
  --col-sand: #f018b3;
  

  --nav-h: 64px;
  --ease:  cubic-bezier(0.25, 1, 0.5, 1);
  --mono:  'Space Mono', monospace;
}

body {
  background: var(--black);
  color: var(--ink-lt);
  font-family: 'DM Sans', sans-serif;
  overflow-x: hidden;
  cursor: none;
  -webkit-font-smoothing: antialiased;
}

::-webkit-scrollbar { width: 3px; }
::-webkit-scrollbar-track { background: var(--black); }
::-webkit-scrollbar-thumb { background: var(--yellow); }

/* ════════════════════════════════════════
   CURSOR — yellow
════════════════════════════════════════ */
#cur-dot {
  width: 10px; height: 10px; border-radius: 50%;
  background: var(--yellow);
  border: 1.5px solid #000;
  position: fixed; top: 0; left: 0; z-index: 9999;
  transform: translate(-50%,-50%);
  pointer-events: none;
  transition: transform .15s var(--ease);
}
#cur-ring {
  width: 36px; height: 36px; border-radius: 50%;
  border: 1.5px solid var(--yellow);
  box-shadow: 0px 0px 0px 1.5px #000 inset;
  position: fixed; top: 0; left: 0; z-index: 9998;
  transform: translate(-50%,-50%);
  pointer-events: none;
  transition: opacity .2s;
}
body.cursor-hover #cur-dot { transform: translate(-50%,-50%) scale(2.2); }
body.cursor-hover #cur-ring { opacity: 0.4; }

/* ════════════════════════════════════════
   NAV — always WHITE
════════════════════════════════════════ */
nav {
  position: fixed; top: 0; left: 0; right: 0;
  height: var(--nav-h);
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 3rem;
  z-index: 200;
  background: #ffffff;
  box-shadow: 0 1px 0 rgba(0,0,0,0.08);
}

.nav-logo { display: block; text-decoration: none; }
.logo-box {
  width: 150px; height: 62px;
  display: flex; align-items: center; justify-content: center;
  overflow: hidden;
  transition: border-color .2s;
}
.logo-box:hover { border-color: #bbb; }
.logo-placeholder {
  font-family: var(--mono);
  font-size: .52rem; color: rgba(0,0,0,0.22);
  text-align: center; line-height: 1.5;
  pointer-events: none;
}

.nav-links { display: flex; gap: 2.5rem; list-style: none; }
.nav-links a {
  font-family: var(--mono);
  font-size: .82rem; letter-spacing: .1em; text-transform: uppercase; font-weight: 700;
  color: #555; text-decoration: none;
  position: relative; transition: color .2s;
}
.nav-links a::after {
  content: ''; position: absolute; bottom: -3px; left: 0; right: 0;
  height: 5px; background: var(--yellow);
  transform: scaleX(0); transform-origin: left;
  transition: transform .3s var(--ease);
}
.nav-links a:hover { color: #000; }
.nav-links a:hover::after { transform: scaleX(1); }

/* hamburger */
.nav-toggle {
  display: none;
  flex-direction: column; gap: 5px;
  background: none; border: none; cursor: none; padding: 4px;
}
.nav-toggle span { display: block; width: 24px; height: 1.5px; background: #111; transition: transform .3s, opacity .3s; }
.nav-open .nav-toggle span:nth-child(1) { transform: translateY(6.5px) rotate(45deg); }
.nav-open .nav-toggle span:nth-child(2) { opacity: 0; }
.nav-open .nav-toggle span:nth-child(3) { transform: translateY(-6.5px) rotate(-45deg); }

/* ════════════════════════════════════════
   HERO — BLACK
   Photo LEFT  |  Name + text RIGHT
════════════════════════════════════════ */
.hero {
  background: var(--black);
  min-height: 100vh;
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: center;
  gap: 5rem;
  padding: calc(var(--nav-h) + 5rem) 5rem 5rem;
}

.hero-left {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  height: 100%;
}

.photo-frame {
  width: 100%;
  max-width: 320px;
  aspect-ratio: 3 / 4;
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 3px;
  overflow: hidden;
  position: relative;
  background: #161616;
  flex-shrink: 1;
}
.photo-frame::before {
  content: ''; position: absolute; top: 0; left: 0;
  width: 48px; height: 48px;
  border-top: 2px solid var(--yellow); border-left: 2px solid var(--yellow);
  z-index: 2; pointer-events: none;
}
.photo-frame::after {
  content: ''; position: absolute; bottom: 0; right: 0;
  width: 48px; height: 48px;
  border-bottom: 2px solid var(--yellow); border-right: 2px solid var(--yellow);
  z-index: 2; pointer-events: none;
}
.photo-placeholder {
  width: 100%; height: 100%;
  display: flex; flex-direction: column;
  align-items: center; justify-content: center; gap: .7rem;
  color: #333;
}
.photo-placeholder span { font-family: var(--mono); font-size: .65rem; color: #333; }

.typing-block { font-family: var(--mono); }
.typing-comment { font-size: .67rem; color: #3d6135; margin-bottom: .22rem; }
.typing-meta    { font-size: .67rem; color: #555; margin-bottom: .18rem; }
.typing-keyword { color: #569cd6; }
.typing-str     { color: var(--yellow); }

.typing-display {
  display: flex; align-items: center;
  font-family: var(--mono);
  font-size: clamp(1rem, 1.8vw, 1.5rem);
  font-weight: 700; color: var(--white);
  min-height: 2rem;
}
.typing-prompt { color: var(--yellow); margin-right: .4rem; }
.cursor-blink {
  display: inline-block; width: 2px; height: 1em;
  background: var(--yellow); margin-left: 3px;
  vertical-align: middle;
  animation: blink .75s step-end infinite;
}
@keyframes blink { 0%,100%{opacity:1} 50%{opacity:0} }
.typing-close { font-size: .67rem; color: var(--yellow); margin-top: .18rem; }

.hero-right {
  display: flex; flex-direction: column;
  justify-content: center; gap: 1.8rem;
  height: 100%;
  opacity: 0; animation: fadeUp .9s .2s forwards;
}

.hero-name {
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(5rem, 9vw, 9.5rem);
  line-height: 1.1; letter-spacing: .02em;
  color: var(--white);
}

.hero-tagline {
  font-family: 'Fraunces', serif;
  text-align: justify; font-weight: 300;
  font-size: clamp(.88rem, 1.3vw, 1.08rem);
  color: #888; line-height: 1.9; max-width: 420px;
}

.hero-ctas { display: flex; gap: .9rem; flex-wrap: wrap; }

.btn {
  display: inline-flex; align-items: center; gap: .55rem;
  padding: .76rem 1.8rem; border-radius: 2px;
  font-family: var(--mono); font-size: .7rem; font-weight: 700;
  letter-spacing: .09em; text-transform: uppercase;
  text-decoration: none; border: none; cursor: none;
  position: relative; overflow: hidden;
  transition: transform .2s var(--ease), box-shadow .2s;
}
.btn::after {
  content: ''; position: absolute; inset: 0;
  background: rgba(255,255,255,.14);
  transform: translateX(-110%) skewX(-18deg);
  transition: transform .4s var(--ease);
}
.btn:hover::after { transform: translateX(110%) skewX(-18deg); }
.btn:hover { transform: translateY(-3px); box-shadow: 0 10px 28px rgba(255,255,0,.2); }
.btn-fill    { background: var(--yellow); color: #000; }
.btn-outline { background: transparent; color: var(--yellow); box-shadow: inset 0 0 0 1.5px var(--yellow); }
.btn-outline:hover { background: rgba(255,255,0,.06); }

/* ════════════════════════════════════════
   FEATURED — WHITE background
════════════════════════════════════════ */
.featured-section {
  background: #ffffff;
  padding: 5rem 0 4rem;
  overflow: hidden;
}
.featured-header { padding: 0 5rem 3rem; }
.featured-eyebrow {
  font-family: var(--mono);
  font-size: .67rem; font-weight: 700; letter-spacing: .22em;
  text-transform: uppercase; color: #bbb;
  display: flex; align-items: center; gap: .7rem; margin-bottom: .5rem;
}
.featured-eyebrow::before { content:''; width:1.4rem; height:1px; background:#bbb; display:block; }
.featured-title {
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(2.2rem, 4.5vw, 3.5rem);
  letter-spacing: .03em; color: #111;
}

.carousel-strip {
  display: flex;
  gap: 1.4rem;
  width: max-content;
  padding: 0 1.4rem 1rem;
  animation: infiniteScroll 50s linear infinite;
}
.carousel-strip:hover { animation-play-state: paused; }

@keyframes infiniteScroll {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

.portrait-card {
  width: 400px;
  flex-shrink: 0;
  aspect-ratio: 16 / 9;
  border-radius: 4px;
  overflow: hidden;
  background: #ffffff;
  border: 1px solid rgba(0,0,0,0.07);
  position: relative;
  cursor: none;
  transition: box-shadow .3s, transform .3s var(--ease);
}
.portrait-card:hover {
  box-shadow: 0 16px 48px rgba(0,0,0,0.16);
  transform: translateY(-5px);
}
.portrait-card img { width:100%; height:100%; object-fit:contain; display:block; }

.portrait-placeholder {
  width: 100%; height: 100%;
  display: flex; flex-direction: column;
  align-items: center; justify-content: center; gap: .5rem;
}
.ph-icon { opacity: .25; }
.ph-label {
  font-family: var(--mono); font-size: .58rem;
  text-align: center; color: #999; padding: 0 .8rem; line-height: 1.5;
}

.portrait-cat-tag {
  position: absolute; bottom: .7rem; left: .7rem;
  font-family: var(--mono); font-size: .58rem; font-weight: 700;
  letter-spacing: .08em; text-transform: uppercase;
  padding: .18rem .55rem; border-radius: 2px;
  background: var(--tc, #ffff00); color: var(--tc-text, #000);
}

/* ════════════════════════════════════════
   ABOUT ME — BLACK background
════════════════════════════════════════ */
.about-me-section {
  background: var(--black);
  padding: 5rem;
  border-top: 1px solid rgba(255,255,255,0.05);
  border-bottom: 1px solid rgba(255,255,255,0.05);
}

.about-me-header {
  padding: 0 0 3rem 0;
  margin-bottom: 0;
}

.about-me-eyebrow {
  font-family: var(--mono);
  font-size: 0.67rem;
  font-weight: 700;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--yellow);
  display: flex;
  align-items: center;
  gap: 0.7rem;
  margin-bottom: 0.5rem;
}

.about-me-eyebrow::before {
  content: '';
  width: 1.4rem;
  height: 1px;
  background: var(--yellow);
  display: block;
}

.about-me-title {
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(2.2rem, 4.5vw, 3.5rem);
  letter-spacing: 0.03em;
  color: var(--white);
}

.about-me-container {
  display: grid;
  grid-template-columns: 1fr 1fr; /* 2 colunas */
  gap: 4rem;
  align-items: center;
}

.about-me-dome {
  width: 100%;
  height: 500px; /* altura do dome */
  position: relative;
}

.about-me-dome canvas,
.about-me-dome img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.about-me-inner {
  max-width: 500px;
}

.about-me-text {
  font-family: 'Fraunces', serif;
  font-size: clamp(0.95rem, 1.2vw, 1.1rem);
  font-weight: 300;
  color: #888;
  line-height: 1.9;
  margin-bottom: 1.5em;
  text-align: justify;
}

/* ════════════════════════════════════════
   DOME GALLERY — ABOUT ME 
════════════════════════════════════════ */
.about-me-dome {
  width: 100%;
  height: 600px;
  position: relative;
  overflow: hidden;
}

.dome-viewport {
  width: 100%;
  height: 100%;
  perspective: 800px;
  perspective-origin: 50% 75%;
  cursor: grab;
  position: relative;
}
.dome-viewport.grabbing { cursor: grabbing; }

.dome-stage {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 0;
  height: 0;
  transform-style: preserve-3d;
  transition: transform 0.05s linear;
  will-change: transform;
}

.dome-tile {
  position: absolute;
  top: 0;
  left: 0;
  border-radius: 18px;
  overflow: hidden;
  backface-visibility: visible;  /* use hidden para deixar o fundo preto*/
  box-shadow: 0 8px 24px rgba(0,0,0,0.5);
  transition: filter 0.3s ease;
}

.dome-tile img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  filter: grayscale(60%) brightness(0.85);
  transition: filter 0.3s ease;
}

.dome-tile:hover img {
  filter: grayscale(0%) brightness(1);
}

/* fades pra suavizar bordas */
.dome-fade {
  position: absolute;
  left: 0; right: 0;
  height: 110px;
  z-index: 3;
  pointer-events: none;
}
.dome-fade-top {
  top: 0;
  background: linear-gradient(to bottom, var(--black) 10%, transparent);
}
.dome-fade-bottom {
  bottom: 0;
  background: linear-gradient(to top, var(--black) 10%, transparent);
}

/* ════════════════════════════════════════
   CALL TO ACTION — FALLING LETTERS (PREMIUM)
════════════════════════════════════════ */

.cta-section {
  background: #ffffff;
  padding: 6rem 5rem; /* mais respiro */
}

.cta-inner {
  max-width: 1000px;
  margin: 0 auto;
  text-align: center;
}

/* Container da física */
#falling-text-container {
  position: relative;
  width: 100%;
  min-height: 420px; /* mais espaço pra queda */
  padding: 2rem 1rem;
  cursor: pointer;
  overflow: hidden;
  pointer-events: auto;
}

/* Container das letras */
#falling-text-words {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  height: 100%;
  padding: 2rem;
}

/* Letras */
.ft-word {
  display: inline-block;
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(2rem, 4vw, 3.2rem); /* maior impacto */
  letter-spacing: 0.05em;
  color: var(--black);
  margin: 0 3px;
  user-select: none;
  position: static;
  transform-origin: center center;
  will-change: transform;

  /* micro interação suave */
  transition: transform 0.2s ease, opacity 0.2s ease;
}

/* Hover leve (efeito Apple) */
#falling-text-container:hover .ft-word {
  opacity: 0.85;
}

/* Quando ativa física */
.ft-word.ft-falling {
  position: absolute;
  transition: none; /* evita conflito com GSAP/anime */
}

/* Canvas Matter.js */
#falling-text-canvas {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
  pointer-events: none;
  opacity: 0;
}

/* Hint */
.cta-hint {
  margin-top: 1.5rem;
  font-family: var(--mono);
  font-size: 0.65rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: #bbb;
  animation: hintPulse 2.5s ease-in-out infinite;
}

@keyframes hintPulse {
  0%, 100% { opacity: 0.4; }
  50% { opacity: 1; }
}

/* ════════════════════════════════════════
   SELECTED WORK — BLACK background
════════════════════════════════════════ */
#projects {
  background: var(--black);
  padding: 5rem;
  border-top: 1px solid rgba(255,255,255,0.05);
  border-bottom: 1px solid rgba(255,255,255,0.05);
}

.projects-inner {
  max-width: 100%;
}

.projects-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  margin-bottom: 3rem;
  flex-wrap: wrap;
  gap: 1.5rem;
}

.projects-header > div:first-child {
  flex: 1;
}

.projects-section-eyebrow {
  font-family: var(--mono);
  font-size: .67rem;
  font-weight: 700;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--yellow);
  display: flex;
  align-items: center;
  gap: .7rem;
  margin-bottom: .5rem;
}

.projects-section-eyebrow::before {
  content: '';
  width: 1.4rem;
  height: 1px;
  background: var(--yellow);
  display: block;
}

.projects-section-title {
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(2.2rem, 4.5vw, 3.5rem);
  letter-spacing: .03em;
  color: var(--white);
}

.filter-pills {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
}

.fpill {
  padding: .38rem 1rem;
  border-radius: 2px;
  font-family: var(--mono);
  font-size: .63rem;
  font-weight: 700;
  letter-spacing: .07em;
  text-transform: uppercase;
  background: transparent;
  border: 1px solid rgba(255,255,255,0.12);
  color: #555;
  cursor: none;
  transition: all .2s var(--ease);
}

.fpill:hover {
  border-color: var(--yellow);
  color: var(--yellow);
}

.fpill.active {
  background: var(--yellow);
  color: #000;
  border-color: var(--yellow);
}

/* ════════════════════════════════════════
   CAROUSEL CONTROLS (arrow buttons)
════════════════════════════════════════ */
.carousel-controls {
  display: flex;
  gap: 0.8rem;
  align-items: center;
  justify-content: flex-end;
  margin-bottom: 1.5rem;
}

.carousel-arrow {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 3px;
  border: 1px solid rgba(255, 255, 255, 0.2);
  background: transparent;
  color: #aaa;
  cursor: pointer;
  transition: all 0.2s var(--ease);
  padding: 0;
}

.carousel-arrow:hover {
  border-color: var(--yellow);
  color: var(--yellow);
  background: rgba(255, 255, 0, 0.06);
}

.carousel-arrow:active {
  transform: scale(0.95);
}

.carousel-arrow svg {
  width: 18px;
  height: 18px;
  stroke-linecap: round;
  stroke-linejoin: round;
}

/* ── The scrollable wrapper ── */
.projects-carousel-wrapper {
  overflow-x: auto;
  overflow-y: hidden;
  width: 100%;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  cursor: grab;
}
.projects-carousel-wrapper::-webkit-scrollbar { display: none; }
.projects-carousel-wrapper.dragging { cursor: grabbing; }

/* ── The flex row of cards ── */
.projects-grid {
  display: flex;
  gap: 1.3rem;
  padding-bottom: 1rem; /* breathing room */
  user-select: none;
  width: max-content;
}

.project-card {
  position: relative;
  background: #1b1b1b;
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 3px;
  overflow: hidden;
  cursor: pointer;
  display: flex;
  flex-direction: column;
  transition: transform .35s var(--ease), box-shadow .35s, border-color .3s;
  /* Each card is ~1/3 of the visible area */
  flex: 0 0 calc((100vw - 10rem) / 3);
  min-width: 260px;
  max-width: 400px;
}

.project-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 20px 50px rgba(0,0,0,.7);
  border-color: var(--cc, var(--yellow));
}
.card-color-bar {
  height: 2px; background: var(--cc, var(--yellow));
  transform: scaleX(0); transform-origin: left;
  transition: transform .45s var(--ease);
}
.project-card:hover .card-color-bar { transform: scaleX(1); }
.card-body {
  padding: 1.4rem;
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  min-width: 0;
}

/* ── Card inner layout: text left + image right ── */
.card-content {
  display: flex;
  flex-direction: row;
  align-items: stretch;
  flex: 1;
  gap: 0;
}

.card-img {
  width: 120px;
  min-width: 120px;
  aspect-ratio: 1 / 1;
  overflow: hidden;
  flex-shrink: 0;
  align-self: center;
  margin: 1rem 1rem 1rem 0;
  border-radius: 4px;
}

.card-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  filter: grayscale(40%) brightness(0.9);
  transition: filter 0.3s ease;
}

.project-card:hover .card-img img {
  filter: grayscale(0%) brightness(1);
}

.card-meta { display: flex; justify-content: space-between; align-items: center; margin-bottom: .9rem; }
.card-cat-badge {
  font-family: var(--mono); padding: .18rem .65rem; border-radius: 2px;
  font-size: .59rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase;
  border: 1px solid var(--cc, var(--yellow)); color: var(--cc, var(--yellow)); background: transparent;
}
.card-num { font-family: var(--mono); font-size: .72rem; color: #2a2a2a; letter-spacing: .1em; }
.card-title {
  font-family: 'Fraunces', serif; font-size: 1.06rem; font-weight: 600;
  line-height: 1.35; margin-bottom: .5rem; color: var(--white); transition: color .2s;
}
.project-card:hover .card-title { color: var(--cc, var(--yellow)); }
.card-desc { font-size: .77rem; color: #555; line-height: 1.72; margin-bottom: 1rem; }
.card-footer { padding-top: .85rem; border-top: 1px solid rgba(255,255,255,0.05); }
.card-link {
  display: inline-flex; align-items: center; gap: .42rem;
  font-family: var(--mono); font-size: .66rem; font-weight: 700;
  letter-spacing: .07em; text-transform: uppercase; color: #444; text-decoration: none;
  transition: gap .25s var(--ease), color .2s;
}
.card-link:hover { gap: .85rem; color: var(--cc, var(--yellow)); }
.card-link svg { transition: transform .25s var(--ease); }
.card-link:hover svg { transform: rotate(-45deg); }
@keyframes cardIn { from{opacity:0;transform:translateY(12px)} to{opacity:1;transform:translateY(0)} }
.project-card.fade-in { animation: cardIn .4s var(--ease) forwards; }

/* ════════════════════════════════════════
   CAROUSEL HINT
════════════════════════════════════════ */
.carousel-hint {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 1rem;
  margin-top: 2rem;
  opacity: 0.6;
  transition: opacity 0.3s var(--ease);
}
.carousel-hint:hover { opacity: 1; }
.hint-text {
  font-family: var(--mono);
  font-size: 0.7rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #555;
}
.hint-arrows { display: flex; gap: 0.3rem; align-items: center; }
.arrow { font-size: 0.8rem; color: #444; transition: all 0.6s var(--ease); display: inline-block; }
.arrow-left  { animation: slideLeftHint 1.5s ease-in-out infinite; }
.arrow-right { animation: slideRightHint 1.5s ease-in-out infinite; }
@keyframes slideLeftHint  { 0%,100%{transform:translateX(0);opacity:.4} 50%{transform:translateX(-4px);opacity:1} }
@keyframes slideRightHint { 0%,100%{transform:translateX(0);opacity:.4} 50%{transform:translateX(4px);opacity:1} }

/* ════════════════════════════════════════
   CONTACT — WHITE background
   FIX: two columns aligned at the top
════════════════════════════════════════ */
.contact-section {
  background: #ffffff;
  padding: 5rem;
  border-top: 1px solid rgba(0,0,0,0.05);
  border-bottom: 1px solid rgba(0,0,0,0.05);
}

.contact-header {
  padding: 0 0 3rem 0;
}

.contact-eyebrow {
  font-family: var(--mono);
  font-size: 0.67rem;
  font-weight: 700;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: #bbb;
  display: flex;
  align-items: center;
  gap: 0.7rem;
  margin-bottom: 0.5rem;
}
.contact-eyebrow::before {
  content: '';
  width: 1.4rem;
  height: 1px;
  background: #bbb;
  display: block;
}

.contact-title {
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(2.2rem, 4.5vw, 3.5rem);
  letter-spacing: 0.03em;
  color: var(--black);
}

/* Two-column grid — BOTH columns start at the top */
.contact-container {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4rem;
  align-items: start;   /* alinha tudo no topo */
}

.contact-inner {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  height: 100%;
}

.contact-email-label {
  font-family: var(--mono);
  font-size: 0.67rem;
  font-weight: 700;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: #999;
  margin-bottom: 0.8rem;
  display: block;
}

.contact-email-link {
  font-family: 'Fraunces', serif;
  font-size: clamp(0.95rem, 1.2vw, 1.1rem);
  font-weight: 600;
  color: var(--black);
  text-decoration: none;
  transition: color 0.3s var(--ease);
  border-bottom: 5px solid var(--yellow);
  padding-bottom: 0.2rem;
  display: inline-block;
  margin-bottom: 2rem;
}
.contact-email-link:hover { color: #555; }

.contact-location-time {
  font-family: var(--mono);
  font-size: 0.75rem;
  letter-spacing: 0.05em;
  color: #999;
  margin-top: 1rem;
}

/* Right column text — vertically starts at top, same as email */
.contact-message-section {
  padding-top: 0;   /* no extra push downward */
}

.contact-text {
  font-family: 'Fraunces', serif;
  font-size: clamp(0.95rem, 1.2vw, 1.1rem);
  font-weight: 300;
  text-align: justify;
  color: #666;
  line-height: 1.9;
}

/* ════════════════════════════════════════
   FOOTER — redesigned
   Phrase + social links (white, bold, bigger)
════════════════════════════════════════ */
footer {
  background: var(--black);
  padding: 3.5rem 5rem;
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 1.8rem;
  border-top: 1px solid rgba(255,255,255,0.06);
}

/* Left: tagline phrase */
.footer-tagline {
  font-family: 'Fraunces', serif;
  text-align: justify;
  font-weight: 400;
  font-size: clamp(1rem, 1.4vw, 1.2rem);
  color: #ffffff;
  max-width: 380px;
  line-height: 1.5;
}
.footer-tagline em {
  font-style: normal;
  color: var(--yellow);
}

/* Right: social links */
.footer-links {
  display: flex;
  gap: 2rem;
  list-style: none;
  flex-wrap: wrap;
}
.footer-links a {
  font-family: var(--mono);
  font-size: .82rem;        /* bigger than before */
  font-weight: 700;         /* bold */
  letter-spacing: .08em;
  text-transform: uppercase;
  color: #ffffff;           /* white */
  text-decoration: none;
  position: relative;
  transition: color .2s;
}
.footer-links a::after {
  content: '';
  position: absolute; bottom: -3px; left: 0; right: 0;
  height: 3px; background: var(--yellow);
  transform: scaleX(0); transform-origin: left;
  transition: transform .3s var(--ease);
}
.footer-links a:hover { color: var(--yellow); }
.footer-links a:hover::after { transform: scaleX(1); }

.footer-copy {
  width: 100%;
  font-family: var(--mono);
  font-size: .6rem;
  color: #8b8989;
  text-align: right;
}

/* ════════════════════════════════════════
   SCROLL REVEAL
════════════════════════════════════════ */
.reveal { opacity:0; transform:translateY(24px); transition:opacity .7s var(--ease),transform .7s var(--ease); }
.reveal.in { opacity:1; transform:translateY(0); }
.reveal-l { opacity:0; transform:translateX(-26px); transition:opacity .7s var(--ease),transform .7s var(--ease); }
.reveal-l.in { opacity:1; transform:translateX(0); }
.reveal-r { opacity:0; transform:translateX(26px); transition:opacity .7s var(--ease),transform .7s var(--ease); }
.reveal-r.in { opacity:1; transform:translateX(0); }
@keyframes fadeUp { from{opacity:0;transform:translateY(20px)} to{opacity:1;transform:translateY(0)} }

/* ════════════════════════════════════════
   RESPONSIVE
════════════════════════════════════════ */
@media (max-width: 900px) {
  nav { padding: 0 1.5rem; }
  .nav-toggle { display: flex; }
  .nav-links {
    display: none; position: fixed;
    inset: var(--nav-h) 0 0 0;
    background: #fff; flex-direction: column;
    align-items: center; justify-content: center; gap: 2.5rem; z-index: 199;
  }
  .nav-links.open { display: flex; }
  .nav-links a { font-size: 1rem; color: #111; }

  .hero {
    grid-template-columns: 1fr; min-height: auto;
    padding: calc(var(--nav-h) + 3rem) 2rem 4rem; gap: 3rem;
  }
  .hero-left { align-items: center; }
  .photo-frame { max-width: 280px; width: 100%; margin: 0 auto; }
  .hero-right { align-items: center; text-align: center; }
  .hero-name { font-size: clamp(4rem,14vw,7rem); }
  .hero-tagline { max-width: 100%; }
  .hero-ctas { justify-content: center; }

  .featured-header { padding: 0 2rem 2.5rem; }
  #projects { padding: 3rem 2rem; }
  .contact-section { padding: 3rem 2rem; }
  .contact-container { grid-template-columns: 1fr; gap: 2rem; }
  footer { padding: 2.5rem 2rem; }

  .about-me-section { padding: 3rem 2rem; }
  .about-me-container { grid-template-columns: 1fr; gap: 2rem; }

  .cta-section { padding: 3rem 2rem; }
}

@media (max-width: 560px) {
  .hero { padding: calc(var(--nav-h) + 1.5rem) 1.25rem 3rem; }
  .photo-frame { max-width: 220px; }
  .hero-name { font-size: clamp(3.2rem,18vw,5rem); }
  .portrait-card { width: 240px; }
  .section-header { flex-direction: column; align-items: flex-start; }
  .filter-pills { gap: .3rem; }
  #projects { padding: 3rem 1.25rem; }
  .contact-section { padding: 2rem 1.25rem; }
  footer { padding: 2rem 1.25rem; flex-direction: column; align-items: flex-start; }
  .footer-copy { text-align: left; }

  .about-me-section { padding: 2rem 1.25rem; }
  .cta-section { padding: 2rem 1.25rem; }
  .cta-text { font-size: clamp(1.4rem, 2.5vw, 2rem); }
}
