/* ============================================================
   DESIGN TOKENS
   ============================================================ */
:root{
  --bg-primary:#EAEAE5;
  --surface-primary:#F5F4EF;
  --surface-white:#FFFFFF;
  --text-primary:#1C1C1C;
  --text-secondary:#66645E;
  --border-default:#D2D0C8;
  --accent-primary:#2E1437;
  --accent-soft:#CAD1C3;
  --footer-bg:#1C1C1C;
  --footer-text:#F5F4EF;

  --font-display:"Inter Tight",sans-serif;
  --font-body:"Inter",sans-serif;
  --font-mono:"IBM Plex Mono",monospace;

  --container:1400px;
  --pad-x:clamp(20px,5vw,48px);

  --ease:cubic-bezier(.22,.61,.36,1);
}

/* ============================================================
   RESET
   ============================================================ */
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{
  font-family:var(--font-body);
  background:var(--bg-primary);
  color:var(--text-primary);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none;}
img{max-width:100%;display:block;}
button{font-family:inherit;cursor:pointer;border:none;background:none;}
ul{list-style:none;}

::selection{background:var(--accent-primary);color:#fff;}

/* Focus visibility */
a:focus-visible,button:focus-visible{
  outline:2px solid var(--accent-primary);
  outline-offset:3px;
  border-radius:1px;
}

/* ============================================================
   PRELOADER
   ============================================================ */
#preloader{
  position:fixed;inset:0;z-index:9999;
  background:var(--bg-primary);
  display:flex;align-items:center;justify-content:center;
  flex-direction:column;gap:1.2rem;
}
.preloader-mark{
  font-family:var(--font-mono);
  font-size:.72rem;letter-spacing:.32em;text-transform:uppercase;
  color:var(--text-secondary);
}
.preloader-bar{
  width:min(220px,50vw);height:1px;background:var(--border-default);
  position:relative;overflow:hidden;
}
.preloader-bar span{
  position:absolute;inset:0;width:0%;background:var(--accent-primary);
}

/* ============================================================
   LAYOUT HELPERS
   ============================================================ */
.container{
  max-width:var(--container);
  margin:0 auto;
  padding-inline:var(--pad-x);
}
.edge-borders{
  position:fixed;inset:0;pointer-events:none;z-index:50;
  max-width:var(--container);margin:0 auto;
}
.edge-borders::before,.edge-borders::after{
  content:"";position:absolute;top:0;bottom:0;width:1px;
  background:var(--border-default);opacity:.55;
}
.edge-borders::before{left:var(--pad-x);}
.edge-borders::after{right:var(--pad-x);}
@media(max-width:760px){.edge-borders{display:none;}}

.eyebrow{
  font-family:var(--font-mono);
  font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--text-secondary);
  display:flex;align-items:center;gap:.6rem;
}
.eyebrow::before{
  content:"";width:7px;height:7px;background:var(--accent-primary);
  display:inline-block;transform:rotate(45deg);flex:none;
}

.section{padding-block:clamp(5rem,11vh,9rem);border-top:1px solid var(--border-default);}

/* Masked reveal lines */
.line-mask{display:block;overflow:hidden;}
.line-mask>span{display:block;will-change:transform;}

/* ============================================================
   HEADER
   ============================================================ */
