/* ================================================================
   DEAD SAILOR · HI-FI HOME · BLACK FLAG NAVIGATION
   ================================================================ */

:root{
  --abyss:#080A0A;
  --abyss-2:#06080A;
  --hull:#10141A;
  --hull-2:#0C1014;
  --hull-3:#161B22;
  --bone:#E8E2D8;
  --bone-2:#F5F0E6;
  --bone-dim:#C9C3B9;
  --fog:#8B8D88;
  --fog-2:#5A5D58;
  --steel:#23272B;
  --steel-2:#1A1E22;
  --steel-3:#2E343A;
  --amber:#00FF66;
  --amber-2:#33FF85;
  --oxide:#772C24;

  --serif:"Newsreader", "Times New Roman", serif;
  --sans:"DM Sans", "Geist", "Helvetica Neue", Arial, sans-serif;
  --mono:"Geist Mono", ui-monospace, Menlo, monospace;
  --display:"Oswald", "Geist", "Helvetica Neue", Arial, sans-serif;

  --canvas-w: 1920px;
  --gutter: clamp(20px, 4.5vw, 96px);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;overflow-x:clip;max-width:100vw}
html,body{
  background:var(--abyss);
  color:var(--bone);
  max-width:100vw;
  overflow-x:clip;
}
body{
  font-family:var(--sans);
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:clip;
  cursor:none;
}

/* hide native cursor on interactive too */
a, button, [data-cursor]{cursor:none}

/* === Canvas === */
.canvas{
  width:100%;
  max-width:min(var(--canvas-w), 100vw);
  margin:0 auto;
  background:var(--abyss);
  position:relative;
}

/* ---- Global grain & vignette ---- */
.grain{
  position:fixed;left:-5%;top:-5%;width:110%;height:110%;
  pointer-events:none;z-index:80;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='260' height='260'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.78' numOctaves='3' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.96 0 0 0 0 0.92 0 0 0 0 0.86 0 0 0 1 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
  mix-blend-mode:overlay;opacity:.48;
  will-change:transform;
  animation:grainShift 1.2s steps(10) infinite;
}
@keyframes grainShift{
  0%   { transform: translate3d(0%, 0%, 0) }
  10%  { transform: translate3d(-2%, -3%, 0) }
  20%  { transform: translate3d(-4%, 2%, 0) }
  30%  { transform: translate3d(2%, -4%, 0) }
  40%  { transform: translate3d(-3%, 3%, 0) }
  50%  { transform: translate3d(-4%, -2%, 0) }
  60%  { transform: translate3d(3%, 1%, 0) }
  70%  { transform: translate3d(1%, 3%, 0) }
  80%  { transform: translate3d(-2%, -4%, 0) }
  90%  { transform: translate3d(-1%, 2%, 0) }
  100% { transform: translate3d(0%, 0%, 0) }
}
@media (prefers-reduced-motion: reduce){
  .grain{animation:none}
}
.vignette{
  position:fixed;inset:0;pointer-events:none;z-index:78;
  background:
    radial-gradient(120% 80% at 50% 0%, transparent 65%, rgba(0,0,0,.22) 100%),
    radial-gradient(80% 60% at 50% 110%, transparent 60%, rgba(0,0,0,.22) 100%);
}

/* ---- Custom cursor ---- */
.cursor-dot,.cursor-ring{
  position:fixed;top:0;left:0;pointer-events:none;z-index:4000;
  transform:translate(-50%,-50%);
}
.cursor-dot{
  width:4px;height:4px;background:var(--amber);border-radius:50%;
  transition:opacity .18s ease, transform .12s ease;
}
.cursor-ring{
  width:28px;height:28px;border:1px solid rgba(232,226,216,.55);
  border-radius:50%;
  transition:width .22s ease, height .22s ease, border-color .22s ease, background .22s ease, opacity .22s ease;
  display:grid;place-items:center;
}
.cursor-ring::before,.cursor-ring::after{
  content:"";position:absolute;background:rgba(232,226,216,.45);
}
.cursor-ring::before{width:1px;height:6px}
.cursor-ring::after{height:1px;width:6px}
.cursor-label{
  position:absolute;top:24px;left:24px;
  font-family:var(--mono);font-size:9.5px;letter-spacing:.22em;
  color:var(--amber);white-space:nowrap;text-transform:uppercase;
  opacity:0;transition:opacity .2s ease;
}
.cursor-ring.hover{width:54px;height:54px;border-color:var(--amber);background:rgba(0,255,102,.05)}
.cursor-ring.hover::before,.cursor-ring.hover::after{background:var(--amber)}
.cursor-ring.hover .cursor-label{opacity:1}

/* ---- Type system ---- */
.mono{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--fog);font-weight:500}
.mono-sm{font-family:var(--mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--fog-2);font-weight:500}
.amber{color:var(--amber)}
.bone{color:var(--bone)}
.dim{color:var(--fog)}

.kicker{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--bone-dim);
  font-weight:500;
}
.kicker::before{content:"";width:18px;height:1px;background:var(--amber)}
.kicker .num{color:var(--fog-2)}

h1,h2,h3,h4{font-family:var(--serif);font-weight:400;font-style:normal;color:var(--bone)}
h1 em,h2 em,h3 em,h4 em{
  font-style:italic;
  color:#00ff66;
  text-shadow:0 0 24px rgba(0,255,102,.22);
}

/* ---- Buttons ---- */
.btn{
  display:inline-flex;align-items:center;gap:14px;
  font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;font-weight:500;
  padding:15px 22px;border:1px solid rgba(232,226,216,.28);background:rgba(232,226,216,.04);color:var(--bone);
  text-decoration:none;line-height:1;position:relative;overflow:hidden;
  white-space:nowrap;
  transition:border-color .25s ease, color .25s ease, background .25s ease, transform .25s ease, box-shadow .25s ease;
}
.btn .arr{font-family:var(--mono);color:var(--amber);transition:transform .25s ease}
.btn:hover{border-color:var(--bone);background:rgba(232,226,216,.10);box-shadow:0 0 0 1px rgba(232,226,216,.08)}
.btn:hover .arr{transform:translateX(4px)}
.btn-primary{background:var(--bone);color:var(--abyss);border-color:var(--bone)}
.btn-primary .arr{color:var(--abyss)}
.btn-primary:hover{background:var(--bone-2);border-color:var(--bone-2);box-shadow:0 0 20px rgba(232,226,216,.15)}
.btn-ghost{border-color:transparent;background:transparent;padding-left:0;padding-right:0}
.btn-ghost:hover{background:transparent;box-shadow:none}
.btn-amber{
  border-color:var(--amber);color:var(--bone);
  background:rgba(0,255,102,.06);
  box-shadow:0 0 0 0 rgba(0,255,102,0);
}
.btn-amber:hover{
  background:rgba(0,255,102,.14);border-color:var(--amber-2);
  box-shadow:0 0 18px rgba(0,255,102,.18);
}
.btn-green{background:var(--amber);color:var(--abyss);border-color:var(--amber)}
.btn-green:hover{background:var(--amber-2);border-color:var(--amber-2);box-shadow:0 0 22px rgba(0,255,102,.3)}
.btn-green .arr{color:var(--abyss)}

/* ---- Header ---- */
header.hdr{
  position:fixed;top:0;left:50%;transform:translateX(-50%);
  width:100%;max-width:var(--canvas-w);z-index:60;
  display:grid;grid-template-columns:1fr auto 1fr;align-items:center;
  padding:22px clamp(20px, 3vw, 40px);gap:40px;
  background:rgba(8,10,10,0);
  border-bottom:1px solid transparent;
  transition:background .35s ease, border-color .35s ease, padding .35s ease;
}
header.hdr.scrolled{
  background:rgba(8,10,10,.78);
  backdrop-filter:blur(14px) saturate(110%);
  -webkit-backdrop-filter:blur(14px) saturate(110%);
  border-bottom-color:var(--steel);
  padding:14px clamp(20px, 3vw, 40px);
}
.brand{display:flex;align-items:center;gap:14px}
.brand-logo{
  display:block;height:32px;aspect-ratio: 105.22 / 28.54;
  background-color:var(--bone);
  -webkit-mask:url(assets/logo.svg) no-repeat center / contain;
  mask:url(assets/logo.svg) no-repeat center / contain;
  transition:background-color .25s ease, opacity .25s ease;
}
.brand:hover .brand-logo{background-color:var(--bone-2);opacity:.9}
.brand-mark{
  width:24px;height:24px;border:1px solid var(--bone);
  display:grid;place-items:center;color:var(--bone);
  font-family:var(--mono);font-size:10px;letter-spacing:.04em;font-weight:600;
  position:relative;
}
.brand-mark::after{
  content:"";position:absolute;inset:3px;border:1px solid rgba(232,226,216,.18);
}
.brand-name{
  font-family:var(--mono);font-size:13px;letter-spacing:.32em;color:var(--bone);font-weight:500;
}
header.hdr nav{display:flex;gap:34px;justify-content:center}
header.hdr nav a{
  font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--bone-dim);text-decoration:none;padding:6px 0;font-weight:500;
  position:relative;transition:color .2s ease;
}
header.hdr nav a::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:1px;background:var(--amber);
  transform:scaleX(0);transform-origin:left;transition:transform .3s ease;
}
header.hdr nav a:hover{color:var(--bone)}
header.hdr nav a:hover::after,header.hdr nav a.active::after{transform:scaleX(1)}
header.hdr .actions{display:flex;justify-content:flex-end;gap:18px;align-items:center}
.progress{position:relative;width:120px;height:1px;background:var(--steel)}
.progress::before{content:"";position:absolute;left:0;top:0;height:1px;background:var(--amber);width:0;transition:width .15s linear}

/* ============ HERO ============ */
.hero-video{position:absolute;inset:0;overflow:hidden;z-index:0;pointer-events:none}
.hero-video video{
  width:100%;height:100%;object-fit:cover;
  opacity:.88;filter:contrast(1.02) saturate(.95) brightness(.95);
  display:block;
}
.hero-video-overlay{
  position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(70% 60% at 25% 65%, rgba(8,10,10,0), rgba(8,10,10,.3) 80%),
    linear-gradient(180deg,
      rgba(8,10,10,.35) 0%,
      rgba(8,10,10,.05) 25%,
      rgba(8,10,10,.05) 45%,
      rgba(8,10,10,.55) 75%,
      rgba(8,10,10,.92) 92%,
      rgba(8,10,10,.98) 100%),
    linear-gradient(90deg, rgba(8,10,10,.45) 0%, rgba(8,10,10,0) 35%, rgba(8,10,10,0) 65%, rgba(8,10,10,.45) 100%);
}
.hero-video-fallback{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  font-family:var(--mono);font-size:10px;letter-spacing:.28em;color:var(--fog-2);text-transform:uppercase;
  border:1px dashed var(--steel);margin:80px;
  pointer-events:none;opacity:.4;
}
.hero-video.has-video .hero-video-fallback{display:none}
.hero{
  width:100%;
  min-height:max(720px, 56.25vw);
  padding:clamp(80px, 6.5vw, 112px) var(--gutter) clamp(56px, 5vw, 80px);
  position:relative;
  display:flex;flex-direction:column;justify-content:space-between;
  overflow:hidden;
  background:var(--abyss);
}
/* Spacer invisível que empurra o hero-foot para baixo no flex */
.hero-slider > .hero-foot{ flex-shrink:0 }
.hero-bg{
  position:absolute;inset:0;pointer-events:none;z-index:1;
  background-image:
    linear-gradient(to right, rgba(43,48,48,.18) 1px, transparent 1px);
  background-size: calc((var(--canvas-w) - var(--gutter)*2)/12) 100%;
  background-position: var(--gutter) 0;
  opacity:.35;
}
.hero-bg::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(120% 90% at 50% 60%, transparent 30%, rgba(6,8,10,.7) 100%);
}

.meta-top{display:none}

/* ---- Floating meta block over hero (right, aligned w/ "rotas prontas." line) ---- */
.meta-floating{
  position:absolute;top:clamp(320px, 24vw, 460px);right:var(--gutter);
  z-index:3;
  display:flex;flex-direction:column;align-items:flex-end;gap:10px;
  text-align:right;
  pointer-events:none;
}
.meta-floating .m-item,
.meta-floating .m-session{
  display:flex;flex-direction:column;gap:3px;
  position:relative;
}
.meta-floating .m-session{
  margin-top:4px;padding-top:9px;border-top:1px solid var(--steel);
  min-width:200px;
}
.meta-floating .m-label{
  font-family:var(--mono);font-size:7.5px;letter-spacing:.26em;color:var(--fog-2);
  text-transform:uppercase;font-weight:500;
}
.meta-floating .m-val{
  font-family:var(--mono);font-size:8.5px;letter-spacing:.18em;color:var(--bone-dim);
  text-transform:uppercase;font-weight:500;
  display:inline-flex;align-items:center;gap:5px;justify-content:flex-end;
  position:relative;
}
.meta-floating .m-val .dot{
  width:4px;height:4px;background:var(--amber);border-radius:50%;display:inline-block;
  box-shadow:0 0 5px rgba(0,255,102,.6);
}
.meta-floating .m-val .dot.pulse{animation:pulse 2.4s ease-in-out infinite}

