/* =============== */
/* BASE / TOKENS   */
/* =============== */
:root{
  --bg0:#07080b;
  --bg1:#0b0c10;
  --bg2:#10121a;
  --soft:#f4f4f6;
  --soft2:#efeff3;
  --card:#11131b;
  --card2:#151827;

  --text:#12131a;
  --textInv:#f5f6f8;
  --muted:#6b6f7a;
  --mutedInv:rgba(245,246,248,.72);

  --line:rgba(255,255,255,.10);
  --line2:rgba(0,0,0,.10);

  --accent:#d9c7a5; /* areia premium */
  --accent2:#bfa57a;

  --shadow: 0 18px 60px rgba(0,0,0,.40);
  --shadowSoft: 0 14px 40px rgba(0,0,0,.16);

  --r:18px;
  --r2:26px;

  --container:1200px;

  --ease: cubic-bezier(.2,.8,.2,1);
  --paper1:#fbfaf8;
  --paper2:#f3f1ee;
  --ink: rgba(18,19,26,.90);
  --ink2: rgba(18,19,26,.72);
}

*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{
  font-family:Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color:var(--text);
  background:#fff;
  line-height:1.55;
}

/* containers */
.container{
  width:min(92%, var(--container));
  margin:0 auto;
}

/* typography */
.h2{
  font-family:"Playfair Display", serif;
  font-weight:700;
  letter-spacing:-.02em;
  font-size: clamp(28px, 3vw, 40px);
  line-height:1.15;
}
.h2--light{color:var(--textInv);}

.lead{
  margin-top:14px;
  font-size: clamp(16px, 1.4vw, 18px);
  color:rgba(18,19,26,.78);
}
.muted{
  color:var(--muted);
  margin-top:10px;
}
.muted--light{color:var(--mutedInv);}

/* buttons */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  text-decoration:none;
  border:1px solid transparent;
  border-radius:999px;
  padding:14px 18px;
  font-weight:600;
  letter-spacing:.01em;
  transition: transform .25s var(--ease), background .25s var(--ease), border-color .25s var(--ease), color .25s var(--ease), box-shadow .25s var(--ease);
  user-select:none;
}
.btn:active{transform:scale(.98);}
.btn--small{padding:10px 14px;font-size:14px;}

.btn--primary{
  background:linear-gradient(180deg, var(--accent), var(--accent2));
  color:#131318;
  box-shadow: 0 14px 40px rgba(217,199,165,.18);
}
.btn--primary:hover{transform:translateY(-1px);}

.btn--ghost{
  background:transparent;
  border-color:rgba(255,255,255,.22);
  color:rgba(255,255,255,.86);
}
.btn--ghost:hover{
  border-color:rgba(255,255,255,.42);
  transform:translateY(-1px);
}

.btn--ghostLight{
  border-color:rgba(255,255,255,.26);
  color:rgba(255,255,255,.92);
}

.btn--outline{
  background:transparent;
  border-color:rgba(0,0,0,.28);
  color:#111;
}
.btn--outline:hover{border-color:rgba(0,0,0,.55);transform:translateY(-1px);}

.btn--outlineLight{
  background:transparent;
  border-color:rgba(255,255,255,.30);
  color:rgba(255,255,255,.92);
}
.btn--outlineLight:hover{
  border-color:rgba(255,255,255,.55);
  background:rgba(255,255,255,.06);
  transform:translateY(-1px);
}

/* =============== */
/* HEADER / NAV    */
/* =============== */
.header{
  position:fixed;
  top:0;left:0;right:0;
  z-index:1000;
  transition: background .25s var(--ease), box-shadow .25s var(--ease), border-color .25s var(--ease), color .25s var(--ease);
  border-bottom:1px solid transparent;
}
.nav{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:16px 0;
}

.logo{
  display:flex;
  align-items:center;
  gap:10px;
  text-decoration:none;
}
.logo__mark{
  width:10px;height:10px;
  border-radius:999px;
  background:linear-gradient(180deg,var(--accent),var(--accent2));
  box-shadow: 0 0 0 6px rgba(217,199,165,.10);
}
.logo__text{
  font-weight:650;
  letter-spacing:.02em;
}