header{
  position:fixed;top:0;left:0;right:0;z-index:100;
  transition:background .4s var(--ease),border-color .4s var(--ease),backdrop-filter .4s;
  border-bottom:1px solid transparent;
}
header.scrolled{
  background:rgba(234,234,229,.82);
  backdrop-filter:blur(14px) saturate(1.2);
  border-bottom-color:var(--border-default);
}
.nav{
  display:grid;grid-template-columns:1fr auto 1fr;align-items:center;
  height:74px;
}
.nav-left,.nav-right{display:flex;align-items:center;gap:2rem;}
.nav-right{justify-content:flex-end;}
.nav a.nav-link{
  font-family:var(--font-mono);font-size:.74rem;
  letter-spacing:.14em;text-transform:uppercase;color:var(--text-secondary);
  position:relative;transition:color .3s var(--ease);
}
.nav a.nav-link::after{
  content:"";position:absolute;left:0;bottom:-5px;height:1px;width:0;
  background:var(--accent-primary);transition:width .35s var(--ease);
}
.nav a.nav-link:hover{color:var(--text-primary);}
.nav a.nav-link:hover::after{width:100%;}
.signature{
  font-family:var(--font-display);font-weight:600;
  letter-spacing:.04em;font-size:.95rem;white-space:nowrap;
  display:flex;align-items:center;gap:.55rem;justify-content:center;
}
.sig-glyph{
  width:13px;height:13px;border:1.5px solid var(--accent-primary);
  transform:rotate(45deg);position:relative;flex:none;
}
.sig-glyph::after{
  content:"";position:absolute;inset:3px;background:var(--accent-primary);
}
.btn-contact{
  font-family:var(--font-mono);font-size:.74rem;letter-spacing:.12em;
  text-transform:uppercase;padding:.6rem 1.1rem;
  background:var(--accent-primary);color:#fff;
  transition:transform .3s var(--ease),background .3s;
  display:inline-flex;align-items:center;gap:.5rem;
}
.btn-contact:hover{transform:translateY(-2px);}
.btn-contact .dot{width:6px;height:6px;border-radius:50%;background:var(--accent-soft);}

/* mobile menu */
.menu-toggle{display:none;flex-direction:column;gap:5px;width:30px;height:30px;justify-content:center;align-items:flex-end;}
.menu-toggle span{display:block;height:1.5px;width:24px;background:var(--text-primary);transition:transform .35s var(--ease),opacity .25s;}
.menu-toggle.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg);}
.menu-toggle.open span:nth-child(2){opacity:0;}
.menu-toggle.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg);}

.mobile-menu{
  position:fixed;inset:0;z-index:99;background:var(--bg-primary);
  display:flex;flex-direction:column;justify-content:center;gap:1.4rem;
  padding:var(--pad-x);transform:translateY(-100%);
  transition:transform .5s var(--ease);
}
.mobile-menu.open{transform:translateY(0);}
.mobile-menu a{font-family:var(--font-display);font-size:2rem;font-weight:600;letter-spacing:-.02em;}
.mobile-menu a.mm-cta{color:var(--accent-primary);}
.mobile-menu .mm-meta{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--text-secondary);margin-top:1rem;}

@media(max-width:880px){
  .nav-left,.nav-right .nav-link{display:none;}
  .nav-right .btn-contact{display:none;}
  .nav{grid-template-columns:1fr auto;}
  .signature{justify-content:flex-start;}
  .menu-toggle{display:flex;}
  .nav-right{gap:0;}
}

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative;min-height:100svh;display:flex;align-items:flex-end;
  padding-top:74px;padding-bottom:clamp(2rem,5vh,4rem);overflow:hidden;
}
#hero-canvas{
  position:absolute;inset:0;z-index:0;
}
.hero .container{position:relative;z-index:2;width:100%;}
.hero-grid{
  display:grid;grid-template-columns:1fr;gap:2.5rem;align-items:end;
}
@media(min-width:980px){
  .hero-grid{grid-template-columns:1.7fr .9fr;gap:3rem;}
}
.hero-label{margin-bottom:1.8rem;}
.hero-title{
  font-family:var(--font-display);font-weight:600;
  font-size:clamp(2.5rem,7vw,6.4rem);line-height:1.02;
  letter-spacing:-.035em;
}
.hero-title .accent-word{color:var(--accent-primary);font-style:italic;font-weight:500;}
.hero-text{
  margin-top:1.8rem;max-width:38ch;
  font-size:clamp(1rem,1.2vw,1.2rem);color:var(--text-secondary);line-height:1.65;
}
.hero-ctas{display:flex;flex-wrap:wrap;gap:1rem;margin-top:2.2rem;}
.cta-primary{
  background:var(--accent-primary);color:#fff;
  font-family:var(--font-mono);font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;
  padding:1rem 1.6rem;display:inline-flex;align-items:center;gap:.7rem;
  transition:transform .3s var(--ease);
}
.cta-primary:hover{transform:translateY(-3px);}
.cta-primary svg{width:15px;height:15px;}
.cta-secondary{
  font-family:var(--font-mono);font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;
  padding:1rem 1.4rem;border:1px solid var(--border-default);
  display:inline-flex;align-items:center;gap:.7rem;
  transition:border-color .3s,background .3s;
}
.cta-secondary:hover{border-color:var(--text-primary);background:var(--surface-white);}
.cta-secondary .arrow{transition:transform .3s var(--ease);}
.cta-secondary:hover .arrow{transform:translateY(3px);}