/* ---- Glitch ---- */
.meta-floating .m-val{
  text-shadow:
    0 0 0 transparent;
}
.meta-floating .m-val::before,
.meta-floating .m-val::after{
  content: attr(data-text);
  position:absolute;top:0;right:0;
  font:inherit;letter-spacing:inherit;text-transform:inherit;
  display:inline-flex;align-items:center;gap:5px;
  pointer-events:none;
  opacity:0;
  white-space:nowrap;
}
.meta-floating .m-val::before{color:#5CCBE5;mix-blend-mode:screen}
.meta-floating .m-val::after{color:#00FF66;mix-blend-mode:screen}

.meta-floating .m-item:nth-child(1) .m-val{animation:glitchVal 7s 0.3s infinite}
.meta-floating .m-item:nth-child(2) .m-val{animation:glitchVal 8.2s 1.6s infinite}
.meta-floating .m-item:nth-child(3) .m-val{animation:glitchVal 9.4s 2.9s infinite}
.meta-floating .m-item:nth-child(4) .m-val{animation:glitchVal 6.8s 4.1s infinite}
.meta-floating .m-session .m-val{animation:glitchVal 10.6s 5.2s infinite}

.meta-floating .m-item:nth-child(1) .m-val::before{animation:glitchA 7s 0.3s infinite}
.meta-floating .m-item:nth-child(1) .m-val::after{animation:glitchB 7s 0.3s infinite}
.meta-floating .m-item:nth-child(2) .m-val::before{animation:glitchA 8.2s 1.6s infinite}
.meta-floating .m-item:nth-child(2) .m-val::after{animation:glitchB 8.2s 1.6s infinite}
.meta-floating .m-item:nth-child(3) .m-val::before{animation:glitchA 9.4s 2.9s infinite}
.meta-floating .m-item:nth-child(3) .m-val::after{animation:glitchB 9.4s 2.9s infinite}
.meta-floating .m-item:nth-child(4) .m-val::before{animation:glitchA 6.8s 4.1s infinite}
.meta-floating .m-item:nth-child(4) .m-val::after{animation:glitchB 6.8s 4.1s infinite}
.meta-floating .m-session .m-val::before{animation:glitchA 10.6s 5.2s infinite}
.meta-floating .m-session .m-val::after{animation:glitchB 10.6s 5.2s infinite}

@keyframes glitchVal{
  0%, 92%, 100% { transform:translate(0,0); filter:none }
  92.5% { transform:translate(-1px, 0); filter:contrast(1.4) }
  93%   { transform:translate(1px, 0) }
  93.5% { transform:translate(-1px, 1px); clip-path:inset(40% 0 30% 0) }
  94%   { transform:translate(2px, -1px); clip-path:inset(10% 0 60% 0) }
  94.5% { transform:translate(-2px, 0); clip-path:inset(60% 0 10% 0) }
  95%   { transform:translate(0, 1px); clip-path:inset(0 0 0 0) }
  95.5% { transform:translate(1px, -1px); clip-path:inset(20% 0 40% 0) }
  96%   { transform:translate(0, 0); clip-path:none }
}
@keyframes glitchA{
  0%, 92%, 100% { opacity:0; transform:translate(0,0) }
  92.5% { opacity:.55; transform:translate(-2px, 0) }
  93%   { opacity:.65; transform:translate(2px, 1px) }
  93.5% { opacity:.55; transform:translate(-2px, 0) }
  94%   { opacity:.5;  transform:translate(2px, -1px) }
  95%   { opacity:.4;  transform:translate(-1px, 0) }
  96%   { opacity:0;   transform:translate(0,0) }
}
@keyframes glitchB{
  0%, 92%, 100% { opacity:0; transform:translate(0,0) }
  92.5% { opacity:.6;  transform:translate(2px, 0) }
  93%   { opacity:.7;  transform:translate(-2px, -1px) }
  93.5% { opacity:.55; transform:translate(2px, 0) }
  94%   { opacity:.5;  transform:translate(-2px, 1px) }
  95%   { opacity:.4;  transform:translate(1px, 0) }
  96%   { opacity:0;   transform:translate(0,0) }
}

@media (max-width: 1024px){
  .meta-floating{top:clamp(240px, 28vw, 340px);right:24px;gap:8px}
  .meta-floating .m-label{font-size:7px}
  .meta-floating .m-val{font-size:8px}
  .meta-floating .m-session{min-width:0}
}
@media (max-width: 640px){
  .meta-floating{display:none}
}
@keyframes pulse{
  0%,100%{opacity:1;box-shadow:0 0 8px rgba(0,255,102,.6)}
  50%{opacity:.5;box-shadow:0 0 0 rgba(0,255,102,0)}
}
.meta-top .session{
  border:1px solid var(--steel);padding:8px 12px;
  display:flex;align-items:center;gap:12px;
  justify-self:end;
}
.meta-top .session .t1{font-family:var(--mono);font-size:8.5px;letter-spacing:.24em;color:var(--fog-2);text-transform:uppercase}
.meta-top .session .t2{font-family:var(--mono);font-size:9.5px;letter-spacing:.14em;color:var(--bone);text-transform:uppercase}

.hero-body{
  margin-top:24px;
}
.hero h1{
  font-family:var(--serif);
  font-size:clamp(40px, 4.5vw, 68px);line-height:0.95;letter-spacing:-.01em;
  color:var(--bone);font-weight:400;
  max-width:100%;
  text-transform:uppercase;
}
.hero h1 .line1,.hero h1 .line2,.hero h1 .line3{white-space:nowrap}
.hero h1 .line1{display:block}
.hero h1 .line2{display:block}
.hero h1 .line3{
  display:block;
  font-family:var(--serif);
  font-style:italic;
  color:var(--amber);
  text-transform:none;
  font-weight:400;
  text-shadow:0 0 32px rgba(0,255,102,.28);
}
@keyframes rise{
  from{opacity:0;transform:translateY(20px)}
  to{opacity:1;transform:translateY(0)}
}

.hero .rail-row{
  display:grid;grid-template-columns:minmax(0,1fr) 420px;gap:80px;align-items:end;
  border-top:1px solid var(--steel);padding-top:32px;
  /* Opacidade controlada por .slide-text.active .rail-row */
}
.hero .rail-row .left-rail{display:flex;flex-direction:column;gap:18px;padding-bottom:6px}
.hero .rail-row .left-rail .lede-label{font-family:var(--mono);font-size:10px;letter-spacing:.24em;color:var(--fog-2);text-transform:uppercase;font-weight:500}
.hero .right-rail{display:flex;flex-direction:column;gap:24px;padding-bottom:6px}
@keyframes fadeIn{to{opacity:1}}
.hero .lede{font-size:16px;line-height:1.55;color:var(--bone-dim);max-width:340px;font-weight:300}
.hero .lede strong{color:var(--bone);font-weight:500}
.hero .ctas{display:flex;gap:12px;flex-wrap:wrap}
.hero .reserve{
  margin-top:6px;border-top:1px solid var(--steel);padding-top:18px;
  font-family:var(--mono);font-size:10px;letter-spacing:.22em;color:var(--fog-2);text-transform:uppercase;
  display:flex;justify-content:space-between;
}

.hero-foot{
  position:relative;z-index:2;
  margin-top:24px;padding-top:20px;border-top:1px solid var(--steel);
  display:grid;grid-template-columns:auto 1fr auto;gap:48px;align-items:center;
}
.scroll-pill{
  font-family:var(--mono);font-size:10px;letter-spacing:.28em;color:var(--bone-dim);font-weight:500;
  display:flex;align-items:center;gap:14px;
}
.scroll-pill .line{width:36px;height:1px;background:var(--amber);display:inline-block;position:relative}
.scroll-pill .line::after{content:"";position:absolute;right:-3px;top:-2px;width:5px;height:5px;background:var(--amber);transform:rotate(45deg)}

.horizon{position:relative;height:40px}
.horizon::before{
  content:"";position:absolute;left:0;right:0;top:50%;height:1px;background:var(--steel);
}
.horizon .progress-line{
  position:absolute;left:0;top:50%;height:1px;background:var(--amber);
  width:18%;transform-origin:left;
  box-shadow:0 0 10px rgba(0,255,102,.4);
}
.horizon .ticker{
  position:absolute;left:0;top:50%;width:1px;height:10px;background:var(--amber);transform:translate(-50%,-50%);
  margin-left:18%;
}
.horizon .c{position:absolute;font-family:var(--mono);font-size:10px;letter-spacing:.22em;color:var(--fog-2);text-transform:uppercase}
.horizon .c.a{left:0;top:-16px}
.horizon .c.b{right:0;top:-16px}
.horizon .c.c{left:0;top:14px}
.horizon .c.d{right:0;top:14px;color:var(--bone-dim)}

.hero .sig-corner{
  font-family:var(--mono);font-size:10px;letter-spacing:.22em;color:var(--bone-dim);text-transform:uppercase;
  display:flex;flex-direction:column;align-items:flex-end;gap:4px;
}
.hero .sig-corner span{color:var(--amber)}

/* ============ HERO SLIDESHOW ============ */

/* Grid principal do hero split (duas colunas) */
.hero-grid {
  display: grid;
  grid-template-columns: 1.25fr 1fr;
  gap: clamp(40px, 5vw, 80px);
  align-items: center;
  width: 100%;
  flex: 1;
  min-height: 0;
  margin-top: 24px;
  margin-bottom: 16px;
}

/* Frame de mídia na coluna da direita */
.hero-media-frame {
  position: absolute;
  top: 0;
  bottom: 0;
  right: 0;
  width: 55%;
  z-index: 2;
  pointer-events: none;
  background: transparent;
  border: none;
  box-shadow: none;
}

.hero-media-frame::after {
  content: "";
  position: absolute;
  inset: -1px;
  z-index: 2;
  pointer-events: none;
  background: 
    linear-gradient(90deg, var(--abyss) 0%, rgba(8, 10, 10, 0.9) 10%, rgba(8, 10, 10, 0) 45%),
    radial-gradient(circle at center, transparent 30%, var(--abyss) 75%);
}

.hero-media-frame .brutalist-number-box,
.hero-media-frame .brutalist-badge,
.hero-media-frame .brutalist-asterisk,
.hero-media-frame .crop-line {
  display: none !important;
}



.hero-slides {
  position: absolute;
  inset: 0;
  overflow: hidden;
  z-index: 1;
}

.hero-slide {
  position: absolute;
  inset: 0;
  opacity: 0;
  transition: opacity 0.9s cubic-bezier(.4,0,.2,1);
  pointer-events: none;
}

.hero-slide.active {
  opacity: 1;
  pointer-events: auto;
}

/* Vídeo por slide */
.slide-video-wrap {
  position: absolute;
  inset: 0;
  overflow: hidden;
  z-index: 0;
}

.slide-video-wrap video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 90% 50%;
  opacity: 0.88;
  filter: contrast(1.02) saturate(0.95) brightness(0.95);
  display: block;
  transform: translate3d(0,0,0);
  -webkit-transform: translate3d(0,0,0);
}

/* ─── hero-body: container flex do conteúdo (filho do .hero flex) ─── */
.hero-body {
  position: relative;
  z-index: 3;
  display: grid;
  grid-template-areas: "stack";
  align-self: stretch;
  align-content: center;
}

/* Todos os textos empilhados na mesma célula */
.slide-text {
  grid-area: stack;
  display: flex;
  flex-direction: column;
  gap: 28px;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.6s cubic-bezier(.4,0,.2,1);
}

.slide-text.active {
  opacity: 1;
  pointer-events: auto;
}

/* Animações de entrada das linhas apenas no slide ativo */
.slide-text .line1, .slide-text .line2, .slide-text .line3 {
  display: block;
  white-space: nowrap;
}

.slide-text.active .line1 { animation: rise 0.9s 0.05s cubic-bezier(.2,.7,.2,1) both }
.slide-text.active .line2 { animation: rise 0.9s 0.18s cubic-bezier(.2,.7,.2,1) both }
.slide-text.active .line3 { animation: rise 0.9s 0.3s cubic-bezier(.2,.7,.2,1) both }

/* rail-row aparece com fade após o título */
.slide-text .rail-row { opacity: 0; }
.slide-text.active .rail-row { animation: fadeIn 0.9s 0.55s ease both }

/* Elementos decorativos brutalistas */
.brutalist-number-box {
  position: absolute;
  right: -1.5px;
  bottom: 24px;
  background: var(--amber); /* Neon green background */
  color: #000; /* Black number text for high contrast */
  border: 1.5px solid var(--steel);
  padding: 6px 14px;
  font-family: var(--display);
  font-size: clamp(32px, 3.5vw, 48px);
  font-weight: 700;
  line-height: 1;
  z-index: 10;
  letter-spacing: -0.02em;
  box-shadow: 0 0 20px rgba(0, 255, 102, 0.2);
}

.brutalist-badge {
  position: absolute;
  left: 24px;
  top: 24px;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  border: 1.5px solid var(--steel);
  background: var(--abyss);
  color: var(--bone);
  display: grid;
  place-items: center;
  font-family: var(--mono);
  font-size: 10px;
  font-weight: 600;
  z-index: 10;
}

.brutalist-asterisk {
  position: absolute;
  right: 24px;
  top: 24px;
  font-size: 32px;
  color: var(--amber); /* Neon green asterisk */
  line-height: 1;
  animation: rotateAsterisk 25s linear infinite;
  z-index: 10;
  text-shadow: 0 0 15px rgba(0, 255, 102, 0.4);
}

@keyframes rotateAsterisk {
  from { transform: rotate(0deg); }
  to { transform: rotate(360deg); }
}

/* Crop lines */
.crop-line {
  position: absolute;
  width: 14px;
  height: 14px;
  z-index: 8;
  pointer-events: none;
}

.crop-tl {
  top: -7px;
  left: -7px;
  border-left: 1.5px solid var(--steel);
  border-top: 1.5px solid var(--steel);
}

.crop-tr {
  top: -7px;
  right: -7px;
  border-right: 1.5px solid var(--steel);
  border-top: 1.5px solid var(--steel);
}

.crop-bl {
  bottom: -7px;
  left: -7px;
  border-left: 1.5px solid var(--steel);
  border-bottom: 1.5px solid var(--steel);
}

.crop-br {
  bottom: -7px;
  right: -7px;
  border-right: 1.5px solid var(--steel);
  border-bottom: 1.5px solid var(--steel);
}

/* ---- Slider UI (dots, arrows, counter) ---- */
.hero-slider-ui{
  position:relative;z-index:10;
  display:flex;align-items:center;gap:24px;
  padding-bottom:clamp(32px, 4.5vw, 56px);
  flex-shrink:0;
}

/* Arrows */
.slider-arrow{
  width:40px;height:40px;border:1px solid rgba(232,226,216,.22);background:rgba(8,10,10,.4);
  display:grid;place-items:center;color:var(--bone-dim);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  cursor:none;transition:border-color .2s ease, color .2s ease, background .2s ease;
  flex-shrink:0;
}
.slider-arrow:hover{border-color:var(--bone);color:var(--bone);background:rgba(232,226,216,.08)}

/* Dots */
.slider-dots{
  display:flex;gap:10px;align-items:center;
}
.slider-dot{
  display:flex;flex-direction:column;gap:5px;align-items:center;
  background:none;border:none;cursor:none;padding:0;
  opacity:.45;transition:opacity .3s ease;
}
.slider-dot.active{ opacity:1 }
.slider-dot:hover{ opacity:.75 }
.dot-bar{
  display:block;width:48px;height:1px;background:rgba(232,226,216,.2);position:relative;overflow:hidden;
}
.dot-fill{
  position:absolute;left:0;top:0;height:100%;width:0%;background:var(--amber);
  transition:width .25s ease;
}
.slider-dot.active .dot-fill{
  width:100%;
  /* Overridden by JS with animation duration */
}
.dot-label{
  font-family:var(--mono);font-size:8px;letter-spacing:.26em;color:var(--bone-dim);text-transform:uppercase;
}

/* Counter */
.slider-counter{
  display:flex;align-items:baseline;gap:4px;
  font-family:var(--mono);font-size:10px;letter-spacing:.18em;color:var(--fog-2);text-transform:uppercase;
}
.slider-current{ font-size:13px;color:var(--bone);font-weight:500 }
.slider-sep{ color:var(--fog-2) }
.slider-total{ color:var(--fog-2) }

/* Mobile adjustments */
@media (max-width: 768px){
  .hero-slider-ui{ gap:14px;padding-bottom:12px }
  .slider-arrow{ width:34px;height:34px }
  .dot-bar{ width:32px }
  .dot-label{ display:none }
  .slider-counter{ display:none }
  .slide-content{ padding-top:clamp(72px, 12vw, 96px) }
}

/* ============ Section base ============ */
.section{padding:clamp(48px, 7vw, 100px) var(--gutter);position:relative;border-top:1px solid var(--steel-2)}
.section-head{
  display:grid;grid-template-columns:1fr 320px;
  gap:60px;padding-bottom:32px;border-bottom:1px solid var(--steel);margin-bottom:48px;align-items:end;
}
.section-head .label{margin-bottom:28px}
.section-head h2{
  font-size:clamp(44px, 6vw, 88px);line-height:.98;letter-spacing:-.018em;font-weight:400;
}
.section-head .right{color:var(--fog);font-size:14.5px;line-height:1.65;padding-bottom:8px;font-weight:300}

.reveal{opacity:0;transform:translateY(28px);transition:opacity .9s ease, transform .9s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:translateY(0)}

/* ============ CLIENTS · LOGO STRIP ============ */
.clients{
  border-top:1px solid var(--steel);border-bottom:1px solid var(--steel);
  background:var(--abyss);
  padding:clamp(28px, 3.5vw, 44px) 0 clamp(32px, 4vw, 56px);
  position:relative;overflow:hidden;
}
.clients-head{
  display:flex;justify-content:space-between;align-items:center;gap:24px;
  padding:0 var(--gutter);margin-bottom:clamp(20px, 2vw, 32px);
}
.clients-marquee{
  position:relative;overflow:hidden;width:100%;
  mask-image:linear-gradient(90deg, transparent 0, #000 8%, #000 92%, transparent 100%);
  -webkit-mask-image:linear-gradient(90deg, transparent 0, #000 8%, #000 92%, transparent 100%);
}
.clients-marquee .track{
  display:flex;align-items:center;
  width:max-content;
  animation:clientsScroll 55s linear infinite;
  will-change:transform;
}
.clients-marquee .track-group{
  display:flex;align-items:center;
  gap:clamp(48px, 6vw, 88px);
  padding-right:clamp(48px, 6vw, 88px);
}
.clients-marquee:hover .track{animation-play-state:paused}
@keyframes clientsScroll{
  from{transform:translate3d(0,0,0)}
  to{transform:translate3d(-50%,0,0)}
}
.clients-marquee .logo{
  display:inline-flex;align-items:center;gap:10px;flex-shrink:0;
  color:var(--bone-dim);
  opacity:.55;transition:opacity .3s ease, color .3s ease;
  text-transform:none;
  height:120px;
}
.clients-marquee .logo:hover{opacity:1;color:var(--bone)}
.clients-marquee .logo .name{
  font-family:var(--sans);font-size:20px;color:inherit;line-height:1;
}
.clients-marquee .logo .dot{
  display:inline-block;width:5px;height:5px;background:var(--amber);border-radius:50%;
}
.clients-marquee .edge{position:absolute;top:0;bottom:0;width:80px;pointer-events:none;z-index:2}
.clients-marquee .edge-l{left:0;background:linear-gradient(90deg, var(--abyss), transparent)}
.clients-marquee .edge-r{right:0;background:linear-gradient(-90deg, var(--abyss), transparent)}

@media (max-width: 1024px){
  .clients-head{flex-direction:column;align-items:flex-start;gap:10px}
  .clients-marquee .logo .name{font-size:17px}
}
@media (max-width: 640px){
  .clients-marquee .track{gap:36px;animation-duration:38s}
  .clients-marquee .logo .name{font-size:15px}
}

/* ============ Explored Territories ============ */
.work-grid{
  display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:clamp(20px, 1.6vw, 28px) clamp(16px, 1.4vw, 24px);
}
.work-grid .card{display:flex;flex-direction:column;gap:18px;position:relative}

.case-art{
  position:relative;overflow:hidden;border:1px solid var(--steel);
  background:var(--hull-2);
  width:100%;
  aspect-ratio: 4 / 3;
  transition:border-color .35s ease, transform .5s cubic-bezier(.2,.7,.2,1);
}
.case-info{
  display:flex;flex-direction:column;gap:12px;flex:1;
}
.case-art .badge-tr{
  position:absolute;top:18px;right:18px;display:flex;gap:8px;align-items:center;z-index:3;
  font-family:var(--mono);font-size:9.5px;letter-spacing:.22em;color:var(--bone-dim);text-transform:uppercase;
}
.case-art .badge-tr .dot{width:5px;height:5px;background:var(--amber);border-radius:50%}
.tag-new {
  background: var(--amber);
  color: var(--abyss);
  font-family: var(--mono);
  font-size: 8px;
  font-weight: 700;
  padding: 2px 6px;
  border-radius: 2px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  display: inline-block;
  box-shadow: 0 0 10px rgba(0, 255, 102, 0.4);
  animation: pulse-glow 2s infinite alternate;
  margin-right: 4px;
}
@keyframes pulse-glow {
  0% { box-shadow: 0 0 4px rgba(0, 255, 102, 0.2); transform: scale(1); }
  100% { box-shadow: 0 0 12px rgba(0, 255, 102, 0.65); transform: scale(1.02); }
}

.case-art .badge-tl{
  position:absolute;top:18px;left:18px;z-index:3;
  font-family:var(--mono);font-size:9.5px;letter-spacing:.22em;color:var(--fog);text-transform:uppercase;
}
.case-art .corner-tl,.case-art .corner-tr,.case-art .corner-bl,.case-art .corner-br{
  position:absolute;width:12px;height:12px;border-color:var(--steel-3);z-index:3;
}
.case-art .corner-tl{top:8px;left:8px;border-top:1px solid var(--bone-dim);border-left:1px solid var(--bone-dim)}
.case-art .corner-tr{top:8px;right:8px;border-top:1px solid var(--bone-dim);border-right:1px solid var(--bone-dim)}
.case-art .corner-bl{bottom:8px;left:8px;border-bottom:1px solid var(--bone-dim);border-left:1px solid var(--bone-dim)}
.case-art .corner-br{bottom:8px;right:8px;border-bottom:1px solid var(--bone-dim);border-right:1px solid var(--bone-dim)}

.card:hover .case-art{border-color:var(--amber-2)}
.card:hover .case-art .stage{transform:scale(1.02)}
.card .stage{transition:transform .8s cubic-bezier(.2,.7,.2,1);width:100%;height:100%}

.case-meta{
  display:flex;justify-content:space-between;align-items:center;
  font-family:var(--mono);font-size:10.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--fog);font-weight:500;
}
.case-meta .right-meta{display:flex;align-items:center;gap:8px;color:var(--bone-dim)}
.case-meta .right-meta .dot{width:5px;height:5px;background:var(--amber);border-radius:50%;display:inline-block}
.case-title{
  font-family:var(--serif);font-weight:400;font-size:22px;line-height:1.15;color:var(--bone);
  letter-spacing:-.005em;
}
.case-title em{font-style:italic;color:#00ff66}
.case-desc{font-size:13px;line-height:1.6;color:var(--fog);font-weight:300}
.case-tags{font-family:var(--mono);font-size:10.5px;letter-spacing:.16em;color:var(--bone-dim);text-transform:uppercase;font-weight:500}
.case-foot{
  display:flex;justify-content:space-between;align-items:center;
  border-top:1px solid var(--steel);padding-top:14px;margin-top:auto;
}
.case-foot a{
  font-family:var(--mono);font-size:10.5px;letter-spacing:.22em;color:var(--bone);text-decoration:none;text-transform:uppercase;font-weight:500;
  display:inline-flex;align-items:center;gap:10px;transition:color .25s ease;
}
.case-foot a .arr{color:var(--amber);transition:transform .25s ease}
.case-foot a:hover .arr{transform:translateX(4px)}

.cta-soon {
  font-family:var(--mono);font-size:10.5px;letter-spacing:.22em;color:var(--bone);text-transform:uppercase;font-weight:500;
  display:inline-flex;align-items:center;gap:10px;opacity:0.45;cursor:default;pointer-events:none;user-select:none;
}
.cta-soon .arr {
  color:var(--fog-2);
}

.work-cta{
  margin-top:80px;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:24px;
  border-top:1px solid var(--steel);
  padding-top:48px;
  text-align:center;
}
.work-cta .mono {
  color: var(--fog-2);
  font-size: 10.5px;
  letter-spacing: .22em;
}
.work-cta .btn {
  padding: 18px 42px;
  font-size: 12.5px;
  letter-spacing: .26em;
  background: var(--amber); /* neon green */
  color: var(--abyss);
  border-color: var(--amber);
  box-shadow: 0 0 24px rgba(0, 255, 102, 0.15);
  transition: transform .25s ease, box-shadow .25s ease, background .25s ease, border-color .25s ease;
}
.work-cta .btn .arr {
  color: var(--abyss);
  transition: transform .25s ease;
}
.work-cta .btn:hover {
  background: var(--amber-2);
  border-color: var(--amber-2);
  box-shadow: 0 0 35px rgba(0, 255, 102, 0.35);
  transform: translateY(-3px);
}
.work-cta .btn:hover .arr {
  transform: translate(3px, -3px);
}

/* ---- Case artwork — 5 distinct placeholders ---- */
.art-base{position:relative;width:100%;height:100%;display:grid;place-items:center;overflow:hidden}

/* Standardized artwork heights — all artworks fill their 4:3 wrapper */
.case-art > .art-base,
.case-art .stage,
.case-art{position:relative}
.art-01,.art-02,.art-03,.art-04,.art-05,.art-06{height:100%;width:100%;padding:0}

/* CASE 01 — Brand experience, monumental wordmark */
.art-01{
  background:
    radial-gradient(80% 70% at 50% 110%, rgba(119,44,36,.32), transparent 70%),
    radial-gradient(60% 50% at 50% -10%, rgba(0,255,102,.14), transparent 70%),
    linear-gradient(180deg, #0E1216 0%, #050709 100%);
}
.art-01 .marquee{
  position:absolute;left:0;right:0;top:50%;transform:translateY(-50%);
  text-align:center;padding:0 24px;
}
.art-01 .marquee .small{font-family:var(--mono);font-size:9px;letter-spacing:.34em;color:var(--bone-dim);text-transform:uppercase;margin-bottom:12px;display:block}
.art-01 .marquee h4{
  font-family:var(--serif);font-style:italic;font-size:clamp(56px, 6.5vw, 96px);line-height:.9;color:var(--bone);letter-spacing:-.02em;font-weight:400;
}
.art-01 .marquee .caption{
  margin-top:14px;font-family:var(--mono);font-size:9px;letter-spacing:.26em;color:var(--fog);text-transform:uppercase;
}
.art-01 .ticker-bar{
  position:absolute;left:0;right:0;bottom:36px;
  font-family:var(--mono);font-size:10px;letter-spacing:.28em;color:var(--fog-2);text-transform:uppercase;
  display:flex;justify-content:space-between;padding:0 36px;
}
.art-01 .rays{
  position:absolute;inset:0;
  background:
    repeating-linear-gradient(90deg, transparent 0 calc(100%/12 - 1px), rgba(43,48,48,.35) calc(100%/12 - 1px) calc(100%/12));
  opacity:.5;mix-blend-mode:screen;
}

/* CASE 02 — Identity, monogram */
.art-02{
  background:
    radial-gradient(70% 60% at 50% 50%, rgba(232,226,216,.04), transparent 70%),
    linear-gradient(180deg, #14181C 0%, #08090B 100%);
}
.art-02 .frame{
  position:absolute;inset:24px;border:1px solid var(--steel-3);
}
.art-02 .frame .ind{position:absolute;font-family:var(--mono);font-size:8.5px;letter-spacing:.22em;color:var(--fog);text-transform:uppercase}
.art-02 .frame .ind.tl{top:6px;left:8px}
.art-02 .frame .ind.tr{top:6px;right:8px}
.art-02 .frame .ind.bl{bottom:6px;left:8px}
.art-02 .frame .ind.br{bottom:6px;right:8px}
.art-02 .mono-letter{
  font-family:var(--serif);font-style:italic;font-size:clamp(110px, 13vw, 160px);color:var(--bone);line-height:1;font-weight:400;
}
.art-02 .mono-letter .dot{color:var(--amber);font-style:normal}
.art-02 .below{
  position:absolute;left:0;right:0;bottom:40px;text-align:center;
  font-family:var(--mono);font-size:9.5px;letter-spacing:.36em;color:var(--bone-dim);text-transform:uppercase;
}

/* CASE 03 — Platform UI mock */
.art-03{
  background:linear-gradient(180deg, #0B0E12 0%, #060809 100%);
}
.art-03 .browser{
  position:absolute;inset:24px;border:1px solid var(--steel);background:var(--hull-2);
  display:flex;flex-direction:column;
}
.art-03 .browser .bar{
  display:flex;align-items:center;gap:8px;padding:10px 12px;border-bottom:1px solid var(--steel);
}
.art-03 .browser .bar span{width:6px;height:6px;border:1px solid var(--steel-3);border-radius:50%}
.art-03 .browser .bar .url{margin-left:auto;font-family:var(--mono);font-size:9px;letter-spacing:.2em;color:var(--fog-2);text-transform:uppercase}
.art-03 .browser .body{flex:1;display:grid;grid-template-columns:80px 1fr;gap:0}
.art-03 .browser .side{border-right:1px solid var(--steel);padding:12px 10px;display:flex;flex-direction:column;gap:10px}
.art-03 .browser .side .item{height:8px;background:var(--steel);width:100%;border-radius:1px}
.art-03 .browser .side .item.active{background:var(--amber);width:60%}
.art-03 .browser .main{padding:14px;display:flex;flex-direction:column;gap:14px}
.art-03 .browser .main .head{display:flex;justify-content:space-between;align-items:center}
.art-03 .browser .main .head .h{font-family:var(--serif);font-size:18px;color:var(--bone);font-style:italic}
.art-03 .browser .main .head .pill{font-family:var(--mono);font-size:8.5px;letter-spacing:.22em;color:var(--amber);border:1px solid var(--amber);padding:3px 6px;text-transform:uppercase}
.art-03 .browser .main .grid-row{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.art-03 .browser .main .cell{background:var(--hull-3);border:1px solid var(--steel);height:48px;position:relative}
.art-03 .browser .main .cell::before{content:"";position:absolute;left:8px;top:8px;width:30%;height:5px;background:var(--steel-3)}
.art-03 .browser .main .cell::after{content:"";position:absolute;left:8px;top:18px;width:20%;height:5px;background:var(--steel-3)}
.art-03 .browser .main .chart{
  flex:1;border:1px solid var(--steel);background:linear-gradient(180deg, rgba(0,255,102,.07), transparent);position:relative;
  overflow:hidden;
}
.art-03 .browser .main .chart svg{position:absolute;inset:0;width:100%;height:100%}

/* CASE 04 — Hybrid AI tool — terminal/agent */
.art-04{
  background:linear-gradient(180deg, #0A0D11 0%, #050708 100%);
}
.art-04 .agent{
  position:absolute;inset:24px;border:1px solid var(--steel);background:var(--hull-2);
  display:flex;flex-direction:column;font-family:var(--mono);
}
.art-04 .agent .head{
  display:flex;justify-content:space-between;align-items:center;padding:10px 14px;border-bottom:1px solid var(--steel);
  font-size:9.5px;letter-spacing:.24em;color:var(--fog);text-transform:uppercase;
}
.art-04 .agent .head .live{color:var(--amber);display:flex;gap:6px;align-items:center}
.art-04 .agent .head .live::before{content:"";width:5px;height:5px;background:var(--amber);border-radius:50%;animation:pulse 1.8s infinite}
.art-04 .agent .body{flex:1;padding:14px 16px;display:flex;flex-direction:column;gap:10px;font-size:11px;letter-spacing:.04em;line-height:1.4;color:var(--bone-dim)}
.art-04 .agent .body .you{color:var(--fog)}
.art-04 .agent .body .you::before{content:"// USER ";color:var(--amber);font-size:9px;letter-spacing:.22em;display:block;margin-bottom:4px}
.art-04 .agent .body .ai{color:var(--bone-2)}
.art-04 .agent .body .ai::before{content:"// AGENT ";color:var(--amber);font-size:9px;letter-spacing:.22em;display:block;margin-bottom:4px}
.art-04 .agent .body .ai .caret{display:inline-block;width:6px;height:11px;background:var(--amber);margin-left:3px;vertical-align:-1px;animation:blink 1.1s steps(2) infinite}
@keyframes blink{50%{opacity:0}}
.art-04 .agent .footin{
  padding:10px 14px;border-top:1px solid var(--steel);
  display:flex;justify-content:space-between;font-size:9px;letter-spacing:.22em;color:var(--fog-2);text-transform:uppercase;
}

/* CASE 05 — Generative experiment */
.art-05{
  background:
    radial-gradient(60% 70% at 50% 50%, rgba(0,255,102,.05), transparent 60%),
    linear-gradient(180deg, #0C0F12 0%, #060708 100%);
}
.art-05 .gen{position:absolute;inset:0;display:grid;place-items:center}
.art-05 .gen svg{width:80%;height:60%}
.art-05 .label-corner{
  position:absolute;left:24px;bottom:24px;
  font-family:var(--mono);font-size:10px;letter-spacing:.3em;color:var(--bone);text-transform:uppercase;
  display:flex;flex-direction:column;gap:4px;
}
.art-05 .label-corner span{color:var(--fog);font-size:9px;letter-spacing:.22em}
.art-05 .seed{
  position:absolute;right:24px;bottom:24px;
  font-family:var(--mono);font-size:9px;letter-spacing:.22em;color:var(--fog-2);text-transform:uppercase;
  text-align:right;line-height:1.7;
}

/* CASE 06 — Fluxorama mini */
.art-06{
  background:
    radial-gradient(80% 60% at 50% 50%, rgba(0,255,102,.06), transparent 70%),
    linear-gradient(180deg, #0D1014 0%, #060809 100%);
}
.art-06 .flux-mini{
  position:absolute;inset:0;display:flex;flex-direction:column;justify-content:center;align-items:center;
  padding:32px 24px;gap:10px;text-align:center;
}
.art-06 .flux-mini .flux-small{font-family:var(--mono);font-size:9px;letter-spacing:.34em;color:var(--bone-dim);text-transform:uppercase}
.art-06 .flux-mini .flux-word{font-family:var(--serif);font-style:italic;font-size:clamp(56px, 6vw, 84px);line-height:.95;color:var(--bone);letter-spacing:-.02em}
.art-06 .flux-mini .flux-cap{font-family:var(--mono);font-size:9.5px;letter-spacing:.26em;color:var(--fog);text-transform:uppercase;margin-bottom:14px}
.art-06 .flux-mini .flux-bars{display:flex;flex-direction:column;gap:6px;width:60%;max-width:240px}
.art-06 .flux-mini .flux-bars .bar{height:3px;background:var(--steel)}
.art-06 .flux-mini .flux-bars .bar i{display:block;height:100%;background:var(--amber)}

/* ============ BELIEF ============ */
.belief{
  padding:clamp(64px, 8vw, 120px) var(--gutter);
  border-top:1px solid var(--abyss);border-bottom:1px solid var(--abyss);
  background:var(--amber);
  color:var(--abyss);
  position:relative;
}
.belief .container{
  display:grid;grid-template-columns:200px 1fr 300px;gap:60px;align-items:start;
}
.belief .label{padding-top:8px}
.belief .kicker{
  color:var(--abyss);
}
.belief .kicker::before{
  background:var(--abyss);
}
.belief .kicker .num{
  color:rgba(8,10,10,0.6);
}
.belief .mono{
  color:rgba(8,10,10,0.7);
}
.belief h2{
  font-size:clamp(56px, 7.5vw, 112px);line-height:1.02;letter-spacing:-.02em;font-weight:400;
  color:var(--abyss);
}
.belief h2 em{
  font-style:italic;
  color:var(--abyss);
  text-shadow:none;
}
.belief .quote-mark{
  font-family:var(--serif);font-size:120px;line-height:.5;color:var(--abyss);font-style:italic;
  display:inline-block;margin-bottom:-30px;
}
.belief .body{
  font-size:15px;line-height:1.7;color:var(--abyss);padding-top:36px;font-weight:400;
}
.belief .body small{
  display:block;margin-top:24px;
  font-family:var(--mono);font-size:10px;letter-spacing:.24em;
  color:rgba(8,10,10,0.6);
  text-transform:uppercase;
}
.belief .sig-l,.belief .sig-r{
  position:absolute;bottom:48px;font-family:var(--mono);font-size:10px;letter-spacing:.28em;
  color:rgba(8,10,10,0.6);
  text-transform:uppercase;
}
.belief .sig-l{left:var(--gutter)}
.belief .sig-r{right:var(--gutter)}
.belief .sig-r .amb{
  color:var(--abyss);
}

.cap-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
  perspective: 1200px;
  transform-style: preserve-3d;
}
@media (max-width: 1200px) {
  .cap-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 768px) {
  .cap-grid {
    grid-template-columns: 1fr;
  }
}
.cap-card{
  background:linear-gradient(180deg, var(--hull-2) 0%, var(--abyss-2) 100%);
  border:1px solid var(--steel);
  padding:40px 36px 36px;display:flex;flex-direction:column;gap:24px;min-height:480px;
  position:relative;transition:border-color .3s ease;
  overflow:hidden;
  z-index: 1;
  will-change: transform;
}
.cap-card:hover{border-color:var(--amber)}

.cap-card-bg {
  position: absolute;
  inset: -60px 0; /* extra vertical height for scroll parallax */
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  z-index: 0;
  opacity: 0.36; /* significantly increased base opacity to make images highly evident */
  background-color: #06080a;
  transition: opacity 0.4s ease, filter 0.4s ease, border-color 0.4s ease;
  filter: saturate(0.4) contrast(1.15) brightness(0.9);
  pointer-events: none;
  will-change: transform;
}

/* Vector wireframe technical grid fallback - layers beautifully behind/with the image */
.cap-card-bg::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: 
    linear-gradient(rgba(0, 255, 102, 0.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0, 255, 102, 0.035) 1px, transparent 1px);
  background-size: 24px 24px;
  z-index: 1;
  pointer-events: none;
}

.cap-card:hover .cap-card-bg {
  opacity: 0.68; /* highly detailed hover opacity */
  filter: saturate(0.85) contrast(1.2) brightness(0.95);
}

.cap-card * {
  position: relative;
  z-index: 2;
}

.cap-card .cap-card-bg {
  position: absolute;
  z-index: 0;
}

.cap-card .code{font-family:var(--mono);font-size:11px;letter-spacing:.26em;color:var(--amber);font-weight:500}
.cap-card .kicker-line{font-family:var(--mono);font-size:11px;letter-spacing:.22em;color:var(--fog);text-transform:uppercase;font-weight:500}
.cap-card .title{font-family:var(--serif);font-size:46px;line-height:1;color:var(--bone);font-weight:400;letter-spacing:-.012em;margin-top:8px}
.cap-card .title em{font-style:italic;color:#00ff66}
.cap-card .desc{font-size:14px;line-height:1.65;color:var(--bone-dim);max-width:340px;font-weight:300}
.cap-card .tags{font-family:var(--mono);font-size:10.5px;letter-spacing:.14em;color:var(--fog);line-height:1.85;text-transform:uppercase;padding-top:24px;border-top:1px solid var(--steel)}
.cap-card .foot{margin-top:auto;display:flex;justify-content:space-between;align-items:center;padding-top:24px;border-top:1px solid var(--steel)}
.cap-card .foot a{font-family:var(--mono);font-size:11px;letter-spacing:.22em;color:var(--bone);text-decoration:none;text-transform:uppercase;font-weight:500;display:inline-flex;align-items:center;gap:10px}
.cap-card .foot a .arr{color:var(--amber);transition:transform .25s ease}
.cap-card .foot a:hover .arr{transform:translateX(4px)}
.cap-card .marker{
  position:absolute;top:36px;right:36px;width:10px;height:10px;border:1px solid var(--steel-3);
  z-index: 3;
}
.cap-card:hover .marker{background:var(--amber);border-color:var(--amber)}

.cap-card .glyph{
  position:absolute;top:36px;right:64px;
  font-family:var(--serif);font-style:italic;font-size:80px;color:rgba(232,226,216,.06);line-height:1;pointer-events:none;
  z-index: 1;
}

.cap-foot{margin-top:48px;display:flex;justify-content:space-between;align-items:center;border-top:1px solid var(--steel);padding-top:28px}

/* ============ CAPABILITIES (INVERTED) ============ */
#capabilities {
  background: var(--amber);
  color: var(--abyss);
  border-top: 1px solid var(--abyss);
  border-bottom: 1px solid var(--abyss);
  position: relative;
  overflow: hidden;
}

/* Nautical cartography background texture */
#capabilities::before {
  content: "";
  position: absolute;
  inset: 0;
  background: url('assets/bg-capabilities.png') center / cover no-repeat;
  opacity: 0.18;
  mix-blend-mode: multiply;
  pointer-events: none;
  z-index: 0;
}

/* Dark vignette overlay for depth */
#capabilities::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 80% 60% at 50% 50%, transparent 30%, rgba(0, 180, 60, 0.25) 100%);
  pointer-events: none;
  z-index: 0;
}

/* Ensure all content sits above background layers */
#capabilities > * {
  position: relative;
  z-index: 1;
}

#capabilities .section-head {
  border-bottom-color: rgba(8, 10, 10, 0.15);
}

#capabilities .section-head h2 {
  color: var(--abyss);
}

#capabilities .section-head h2 em {
  color: var(--abyss);
  text-shadow: none;
}

#capabilities .section-head .right {
  color: rgba(8, 10, 10, 0.8);
}

#capabilities .kicker {
  color: var(--abyss);
}