/* top state: transparent over hero */
.header--top{
  background:transparent;
  color:rgba(255,255,255,.92);
}
.header--top .logo__text{color:rgba(255,255,255,.92);}
.header--top .nav-menu a{color:rgba(255,255,255,.80);}
.header--top .btn--outline{border-color:rgba(255,255,255,.28);color:rgba(255,255,255,.92);}

/* scrolled state: white */
.header--scrolled{
  background:rgba(255,255,255,.92);
  backdrop-filter: blur(12px);
  box-shadow: 0 10px 30px rgba(0,0,0,.10);
  border-bottom:1px solid rgba(0,0,0,.06);
  color:#111;
}
.header--scrolled .logo__text{color:#111;}
.header--scrolled .nav-menu a{color:#111;}
.header--scrolled .btn--outline{border-color:rgba(0,0,0,.26);color:#111;}

.nav-menu{
  display:flex;
  gap:22px;
  align-items:center;
}
.nav-menu a{
  text-decoration:none;
  font-weight:600;
  letter-spacing:.01em;
  font-size:14px;
  opacity:.95;
  transition: opacity .2s var(--ease), transform .2s var(--ease);
}
.nav-menu a:hover{opacity:.70;transform:translateY(-1px);}

/* mobile nav */
.nav-toggle{
  display:none;
  width:44px;height:44px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.20);
  background:rgba(255,255,255,.06);
  cursor:pointer;
  align-items:center;
  justify-content:center;
  gap:6px;
}
.header--scrolled .nav-toggle{
  border-color:rgba(0,0,0,.12);
  background:rgba(0,0,0,.03);
}
.nav-toggle span{
  display:block;
  width:18px;height:2px;
  background:currentColor;
  border-radius:2px;
}

/* =============== */
/* HERO            */
/* =============== */
.hero{
  position:relative;
  min-height:100vh;
  display:flex;
  align-items:center;
  overflow:hidden;
  background:var(--bg1);
}
.hero__bg{
  position:absolute; inset:0;
  background:
    url("https://images.unsplash.com/photo-1600585154340-be6161a56a0c?auto=format&fit=crop&w=2200&q=80")
    center/cover no-repeat;
  transform:scale(1.04);
}
.hero__overlay{
  position:absolute; inset:0;
  background:
    radial-gradient(1200px 600px at 65% 35%, rgba(217,199,165,.18), transparent 60%),
    linear-gradient(180deg, rgba(7,8,11,.35), rgba(7,8,11,.86));
}
.hero__grain{
  position:absolute; inset:-40%;
  background-image:
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='260' height='260'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='260' height='260' filter='url(%23n)' opacity='.25'/%3E%3C/svg%3E");
  opacity:.12;
  pointer-events:none;
  mix-blend-mode:overlay;
  transform:rotate(8deg);
}

.hero__content{
  position:relative;
  padding-top:110px; /* espaço do header */
  padding-bottom:72px;
  text-align:center;
  color:var(--textInv);
}
.hero__eyebrow{
  display:inline-block;
  font-size:13px;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:rgba(245,246,248,.78);
  margin-bottom:14px;
}
.hero__title{
  font-family:"Playfair Display", serif;
  font-weight:700;
  letter-spacing:-.03em;
  font-size: clamp(38px, 5vw, 64px);
  line-height:1.05;
  max-width: 980px;
  margin:0 auto;
}
.accent{color:var(--accent);}

.hero__subtitle{
  margin:16px auto 0;
  max-width: 720px;
  font-size: clamp(16px, 1.6vw, 20px);
  color:rgba(245,246,248,.78);
}

.hero__actions{
  margin-top:26px;
  display:flex;
  gap:12px;
  justify-content:center;
  flex-wrap:wrap;
}

.hero__stats{
  margin-top:34px;
  display:flex;
  justify-content:center;
  gap:22px;
  flex-wrap:wrap;
}
.stat{
  padding:14px 18px;
  border:1px solid rgba(255,255,255,.16);
  background:rgba(255,255,255,.06);
  border-radius:16px;
  backdrop-filter: blur(10px);
}
.stat__num{
  font-weight:800;
  font-size:18px;
  letter-spacing:.01em;
}
.stat__label{
  font-size:13px;
  color:rgba(245,246,248,.72);
  margin-top:4px;
}

.hero__scroll{
  margin:40px auto 0;
  display:inline-flex;
  align-items:center;
  gap:10px;
  text-decoration:none;
  color:rgba(245,246,248,.70);
  font-weight:600;
  font-size:13px;
  letter-spacing:.08em;
  text-transform:uppercase;
  opacity:.9;
}
.hero__scrollDot{
  width:24px;height:38px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.22);
  position:relative;
}
.hero__scrollDot::after{
  content:"";
  width:6px;height:6px;
  border-radius:99px;
  background:var(--accent);
  position:absolute;
  left:50%;
  top:8px;
  transform:translateX(-50%);
  animation: dot 1.5s infinite var(--ease);
}
@keyframes dot{
  0%{transform:translate(-50%,0);opacity:1;}
  65%{transform:translate(-50%,16px);opacity:.55;}
  100%{transform:translate(-50%,0);opacity:1;}
}

/* =============== */
/* SECTIONS        */
/* =============== */
.section{
  padding: 96px 0;
  position:relative;
}
.section--soft{
  background:
    radial-gradient(1200px 600px at 15% 20%, rgba(217,199,165,.16), transparent 55%),
    linear-gradient(180deg, #ffffff, #f6f6f9);
}
.section--dark{
  background:
    radial-gradient(900px 500px at 70% 10%, rgba(217,199,165,.10), transparent 55%),
    linear-gradient(180deg, var(--bg0), var(--bg2));
  color:var(--textInv);
}

/* split manifesto */
.split{
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap: 44px;
  align-items:start;
}
.pillRow{
  margin-top:18px;
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}
.pill{
  padding:10px 12px;
  border-radius:999px;
  background:rgba(0,0,0,.05);
  border:1px solid rgba(0,0,0,.08);
  font-weight:650;
  font-size:13px;
}

.quoteCard{
  border-radius: var(--r2);
  background: linear-gradient(180deg, #ffffff, #f4f4f7);
  border:1px solid rgba(0,0,0,.08);
  box-shadow: var(--shadowSoft);
  padding: 22px;
  position:relative;
  overflow:hidden;
}
.quoteMark{
  position:absolute;
  top:-10px; left:16px;
  font-family:"Playfair Display", serif;
  font-size:82px;
  color:rgba(0,0,0,.06);
}
.quoteText{font-size:16px; color:rgba(18,19,26,.80); margin-top:18px;}
.quoteMeta{
  margin-top:12px;
  display:flex;
  align-items:center;
  gap:10px;
  color:rgba(18,19,26,.62);
  font-weight:600;
  font-size:13px;
}
.dot{
  width:8px;height:8px;border-radius:99px;
  background:linear-gradient(180deg,var(--accent),var(--accent2));
}

.microGrid{
  margin-top:16px;
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:12px;
}
.microCard{
  border-radius: 18px;
  background: rgba(255,255,255,.70);
  border: 1px solid rgba(0,0,0,.06);
  padding: 16px;
}
.microCard__title{font-weight:800; font-size:13px; letter-spacing:.02em;}
.microCard__text{margin-top:6px; font-size:13px; color:rgba(18,19,26,.70);}

/* section head */
.sectionHead{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:18px;
  flex-wrap:wrap;
}
.chips{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}
.chip{
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.14);
  color:rgba(255,255,255,.84);
  padding:10px 14px;
  border-radius:999px;
  font-weight:700;
  font-size:13px;
  cursor:pointer;
  transition: background .2s var(--ease), border-color .2s var(--ease), transform .2s var(--ease);
}
.chip:hover{transform:translateY(-1px); border-color:rgba(255,255,255,.30);}
.chip.is-active{
  background:linear-gradient(180deg, rgba(217,199,165,.22), rgba(217,199,165,.10));
  border-color:rgba(217,199,165,.45);
  color:rgba(255,255,255,.92);
}

/* projects grid */
.projectsGrid{
  margin-top:34px;
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap:18px;
}
.projectCard{
  border-radius: var(--r2);
  overflow:hidden;
  background: rgba(255,255,255,.02);
  border:1px solid rgba(255,255,255,.10);
  box-shadow: 0 18px 50px rgba(0,0,0,.28);
  transform: translateZ(0);
}
.projectCard__media{
  position:relative;
  height: 420px;
}
.projectCard img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  transform: scale(1.02);
  transition: transform .7s var(--ease);
  filter:saturate(1.05) contrast(1.02);
}
.projectCard__shade{
  position:absolute; inset:0;
  background: linear-gradient(180deg, rgba(0,0,0,.00), rgba(0,0,0,.70));
  opacity:.82;
  transition: opacity .35s var(--ease);
}
.projectCard__hover{
  position:absolute; inset:0;
  padding: 22px;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  transform: translateY(16px);
  opacity:0;
  transition: opacity .35s var(--ease), transform .35s var(--ease);
}
.projectCard__kicker{
  font-size:12px;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:rgba(255,255,255,.78);
}
.projectCard__title{
  margin-top:10px;
  font-family:"Playfair Display", serif;
  font-size:28px;
  letter-spacing:-.02em;
}
.projectCard__desc{
  margin-top:10px;
  color:rgba(255,255,255,.78);
  font-size:14px;
  max-width: 92%;
}
.projectCard__meta{
  margin-top:14px;
  display:flex;
  gap:14px;
  flex-wrap:wrap;
  color:rgba(255,255,255,.68);
  font-size:12px;
}
.projectCard:hover img{transform:scale(1.08);}
.projectCard:hover .projectCard__shade{opacity:.92;}
.projectCard:hover .projectCard__hover{opacity:1;transform:translateY(0);}

.sectionFoot{
  margin-top:22px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  flex-wrap:wrap;
}
.note{
  display:flex;
  align-items:center;
  gap:10px;
  color:rgba(255,255,255,.70);
  font-weight:600;
  font-size:13px;
}
.note__dot{
  width:8px;height:8px;border-radius:99px;
  background:linear-gradient(180deg,var(--accent),var(--accent2));
}

/* =============== */
/* METHOD          */
/* =============== */
.methodWrap{
  display:grid;
  gap:24px;
}
.timeline{
  margin-top:10px;
  display:grid;
  gap:14px;
}
.timeItem{
  display:grid;
  grid-template-columns: 74px 1fr;
  gap:16px;
  padding:18px;
  border-radius: var(--r2);
  background: rgba(255,255,255,.72);
  border:1px solid rgba(0,0,0,.07);
  box-shadow: var(--shadowSoft);
  position:relative;
  overflow:hidden;
}
.timeItem::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(600px 240px at 10% 20%, rgba(217,199,165,.18), transparent 55%);
  opacity:.8;
  pointer-events:none;
}
.timeNo{
  font-weight:900;
  font-size:22px;
  letter-spacing:.03em;
  color:rgba(18,19,26,.86);
  display:flex;
  align-items:flex-start;
  justify-content:center;
  padding-top:6px;
}
.timeBody h3{
  font-size:18px;
  font-weight:850;
  letter-spacing:-.01em;
  position:relative;
}
.timeBody p{
  margin-top:8px;
  color:rgba(18,19,26,.72);
  font-size:14px;
  position:relative;
}
.timeTags{
  margin-top:12px;
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  position:relative;
}
.timeTags span{
  padding:8px 10px;
  border-radius:999px;
  background:rgba(0,0,0,.05);
  border:1px solid rgba(0,0,0,.08);
  font-weight:700;
  font-size:12px;
  color:rgba(18,19,26,.76);
}