/* hero stat column */
.hero-stats{display:flex;flex-direction:column;border-top:1px solid var(--border-default);}
.stat{
  padding:1.3rem 0;border-bottom:1px solid var(--border-default);
  display:flex;flex-direction:column;gap:.3rem;
}
.stat .num{font-family:var(--font-display);font-size:clamp(1.8rem,2.4vw,2.6rem);font-weight:600;letter-spacing:-.02em;line-height:1;}
.stat .lbl{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--text-secondary);}
.stat .num.stack-text{font-size:clamp(1.1rem,1.5vw,1.4rem);}

.scroll-hint{
  position:absolute;left:var(--pad-x);bottom:1.4rem;z-index:3;
  font-family:var(--font-mono);font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--text-secondary);display:flex;align-items:center;gap:.6rem;
}
.scroll-hint .bar{width:36px;height:1px;background:var(--text-secondary);position:relative;overflow:hidden;}
.scroll-hint .bar::after{content:"";position:absolute;inset:0;background:var(--accent-primary);width:40%;animation:scrollbar 2.4s var(--ease) infinite;}
@keyframes scrollbar{0%{transform:translateX(-110%);}100%{transform:translateX(260%);}}
@media(max-width:760px){.scroll-hint{display:none;}}

/* ============================================================
   MARQUEE
   ============================================================ */
.marquee{
  border-top:1px solid var(--border-default);border-bottom:1px solid var(--border-default);
  padding-block:1.4rem;overflow:hidden;white-space:nowrap;background:var(--surface-primary);
}
.marquee-track{display:inline-flex;gap:0;will-change:transform;}
.marquee-track span{
  font-family:var(--font-display);font-weight:500;
  font-size:clamp(1.1rem,1.8vw,1.7rem);letter-spacing:-.01em;
  padding-inline:1.3rem;display:inline-flex;align-items:center;
}
.marquee-track span::after{content:"";width:7px;height:7px;background:var(--accent-primary);margin-left:2.6rem;transform:rotate(45deg);}

/* ============================================================
   MANIFESTO
   ============================================================ */
.manifesto-title{
  font-family:var(--font-display);font-weight:600;
  font-size:clamp(2rem,4.6vw,4.4rem);line-height:1.06;letter-spacing:-.03em;
  max-width:18ch;margin-top:2rem;
}
.manifesto-body{
  display:grid;gap:2rem;margin-top:3rem;
  grid-template-columns:1fr;
}
@media(min-width:900px){.manifesto-body{grid-template-columns:1fr 1fr;gap:4rem;}}
.manifesto-body p{font-size:clamp(1rem,1.2vw,1.18rem);color:var(--text-secondary);line-height:1.7;max-width:52ch;}
.manifesto-highlight{
  font-family:var(--font-display);font-weight:500;color:var(--text-primary);
  font-size:clamp(1.3rem,2vw,1.9rem);line-height:1.3;letter-spacing:-.02em;
  border-left:2px solid var(--accent-primary);padding-left:1.4rem;
}

/* ============================================================
   PROJECTS
   ============================================================ */