#capabilities .kicker::before {
  background: var(--abyss);
}

#capabilities .kicker .num {
  color: rgba(8, 10, 10, 0.5);
}

/* Cards with strong left border accent — bold, structured, premium */
#capabilities .cap-card {
  background: #06080a;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  border: 1.5px solid #000000;
  border-left: 6px solid #000000;
  box-shadow: 0 16px 40px rgba(0, 0, 0, 0.35);
  transition: border-color .35s ease, background .35s ease, box-shadow .35s ease, transform .35s ease;
}

#capabilities .cap-card:hover {
  background: #090c0f;
  border-color: #000000;
  border-left-color: #00ff66;
  box-shadow: 0 28px 70px rgba(0, 0, 0, 0.5);
  transform: translateY(-6px);
}

/* Large prominent code/number — visual anchor */
#capabilities .cap-card .code {
  color: #e8e2d8;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: .3em;
  opacity: 0.95;
}

#capabilities .cap-card .kicker-line {
  color: rgba(232, 226, 216, 0.5);
}

#capabilities .cap-card .title {
  color: #e8e2d8;
}

#capabilities .cap-card .title em {
  color: #00ff66;
  text-shadow: 0 0 20px rgba(0, 255, 102, 0.2);
}

#capabilities .cap-card .desc {
  color: rgba(232, 226, 216, 0.75);
}