.methodCTA{
  margin-top:14px;
}
.methodCTA__box{
  border-radius: var(--r2);
  padding:22px;
  background: linear-gradient(180deg, var(--bg1), var(--bg2));
  border:1px solid rgba(255,255,255,.12);
  box-shadow: var(--shadow);
  color:var(--textInv);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  flex-wrap:wrap;
}
.methodCTA__title{
  font-family:"Playfair Display", serif;
  font-size:22px;
  letter-spacing:-.02em;
}
.methodCTA__text{
  color:rgba(245,246,248,.72);
  font-weight:600;
  font-size:14px;
  max-width: 520px;
}

/* =============== */
/* ABOUT           */
/* =============== */
.aboutGrid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 28px;
  align-items:center;
}
.aboutMedia{
  position:relative;
  min-height: 520px;
  border-radius: var(--r2);
  overflow:hidden;
  border:1px solid rgba(255,255,255,.10);
  box-shadow: 0 24px 80px rgba(0,0,0,.42);
}
.aboutMedia__img{
  position:absolute; inset:0;
  background:
    url("https://images.unsplash.com/photo-1496307653780-42ee777d4833?auto=format&fit=crop&w=1600&q=80")
    center/cover no-repeat;
  transform:scale(1.03);
}
.aboutMedia__panel{
  position:absolute;
  left:18px; right:18px; bottom:18px;
  padding:18px;
  border-radius: 20px;
  background: rgba(8,10,12,.62);
  border:1px solid rgba(255,255,255,.14);
  backdrop-filter: blur(14px);
}
.aboutMedia__kicker{
  font-size:12px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:rgba(255,255,255,.72);
}
.aboutMedia__headline{
  margin-top:10px;
  font-family:"Playfair Display", serif;
  font-size:26px;
  letter-spacing:-.02em;
}
.aboutMedia__line{
  margin-top:12px;
  height:1px;
  background: rgba(255,255,255,.16);
}
.aboutMedia__meta{
  margin-top:12px;
  display:flex;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
  color:rgba(255,255,255,.70);
  font-weight:600;
  font-size:13px;
}
.aboutText p{margin-top:12px;}