.section-head{display:flex;flex-direction:column;gap:1.4rem;margin-bottom:3rem;}
.section-head h2{
  font-family:var(--font-display);font-weight:600;
  font-size:clamp(1.8rem,3.4vw,3.4rem);line-height:1.08;letter-spacing:-.03em;max-width:20ch;
}
.projects-list{border-top:1px solid var(--border-default);}
.project{
  border-bottom:1px solid var(--border-default);
  display:grid;grid-template-columns:1fr;gap:1.5rem;
  padding-block:2.4rem;position:relative;
  transition:background .4s var(--ease);
}
.project::before{
  content:"";position:absolute;inset:0;background:var(--surface-white);
  opacity:0;transition:opacity .4s var(--ease);z-index:-1;
}
.project:hover::before{opacity:1;}
@media(min-width:900px){
  .project{grid-template-columns:1.05fr 1fr;gap:3rem;align-items:center;padding-inline:1.4rem;margin-inline:-1.4rem;}
}
.project-info{display:flex;flex-direction:column;gap:1rem;}
.project-meta{display:flex;align-items:center;gap:1rem;}
.project-num{font-family:var(--font-mono);font-size:.78rem;color:var(--accent-primary);letter-spacing:.1em;}
.project-cat{font-family:var(--font-mono);font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;color:var(--text-secondary);}
.project-title{
  font-family:var(--font-display);font-weight:600;
  font-size:clamp(1.7rem,3vw,2.8rem);letter-spacing:-.025em;line-height:1.05;
  transition:transform .4s var(--ease);
}
.project:hover .project-title{transform:translateX(8px);}
.project-desc{color:var(--text-secondary);font-size:1rem;line-height:1.65;max-width:46ch;}
.project-tags{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.06em;color:var(--text-secondary);}
.project-visual{
  aspect-ratio:4/3;background:var(--surface-primary);
  border:1px solid var(--border-default);position:relative;overflow:hidden;
  display:flex;align-items:center;justify-content:center;
}
@media(min-width:900px){.project-visual{aspect-ratio:16/11;}}
.project-visual .placeholder-grid{
  position:absolute;inset:0;opacity:.5;
  background-image:linear-gradient(var(--border-default) 1px,transparent 1px),linear-gradient(90deg,var(--border-default) 1px,transparent 1px);
  background-size:34px 34px;
  transition:transform .6s var(--ease);
}
.project:hover .project-visual .placeholder-grid{transform:scale(1.06);}
.project-image{
  width:100%;height:100%;object-fit:cover;display:block;
  transition:transform .6s var(--ease);
}
.project:hover .project-image{transform:scale(1.04);}
.project-visual .ph-label{
  position:relative;z-index:2;font-family:var(--font-mono);font-size:.66rem;
  letter-spacing:.16em;text-transform:uppercase;color:var(--text-secondary);
  text-align:center;padding:1rem;
}
.project-visual .ph-label strong{display:block;color:var(--text-primary);font-size:.78rem;margin-bottom:.4rem;letter-spacing:.1em;}

.projects-cta{margin-top:3rem;display:flex;justify-content:flex-start;}

/* ============================================================
   COMPETENCIES
   ============================================================ */
.comp-grid{display:grid;grid-template-columns:1fr;border-top:1px solid var(--border-default);border-left:1px solid var(--border-default);}
@media(min-width:680px){.comp-grid{grid-template-columns:1fr 1fr;}}
@media(min-width:1080px){.comp-grid{grid-template-columns:repeat(4,1fr);}}
.comp{
  padding:2rem 1.6rem;border-right:1px solid var(--border-default);border-bottom:1px solid var(--border-default);
  display:flex;flex-direction:column;gap:1rem;position:relative;overflow:hidden;
  transition:background .4s var(--ease);
}
.comp:hover{background:var(--surface-white);}
.comp .c-num{font-family:var(--font-mono);font-size:.72rem;color:var(--accent-primary);letter-spacing:.1em;}
.comp h3{font-family:var(--font-display);font-weight:600;font-size:1.4rem;letter-spacing:-.02em;}
.comp p{color:var(--text-secondary);font-size:.95rem;line-height:1.6;}
.comp ul{margin-top:.4rem;display:flex;flex-direction:column;gap:.4rem;}
.comp ul li{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.04em;color:var(--text-secondary);display:flex;align-items:center;gap:.55rem;}
.comp ul li::before{content:"";width:5px;height:5px;background:var(--accent-soft);transform:rotate(45deg);flex:none;}