#capabilities .cap-card .tags {
  color: rgba(232, 226, 216, 0.45);
  border-top-color: rgba(232, 226, 216, 0.1);
}

#capabilities .cap-card .foot {
  border-top-color: rgba(232, 226, 216, 0.1);
}

#capabilities .cap-card .foot a {
  color: #e8e2d8;
}

#capabilities .cap-card .foot a .arr {
  color: #00ff66;
}

#capabilities .cap-card .marker {
  border-color: rgba(232, 226, 216, 0.2);
}

#capabilities .cap-card:hover .marker {
  background: #00ff66;
  border-color: #00ff66;
}

/* Glyph subtle on dark card */
#capabilities .cap-card .glyph {
  color: rgba(232, 226, 216, 0.05);
}

/* Background images — now more visible inside the darker cards */
#capabilities .cap-card-bg {
  opacity: 0.25;
  filter: saturate(0.3) contrast(1.3) brightness(0.5);
}

#capabilities .cap-card:hover .cap-card-bg {
  opacity: 0.4;
  filter: saturate(0.6) contrast(1.25) brightness(0.55);
}

#capabilities .cap-card-bg::before {
  background-image:
    linear-gradient(rgba(0, 255, 102, 0.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0, 255, 102, 0.025) 1px, transparent 1px);
}

#capabilities .cap-foot {
  border-top-color: rgba(8, 10, 10, 0.15);
}

#capabilities .cap-foot .mono-sm {
  color: rgba(8, 10, 10, 0.6);
}