.aboutBullets{
  margin-top:18px;
  display:grid;
  gap:12px;
}
.bullet{
  padding:14px 16px;
  border-radius: 18px;
  background: rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.10);
}
.bullet__title{font-weight:850; letter-spacing:.01em;}
.bullet__text{margin-top:6px;color:rgba(245,246,248,.72);font-size:14px;}

/* =============== */
/* CTA BAND        */
/* =============== */
.ctaBand{
  background:
    radial-gradient(900px 300px at 20% 30%, rgba(217,199,165,.16), transparent 60%),
    linear-gradient(180deg, #07080b, #0f121a);
  color:var(--textInv);
  padding: 72px 0;
}
.ctaBand__inner{
  border-radius: var(--r2);
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
  backdrop-filter: blur(12px);
  padding: 26px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  flex-wrap:wrap;
}
.ctaBand__title{
  font-family:"Playfair Display", serif;
  font-size: clamp(24px, 2.6vw, 34px);
  letter-spacing:-.02em;
}
.ctaBand__text{
  margin-top:8px;
  color:rgba(245,246,248,.72);
  font-weight:600;
  max-width: 620px;
}
.ctaBand__actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}

/* =============== */
/* CONTACT         */
/* =============== */
.contactGrid{
  display:grid;
  grid-template-columns: .9fr 1.1fr;
  gap: 28px;
  align-items:start;
}
.contactInfo{margin-top:18px; display:grid; gap:12px;}
.infoRow{
  display:flex;
  gap:12px;
  align-items:flex-start;
  padding:14px 16px;
  border-radius: 18px;
  background: rgba(255,255,255,.72);
  border:1px solid rgba(0,0,0,.07);
  box-shadow: var(--shadowSoft);
}
.infoDot{
  width:10px;height:10px;border-radius:99px;
  margin-top:6px;
  background:linear-gradient(180deg,var(--accent),var(--accent2));
  box-shadow:0 0 0 6px rgba(217,199,165,.12);
}
.infoLabel{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:rgba(18,19,26,.58);font-weight:800;}
.infoValue{margin-top:6px;font-weight:750;color:rgba(18,19,26,.86);}