/* ============================================================
   ABOUT
   ============================================================ */
.about-grid{display:grid;grid-template-columns:1fr;gap:2.5rem;}
@media(min-width:900px){.about-grid{grid-template-columns:.85fr 1.15fr;gap:4rem;align-items:start;}}
.about-photo{
  position:relative;aspect-ratio:3/4;background:var(--surface-white);
  border:1px solid var(--border-default);overflow:hidden;
  display:flex;flex-direction:column;padding:clamp(.8rem,1.7vw,1.2rem);
  box-shadow:0 18px 40px rgba(28,28,28,.06);
}
.about-photo-image{
  flex:1;min-height:0;background:var(--surface-primary);
  border:1px solid var(--border-default);overflow:hidden;
  display:flex;align-items:center;justify-content:center;
}
.about-photo-image img{width:100%;height:100%;object-fit:cover;object-position:center top;}
.photo-caption{
  padding:1rem .2rem .15rem;font-family:var(--font-mono);font-size:.66rem;letter-spacing:.12em;
  text-transform:uppercase;color:var(--text-secondary);line-height:1.9;
}
.about-content h2{
  font-family:var(--font-display);font-weight:600;
  font-size:clamp(1.7rem,3vw,2.9rem);letter-spacing:-.03em;line-height:1.08;margin:1.4rem 0 1.8rem;
}
.about-content p{color:var(--text-secondary);font-size:1.02rem;line-height:1.72;margin-bottom:1.2rem;max-width:54ch;}
.about-micro{
  display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--border-default);
  border:1px solid var(--border-default);margin:2rem 0;
}
@media(min-width:560px){.about-micro{grid-template-columns:repeat(4,1fr);}}
.about-micro .m{background:white;padding:1.2rem 1rem;display:flex;flex-direction:column;gap:.4rem;}
.about-micro .m .mh{font-family:var(--font-display);font-weight:600;font-size:1.15rem;letter-spacing:-.01em;color:var(--accent-primary);}
.about-micro .m .mt{font-family:var(--font-mono);font-size:.64rem;letter-spacing:.1em;text-transform:uppercase;color:var(--text-secondary);line-height:1.5;}
.about-link{font-family:var(--font-mono);font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;display:inline-flex;align-items:center;gap:.6rem;border-bottom:1px solid var(--text-primary);padding-bottom:.3rem;transition:gap .3s var(--ease);}
.about-link:hover{gap:1rem;}

/* ============================================================
   STACK (Figma + Lovable + IA)
   ============================================================ */
.stack-flow{
  font-family:var(--font-mono);font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--text-secondary);display:flex;flex-wrap:wrap;gap:.8rem;align-items:center;margin:2rem 0 2.5rem;
}
.stack-flow .step{color:var(--text-primary);}
.stack-flow .sep{color:var(--accent-primary);}
.stack-grid{display:grid;grid-template-columns:1fr;gap:1px;background:var(--border-default);border:1px solid var(--border-default);}
@media(min-width:820px){.stack-grid{grid-template-columns:repeat(3,1fr);}}
.stack-card{
  background:var(--bg-primary);padding:2.2rem 1.8rem;display:flex;flex-direction:column;gap:1rem;
  position:relative;transition:background .4s var(--ease);min-height:230px;
}
.stack-card:hover{background:var(--surface-white);}
.stack-card .sc-index{font-family:var(--font-mono);font-size:.7rem;color:var(--accent-primary);letter-spacing:.1em;}
.stack-card h3{font-family:var(--font-display);font-weight:600;font-size:1.9rem;letter-spacing:-.02em;}
.stack-card p{color:var(--text-secondary);font-size:.96rem;line-height:1.65;}
.stack-card .sc-line{margin-top:auto;height:2px;width:0;background:var(--accent-primary);transition:width .5s var(--ease);}
.stack-card:hover .sc-line{width:100%;}

/* ============================================================
   PROCESS
   ============================================================ */