/* ============ INTELLIGENCE ON BOARD ============ */
.intel{
  padding:clamp(96px, 11vw, 160px) var(--gutter);
  background:var(--abyss);
  border-top:1px solid var(--steel);
}
.intel .row{display:grid;grid-template-columns:1fr 1.05fr;gap:60px;align-items:start}
.intel h2{font-size:clamp(44px, 6vw, 84px);line-height:1;letter-spacing:-.014em;font-weight:400}
.intel h2 em{font-style:italic;color:#00ff66;text-shadow:0 0 24px rgba(0,255,102,.25)}
.intel .lede{font-size:15px;line-height:1.7;color:var(--bone-dim);max-width:520px;margin-top:36px;font-weight:300}
.intel .lede em{font-style:italic;color:var(--bone)}
.intel .sig{margin-top:48px;display:flex;align-items:center;gap:18px}
.intel .sig .pulse-dot{width:8px;height:8px;background:var(--amber);border-radius:50%;animation:pulse 2.4s infinite;box-shadow:0 0 12px rgba(0,255,102,.6)}
.intel .sig .text{font-family:var(--mono);font-size:11px;letter-spacing:.24em;color:var(--bone-dim);text-transform:uppercase;font-weight:500}

.flow{
  background:linear-gradient(180deg, var(--hull-2) 0%, var(--abyss-2) 100%);
  border:1px solid var(--steel);padding:40px;
  display:flex;flex-direction:column;gap:36px;position:relative;overflow:hidden;
}
.flow::before{
  content:"";position:absolute;left:0;right:0;top:0;height:1px;
  background:linear-gradient(90deg, transparent, var(--amber), transparent);
  opacity:.4;
}
.flow .flow-head{display:flex;justify-content:space-between;font-family:var(--mono);font-size:10px;letter-spacing:.24em;color:var(--fog);text-transform:uppercase}
.flow .flow-head .live{color:var(--amber);display:flex;gap:8px;align-items:center}
.flow .flow-head .live::before{content:"";width:6px;height:6px;background:var(--amber);border-radius:50%;animation:pulse 1.8s infinite}

.stations{position:relative;display:grid;grid-template-columns:repeat(5,1fr);gap:0;padding-top:24px}
.stations .track{
  position:absolute;left:5%;right:5%;top:28px;height:1px;background:var(--steel-3);z-index:0;
}
.stations .track .pulse-line{
  position:absolute;left:0;top:-1px;height:3px;width:18%;
  background:linear-gradient(90deg, transparent, var(--amber), transparent);
  animation:slide 3.6s ease-in-out infinite;
  filter:blur(.5px);
}
@keyframes slide{
  0%{left:-18%}
  100%{left:100%}
}
.station{position:relative;z-index:1;text-align:left}
.station .dot{
  width:14px;height:14px;border-radius:50%;background:var(--abyss);border:1px solid var(--fog-2);
  margin-bottom:18px;display:block;position:relative;
}
.station .dot::after{content:"";position:absolute;inset:3px;border-radius:50%;background:transparent}
.station.active .dot{border-color:var(--amber)}
.station.active .dot::after{background:var(--amber);box-shadow:0 0 8px rgba(0,255,102,.6)}
.station .num{font-family:var(--mono);font-size:9px;letter-spacing:.24em;color:var(--fog-2);text-transform:uppercase;margin-bottom:4px}
.station .name{font-family:var(--mono);font-size:12px;letter-spacing:.18em;color:var(--bone);text-transform:uppercase;font-weight:500}

.flow .center-label{
  text-align:center;font-family:var(--mono);font-size:10px;letter-spacing:.3em;color:var(--amber);text-transform:uppercase;
  border-top:1px dashed var(--steel-3);border-bottom:1px dashed var(--steel-3);padding:14px 0;
}
.flow .micro{display:grid;grid-template-columns:repeat(5,1fr);gap:8px}
.flow .micro .item{padding-top:14px;border-top:1px solid var(--steel)}
.flow .micro .item .h{font-family:var(--mono);font-size:10px;letter-spacing:.22em;color:var(--bone);text-transform:uppercase;margin-bottom:8px;font-weight:500}
.flow .micro .item .t{font-size:12px;line-height:1.55;color:var(--fog);font-weight:300}

.intel .protect{
  margin-top:80px;border-top:1px solid var(--steel);padding-top:40px;
  display:grid;grid-template-columns:1.4fr 1fr;gap:60px;align-items:end;
}
.intel .protect .quote{
  font-family:var(--serif);font-size:32px;line-height:1.25;color:var(--bone-dim);font-style:italic;max-width:780px;font-weight:400;
}
.intel .protect .quote em{color:var(--bone);font-style:italic}
.intel .protect .stamp{
  font-family:var(--mono);font-size:10px;letter-spacing:.28em;color:var(--fog-2);text-transform:uppercase;text-align:right;line-height:1.8;
}
.intel .protect .stamp span{color:var(--amber)}

/* ============ THE CROSSING ============ */
.crossing{
  border-top:1px solid var(--steel);background:var(--abyss);
  position:relative;
  height:max(260vh, 2000px);
  padding:0;
}
.crossing-pin{
  position:sticky;top:0;
  height:100vh;
  padding:clamp(64px, 7vw, 96px) var(--gutter) clamp(36px, 4vw, 56px);
  display:flex;flex-direction:column;justify-content:center;gap:clamp(20px, 2.5vw, 40px);
  overflow:hidden;
}
.crossing-pin .section-head{
  margin-bottom:0;padding-bottom:0;border-bottom:0;
  grid-template-columns:1fr 360px;
}
.crossing-pin .section-head h2{font-size:clamp(32px, 4.4vw, 64px);line-height:1.02}

.crossing-intro{display:flex;flex-direction:column;gap:14px;padding-bottom:6px}
.crossing-intro .right{margin:0}
.crossing-intro .ai-stamp{
  display:flex;align-items:center;gap:10px;
  padding:10px 14px;border:1px solid var(--steel);align-self:flex-start;
  background:rgba(0,255,102,.03);
}
.crossing-intro .ai-stamp .pulse-dot{
  width:7px;height:7px;background:var(--amber);border-radius:50%;
  animation:pulse 2.4s infinite;box-shadow:0 0 8px rgba(0,255,102,.6);
}
.crossing-intro .ai-stamp-text{
  font-family:var(--mono);font-size:9.5px;letter-spacing:.26em;color:var(--amber);text-transform:uppercase;font-weight:500;
}

.timeline{margin-top:0;position:relative}
.timeline .axis-wrap{margin:clamp(20px, 2.5vw, 36px) 0 clamp(14px, 1.8vw, 24px)}

/* Stop layers — creative + AI */
.crossing-pin .stop h4{font-size:clamp(22px, 2.4vw, 32px);margin-bottom:10px}
.crossing-pin .stop .verb{font-size:9.5px;margin-bottom:14px;letter-spacing:.18em}
.stop-layers{display:flex;flex-direction:column;gap:10px;margin-bottom:14px}
.layer-creative,.layer-ai{
  display:flex;flex-direction:column;gap:4px;
  padding:8px 0;
}
.layer-ai{border-top:1px dashed var(--steel-3)}
.layer-tag{
  font-family:var(--mono);font-size:8.5px;letter-spacing:.22em;text-transform:uppercase;font-weight:500;
  color:var(--fog);
  display:inline-flex;align-items:center;gap:6px;
}
.layer-ai .layer-tag{color:var(--amber)}
.layer-ai .dot-ai{
  width:5px;height:5px;background:var(--amber);border-radius:50%;display:inline-block;
  box-shadow:0 0 5px rgba(0,255,102,.7);
  animation:pulse 2.4s infinite;
}
.layer-creative p,.layer-ai p{font-size:11.5px;line-height:1.5;color:var(--fog);font-weight:300;margin:0}
.layer-ai p{color:var(--bone-dim)}

.crossing-pin .stop .tags{margin-top:0;padding-top:10px;font-size:9px;letter-spacing:.16em}
.crossing-pin .crossing-foot{margin-top:0;padding-top:14px}
.timeline .axis-wrap{position:relative;height:32px;margin:80px 0 36px}
.timeline .axis{position:absolute;left:0;right:0;top:50%;height:1px;background:var(--steel-3)}
.timeline .axis-overlay{
  position:absolute;left:0;top:50%;height:1px;background:var(--amber);width:0;
  box-shadow:0 0 10px rgba(0,255,102,.5);
  transition:width .25s cubic-bezier(.2,.7,.2,1);
}
.timeline .axis-wrap .dot{
  position:absolute;top:50%;transform:translate(-50%,-50%);
  width:14px;height:14px;border-radius:50%;
  background:var(--abyss);border:1px solid var(--fog-2);
  transition:background .35s ease, border-color .35s ease, box-shadow .35s ease;
}
.timeline .axis-wrap .dot.active{
  background:var(--amber);border-color:var(--amber);
  box-shadow:0 0 12px rgba(0,255,102,.7);
}
.timeline .axis-wrap .dot.active::after{
  content:"";position:absolute;inset:-6px;border:1px solid var(--amber);border-radius:50%;
  opacity:0;animation:dotPulse 1.8s ease-out infinite;
}
@keyframes dotPulse{
  0%{opacity:.7;transform:scale(.7)}
  100%{opacity:0;transform:scale(1.7)}
}
.timeline .axis-wrap .label{
  position:absolute;top:24px;transform:translateX(-50%);
  font-family:var(--mono);font-size:9.5px;letter-spacing:.22em;color:var(--fog-2);text-transform:uppercase;white-space:nowrap;
}

.stops{display:grid;grid-template-columns:repeat(5,1fr);gap:24px}
.stop{padding-right:24px;position:relative;opacity:.32;filter:saturate(.6);
  transition:opacity .7s cubic-bezier(.2,.7,.2,1), filter .7s ease;
}
.stop.active{opacity:1;filter:saturate(1)}
.stop .num{font-family:var(--mono);font-size:11px;letter-spacing:.24em;color:var(--amber);margin-bottom:14px;font-weight:500}
.stop h4{font-family:var(--serif);font-weight:400;font-size:42px;letter-spacing:-.012em;color:var(--bone);line-height:1;margin-bottom:18px}
.stop h4 em{font-style:italic;color:#00ff66}
.stop .verb{font-family:var(--mono);font-size:10.5px;letter-spacing:.2em;color:var(--bone-dim);text-transform:uppercase;margin-bottom:18px;font-weight:500}
.stop .body{font-size:13px;line-height:1.65;color:var(--fog);max-width:220px;font-weight:300}
.stop .tags{margin-top:22px;font-family:var(--mono);font-size:10px;letter-spacing:.16em;color:var(--fog-2);text-transform:uppercase;line-height:1.85;font-weight:500;padding-top:18px;border-top:1px solid var(--steel)}

.crossing-foot{margin-top:64px;display:flex;justify-content:space-between;align-items:center;border-top:1px solid var(--steel);padding-top:28px}

/* ============ FEATURED CROSSING ============ */
.featured{
  padding:clamp(96px, 11vw, 160px) var(--gutter);border-top:1px solid var(--steel);
  background:var(--abyss);
  position:relative;
  overflow:hidden;
}
.featured .head{
  display:grid;grid-template-columns:1fr 320px;gap:60px;align-items:end;
  margin-bottom:56px;border-bottom:1px solid var(--steel);padding-bottom:48px;
  position:relative;
  z-index:3;
}
.featured h2{font-size:clamp(44px, 6vw, 84px);line-height:1;letter-spacing:-.014em;font-weight:400}
.featured h2 em{font-style:italic;color:#00ff66;text-shadow:0 0 24px rgba(0,255,102,.25)}
.featured .lede{font-size:14.5px;line-height:1.65;color:var(--fog);padding-bottom:8px;font-weight:300}

.featured .body{
  display:grid;grid-template-columns:1fr 360px;gap:60px;align-items:end;
  position:relative;
  z-index:3;
}
.featured .ph-large{
  height:560px;
  position:relative;
  border:1px solid var(--steel-3);
  overflow:hidden;
  background:rgba(7, 10, 14, 0.45);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}
.featured .ph-large .badge-tl{position:absolute;top:20px;left:20px;z-index:5;font-family:var(--mono);font-size:10px;letter-spacing:.24em;color:var(--bone-dim);text-transform:uppercase}
.featured .ph-large .badge-tr{position:absolute;top:20px;right:20px;z-index:5;display:flex;gap:8px;align-items:center;font-family:var(--mono);font-size:10px;letter-spacing:.24em;color:var(--amber);text-transform:uppercase}
.featured .ph-large .badge-tr::before{content:"";width:6px;height:6px;background:var(--amber);border-radius:50%;animation:pulse 2s infinite}
.featured .ph-large .stamp-bl{position:absolute;bottom:20px;left:20px;z-index:5;font-family:var(--mono);font-size:9.5px;letter-spacing:.22em;color:var(--fog-2);text-transform:uppercase;line-height:1.7}
.featured .ph-large .stamp-br{position:absolute;bottom:20px;right:20px;z-index:5;font-family:var(--mono);font-size:9.5px;letter-spacing:.22em;color:var(--fog-2);text-transform:uppercase;text-align:right;line-height:1.7}
/* Agent system background and showcase */
.agent-bg-video-container {
  position: absolute;
  inset: 0;
  overflow: hidden;
  background: #030508;
  z-index: 1;
}

.agent-bg-video {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transform: translate(-50%, -50%);
  opacity: 0.18;
  filter: saturate(0.1) contrast(1.15) brightness(0.85);
}

.agent-bg-texture {
  position: absolute;
  inset: 0;
  background: 
    radial-gradient(circle at center, transparent 20%, rgba(3, 5, 8, 0.95) 90%),
    linear-gradient(rgba(18, 18, 18, 0) 50%, rgba(0, 0, 0, 0.45) 50%),
    linear-gradient(90deg, rgba(255, 255, 255, 0.02) 1px, transparent 1px),
    linear-gradient(0deg, rgba(255, 255, 255, 0.02) 1px, transparent 1px);
  background-size: 100% 100%, 100% 4px, 40px 40px, 40px 40px;
  z-index: 2;
  pointer-events: none;
}

/* Corsário Vision Simulated Dashboard */
.corsario-dashboard {
  position: absolute;
  inset: 0;
  display: grid;
  grid-template-columns: 1.2fr 0.8fr;
  padding: 60px 40px 40px;
  gap: 30px;
  box-sizing: border-box;
  z-index: 3;
}

.corsario-chat {
  display: flex;
  flex-direction: column;
  height: 100%;
  border-right: 1px solid var(--steel-3);
  padding-right: 25px;
}

.chat-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 20px;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--steel-3);
}

.chat-title {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  color: var(--bone);
  text-transform: uppercase;
}

.chat-status {
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: 0.15em;
  color: #00ff66;
  display: flex;
  align-items: center;
  gap: 6px;
}

.chat-status .pulse-dot {
  width: 5px;
  height: 5px;
  background: #00ff66;
  border-radius: 50%;
  animation: pulse-green 1.5s infinite;
}

.chat-messages {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 16px;
  overflow-y: auto;
  scroll-behavior: smooth;
  max-height: 360px;
}

.chat-messages::-webkit-scrollbar {
  display: none;
}

.msg {
  font-family: var(--sans);
  font-size: 13px;
  line-height: 1.5;
  color: var(--bone-dim);
}

.msg .sender {
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: 0.2em;
  display: block;
  margin-bottom: 4px;
}

.msg.user-msg .sender {
  color: var(--amber);
}

.msg.user-msg p {
  color: var(--bone);
  background: rgba(250, 208, 44, 0.05);
  padding: 8px 12px;
  border-radius: 4px;
  border-left: 2px solid var(--amber);
  margin: 0;
}

.msg.agent-msg .sender {
  color: #00ff66;
}

.msg.agent-msg p {
  margin: 0 0 6px 0;
}

.msg.agent-msg p:last-child {
  margin-bottom: 0;
}

.thought-badge {
  display: inline-block;
  font-family: var(--mono);
  font-size: 8.5px;
  letter-spacing: 0.15em;
  color: var(--fog-2);
  background: rgba(255, 255, 255, 0.04);
  padding: 4px 8px;
  border-radius: 2px;
  margin-bottom: 6px;
  text-transform: uppercase;
  border: 1px solid var(--steel-3);
}

/* Animations for simulated conversation */
.msg.user-msg {
  animation: chatFadeIn 1s cubic-bezier(0.2, 0.8, 0.2, 1) forwards;
  opacity: 0;
}

.msg.step-1 {
  animation: chatFadeIn 1.2s cubic-bezier(0.2, 0.8, 0.2, 1) forwards;
  animation-delay: 2.5s;
  opacity: 0;
}

.msg.step-2 {
  animation: chatFadeIn 1.2s cubic-bezier(0.2, 0.8, 0.2, 1) forwards;
  animation-delay: 6s;
  opacity: 0;
}

@keyframes chatFadeIn {
  to {
    opacity: 1;
    transform: translateY(0);
  }
  from {
    opacity: 0;
    transform: translateY(8px);
  }
}

/* Right column preview canvas */
.corsario-canvas {
  display: flex;
  flex-direction: column;
  height: 100%;
}

.canvas-header {
  display: flex;
  justify-content: space-between;
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: 0.2em;
  color: var(--fog-2);
  margin-bottom: 12px;
  padding-bottom: 8px;
  border-bottom: 1px dashed var(--steel-3);
}

.canvas-slide-wrapper {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
}

.canvas-slide {
  width: 100%;
  aspect-ratio: 1 / 1;
  max-width: 300px;
  background: #0b0c0e;
  border: 1px solid var(--steel-3);
  border-radius: 8px;
  position: relative;
  padding: 24px;
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  box-shadow: 0 20px 40px rgba(0, 0, 0, 0.6), inset 0 0 40px rgba(0,0,0,0.8);
  opacity: 0;
  transform: scale(0.95) translateX(10px);
  animation: slideAppear 1.5s cubic-bezier(0.15, 0.85, 0.15, 1) forwards;
  animation-delay: 7.5s;
  overflow: hidden;
}

/* Texture pattern on slide to match the screenshot */
.canvas-slide::before {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  width: 40%;
  background: 
    linear-gradient(90deg, rgba(11, 12, 14, 1) 0%, rgba(11, 12, 14, 0.3) 100%),
    repeating-linear-gradient(45deg, var(--slide-art-color, rgba(250, 208, 44, 0.04)) 0px, var(--slide-art-color, rgba(250, 208, 44, 0.04)) 2px, transparent 2px, transparent 10px);
  z-index: 1;
  border-left: 1px solid rgba(255, 255, 255, 0.05);
}

.canvas-slide * {
  z-index: 2;
}

@keyframes slideAppear {
  to {
    opacity: 1;
    transform: scale(1) translateX(0);
    box-shadow: 0 0 30px rgba(0, 255, 102, 0.15), 0 20px 40px rgba(0, 0, 0, 0.7);
  }
}

.slide-tag {
  font-family: var(--mono);
  font-size: 8px;
  letter-spacing: 0.2em;
  color: var(--amber);
  background: rgba(250, 208, 44, 0.08);
  padding: 4px 8px;
  border-radius: 2px;
  width: fit-content;
}

.slide-headline {
  font-family: var(--sans);
  font-weight: 800;
  font-size: 18px;
  line-height: 1.15;
  color: var(--bone);
  letter-spacing: -0.02em;
  margin: auto 0;
  text-transform: uppercase;
}

.slide-headline span.white-highlight {
  color: var(--bone);
}

.slide-headline span.yellow-highlight {
  color: #fad02c;
}

.slide-footer {
  display: flex;
  justify-content: space-between;
  font-family: var(--mono);
  font-size: 7px;
  letter-spacing: 0.1em;
  color: var(--fog-2);
  border-top: 1px solid rgba(255, 255, 255, 0.05);
  padding-top: 8px;
}

.agent-status-row {
  display: flex;
  gap: 16px;
  align-self: flex-end;
  margin-top: 10px;
}

.agent-status-row .mono-tag {
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: 0.2em;
  color: var(--fog-2);
  text-transform: uppercase;
  background: rgba(0, 0, 0, 0.3);
  border: 1px solid var(--steel-3);
  padding: 6px 12px;
  border-radius: 2px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.agent-status-row .mono-tag.active {
  color: #00ff66;
  border-color: rgba(0, 255, 102, 0.25);
  background: rgba(0, 255, 102, 0.03);
}

.agent-status-row .mono-tag.active::before {
  content: "";
  width: 5px;
  height: 5px;
  background: #00ff66;
  border-radius: 50%;
  animation: pulse-green 1.5s infinite;
}

@keyframes pulse-green {
  0% { transform: scale(0.9); opacity: 0.6; }
  50% { transform: scale(1.3); opacity: 1; box-shadow: 0 0 8px #00ff66; }
  100% { transform: scale(0.9); opacity: 0.6; }
}


.featured .info{display:flex;flex-direction:column;gap:24px;padding-bottom:8px}
.featured .info .proj-code{font-family:var(--mono);font-size:11px;letter-spacing:.24em;color:var(--amber);text-transform:uppercase;font-weight:500}
.featured .info .proj-name{font-family:var(--serif);font-size:84px;color:var(--bone);line-height:.92;letter-spacing:-.022em;font-weight:400;font-style:italic}
.featured .info .proj-desc{font-size:14.5px;line-height:1.65;color:var(--bone-dim);font-weight:300}
.featured .info .proj-tags{font-family:var(--mono);font-size:10.5px;letter-spacing:.16em;color:var(--fog);text-transform:uppercase;padding-top:20px;border-top:1px solid var(--steel)}
.featured .info .actions-row{display:flex;justify-content:space-between;align-items:center;margin-top:6px}

/* ============ ABOUT ============ */
.about{padding:clamp(120px, 13vw, 200px) var(--gutter);border-top:1px solid var(--steel)}
.about .row{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:end}
.about .label{margin-bottom:40px}
.about h2{font-size:clamp(52px, 6.8vw, 100px);line-height:1.02;letter-spacing:-.018em;font-weight:400}
.about h2 em{font-style:italic;color:#00ff66;text-shadow:0 0 28px rgba(0,255,102,.28)}
.about .body{padding-bottom:8px}
.about .body p{font-size:15.5px;line-height:1.75;color:var(--bone-dim);margin-bottom:20px;max-width:520px;font-weight:300}
.about .body p:nth-child(2){color:var(--fog)}
.about .body .cta{margin-top:24px;display:flex;gap:12px;align-items:center}
.about .body .cta .sep{font-family:var(--mono);font-size:10px;letter-spacing:.22em;color:var(--fog-2);text-transform:uppercase}

.about-symbol{
  margin-top:96px;display:grid;grid-template-columns:1fr 320px;gap:60px;align-items:stretch;
  border-top:1px solid var(--steel);padding-top:48px;
}
.ds-signal{
  height:260px;border:1px solid var(--steel);position:relative;overflow:hidden;
  background:radial-gradient(60% 80% at 50% 50%, rgba(0,255,102,.07), transparent 70%), var(--hull-2);
  display:grid;place-items:center;
}
.ds-signal svg{width:160px;height:160px}
.ds-signal .corner-tl,.ds-signal .corner-tr,.ds-signal .corner-bl,.ds-signal .corner-br{
  position:absolute;width:14px;height:14px;
}
.ds-signal .corner-tl{top:14px;left:14px;border-top:1px solid var(--bone-dim);border-left:1px solid var(--bone-dim)}
.ds-signal .corner-tr{top:14px;right:14px;border-top:1px solid var(--bone-dim);border-right:1px solid var(--bone-dim)}
.ds-signal .corner-bl{bottom:14px;left:14px;border-bottom:1px solid var(--bone-dim);border-left:1px solid var(--bone-dim)}
.ds-signal .corner-br{bottom:14px;right:14px;border-bottom:1px solid var(--bone-dim);border-right:1px solid var(--bone-dim)}
.ds-signal .stamp{position:absolute;bottom:18px;left:50%;transform:translateX(-50%);font-family:var(--mono);font-size:9.5px;letter-spacing:.3em;color:var(--fog-2);text-transform:uppercase;white-space:nowrap}
.ds-signal .stamp-tr{position:absolute;top:18px;right:24px;font-family:var(--mono);font-size:9.5px;letter-spacing:.22em;color:var(--amber);text-transform:uppercase}

.about-caption{
  font-family:var(--mono);font-size:11px;letter-spacing:.22em;color:var(--fog);text-transform:uppercase;line-height:1.85;display:flex;flex-direction:column;justify-content:center;gap:12px;
}
.about-caption .h{color:var(--bone-dim);font-size:12px;letter-spacing:.24em}
.about-caption .meta{font-size:10px;letter-spacing:.22em;color:var(--fog-2);border-top:1px solid var(--steel);padding-top:14px;margin-top:6px}

/* ============ FINAL CTA ============ */
.final{
  padding:clamp(120px, 14vw, 200px) var(--gutter) clamp(96px, 11vw, 160px);border-top:1px solid var(--steel);
  background:var(--abyss);
  position:relative;
}
.final .label{margin-bottom:56px}
.final h2{font-size:clamp(72px, 10vw, 152px);line-height:.95;letter-spacing:-.022em;font-weight:400;max-width:1240px}
.final h2 em{font-style:italic;color:#00ff66;text-shadow:0 0 36px rgba(0,255,102,.32)}
.final .row{margin-top:80px;display:grid;grid-template-columns:1fr 360px;gap:80px;align-items:end;border-top:1px solid var(--steel);padding-top:40px}
.final .lede{font-size:15.5px;line-height:1.7;color:var(--fog);max-width:580px;font-weight:300}
.final .lede em{color:var(--bone);font-style:italic}
.final .actions{display:flex;flex-direction:column;gap:14px;align-items:flex-end}
.final .actions .btn-primary{padding:20px 28px;font-size:12px}
.final .actions .note{font-family:var(--mono);font-size:9.5px;letter-spacing:.22em;color:var(--fog-2);text-transform:uppercase;text-align:right}

.final .horizon-bottom{margin-top:100px;height:24px;position:relative}
.final .horizon-bottom::before{content:"";position:absolute;left:0;right:0;top:50%;height:1px;background:var(--steel)}
.final .horizon-bottom::after{content:"";position:absolute;left:0;top:50%;height:1px;width:62%;background:var(--amber);box-shadow:0 0 10px rgba(0,255,102,.4)}
.final .coords{
  position:absolute;width:100%;display:flex;justify-content:space-between;align-items:center;top:-20px;
  font-family:var(--mono);font-size:10px;letter-spacing:.22em;color:var(--fog-2);text-transform:uppercase;
}
.final .coords .center{color:var(--bone-dim)}

/* ============ FOOTER ============ */
footer.ftr{
  padding:clamp(64px, 8vw, 96px) var(--gutter) 40px;
  background:#050606;border-top:1px solid var(--steel);
  position:relative;
}

.ftr .top{
  display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:60px;
  border-bottom:1px solid var(--steel);padding:48px 0;
}
.ftr .brand-col h3{
  display:inline-block;margin-bottom:14px;
}
.ftr .brand-col h3 .brand-logo{height:54px;aspect-ratio: 105.22 / 28.54;display:block}
.ftr .brand-col .sig{font-family:var(--mono);font-size:11px;letter-spacing:.24em;color:var(--amber);margin-bottom:24px}
.ftr .brand-col p{font-size:14px;line-height:1.65;color:var(--fog);max-width:340px;font-weight:300}
.ftr .col h4{font-family:var(--mono);font-size:10px;letter-spacing:.28em;color:var(--fog-2);text-transform:uppercase;margin-bottom:20px;font-weight:500}
.ftr .col ul{list-style:none}
.ftr .col li{margin-bottom:11px}
.ftr .col a{font-family:var(--sans);font-size:14px;color:var(--bone-dim);text-decoration:none;letter-spacing:.005em;transition:color .2s ease}
.ftr .col a:hover{color:var(--bone)}
.ftr .col li.mono{font-family:var(--mono);font-size:11px;letter-spacing:.22em;color:var(--fog);text-transform:uppercase;margin-top:14px}

.ftr .bottom{
  margin-top:32px;display:flex;justify-content:space-between;align-items:center;gap:40px;
  font-family:var(--mono);font-size:10.5px;letter-spacing:.24em;color:var(--fog);text-transform:uppercase;font-weight:500;
}
.ftr .bottom .tag{color:var(--bone-dim)}
.ftr .bottom .closing{color:var(--amber)}

/* ---- Mobile Menu Hamburger Button ---- */
.menu-toggle {
  display: none;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 5px;
  width: 40px;
  height: 40px;
  background: transparent;
  border: 1px solid var(--steel);
  z-index: 100;
  padding: 0;
  transition: border-color 0.3s ease, background 0.3s ease;
}
.menu-toggle:hover {
  border-color: var(--bone);
  background: rgba(232, 226, 216, 0.04);
}
.menu-toggle .line {
  display: block;
  width: 18px;
  height: 1px;
  background: var(--bone);
  transition: transform 0.3s ease, background 0.3s ease;
}

/* ---- Mobile Menu Overlay ---- */
.mobile-menu-overlay {
  position: fixed;
  inset: 0;
  z-index: 150;
  background: rgba(8, 10, 10, 0.75);
  backdrop-filter: blur(24px) saturate(120%);
  -webkit-backdrop-filter: blur(24px) saturate(120%);
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.4s cubic-bezier(0.2, 0.8, 0.2, 1);
  display: flex;
  justify-content: flex-end;
}
.mobile-menu-overlay.open {
  opacity: 1;
  pointer-events: auto;
}
.mobile-menu-container {
  width: 100%;
  max-width: 400px;
  height: 100%;
  background: var(--abyss);
  border-left: 1px solid var(--steel);
  padding: 32px clamp(20px, 5vw, 40px) 48px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  transform: translateX(100%);
  transition: transform 0.5s cubic-bezier(0.2, 0.8, 0.2, 1);
}
.mobile-menu-overlay.open .mobile-menu-container {
  transform: translateX(0);
}
.mobile-menu-hdr {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 40px;
}
.mobile-menu-hdr .menu-close {
  background: transparent;
  border: 1px solid var(--steel);
  color: var(--bone-dim);
  font-size: 14px;
  width: 40px;
  height: 40px;
  display: grid;
  place-items: center;
  cursor: pointer;
  transition: border-color 0.3s ease, color 0.3s ease;
}
.mobile-menu-hdr .menu-close:hover {
  border-color: var(--bone);
  color: var(--bone);
}
.mobile-nav {
  display: flex;
  flex-direction: column;
  gap: 28px;
  margin-bottom: 40px;
}
.mobile-nav a {
  font-family: var(--mono);
  font-size: 16px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--bone-dim);
  text-decoration: none;
  font-weight: 500;
  display: inline-block;
  transition: color 0.3s ease, transform 0.3s ease;
  transform: translateX(20px);
  opacity: 0;
}
.mobile-menu-overlay.open .mobile-nav a {
  transform: translateX(0);
  opacity: 1;
}
.mobile-menu-overlay.open .mobile-nav a:nth-child(1) { transition: transform 0.4s 0.1s cubic-bezier(0.2, 0.8, 0.2, 1), opacity 0.4s 0.1s; }
.mobile-menu-overlay.open .mobile-nav a:nth-child(2) { transition: transform 0.4s 0.15s cubic-bezier(0.2, 0.8, 0.2, 1), opacity 0.4s 0.15s; }
.mobile-menu-overlay.open .mobile-nav a:nth-child(3) { transition: transform 0.4s 0.2s cubic-bezier(0.2, 0.8, 0.2, 1), opacity 0.4s 0.2s; }
.mobile-menu-overlay.open .mobile-nav a:nth-child(4) { transition: transform 0.4s 0.25s cubic-bezier(0.2, 0.8, 0.2, 1), opacity 0.4s 0.25s; }
.mobile-menu-overlay.open .mobile-nav a:nth-child(5) { transition: transform 0.4s 0.3s cubic-bezier(0.2, 0.8, 0.2, 1), opacity 0.4s 0.3s; }

.mobile-nav a:hover {
  color: var(--amber);
  transform: translateX(6px) !important;
}
.mobile-menu-ftr {
  display: flex;
  flex-direction: column;
  gap: 24px;
}
.mobile-menu-ftr .btn {
  width: 100%;
  justify-content: space-between;
}
.mobile-menu-ftr .coords {
  color: var(--fog-2);
  font-size: 11px;
}

/* ---- Language Switcher ---- */
.lang-switcher {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  margin-right: 12px;
}
.lang-btn {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.1em;
  color: var(--fog-2);
  background: transparent;
  border: none;
  cursor: pointer;
  transition: color 0.3s ease, text-shadow 0.3s ease;
  padding: 2px 4px;
}
.lang-btn.active {
  color: var(--amber);
  font-weight: 600;
  text-shadow: 0 0 8px rgba(0, 255, 102, 0.4);
}
.lang-btn:hover {
  color: var(--bone);
}
.lang-switcher .sep {
  font-family: var(--mono);
  font-size: 10px;
  color: var(--steel-3);
  pointer-events: none;
}

/* ---- Page Transition (Fade i18n) ---- */
.i18n-fade {
  transition: opacity 0.2s ease !important;
}
.i18n-hidden {
  opacity: 0 !important;
}

/* ============================================================
   RESPONSIVE BREAKPOINTS
   ============================================================ */

/* ---- Wide tablet & small desktop (≤1280px) ---- */
@media (max-width: 1280px){
  .hero .rail-row{grid-template-columns:minmax(0,1fr) 360px;gap:40px}
  .meta-top{grid-template-columns:repeat(2, auto) 1fr;gap:20px}
  .meta-top > div:nth-child(3),
  .meta-top > div:nth-child(4){display:none}
  .section-head{grid-template-columns:1fr 280px;gap:48px}
  .work-grid{gap:18px}
  .cap-grid{gap:18px}
  .cap-card{padding:32px 28px 28px;min-height:440px}
  .intel .row{gap:48px}
  .featured .body{grid-template-columns:1fr 320px;gap:40px}
  .featured .head{grid-template-columns:1fr 280px;gap:48px}
  .featured .ph-large{height:480px}
  .featured .info .proj-name{font-size:clamp(56px,7vw,72px)}
  .stop h4{font-size:36px}
  .about .row{gap:60px}
}

/* ---- Tablet (≤1024px) ---- */
@media (max-width: 1024px){
  .hero{min-height:680px;padding-bottom:64px}
  .hero h1{font-size:clamp(60px,10vw,108px)}
  .hero .rail-row{grid-template-columns:1fr;gap:32px}
  .hero .right-rail{align-items:flex-start}
  .meta-top{grid-template-columns:repeat(2, auto);gap:18px}
  .meta-top .session{grid-column:1 / -1;justify-self:start}
  .meta-top > div:nth-child(3),
  .meta-top > div:nth-child(4){display:block}
  .hero-foot{grid-template-columns:auto 1fr;gap:24px}
  .hero-foot .sig-corner{display:none}

  .hero-grid {
    grid-template-columns: 1fr !important;
    gap: 32px !important;
  }
  .hero-media-frame {
    position: absolute !important;
    inset: 0 !important;
    width: 100% !important;
    height: 100% !important;
    z-index: 1 !important;
    aspect-ratio: auto !important;
    transform: translate3d(0,0,0);
    -webkit-transform: translate3d(0,0,0);
  }
  .hero-media-frame::after {
    background: radial-gradient(circle at center, transparent 35%, rgba(8, 10, 10, 0.75) 90%) !important;
  }

  header.hdr nav{display:none}
  .menu-toggle{display:flex}
  header.hdr .actions .btn-primary{display:none !important}
  header.hdr .actions .progress{display:none}

  .section-head{grid-template-columns:1fr;gap:24px}
  .section-head .right{padding-bottom:0}

  .work-grid{grid-template-columns:repeat(2,1fr);min-width:0 !important;width:100% !important}
  .work-grid .card{min-width:0 !important;max-width:100% !important}
  .case-art{min-width:0 !important;max-width:100% !important}

  .belief .container{grid-template-columns:1fr;gap:32px}
  .belief .body{padding-top:0}

  .cap-grid{grid-template-columns:1fr;gap:18px}
  .cap-card{min-height:auto}

  .intel .row{grid-template-columns:1fr;gap:48px}
  .intel .protect{grid-template-columns:1fr;gap:24px}
  .intel .protect .stamp{text-align:left}

  .crossing{height:auto !important}
  .crossing-pin{position:relative !important;height:auto !important;top:auto !important;overflow:visible !important;padding:80px var(--gutter) 40px !important}
  .crossing-pin .section-head{grid-template-columns:1fr;gap:24px}
  .stops{grid-template-columns:repeat(2,1fr);gap:40px 24px}
  .stop{opacity:1 !important;filter:none !important}
  .timeline .axis-wrap{display:none}

  .featured .head{grid-template-columns:1fr;gap:24px}
  .featured .body{grid-template-columns:1fr;gap:32px}
  .featured .ph-large{height:auto !important;aspect-ratio:auto !important;padding:40px 20px !important}
  .agent-showcase {
    padding: 60px 24px !important;
    min-height: 440px !important;
    align-items: center !important;
    justify-content: space-between !important;
  }
  .agent-terminal {
    align-self: center !important;
    text-align: center !important;
    width: 100% !important;
    box-sizing: border-box !important;
  }
  .agent-status-row {
    align-self: center !important;
    margin-top: 20px !important;
    flex-wrap: wrap !important;
    justify-content: center !important;
  }
  .agent-title {
    font-size: 32px !important;
  }
  .agent-desc {
    font-size: 12.5px !important;
  }

  .about .row{grid-template-columns:1fr;gap:32px}
  .about-symbol{grid-template-columns:1fr;gap:32px}

  .final .row{grid-template-columns:1fr;gap:32px}
  .final .actions{align-items:flex-start}

  .ftr .top{grid-template-columns:1fr 1fr;gap:40px}
}

/* ---- Mobile (≤640px) ---- */
@media (max-width: 640px){
  body{cursor:auto}
  .cursor-dot,.cursor-ring{display:none}
  a, button, [data-cursor]{cursor:pointer}

  header.hdr nav{display:none}
  header.hdr{grid-template-columns:1fr auto;padding:14px 20px}
  header.hdr .actions .progress{display:none}
  header.hdr .actions .lang-switcher{display:none}
  header.hdr .actions .btn-primary{display:none !important}
  .btn{padding:12px 14px;font-size:10px;letter-spacing:.18em}

  .hero{min-height:560px;padding-top:96px}
  .hero h1{font-size:clamp(32px,11vw,54px)}
  .hero-video video, .slide-video-wrap video{object-position:40% center}
  .hero h1 span{white-space:normal !important;display:inline-block}
  .meta-top{grid-template-columns:1fr 1fr;padding:14px 0;gap:14px}
  .meta-top .session{display:none}
  .hero .ctas{flex-direction:column;align-items:stretch}
  .hero .ctas .btn{justify-content:space-between}
  .hero-foot{grid-template-columns:1fr;gap:18px}
  .hero-foot .horizon{display:none}
  .reserve{flex-direction:column;gap:6px}

  .work-grid{grid-template-columns:1fr;gap:32px;width:100% !important;min-width:0 !important}
  .work-grid .card{grid-column:1 / -1;min-width:0 !important;width:100% !important;max-width:100% !important}
  .case-art{min-width:0 !important;width:100% !important;max-width:100% !important}
  .case-title{font-size:22px}
  .case-foot{flex-direction:column;align-items:flex-start;gap:10px}

  .belief h2{font-size:clamp(36px,8vw,56px)}
  .stops{grid-template-columns:1fr;gap:32px}
  .stop{padding-right:0}

  .flow{padding:24px}
  .flow .stations{grid-template-columns:repeat(3,1fr);gap:18px 6px}
  .flow .micro{grid-template-columns:1fr 1fr;gap:12px}
  .flow .micro .item:last-child{grid-column:1 / -1}

  .section-head h2{font-size:clamp(32px, 8vw, 48px) !important}
  .featured .info .proj-name{font-size:clamp(48px,12vw,64px)}

  .about .body p{font-size:14.5px}
  .ds-signal svg{width:120px;height:120px}

  .about h2{font-size:clamp(32px, 8vw, 48px) !important}
  .final h2{font-size:clamp(32px, 9vw, 54px) !important}
  .final .row{padding-top:24px}
  .final .actions{width:100%}
  .final .actions .btn-primary{width:100%;justify-content:space-between}

  .ftr{padding:48px 20px 32px}
  .ftr .top{grid-template-columns:1fr;gap:32px}
}

/* Card video highlight animation */
.card .case-art video {
  transition: opacity 0.4s cubic-bezier(0.2, 0.8, 0.2, 1);
}
.card:hover .case-art video {
  opacity: 0.95 !important;
}

/* ============ FLOATING CHATBOT ("O TIMONEIRO") ============ */
.chatbot-container {
  position: fixed;
  bottom: 24px;
  right: 24px;
  z-index: 1000;
  font-family: var(--sans);
}

/* FAB (Floating Action Button) */
.chat-fab {
  background: var(--amber) !important;
  border: 1px solid var(--amber) !important;
  border-radius: 50%;
  width: 60px;
  height: 60px;
  cursor: pointer;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--abyss) !important;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.4), 0 0 25px rgba(0, 255, 102, 0.65) !important;
  transition: transform 0.3s cubic-bezier(0.2, 0.8, 0.2, 1), box-shadow 0.3s ease, border-color 0.3s ease, background 0.3s ease, color 0.3s ease;
  animation: fabFloat 4s ease-in-out infinite;
  padding: 0;
  outline: none;
}
.chat-fab:hover {
  border-color: var(--amber-2) !important;
  background: var(--amber-2) !important;
  color: var(--abyss) !important;
  box-shadow: 0 6px 24px rgba(0, 0, 0, 0.5), 0 0 35px rgba(0, 255, 102, 0.95) !important;
  transform: scale(1.08) translateY(-4px);
}
.chat-fab:active {
  transform: scale(0.95) translateY(0);
}
.chat-fab .fab-circle {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
}
.chat-fab .chat-icon {
  width: 26px;
  height: 26px;
  transition: transform 0.3s ease;
  color: var(--abyss) !important;
  stroke: var(--abyss) !important;
}
.chat-fab:hover .chat-icon {
  transform: rotate(-10deg) scale(1.1);
  color: var(--abyss) !important;
  stroke: var(--abyss) !important;
}

/* FAB Tooltip */
.fab-tooltip {
  position: absolute;
  right: 76px;
  top: 50%;
  transform: translateY(-50%) translateX(10px);
  background: rgba(10, 10, 12, 0.95);
  border: 1px solid var(--steel);
  border-radius: 4px;
  padding: 8px 14px;
  font-family: var(--mono);
  font-size: 11.5px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--bone);
  white-space: nowrap;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s ease, transform 0.3s cubic-bezier(0.2, 0.8, 0.2, 1);
  box-shadow: 0 4px 12px rgba(0,0,0,0.3);
}
.chat-fab:hover .fab-tooltip {
  opacity: 1;
  transform: translateY(-50%) translateX(0);
  border-color: rgba(173, 255, 47, 0.4);
}

/* FAB Floating Keyframe */
@keyframes fabFloat {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-6px); }
}