.miniNote{
  margin-top:10px;
  display:flex;
  align-items:center;
  gap:10px;
  color:rgba(18,19,26,.62);
  font-weight:650;
}
.miniNote__dot{width:8px;height:8px;border-radius:99px;background:rgba(0,0,0,.18);}

.formCard{
  border-radius: var(--r2);
  padding: 22px;
  background: linear-gradient(180deg, #ffffff, #f4f4f7);
  border:1px solid rgba(0,0,0,.08);
  box-shadow: var(--shadowSoft);
}
.formRow{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:12px;
  margin-bottom:12px;
}

.field{
  position:relative;
  display:flex;
  flex-direction:column;
}
.field--full{margin-bottom:12px;}

.field input,
.field textarea{
  width:100%;
  border-radius: 16px;
  border:1px solid rgba(0,0,0,.12);
  background: rgba(255,255,255,.92);
  padding: 16px 14px 14px;
  font: inherit;
  outline:none;
  transition: border-color .2s var(--ease), box-shadow .2s var(--ease), transform .2s var(--ease);
}
.field textarea{resize:vertical; min-height:120px;}
.field input:focus,
.field textarea:focus{
  border-color: rgba(191,165,122,.70);
  box-shadow: 0 0 0 6px rgba(217,199,165,.20);
}

.field label{
  position:absolute;
  left:14px;
  top:14px;
  font-weight:700;
  font-size:14px;
  color:rgba(18,19,26,.55);
  pointer-events:none;
  transition: transform .2s var(--ease), top .2s var(--ease), font-size .2s var(--ease), opacity .2s var(--ease);
}
.field input:focus + label,
.field input:not(:placeholder-shown) + label,
.field textarea:focus + label,
.field textarea:not(:placeholder-shown) + label{
  top:8px;
  font-size:12px;
  opacity:.9;
}
.labelStatic{
  position:static !important;
  margin-top:0 !important;
  transform:none !important;
  font-size:12px !important;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:rgba(18,19,26,.58);
  margin-bottom:8px;
}

.field select{
  width:100%;
  border-radius: 16px;
  border:1px solid rgba(0,0,0,.12);
  background: rgba(255,255,255,.92);
  padding: 14px;
  font: inherit;
  outline:none;
}

.formActions{
  margin-top:14px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  flex-wrap:wrap;
}
.formHint{
  color:rgba(18,19,26,.55);
  font-size:12px;
  font-weight:650;
  max-width: 380px;
}
.formSuccess{
  margin-top:12px;
  font-weight:800;
  color:rgba(18,19,26,.78);
}

/* =============== */
/* FOOTER          */
/* =============== */
.footer{
  background: linear-gradient(180deg, #0b0c10, #06070a);
  color:var(--textInv);
  padding: 70px 0 26px;
  border-top: 1px solid rgba(255,255,255,.10);
}
.footerTop{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap: 24px;
  flex-wrap:wrap;
}
.footerBrand{max-width: 420px;}
.footerLogo{display:flex;align-items:center;gap:10px;}
.footerDesc{margin-top:12px;color:rgba(245,246,248,.72);font-weight:600;}

.footerCols{
  display:grid;
  grid-template-columns: 160px 220px 220px;
  gap: 22px;
}
.footerCol{display:grid;gap:10px;}
.footerTitle{
  font-size:12px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:rgba(245,246,248,.70);
  font-weight:850;
}
.footerCol a{
  color:rgba(245,246,248,.82);
  text-decoration:none;
  font-weight:650;
  transition: opacity .2s var(--ease);
}
.footerCol a:hover{opacity:.70;}
.footerCol span{color:rgba(245,246,248,.78);font-weight:650;}
.socialRow{display:flex;gap:12px;flex-wrap:wrap;}

.footerBottom{
  margin-top:34px;
  padding-top:18px;
  border-top:1px solid rgba(255,255,255,.10);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
  color:rgba(245,246,248,.62);
  font-weight:650;
  font-size:13px;
}
.footerFine{opacity:.85;}

/* =============== */
/* REVEAL ANIMS    */
/* =============== */
.reveal{
  opacity:0;
  transform: translateY(14px);
  transition: opacity .8s var(--ease), transform .8s var(--ease);
}
.reveal.is-in{
  opacity:1;
  transform: translateY(0);
}

/* =============== */
/* RESPONSIVE      */
/* =============== */
@media (max-width: 980px){
  .split{grid-template-columns:1fr; gap:20px;}
  .projectsGrid{grid-template-columns:1fr; }
  .projectCard__media{height: 360px;}
  .aboutGrid{grid-template-columns:1fr;}
  .contactGrid{grid-template-columns:1fr;}
  .footerCols{grid-template-columns:1fr 1fr; }
}

@media (max-width: 720px){
  .nav-toggle{display:flex;}
  .nav-menu{
    position:fixed;
    top:74px;
    left:14px; right:14px;
    display:none;
    flex-direction:column;
    gap:10px;
    padding:16px;
    border-radius: 18px;
    background:rgba(255,255,255,.92);
    border:1px solid rgba(0,0,0,.08);
    box-shadow: 0 16px 50px rgba(0,0,0,.18);
  }
  .header--top .nav-menu{background:rgba(10,12,16,.92); border-color:rgba(255,255,255,.12);}
  .nav-menu a{padding:10px 10px;}
  .nav-menu.is-open{display:flex;}

  .formRow{grid-template-columns:1fr;}
  .footerCols{grid-template-columns:1fr;}
}

.section--soft{
  background:
    radial-gradient(1100px 520px at 18% 18%, rgba(217,199,165,.22), transparent 58%),
    radial-gradient(900px 420px at 78% 22%, rgba(11,12,16,.05), transparent 55%),
    linear-gradient(180deg, var(--paper1), var(--paper2));
  position:relative;
  overflow:hidden;
}

/* textura/ruído muito sutil (premium sem “sujo”) */
.section--soft::after{
  content:"";
  position:absolute;
  inset:-30%;
  pointer-events:none;
  opacity:.08;
  mix-blend-mode:multiply;
  background-image:
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='260' height='260'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='260' height='260' filter='url(%23n)' opacity='.28'/%3E%3C/svg%3E");
}

/* divisores topo/rodapé (cara de editorial) */
.section--soft::before{
  content:"";
  position:absolute;
  left:0; right:0; top:0;
  height:1px;
  background: linear-gradient(90deg, transparent, rgba(0,0,0,.10), transparent);
}
.section--soft .container{
  position:relative; /* acima da textura */
}

/* ===================
   MANIFESTO (split)
   =================== */

.split{
  gap: 54px;
  align-items:center;
}

/* título com “underline” dourado discreto */
.split__left .h2{
  position:relative;
  color: var(--ink);
}
.split__left .h2::after{
  content:"";
  display:block;
  width: 84px;
  height: 3px;
  margin-top: 14px;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--accent), rgba(217,199,165,.20));
}