.process-list{border-top:1px solid var(--border-default);}
.process-step{
  border-bottom:1px solid var(--border-default);padding-block:2rem;
  display:grid;grid-template-columns:auto 1fr;gap:1.5rem;align-items:baseline;
  transition:padding-left .4s var(--ease),background .4s var(--ease);
  position:relative;
}
@media(min-width:760px){
  .process-step{grid-template-columns:90px 1fr 1.4fr;gap:2.5rem;padding-inline:1.4rem;margin-inline:-1.4rem;}
  .process-step:hover{padding-left:2.4rem;background:var(--surface-white);}
}
.process-step .ps-num{font-family:var(--font-mono);font-size:.82rem;color:var(--accent-primary);letter-spacing:.08em;}
.process-step h3{font-family:var(--font-display);font-weight:600;font-size:clamp(1.4rem,2.2vw,2rem);letter-spacing:-.02em;}
.process-step p{color:var(--text-secondary);font-size:1rem;line-height:1.65;max-width:50ch;}

/* ============================================================
   PERSONAL / RPG
   ============================================================ */
.rpg{position:relative;overflow:hidden;background:var(--surface-primary);}
.rpg .container{position:relative;z-index:2;}
#rpg-canvas{position:absolute;inset:0;z-index:0;opacity:.9;}
.rpg-grid{display:grid;grid-template-columns:1fr;gap:2.5rem;}
@media(min-width:900px){.rpg-grid{grid-template-columns:1fr 1fr;gap:4rem;align-items:center;}}
.rpg h2{
  font-family:var(--font-display);font-weight:600;
  font-size:clamp(1.9rem,3.6vw,3.6rem);letter-spacing:-.03em;line-height:1.06;margin-top:1.6rem;
}
.rpg p{color:var(--text-secondary);font-size:1.04rem;line-height:1.72;margin-top:1.4rem;max-width:50ch;}
.rpg-highlight{
  font-family:var(--font-display);font-weight:500;color:var(--accent-primary);
  font-size:clamp(1.3rem,2.2vw,2rem);letter-spacing:-.02em;line-height:1.25;
  margin-top:2rem;font-style:italic;
}
.rpg-link{font-family:var(--font-mono);font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;display:inline-flex;align-items:center;gap:.6rem;margin-top:2rem;border-bottom:1px solid var(--accent-primary);color:var(--accent-primary);padding-bottom:.3rem;transition:gap .3s var(--ease);}
.rpg-link:hover{gap:1rem;}

/* decorative dice/sheet panel */
.rpg-panel{
  border:1px solid var(--border-default);background:rgba(255,255,255,.4);
  backdrop-filter:blur(2px);padding:2rem;display:flex;flex-direction:column;gap:1.4rem;
  font-family:var(--font-mono);font-size:.72rem;letter-spacing:.06em;color:var(--text-secondary);
}
.rpg-panel .rp-row{display:flex;justify-content:space-between;align-items:center;border-bottom:1px dashed var(--border-default);padding-bottom:.9rem;}
.rpg-panel .rp-row:last-child{border-bottom:none;padding-bottom:0;}
.rpg-panel .rp-row .v{color:var(--accent-primary);font-family:var(--font-display);font-weight:600;font-size:1.05rem;letter-spacing:0;}
.rpg-panel .rp-title{text-transform:uppercase;letter-spacing:.2em;color:var(--text-primary);font-size:.66rem;}

/* ============================================================
   CONTACT CTA
   ============================================================ */