/* Chat Window Box */
.chat-window {
  position: absolute;
  bottom: 80px;
  right: 0;
  width: 380px;
  height: 520px;
  border-radius: 12px;
  border: 1px solid var(--steel);
  background: rgba(10, 10, 12, 0.88);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  box-shadow: 0 10px 40px rgba(0, 0, 0, 0.6), 0 0 30px rgba(173, 255, 47, 0.08);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  z-index: 1001;
  opacity: 0;
  transform: translateY(20px) scale(0.95);
  transform-origin: bottom right;
  pointer-events: none;
  transition: opacity 0.35s cubic-bezier(0.2, 0.8, 0.2, 1), transform 0.35s cubic-bezier(0.2, 0.8, 0.2, 1);
}
.chat-window.open {
  opacity: 1;
  transform: translateY(0) scale(1);
  pointer-events: auto;
}

/* Chat Header */
.chat-header {
  padding: 16px 20px;
  border-bottom: 1px solid var(--steel);
  display: flex;
  justify-content: space-between;
  align-items: center;
  background: rgba(16, 16, 20, 0.5);
}
.chat-header .bot-info {
  display: flex;
  align-items: center;
  gap: 12px;
}
.chat-header .bot-avatar {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: var(--steel-dim);
  border: 1px solid var(--steel);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 16px;
  position: relative;
}
.chat-header .bot-avatar .pulse-dot {
  position: absolute;
  bottom: 0;
  right: 0;
  width: 8px;
  height: 8px;
  background: var(--amber);
  border-radius: 50%;
  border: 1.5px solid rgba(10, 10, 12, 1);
  box-shadow: 0 0 8px var(--amber);
}
.chat-header .bot-name {
  font-family: var(--sans);
  font-size: 14.5px;
  font-weight: 500;
  color: var(--bone);
  margin: 0 0 2px 0;
}
.chat-header .bot-status {
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: 0.05em;
  color: var(--bone-dim);
  text-transform: uppercase;
}
.chat-header .chat-close {
  background: transparent;
  border: none;
  color: var(--bone-dim);
  font-size: 16px;
  cursor: pointer;
  padding: 4px;
  transition: color 0.2s ease, transform 0.2s ease;
}
.chat-header .chat-close:hover {
  color: var(--bone);
  transform: rotate(90deg);
}

/* Chat Messages Content */
.chat-messages {
  flex: 1;
  padding: 20px;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: 16px;
  scroll-behavior: smooth;
}
/* Scrollbar details */
.chat-messages::-webkit-scrollbar {
  width: 4px;
}
.chat-messages::-webkit-scrollbar-track {
  background: transparent;
}
.chat-messages::-webkit-scrollbar-thumb {
  background: var(--steel);
  border-radius: 2px;
}
.chat-messages::-webkit-scrollbar-thumb:hover {
  background: var(--bone-dim);
}

/* Message Bubbles */
.chat-bubble {
  max-width: 80%;
  padding: 12px 16px;
  border-radius: 10px;
  font-size: 13.5px;
  line-height: 1.5;
  animation: messageSlide 0.3s cubic-bezier(0.2, 0.8, 0.2, 1) forwards;
  word-wrap: break-word;
}
@keyframes messageSlide {
  from { opacity: 0; transform: translateY(10px); }
  to { opacity: 1; transform: translateY(0); }
}

.chat-bubble.bot {
  background: var(--steel-dim);
  border: 1px solid var(--steel);
  color: var(--bone);
  align-self: flex-start;
  border-top-left-radius: 2px;
}
.chat-bubble.user {
  background: rgba(173, 255, 47, 0.06);
  border: 1px solid rgba(173, 255, 47, 0.25);
  color: var(--bone);
  align-self: flex-end;
  border-top-right-radius: 2px;
}
.chat-bubble strong {
  color: var(--bone);
  font-weight: 600;
}
.chat-bubble a {
  color: var(--amber);
  text-decoration: underline;
  transition: opacity 0.2s ease;
}
.chat-bubble a:hover {
  opacity: 0.8;
}

/* Typing Indicator Balloon */
.chat-bubble.typing {
  display: flex;
  align-items: center;
  gap: 4px;
  padding: 10px 14px;
  align-self: flex-start;
  background: var(--steel-dim);
  border: 1px solid var(--steel);
  border-top-left-radius: 2px;
}
.chat-bubble.typing span {
  width: 5px;
  height: 5px;
  background: var(--bone-dim);
  border-radius: 50%;
  display: inline-block;
  animation: typingBounce 1.4s infinite ease-in-out both;
}
.chat-bubble.typing span:nth-child(1) { animation-delay: -0.32s; }
.chat-bubble.typing span:nth-child(2) { animation-delay: -0.16s; }

@keyframes typingBounce {
  0%, 80%, 100% { transform: scale(0); }
  40% { transform: scale(1); }
}