/* texto um pouco mais “ink” */
.split__left .lead{
  color: var(--ink2);
}

/* pills mais sofisticadas (glass + micro-shadow) */
.pill{
  background: rgba(255,255,255,.55);
  border: 1px solid rgba(0,0,0,.08);
  box-shadow: 0 10px 26px rgba(0,0,0,.06);
  backdrop-filter: blur(10px);
  transition: transform .25s var(--ease), border-color .25s var(--ease), box-shadow .25s var(--ease);
}
.pill:hover{
  transform: translateY(-1px);
  border-color: rgba(191,165,122,.45);
  box-shadow: 0 16px 34px rgba(0,0,0,.10);
}

/* quote card com detalhe “premium” */
.quoteCard{
  background:
    radial-gradient(700px 220px at 18% 18%, rgba(217,199,165,.22), transparent 60%),
    linear-gradient(180deg, rgba(255,255,255,.92), rgba(244,244,247,.92));
  border: 1px solid rgba(0,0,0,.10);
  box-shadow: 0 18px 60px rgba(0,0,0,.10);
}
.quoteCard::before{
  content:"";
  position:absolute;
  left: 18px; right: 18px; top: 16px;
  height: 1px;
  background: linear-gradient(90deg, rgba(217,199,165,.65), transparent);
  opacity:.9;
}
.quoteText{ color: rgba(18,19,26,.82); }