.contact{background:var(--footer-bg);color:var(--footer-text);border-top:none;}
.contact .eyebrow{color:#8d8a83;}
.contact .eyebrow::before{background:var(--accent-soft);}
.contact h2{
  font-family:var(--font-display);font-weight:600;
  font-size:clamp(2.2rem,5.4vw,5.2rem);letter-spacing:-.035em;line-height:1.02;margin:2rem 0;max-width:16ch;
}
.contact p{color:#a9a6a0;font-size:clamp(1rem,1.3vw,1.2rem);line-height:1.7;max-width:52ch;margin-bottom:2.6rem;}
.contact-ctas{display:flex;flex-wrap:wrap;gap:1rem;align-items:center;}
.contact .cta-primary{background:var(--surface-white);color:var(--accent-primary);}
.contact .cta-primary:hover{background:var(--accent-soft);}
.contact-secondary{
  font-family:var(--font-mono);font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;
  padding:1rem 1.4rem;border:1px solid #3a3a38;color:var(--footer-text);
  display:inline-flex;align-items:center;gap:.7rem;transition:border-color .3s,background .3s;
}
.contact-secondary:hover{border-color:var(--footer-text);}
.contact-email{margin-top:2rem;font-family:var(--font-mono);font-size:.78rem;letter-spacing:.08em;color:#8d8a83;}
.contact-email a{color:var(--footer-text);border-bottom:1px solid #4a4a48;}

/* ============================================================
   FOOTER
   ============================================================ */
footer{background:var(--footer-bg);color:var(--footer-text);padding-top:4rem;overflow:hidden;}
.footer-cols{
  display:grid;grid-template-columns:1fr;gap:2.5rem;
  padding-bottom:3rem;border-bottom:1px solid #2e2e2c;
}
@media(min-width:760px){.footer-cols{grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:2rem;}}
.footer-cols h4{font-family:var(--font-mono);font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:#76736d;margin-bottom:1.2rem;}
.footer-sig{font-family:var(--font-display);font-weight:600;font-size:1.4rem;letter-spacing:-.01em;}
.footer-sig span{display:block;font-family:var(--font-mono);font-size:.72rem;letter-spacing:.06em;color:#8d8a83;font-weight:400;margin-top:.5rem;text-transform:none;}
.footer-cols ul li{margin-bottom:.7rem;}
.footer-cols ul li a{font-size:.9rem;color:#c4c1bb;transition:color .3s;}
.footer-cols ul li a:hover{color:var(--footer-text);}
.footer-meta{font-family:var(--font-mono);font-size:.74rem;line-height:1.9;color:#8d8a83;}
.footer-big{
  font-family:var(--font-display);font-weight:700;
  font-size:clamp(2.6rem,15vw,13rem);letter-spacing:-.04em;line-height:.9;
  white-space:nowrap;padding-block:2.5rem 1rem;color:var(--footer-text);
  display:flex;will-change:transform;
}
.footer-bottom{
  display:flex;flex-wrap:wrap;justify-content:space-between;gap:1rem;
  padding-bottom:2.5rem;font-family:var(--font-mono);font-size:.68rem;letter-spacing:.06em;color:#76736d;
}
.footer-bottom a{color:#8d8a83;}

/* ============================================================
   FLOATING WHATSAPP
   ============================================================ */
.wa-float{
  position:fixed;right:1.2rem;bottom:1.2rem;z-index:90;
  background:var(--accent-primary);color:#fff;
  display:inline-flex;align-items:center;gap:.6rem;
  padding:.8rem 1.1rem;border-radius:40px;
  font-family:var(--font-mono);font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;
  box-shadow:0 10px 30px rgba(46,20,55,.32);
  opacity:0;transform:translateY(20px) scale(.9);pointer-events:none;
  transition:opacity .4s var(--ease),transform .4s var(--ease);
}
.wa-float.visible{opacity:1;transform:translateY(0) scale(1);pointer-events:auto;}
.wa-float svg{width:16px;height:16px;}
.wa-float .wa-text{display:inline;}
@media(max-width:480px){.wa-float .wa-text{display:none;}.wa-float{padding:.9rem;}}

/* ============================================================
   REVEAL (scroll) base state — applied via JS to avoid FOUC if JS off
   ============================================================ */
.reveal-ready [data-reveal]{opacity:0;transform:translateY(28px);}
.reveal-ready [data-reveal].is-in{opacity:1;transform:none;}
[data-reveal]{transition:opacity .9s var(--ease),transform .9s var(--ease);}

/* ============================================================
   REDUCED MOTION
   ============================================================ */
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important;}
  .reveal-ready [data-reveal]{opacity:1;transform:none;}
  .marquee-track{transform:none!important;}
  .scroll-hint .bar::after{display:none;}
}