/* Chat Input Area */
.chat-input-area {
  border-top: 1px solid var(--steel);
  background: rgba(10, 10, 12, 0.6);
  padding: 14px 20px 20px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

/* Suggestion Chips */
.chat-chips {
  display: flex;
  gap: 8px;
  overflow-x: auto;
  padding-bottom: 4px;
  scroll-behavior: smooth;
  -webkit-overflow-scrolling: touch;
}
.chat-chips::-webkit-scrollbar {
  height: 2px;
}
.chat-chips::-webkit-scrollbar-thumb {
  background: transparent;
}
.chat-chips:hover::-webkit-scrollbar-thumb {
  background: var(--steel);
}

.chat-chip {
  flex-shrink: 0;
  background: transparent;
  border: 1px solid var(--steel);
  border-radius: 16px;
  padding: 6px 12px;
  font-family: var(--sans);
  font-size: 11.5px;
  color: var(--bone-dim);
  cursor: pointer;
  transition: all 0.25s ease;
}
.chat-chip:hover {
  border-color: var(--amber);
  color: var(--bone);
  background: rgba(173, 255, 47, 0.03);
}

/* Input Form */
.chat-form {
  display: flex;
  align-items: center;
  background: var(--steel-dim);
  border: 1px solid var(--steel);
  border-radius: 20px;
  padding: 4px 6px 4px 14px;
  transition: border-color 0.3s ease;
}
.chat-form:focus-within {
  border-color: var(--amber);
}
.chat-form input {
  flex: 1;
  background: transparent;
  border: none;
  outline: none;
  font-family: var(--sans);
  font-size: 13px;
  color: var(--bone);
  padding: 6px 0;
}
.chat-form input::placeholder {
  color: var(--bone-dim);
  opacity: 0.65;
}
.chat-form .chat-send-btn {
  background: transparent;
  border: none;
  color: var(--bone-dim);
  width: 32px;
  height: 32px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: color 0.2s ease, transform 0.2s ease;
  padding: 0;
}
.chat-form .chat-send-btn:hover {
  color: var(--amber);
  transform: scale(1.1);
}
.chat-form .chat-send-btn svg {
  width: 16px;
  height: 16px;
}

/* Responsive Overrides for Mobile */
@media (max-width: 640px) {
  .chatbot-container {
    bottom: 32px;
    right: 20px;
  }
  .chat-window {
    position: fixed;
    bottom: 0;
    right: 0;
    width: 100vw;
    height: 100vh;
    height: -webkit-fill-available;
    border-radius: 0;
    border: none;
    z-index: 2000;
  }
  .chat-window.open {
    transform: none;
  }
  .chat-header {
    padding: 16px 20px;
  }
  .chat-close {
    font-size: 20px;
    padding: 8px;
  }
  .fab-tooltip {
    display: none;
  }
}

/* ============ PROJECT DETAIL MODAL ============ */
body.no-scroll {
  overflow: hidden;
  height: 100vh;
}
.project-modal {
  position: fixed;
  inset: 0;
  z-index: 3000;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.4s cubic-bezier(0.2, 0.8, 0.2, 1);
}
.project-modal.open {
  opacity: 1;
  pointer-events: auto;
}
.project-modal-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(5, 6, 6, 0.85);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
}
.project-modal-container {
  position: relative;
  width: min(1200px, 92vw);
  height: 85vh;
  background: var(--hull-2);
  border: 1px solid var(--steel);
  border-radius: 16px;
  overflow: hidden;
  display: grid;
  grid-template-columns: 1.15fr 1fr;
  z-index: 3001;
  transform: scale(0.96) translateY(24px);
  transition: transform 0.4s cubic-bezier(0.2, 0.8, 0.2, 1);
  box-shadow: 0 30px 90px rgba(0, 0, 0, 0.85), 0 0 60px rgba(0, 255, 102, 0.04);
}
.project-modal.open .project-modal-container {
  transform: scale(1) translateY(0);
}
.project-modal-close-trigger {
  position: absolute;
  top: 24px;
  right: 24px;
  background: rgba(10, 10, 12, 0.6);
  border: 1px solid var(--steel);
  color: var(--bone-dim);
  width: 44px;
  height: 44px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  cursor: pointer;
  z-index: 3005;
  transition: all 0.3s ease;
  font-size: 14px;
}
.project-modal-close-trigger:hover {
  border-color: var(--amber);
  color: var(--amber);
  transform: rotate(90deg) scale(1.05);
  box-shadow: 0 0 15px rgba(0, 255, 102, 0.3);
}

/* Gallery Column */
.project-modal-gallery {
  overflow: hidden;
  height: 100%;
  display: flex;
  flex-direction: column;
  gap: 20px;
  padding: 32px;
  border-right: 1px solid var(--steel);
  background: var(--abyss-2);
}
.project-modal-gallery::-webkit-scrollbar {
  width: 5px;
}
.project-modal-gallery::-webkit-scrollbar-track {
  background: transparent;
}
.project-modal-gallery::-webkit-scrollbar-thumb {
  background: var(--steel-3);
  border-radius: 4px;
}
.project-modal-gallery::-webkit-scrollbar-thumb:hover {
  background: var(--fog-2);
}

.gallery-block {
  width: 100%;
  border-radius: 12px;
  border: 1px solid var(--steel);
  overflow: hidden;
  position: relative;
  background: var(--abyss);
}
.gallery-block.primary-art {
  flex: 1;
  min-height: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}
.gallery-block.primary-art .case-art {
  width: 100% !important;
  height: 100% !important;
  aspect-ratio: auto !important;
  border: none;
  cursor: default !important;
}
.gallery-block.primary-art .case-art .stage {
  display: none !important;
}
.gallery-block.primary-art .case-art video {
  opacity: 0.8;
  object-fit: cover !important;
  object-position: center !important;
}

/* Spec and Blueprint blocks */
.spec-block {
  min-height: 260px;
  padding: 24px;
  background-color: var(--abyss);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  font-family: var(--mono);
  font-size: 11px;
  color: var(--fog);
  position: relative;
  border: 1px solid var(--steel);
  border-radius: 12px;
  box-sizing: border-box;
}
.spec-block.blueprint {
  background-image: linear-gradient(rgba(0, 255, 102, 0.03) 1px, transparent 1px), linear-gradient(90deg, rgba(0, 255, 102, 0.03) 1px, transparent 1px);
  background-size: 16px 16px;
}
.spec-block .hdr {
  display: flex;
  justify-content: space-between;
  border-bottom: 1px solid var(--steel);
  padding-bottom: 8px;
  color: var(--bone-dim);
}
.spec-block .blueprint-tag {
  color: var(--amber);
  text-shadow: 0 0 10px rgba(0, 255, 102, 0.3);
}
.spec-block .color-palette {
  display: flex;
  gap: 12px;
  margin-top: 12px;
}
.spec-block .color-swatch {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.spec-block .color-preview {
  width: 36px;
  height: 36px;
  border-radius: 6px;
  border: 1px solid var(--steel);
}

/* Info Column */
.project-modal-info {
  display: flex;
  flex-direction: column;
  padding: 48px;
  height: 100%;
  overflow-y: auto;
  justify-content: center;
}
.project-modal-category {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.18em;
  color: var(--amber);
  text-transform: uppercase;
  margin-bottom: 16px;
  display: inline-block;
  align-self: flex-start;
  padding: 4px 12px;
  border: 1px solid rgba(0, 255, 102, 0.25);
  border-radius: 20px;
  background: rgba(0, 255, 102, 0.03);
  text-shadow: 0 0 8px rgba(0, 255, 102, 0.3);
}
.project-modal-title {
  font-family: var(--serif);
  font-size: clamp(32px, 3.5vw, 42px);
  line-height: 1.1;
  color: var(--bone);
  font-weight: 400;
  letter-spacing: -0.015em;
  margin-bottom: 24px;
}
.project-modal-title em {
  font-style: italic;
  color: var(--amber);
  font-weight: 300;
}
.project-modal-desc {
  font-size: 15px;
  line-height: 1.75;
  color: var(--bone-dim);
  margin-bottom: 36px;
  font-weight: 300;
}

/* Metadata List */
.project-modal-meta {
  border-top: 1px solid var(--steel);
  margin-bottom: 40px;
}
.project-modal-meta .meta-item {
  display: grid;
  grid-template-columns: 140px 1fr;
  padding: 14px 0;
  border-bottom: 1px solid var(--steel);
  font-size: 13.5px;
}
.project-modal-meta .meta-label {
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: 0.18em;
  color: var(--fog);
  text-transform: uppercase;
}
.project-modal-meta .meta-value {
  color: var(--bone);
  font-weight: 400;
}

/* Testimonial Block */
.project-modal-testimonial {
  margin-top: 10px;
  padding: 24px;
  background: var(--steel-2);
  border-left: 2px solid var(--amber);
  border-radius: 4px;
  position: relative;
  display: flex;
  gap: 20px;
  align-items: center;
}
.testimonial-avatar-container {
  flex-shrink: 0;
  width: 64px;
  height: 64px;
  border-radius: 6px;
  overflow: hidden;
  border: 1px solid var(--steel);
}
.testimonial-avatar {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  filter: grayscale(1) brightness(0.9);
  transition: filter 0.3s ease;
}
.project-modal-testimonial:hover .testimonial-avatar {
  filter: grayscale(0) brightness(1);
}
.testimonial-content {
  flex: 1;
}
.testimonial-quote {
  font-family: var(--serif);
  font-style: italic;
  font-size: 15px;
  line-height: 1.6;
  color: var(--bone);
  margin-bottom: 12px;
}
.testimonial-author {
  font-family: var(--mono);
  font-size: 11px;
  color: var(--amber);
  letter-spacing: 0.05em;
  display: block;
}

/* Carousel Blocks */
.gallery-block.carousel-block {
  padding: 0;
  position: relative;
  overflow: hidden;
  flex: 4;
  min-height: 0;
}
.carousel-container {
  position: relative;
  width: 100%;
  height: 100%;
  overflow: hidden;
}
.carousel-track {
  display: flex;
  height: 100%;
  width: 100%;
  will-change: transform;
}
.carousel-slide {
  flex: 0 0 100%;
  width: 100%;
  height: 100%;
  position: relative;
}
.carousel-slide img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.carousel-nav-btn {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  background: rgba(10, 10, 12, 0.65);
  border: 1px solid var(--steel);
  color: var(--bone-dim);
  width: 40px;
  height: 40px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  cursor: pointer;
  z-index: 5;
  transition: all 0.3s ease;
  padding: 0;
}
.carousel-nav-btn:hover {
  border-color: var(--amber);
  color: var(--amber);
  background: rgba(10, 10, 12, 0.85);
  box-shadow: 0 0 10px rgba(0, 255, 102, 0.25);
}
.carousel-nav-btn.prev {
  left: 16px;
}
.carousel-nav-btn.next {
  right: 16px;
}
.carousel-indicators {
  position: absolute;
  bottom: 16px;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  gap: 8px;
  z-index: 5;
  background: rgba(10, 10, 12, 0.5);
  padding: 6px 12px;
  border-radius: 20px;
  border: 1px solid rgba(255, 255, 255, 0.05);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}
.carousel-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: rgba(232, 226, 216, 0.3);
  border: none;
  cursor: pointer;
  padding: 0;
  transition: all 0.3s ease;
}
.carousel-dot.active {
  background: var(--amber);
  transform: scale(1.25);
  box-shadow: 0 0 8px var(--amber);
}

/* Responsive Modal styles */
@media (max-width: 900px) {
  .project-modal-container {
    grid-template-columns: 1fr;
    grid-template-rows: 280px 1fr;
    height: 90vh;
    width: 94vw;
  }
  .project-modal-gallery {
    border-right: none;
    border-bottom: 1px solid var(--steel);
    padding: 20px;
    overflow-y: auto;
    display: flex;
    flex-direction: column;
    gap: 16px;
  }
  .gallery-block.primary-art {
    height: 80px;
    flex: none;
  }
  .gallery-block.carousel-block {
    height: 320px;
    flex: none;
  }
  .project-modal-info {
    padding: 32px 24px 24px;
    justify-content: flex-start;
  }
  .project-modal-title {
    font-size: 28px;
  }
  .project-modal-close-trigger {
    top: 16px;
    right: 16px;
    width: 36px;
    height: 36px;
    font-size: 12px;
  }
}

/* ================================================================
   SECRET ADMINISTRATIVE CONTROL CONSOLE STYLES
   ================================================================ */

.admin-console {
  position: fixed;
  inset: 0;
  z-index: 3000;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.4s cubic-bezier(0.2, 0.7, 0.2, 1);
}

.admin-console.open {
  opacity: 1;
  pointer-events: all;
}

.admin-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(5, 7, 7, 0.95);
  backdrop-filter: blur(28px);
  -webkit-backdrop-filter: blur(28px);
  z-index: 1;
}

.admin-container {
  position: relative;
  z-index: 2;
  width: min(1200px, 94vw);
  height: min(720px, 85vh);
  background: rgba(10, 14, 14, 0.85);
  border: 1px solid var(--amber);
  border-radius: 8px;
  box-shadow: 0 0 50px rgba(0, 255, 102, 0.15);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  font-family: var(--mono);
  color: var(--amber);
}

.admin-close-btn {
  position: absolute;
  top: 16px;
  right: 16px;
  background: transparent;
  border: 1px solid rgba(0, 255, 102, 0.3);
  color: var(--amber);
  width: 32px;
  height: 32px;
  border-radius: 4px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--mono);
  font-size: 14px;
  cursor: none;
  z-index: 20;
  transition: all 0.2s ease;
}

.admin-close-btn:hover {
  background: rgba(0, 255, 102, 0.15);
  border-color: var(--amber-2);
  box-shadow: 0 0 10px rgba(0, 255, 102, 0.3);
}

/* CRT Graphic Scanline Overlay */
.crt-scanline {
  position: absolute;
  top: 0; left: 0; width: 100%; height: 100%;
  background: linear-gradient(
    to bottom,
    rgba(255, 255, 255, 0),
    rgba(0, 255, 102, 0.05) 10%,
    rgba(0, 255, 102, 0.12) 50%,
    rgba(0, 255, 102, 0.05) 90%,
    rgba(255, 255, 255, 0)
  );
  opacity: 0.6;
  z-index: 10;
  pointer-events: none;
  animation: crtScanline 8s linear infinite;
}

@keyframes crtScanline {
  0% { transform: translateY(-100%); }
  100% { transform: translateY(100%); }
}

.crt-grid {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background-image: 
    linear-gradient(rgba(0, 255, 102, 0.02) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0, 255, 102, 0.02) 1px, transparent 1px);
  background-size: 20px 20px;
  z-index: 9;
  opacity: 0.8;
}

/* Lock Gate Authentication Screen */
.admin-auth-panel {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  height: 100%;
  padding: 60px 40px;
  text-align: center;
  position: relative;
  z-index: 5;
  background: radial-gradient(circle at center, rgba(10, 14, 14, 0.4) 0%, rgba(5, 7, 7, 0.95) 100%);
}

.admin-auth-panel.hidden {
  display: none !important;
}

.auth-header {
  display: flex;
  align-items: center;
  gap: 10px;
  color: var(--oxide);
  border: 1px solid rgba(119, 44, 36, 0.3);
  background: rgba(119, 44, 36, 0.05);
  padding: 8px 16px;
  border-radius: 4px;
}

.pulse-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  display: inline-block;
}

.pulse-dot.red {
  background: #ff3b30;
  box-shadow: 0 0 10px #ff3b30;
  animation: pulseRed 1.5s infinite;
}

.pulse-dot.green {
  background: var(--amber);
  box-shadow: 0 0 10px var(--amber);
  animation: pulseGreen 1.5s infinite;
}

@keyframes pulseRed {
  0%, 100% { opacity: 1; box-shadow: 0 0 10px #ff3b30; }
  50% { opacity: 0.4; box-shadow: 0 0 2px #ff3b30; }
}

@keyframes pulseGreen {
  0%, 100% { opacity: 1; box-shadow: 0 0 10px var(--amber); }
  50% { opacity: 0.4; box-shadow: 0 0 2px var(--amber); }
}

.glitch-title {
  font-family: var(--serif);
  font-size: clamp(38px, 4.5vw, 64px);
  color: var(--bone);
  margin-bottom: 8px;
  position: relative;
  letter-spacing: -0.015em;
  font-weight: 400;
}

.glitch-title::before, .glitch-title::after {
  content: attr(data-text);
  position: absolute;
  top: 0; left: 0; width: 100%; height: 100%;
  font: inherit;
  opacity: 0.8;
}

.glitch-title::before {
  color: #00ff66;
  animation: glitchAnim1 2s infinite linear alternate-reverse;
  clip-path: inset(40% 0 61% 0);
  left: 2px;
}

.glitch-title::after {
  color: #ff2a00;
  animation: glitchAnim2 2s infinite linear alternate-reverse;
  clip-path: inset(92% 0 1% 0);
  left: -2px;
}

@keyframes glitchAnim1 {
  0% { clip-path: inset(40% 0 61% 0); }
  20% { clip-path: inset(92% 0 1% 0); }
  40% { clip-path: inset(15% 0 80% 0); }
  60% { clip-path: inset(80% 0 5% 0); }
  80% { clip-path: inset(5% 0 92% 0); }
  100% { clip-path: inset(40% 0 61% 0); }
}

@keyframes glitchAnim2 {
  0% { clip-path: inset(12% 0 85% 0); }
  20% { clip-path: inset(85% 0 12% 0); }
  40% { clip-path: inset(33% 0 66% 0); }
  60% { clip-path: inset(66% 0 33% 0); }
  80% { clip-path: inset(90% 0 5% 0); }
  100% { clip-path: inset(12% 0 85% 0); }
}

.auth-form-wrap {
  max-width: 320px;
  width: 100%;
  margin: 0 auto;
}

#admin-auth-form {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

#admin-email-field,
#admin-password-field {
  background: rgba(16, 20, 26, 0.8);
  border: 1px solid rgba(0, 255, 102, 0.3);
  border-radius: 4px;
  color: var(--amber);
  padding: 14px;
  font-family: var(--mono);
  font-size: 11px;
  text-align: center;
  outline: none;
  transition: all 0.3s ease;
  width: 100%;
}

#admin-email-field {
  margin-bottom: 12px;
}

#admin-password-field {
  margin-bottom: 18px;
}

#admin-email-field:focus,
#admin-password-field:focus {
  border-color: var(--amber);
  box-shadow: 0 0 15px rgba(0, 255, 102, 0.25);
}

.auth-error-msg {
  color: #ff3b30;
  font-size: 10px;
  letter-spacing: 0.15em;
  margin-top: 14px;
  font-weight: 600;
  opacity: 0;
  transition: opacity 0.3s ease;
  text-shadow: 0 0 8px rgba(255, 59, 48, 0.3);
}

.auth-error-msg.visible {
  opacity: 1;
}

/* Administrative Workspace Dashboard Grid */
.admin-dashboard-panel {
  display: grid;
  grid-template-columns: 260px 1fr;
  width: 100%;
  height: 100%;
  position: relative;
  z-index: 5;
}

.admin-dashboard-panel.hidden {
  display: none !important;
}

.dashboard-sidebar {
  border-right: 1px solid rgba(0, 255, 102, 0.2);
  background: rgba(8, 10, 10, 0.85);
  display: flex;
  flex-direction: column;
  padding: 24px;
  justify-content: space-between;
}

.sidebar-brand {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.15em;
  padding-bottom: 20px;
  border-bottom: 1px solid rgba(0, 255, 102, 0.1);
  color: var(--bone);
}

.sidebar-nav {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-top: 24px;
  flex: 1;
}