/* microCards com hover e mais “recorte” */
.microCard{
  background: rgba(255,255,255,.62);
  border: 1px solid rgba(0,0,0,.08);
  box-shadow: 0 12px 34px rgba(0,0,0,.07);
  transition: transform .25s var(--ease), box-shadow .25s var(--ease), border-color .25s var(--ease);
  position:relative;
  overflow:hidden;
}
.microCard::before{
  content:"";
  position:absolute;
  inset:0;
  background: radial-gradient(420px 180px at 20% 20%, rgba(217,199,165,.18), transparent 60%);
  opacity:.7;
  pointer-events:none;
}
.microCard:hover{
  transform: translateY(-2px);
  border-color: rgba(191,165,122,.38);
  box-shadow: 0 18px 44px rgba(0,0,0,.12);
}
.microCard__title{ position:relative; }
.microCard__text{ position:relative; }

/* ===================
   MÉTODO (timeline)
   =================== */

/* cria a “linha” vertical */
.timeline{ position:relative; }
.timeline::before{ z-index:0; }
/* cards mais “glass” e com hover */
.timeItem{
  position:relative;
  z-index:1;
  background: linear-gradient(180deg, #ffffff, #f4f4f7); /* mais sólido */
}
.timeItem::after{
  content:none !important;
}

.timeItem::before{
  z-index:0;
}
.timeNo,
.timeBody,
.timeTags{
  position:relative;
  z-index:1;
}
/* número vira “badge” premium */
.timeNo{
  width: 44px;
  height: 44px;
  border-radius: 14px;
  margin: 2px auto 0;
  display:flex;
  align-items:center;
  justify-content:center;
  background: linear-gradient(180deg, rgba(217,199,165,.88), rgba(191,165,122,.78));
  color:#141418;
  box-shadow: 0 14px 34px rgba(217,199,165,.22);
  font-size: 16px;
  font-weight: 950;
}

/* pontinho na linha conectando o badge */
.timeItem{
  position:relative;
}
.timeItem::after{
  content:"";
  position:absolute;
  left: 30px;
  top: 28px;
  width: 10px;
  height: 10px;
  border-radius: 99px;
  background: linear-gradient(180deg, var(--accent), var(--accent2));
  box-shadow: 0 0 0 6px rgba(217,199,165,.12);
}

/* tags um pouco mais “chiques” */
.timeTags span{
  background: rgba(255,255,255,.55);
  border:1px solid rgba(0,0,0,.08);
}

/* Texto mais “ink” */
.timeBody p{ color: rgba(18,19,26,.74); }

/* responsivo: evita a linha ficar estranha */
@media (max-width: 720px){
  .timeline::before{ left: 22px; }
  .timeItem::after{ left: 18px; }
  .timeItem{ grid-template-columns: 64px 1fr; }
  .timeNo{ width: 40px; height: 40px; border-radius: 13px; }
}

/* ==============================
   BACKGROUND ATMOSFÉRICO PREMIUM
   Manifesto + Método
============================== */

/* garante referência */
#manifesto .container,
#metodo .container{
  position:relative;
  z-index:1;
}

/* esfera suave atrás do conteúdo */
#manifesto .container::before,
#metodo .container::before{
  content:"";
  position:absolute;

  /* posição da "bola" */
  top:-120px;
  left:-140px;

  width:700px;
  height:700px;

  pointer-events:none;
  z-index:-1;

  /* COR PREMIUM (areia / rosé / champagne) */
  background:
    radial-gradient(
      circle at center,
      rgba(217,199,165,0.28) 0%,
      rgba(217,199,165,0.16) 30%,
      rgba(217,199,165,0.08) 55%,
      rgba(255,255,255,0) 75%
    );

  filter: blur(60px);
}

/* segunda mancha MUITO sutil do outro lado */
#manifesto .container::after,
#metodo .container::after{
  content:"";
  position:absolute;

  bottom:-180px;
  right:-160px;

  width:600px;
  height:600px;

  pointer-events:none;
  z-index:-1;

  background:
    radial-gradient(
      circle at center,
      rgba(191,165,122,0.18),
      rgba(255,255,255,0) 70%
    );

  filter: blur(70px);
}

#manifesto .container::before,
#metodo .container::before{
  width: 620px;
  height: 620px;
  top: -160px;
  left: -180px;
  filter: blur(70px);
  opacity: .85;
}

/* segunda mancha ainda mais sutil */
#manifesto .container::after,
#metodo .container::after{
  width: 520px;
  height: 520px;
  bottom: -220px;
  right: -210px;
  filter: blur(85px);
  opacity: .55;
}

.aboutText .btn{
  margin-top: 22px;
}