.tab-btn {
  background: transparent;
  border: 1px solid transparent;
  border-radius: 4px;
  color: var(--bone-dim);
  padding: 12px 14px;
  display: flex;
  align-items: center;
  gap: 12px;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.12em;
  text-align: left;
  cursor: none;
  transition: all 0.25s ease;
}

.tab-btn .icon {
  font-size: 14px;
  opacity: 0.7;
}

.tab-btn:hover {
  background: rgba(0, 255, 102, 0.05);
  color: var(--amber);
}

.tab-btn.active {
  background: rgba(0, 255, 102, 0.1);
  border-color: rgba(0, 255, 102, 0.3);
  color: var(--amber);
  text-shadow: 0 0 8px rgba(0, 255, 102, 0.4);
}

.sidebar-footer {
  padding-top: 16px;
  border-top: 1px solid rgba(0, 255, 102, 0.1);
}

.sidebar-footer .btn-outline {
  width: 100%;
  border-color: rgba(255, 99, 71, 0.4);
  color: var(--bone-dim);
  font-size: 9px;
  padding: 10px;
}

.sidebar-footer .btn-outline:hover {
  border-color: #ff3b30;
  color: #ff3b30;
  background: rgba(255, 59, 48, 0.05);
}

.dashboard-content {
  flex: 1;
  padding: 32px;
  overflow: hidden;
  position: relative;
  background: rgba(10, 14, 14, 0.55);
  display: flex;
  flex-direction: column;
}

.content-tab {
  display: none;
  flex-direction: column;
  height: 100%;
  overflow: hidden;
}

.content-tab.active {
  display: flex;
}

.tab-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  border-bottom: 1px solid rgba(0, 255, 102, 0.2);
  padding-bottom: 16px;
  margin-bottom: 24px;
}

.tab-header h4 {
  font-size: 12px;
  letter-spacing: 0.18em;
  color: var(--amber);
  text-shadow: 0 0 8px rgba(0, 255, 102, 0.3);
}

/* Leads Log Table Visuals */
.leads-list-wrapper {
  flex: 1;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  position: relative;
  border: 1px solid rgba(0, 255, 102, 0.15);
  border-radius: 4px;
  background: rgba(8, 10, 10, 0.6);
}

.leads-table-container {
  flex: 1;
  overflow-y: auto;
  overflow-x: auto;
}

.leads-table {
  width: 100%;
  border-collapse: collapse;
  text-align: left;
  font-size: 10px;
}

.leads-table th, .leads-table td {
  padding: 14px 18px;
  border-bottom: 1px solid rgba(0, 255, 102, 0.1);
  white-space: nowrap;
}

.leads-table th {
  background: rgba(0, 255, 102, 0.06);
  color: var(--amber);
  font-weight: 600;
  letter-spacing: 0.15em;
  position: sticky;
  top: 0;
  z-index: 2;
}

.leads-table tr:hover {
  background: rgba(0, 255, 102, 0.03);
}

.leads-table td {
  color: var(--bone-dim);
}

.leads-empty-msg {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(10, 14, 14, 0.95);
  z-index: 5;
  color: var(--fog-2);
}

.leads-empty-msg.hidden {
  display: none !important;
}

/* Design System Panel Styles */
.ds-vault-layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  height: 100%;
  overflow-y: auto;
}

.ds-vault-card {
  background: rgba(16, 20, 26, 0.65);
  border: 1px solid rgba(0, 255, 102, 0.2);
  border-radius: 6px;
  padding: 32px;
  display: flex;
  flex-direction: column;
  gap: 20px;
  justify-content: space-between;
}

.vault-icon {
  font-size: 48px;
  opacity: 0.9;
  filter: drop-shadow(0 0 10px rgba(0, 255, 102, 0.3));
}

.vault-info {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.vault-info h3 {
  font-family: var(--mono);
  font-size: 20px;
  color: var(--bone);
  letter-spacing: 0.05em;
}

.vault-info p {
  line-height: 1.7;
  font-size: 11px;
  color: var(--fog);
}

.vault-actions {
  margin-top: 16px;
}

.vault-actions .btn {
  width: 100%;
  justify-content: center;
}

.ds-vault-specs {
  background: rgba(8, 10, 10, 0.8);
  border: 1px solid rgba(0, 255, 102, 0.1);
  border-radius: 6px;
  padding: 24px;
}

/* Telemetry Stats Styles */
.telemetry-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
  margin-bottom: 24px;
}

.telemetry-card {
  background: rgba(16, 20, 26, 0.65);
  border: 1px solid rgba(0, 255, 102, 0.1);
  border-radius: 6px;
  padding: 18px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.telemetry-card h3 {
  font-size: 18px;
  color: var(--amber);
  text-shadow: 0 0 6px rgba(0, 255, 102, 0.3);
}

.telemetry-bar-wrap {
  width: 100%;
  height: 2px;
  background: rgba(0, 255, 102, 0.08);
}

.telemetry-bar {
  height: 100%;
  background: var(--amber);
  box-shadow: 0 0 6px var(--amber);
  transition: width 0.5s ease;
}

.telemetry-chart-container {
  flex: 1;
  background: rgba(8, 10, 10, 0.8);
  border: 1px solid rgba(0, 255, 102, 0.1);
  border-radius: 6px;
  padding: 24px;
  display: flex;
  flex-direction: column;
}

.telemetry-chart-graphics {
  flex: 1;
  min-height: 160px;
  border-bottom: 1px solid rgba(0, 255, 102, 0.15);
  border-left: 1px solid rgba(0, 255, 102, 0.15);
  position: relative;
}

/* CLI command shell */
.cli-terminal-wrapper {
  flex: 1;
  background: rgba(5, 7, 7, 0.95);
  border: 1px solid rgba(0, 255, 102, 0.2);
  border-radius: 4px;
  padding: 20px;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

.cli-output {
  flex: 1;
  overflow-y: auto;
  margin-bottom: 12px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  font-size: 11px;
}

.cli-line {
  color: var(--bone-dim);
  line-height: 1.5;
}

.cli-line.success {
  color: var(--amber);
  text-shadow: 0 0 6px rgba(0, 255, 102, 0.3);
}

.cli-line.error {
  color: #ff3b30;
  text-shadow: 0 0 6px rgba(255, 59, 48, 0.3);
}

.cli-prompt-line {
  display: flex;
  align-items: center;
  gap: 10px;
  border-top: 1px solid rgba(0, 255, 102, 0.15);
  padding-top: 14px;
}

.prompt-sym {
  color: var(--amber);
  font-weight: 600;
  text-shadow: 0 0 6px rgba(0, 255, 102, 0.3);
}

#admin-cli-input {
  flex: 1;
  background: transparent;
  border: none;
  color: var(--amber);
  font-family: var(--mono);
  font-size: 11px;
  outline: none;
}

#admin-cli-input::placeholder {
  color: rgba(0, 255, 102, 0.25);
}

/* Glowing scrollbars matching dark aesthetic */
.leads-table-container::-webkit-scrollbar,
.cli-output::-webkit-scrollbar {
  width: 6px;
  height: 6px;
}

.leads-table-container::-webkit-scrollbar-track,
.cli-output::-webkit-scrollbar-track {
  background: rgba(8, 10, 10, 0.5);
}

.leads-table-container::-webkit-scrollbar-thumb,
.cli-output::-webkit-scrollbar-thumb {
  background: rgba(0, 255, 102, 0.2);
  border-radius: 3px;
}

.leads-table-container::-webkit-scrollbar-thumb:hover,
.cli-output::-webkit-scrollbar-thumb:hover {
  background: rgba(0, 255, 102, 0.45);
}

/* Admin panel responsive layout modifications */
@media (max-width: 900px) {
  .admin-dashboard-panel {
    grid-template-columns: 1fr;
    grid-template-rows: auto 1fr;
  }
  .dashboard-sidebar {
    border-right: none;
    border-bottom: 1px solid rgba(0, 255, 102, 0.2);
    flex-direction: row;
    align-items: center;
    padding: 12px 24px;
    gap: 12px;
  }
  .sidebar-brand {
    border-bottom: none;
    padding-bottom: 0;
  }
  .sidebar-nav {
    flex-direction: row;
    margin-top: 0;
    overflow-x: auto;
    width: auto;
    gap: 4px;
    padding-bottom: 4px;
  }
  .tab-btn {
    padding: 8px 12px;
    white-space: nowrap;
  }
  .tab-btn .lbl {
    display: none;
  }
  .sidebar-footer {
    border-top: none;
    padding-top: 0;
  }
  .sidebar-footer .btn-outline {
    padding: 8px 12px;
    font-size: 8px;
  }
  .ds-vault-layout {
    grid-template-columns: 1fr;
    overflow-y: auto;
  }
  .telemetry-grid {
    grid-template-columns: 1fr 1fr;
  }
}

/* ================================================================
   TARGET AUDIENCE SECTION (PARA QUEM ATRAVESSAMOS)
   ================================================================ */
/* Green background container for Target Audience */
#target {
  background: var(--amber);
  color: var(--abyss);
  border-top: 1px solid var(--abyss);
  border-bottom: 1px solid var(--abyss);
  position: relative;
  overflow: hidden;
}

#target .section-head {
  border-bottom-color: rgba(8, 10, 10, 0.15);
}

#target .section-head h2 {
  color: var(--abyss);
}

#target .section-head h2 em {
  color: var(--abyss);
  text-shadow: none;
}

#target .kicker {
  color: var(--abyss);
}

#target .kicker::before {
  background: var(--abyss);
}

#target .kicker .num {
  color: rgba(8, 10, 10, 0.5);
}

.target-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
  margin-top: 48px;
}

.target-card {
  position: relative;
  background: #06080a;
  border: 1.5px solid #000000;
  border-left: 5px solid #000000;
  box-shadow: 0 16px 40px rgba(0, 0, 0, 0.35);
  padding: 36px 28px;
  transition: border-color .35s ease, background .35s ease, box-shadow .35s ease, transform .35s ease;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
}

.target-card:hover {
  background: #090c0f;
  border-color: #000000;
  border-left-color: #00ff66;
  box-shadow: 0 24px 60px rgba(0, 0, 0, 0.5);
  transform: translateY(-6px);
}

.target-card .target-num {
  font-family: var(--mono);
  font-size: 11px;
  color: #e8e2d8;
  margin-bottom: 20px;
  letter-spacing: 0.1em;
}

.target-card p {
  font-size: 14.5px;
  line-height: 1.7;
  color: rgba(232, 226, 216, 0.75);
  font-weight: 300;
  margin: 0;
}

.target-card:hover p {
  color: var(--bone);
}

/* absolute corners inside card */
.target-card .corner-tl,
.target-card .corner-tr,
.target-card .corner-bl,
.target-card .corner-br {
  position: absolute;
  width: 4px;
  height: 4px;
  border: 1px solid rgba(232, 226, 216, 0.2);
  transition: border-color 0.3s ease;
}
.target-card:hover .corner-tl,
.target-card:hover .corner-tr,
.target-card:hover .corner-bl,
.target-card:hover .corner-br {
  border-color: #00ff66;
}

.target-card .corner-tl { top: -1px; left: -1px; border-right: none; border-bottom: none; }
.target-card .corner-tr { top: -1px; right: -1px; border-left: none; border-bottom: none; }
.target-card .corner-bl { bottom: -1px; left: -1px; border-right: none; border-top: none; }
.target-card .corner-br { bottom: -1px; right: -1px; border-left: none; border-top: none; }

/* Responsive Target grid */
@media (max-width: 1024px) {
  .target-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 640px) {
  .target-grid {
    grid-template-columns: 1fr;
    gap: 16px;
  }
  .target-card {
    padding: 28px 20px;
  }
}

/* ================================================================
   CONTACT FORM STYLES
   ================================================================ */
.contact-form-wrapper {
  max-width: 100%;
  margin: 56px auto 0;
  width: 100%;
}

.contact-form {
  display: flex;
  flex-direction: column;
  gap: 36px;
}

.contact-form .form-row {
  display: flex;
  gap: 24px;
  width: 100%;
}

.contact-form .form-group {
  position: relative;
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.contact-form .form-group.full-width {
  flex: none;
  width: 100%;
}

.contact-form .form-group input,
.contact-form .form-group textarea {
  width: 100%;
  background: rgba(16, 20, 26, 0.6);
  border: 1px solid var(--steel);
  padding: 16px 20px;
  color: var(--bone);
  font-family: inherit;
  font-size: 15px;
  outline: none;
  transition: border-color 0.3s ease, background-color 0.3s ease, box-shadow 0.3s ease;
  border-radius: 2px;
}

.contact-form .form-group input:hover,
.contact-form .form-group textarea:hover {
  border-color: var(--fog-2);
}

.contact-form .form-group input:focus,
.contact-form .form-group textarea:focus {
  border-color: var(--amber);
  background-color: rgba(16, 20, 26, 0.85);
  box-shadow: 0 0 16px rgba(0, 255, 102, 0.08);
}

.contact-form .form-group textarea {
  resize: vertical;
}

.contact-form .form-group label {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  color: var(--bone-dim);
  text-transform: uppercase;
  display: flex;
  align-items: center;
  gap: 6px;
}

.contact-form .form-group label .label-num {
  color: var(--amber);
  font-weight: 600;
}

.contact-form .form-group label .required-mark {
  color: var(--oxide);
  font-weight: bold;
}

.contact-form .form-group .border-highlight {
  display: none; /* Replaced with modern box outline transition */
}

/* Radio button grid selections */
.form-group-selection {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.form-group-selection .selection-title {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  color: var(--bone-dim);
  text-transform: uppercase;
  display: flex;
  align-items: center;
  gap: 6px;
}

.form-group-selection .selection-title .label-num {
  color: var(--amber);
  font-weight: 600;
}

.form-group-selection .selection-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 12px;
}

.selection-option {
  position: relative;
  cursor: none;
}

.selection-option input[type="radio"] {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
}

.selection-option .selection-box {
  display: block;
  border: 1px solid var(--steel);
  padding: 16px 20px;
  text-align: center;
  font-size: 13.5px;
  color: var(--bone-dim);
  background: rgba(16, 20, 26, 0.4);
  transition: all 0.25s ease;
  border-radius: 2px;
}

.selection-option input[type="radio"]:checked + .selection-box {
  border-color: var(--amber);
  color: var(--amber);
  background: rgba(0, 255, 102, 0.04);
  box-shadow: 0 0 16px rgba(0, 255, 102, 0.06);
}

.selection-option:hover .selection-box {
  border-color: rgba(0, 255, 102, 0.45);
  color: var(--bone);
  background: rgba(16, 20, 26, 0.6);
}

/* Form footer controls */
.contact-form .form-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 16px;
  flex-wrap: wrap;
  gap: 20px;
}

.contact-form .feedback-msg {
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: 0.05em;
  flex: 1;
  min-width: 200px;
}

.contact-form .microcopy {
  font-size: 12.5px;
  color: var(--fog);
  font-weight: 300;
  margin: 0;
  text-align: right;
  max-width: 320px;
  line-height: 1.5;
}

@media (max-width: 768px) {
  .contact-form .form-row {
    flex-direction: column;
    gap: 24px;
  }
  .contact-form .form-footer {
    flex-direction: column;
    align-items: flex-start;
    gap: 16px;
  }
  .contact-form .form-footer button {
    width: 100%;
  }
  .contact-form .microcopy {
    text-align: left;
    max-width: 100%;
  }
}

@media (max-width: 640px) {
  .form-group-selection .selection-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 480px) {
  .form-group-selection .selection-grid {
    grid-template-columns: 1fr;
  }
}

/* ================================================================
   PORTFOLIO WORK SECTION BG VIDEO & MEGA CTA STYLES
   ================================================================ */
#work {
  position: relative;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  min-height: clamp(620px, 65vh, 850px);
  padding: clamp(100px, 10vw, 160px) var(--gutter);
  border-top: 1px solid var(--steel);
}

#work .section-head {
  position: relative;
  z-index: 3;
}

.work-cta-center {
  position: relative;
  z-index: 3;
  margin: auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 28px;
  text-align: center;
  width: 100%;
}

.work-cta-center .badge-signal {
  font-family: var(--mono);
  font-size: clamp(10px, 1.1vw, 12px);
  letter-spacing: 0.22em;
  color: var(--amber); /* neon green */
  text-transform: uppercase;
  background: rgba(0, 255, 102, 0.05);
  border: 1px solid rgba(0, 255, 102, 0.2);
  padding: 8px 16px;
  border-radius: 20px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}

.work-cta-center .badge-signal .dot {
  width: 6px;
  height: 6px;
  background: var(--amber);
  border-radius: 50%;
  animation: pulse-green 1.5s infinite;
}

.btn-mega {
  font-family: var(--mono);
  font-size: clamp(14px, 1.6vw, 19px);
  letter-spacing: 0.22em;
  text-transform: uppercase;
  font-weight: 600;
  padding: clamp(20px, 2.4vw, 30px) clamp(44px, 5vw, 68px);
  background: var(--amber); /* neon green */
  color: var(--abyss);
  border: 1px solid var(--amber);
  border-radius: 4px;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 16px;
  box-shadow: 0 0 30px rgba(0, 255, 102, 0.2);
  transition: all 0.3s cubic-bezier(0.2, 0.8, 0.2, 1);
  position: relative;
  overflow: hidden;
}

.btn-mega .arr {
  font-family: var(--mono);
  font-size: 1.1em;
  color: var(--abyss);
  transition: transform 0.3s cubic-bezier(0.2, 0.8, 0.2, 1);
}

.btn-mega:hover {
  background: var(--amber-2);
  border-color: var(--amber-2);
  box-shadow: 0 0 50px rgba(0, 255, 102, 0.55);
  transform: translateY(-4px) scale(1.02);
}

.btn-mega:hover .arr {
  transform: translate(6px, -6px);
}

.btn-mega:active {
  transform: translateY(-1px) scale(0.99);
}

.work-cta-center .cta-meta {
  font-family: var(--mono);
  font-size: clamp(10px, 1vw, 11px);
  letter-spacing: 0.18em;
  color: var(--bone-dim);
  text-transform: uppercase;
  opacity: 0.85;
}


