/* =================================================================
   Brasil-Go Native — Design system override layer
   See DESIGN.md for full system. This file overrides legacy style.css
   tokens to bring the live site in line with the locked-in design.
   ================================================================= */

/* ===== Design Tokens ===== */
:root{
  /* Go brand */
  --go-blue:#00ADD8;
  --go-blue-2:#5DC9E2;
  --go-blue-dark:#007D9C;
  --go-light-blue:#5DC9E2;
  --go-yellow:#FFDF00;     /* aligned with BR flag yellow */
  --go-pink:#F76C6C;       /* coral, used very sparingly */

  /* Brazilian flag accent system — used DELIBERATELY at low frequency */
  --br-yellow:#FFDF00;
  --br-green:#009C3B;
  --br-blue:#002776;
  --accent-coral:#F76C6C;

  /* Surfaces — dark mode default with Go-blue undertone */
  --bg-primary:#0A1929;
  --bg-secondary:#102540;
  --bg-tertiary:#1A3358;
  --bg-surface-3:#0F1F33;

  /* Legacy aliases */
  --bg:var(--bg-primary);
  --surface:var(--bg-secondary);
  --surface-2:var(--bg-tertiary);
  --surface-3:var(--bg-surface-3);

  --text-primary:#F0F6FC;
  --text-secondary:#8B9DAF;
  --text-muted:#6B7D8F;
  --text:var(--text-primary);
  --muted:var(--text-secondary);

  --border-color:rgba(255,255,255,0.08);
  --border-strong:rgba(255,255,255,0.18);
  --rule:var(--border-color);
  --rule-strong:var(--border-strong);

  /* Typography */
  --font-display:'Bricolage Grotesque',system-ui,sans-serif;
  --font-sans:'DM Sans',system-ui,-apple-system,sans-serif;
  --font-body:var(--font-sans);
  --font-mono:'JetBrains Mono',ui-monospace,monospace;

  /* Shadows */
  --shadow-sm:0 1px 2px rgba(0,0,0,0.3);
  --shadow-md:0 4px 12px rgba(0,0,0,0.35);
  --shadow-lg:0 14px 40px rgba(0,0,0,0.45);
  --shadow-go:0 14px 40px rgba(0,173,216,0.18);

  /* Radii */
  --radius-sm:6px;
  --radius-md:10px;
  --radius-lg:14px;
  --radius-pill:999px;

  /* Layout */
  --max:1280px;
  --max-narrow:980px;
}

/* ===== Base typography overrides ===== */
body{
  font-family:var(--font-body);
  font-feature-settings:"ss01";
  background:var(--bg-primary);
  color:var(--text-primary);
}

h1, h2, h3, h4, h5{
  font-family:var(--font-display);
  font-variation-settings:"wdth" 100,"opsz" 72;
  letter-spacing:-0.02em;
  color:var(--text-primary);
}

h1{font-variation-settings:"wdth" 95,"opsz" 96; letter-spacing:-0.03em}

/* Mono font usages */
code, pre, .code-block, .stats-label, .job-meta, .job-location, .nav-submenu a{
  /* leave inline code as mono via existing rules */
}

/* ===== Section flag-stripe utility ===== */
/* Used by stats-bar, empresas card, footer, etc. */
.section-flag-stripe{
  position:relative;
}
.section-flag-stripe::before,
.stats-bar::before,
.site-footer::before{
  content:'';
  position:absolute;
  top:0; left:0; right:0;
  height:3px;
  background:linear-gradient(90deg,
    var(--br-green) 0%,    var(--br-green) 33.33%,
    var(--br-yellow) 33.33%, var(--br-yellow) 66.66%,
    var(--br-blue) 66.66%,  var(--br-blue) 100%
  );
  z-index:1;
  pointer-events:none;
}
.stats-bar, .site-footer{position:relative}

/* ===== Header / Nav (Brasil-Go Native) ===== */
.bgn-header{
  position:sticky; top:0; z-index:60;
  background:rgba(10,25,41,0.85);
  backdrop-filter:blur(12px) saturate(120%);
  -webkit-backdrop-filter:blur(12px) saturate(120%);
  border-bottom:1px solid var(--border-color);
}
.bgn-header-inner{
  display:flex;
  align-items:center;
  gap:16px;
  padding-top:12px;
  padding-bottom:12px;
}

.bgn-logo{
  display:flex;
  align-items:center;
  gap:10px;
  text-decoration:none;
  flex-shrink:0;
}
.bgn-logo-svg{
  width:36px;
  height:36px;
  flex-shrink:0;
}
.bgn-wordmark{
  font-family:var(--font-display);
  font-weight:700;
  font-size:22px;
  letter-spacing:-0.02em;
  color:var(--text-primary);
  font-variation-settings:"wdth" 100;
  white-space:nowrap;
}
.bgn-slash{color:var(--go-blue)}

/* Nav container */
.bgn-nav{
  display:flex;
  align-items:center;
  gap:4px;
  margin-left:auto;
}

/* Nav item with hover submenu */
.bgn-nav-item{
  position:relative;
}
.bgn-nav-link, a.bgn-nav-link{
  display:inline-flex;
  align-items:center;
  gap:6px;
  font-family:var(--font-sans);
  font-weight:500;
  font-size:14px;
  color:var(--text-primary);
  padding:8px 12px;
  border-radius:var(--radius-sm);
  text-decoration:none;
  transition:all 150ms;
  white-space:nowrap;
}
.bgn-nav-link::after{
  content:'';
  display:none;
}
.bgn-nav-item .bgn-nav-link::after{
  content:'▾';
  display:inline-block;
  font-size:9px;
  opacity:0.5;
  transition:transform 150ms;
}
.bgn-nav-link:hover,
.bgn-nav-item:hover .bgn-nav-link,
.bgn-nav-link.active{
  color:var(--go-blue);
  background:rgba(0,173,216,0.08);
}
.bgn-nav-item:hover .bgn-nav-link::after{
  transform:rotate(180deg);
  opacity:1;
}

/* Submenu — shown on hover */
.bgn-submenu{
  position:absolute;
  top:calc(100% + 6px);
  left:0;
  min-width:240px;
  background:var(--bg-secondary);
  border:1px solid var(--border-strong);
  border-radius:var(--radius-md);
  padding:8px;
  display:flex;
  flex-direction:column;
  gap:2px;
  box-shadow:var(--shadow-lg);
  opacity:0;
  visibility:hidden;
  transform:translateY(-4px);
  transition:all 180ms ease-out;
  pointer-events:none;
  z-index:60;
}
/* Bridge so the gap between nav-link and submenu doesn't break hover */
.bgn-nav-item::before{
  content:'';
  position:absolute;
  top:100%;
  left:0;
  right:0;
  height:10px;
  z-index:1;
}
.bgn-nav-item:hover .bgn-submenu,
.bgn-nav-item:focus-within .bgn-submenu{
  opacity:1;
  visibility:visible;
  transform:translateY(0);
  pointer-events:auto;
}
.bgn-submenu a{
  display:block;
  padding:9px 14px;
  font-family:var(--font-sans);
  font-weight:500;
  font-size:14px;
  color:var(--text-primary);
  text-decoration:none;
  border-radius:var(--radius-sm);
  transition:all 120ms;
  white-space:nowrap;
}
.bgn-submenu a:hover{
  background:rgba(0,173,216,0.1);
  color:var(--go-blue);
}
.bgn-submenu-cta{
  margin-top:6px !important;
  padding-top:11px !important;
  border-top:1px solid var(--border-color);
  color:var(--br-yellow) !important;
  font-weight:600 !important;
}
.bgn-submenu-cta:hover{
  background:rgba(255,223,0,0.1) !important;
  color:var(--br-yellow) !important;
}

/* CTA-styled nav link (Vagas) — filled button + submenu chevron */
.bgn-nav-item--cta{
  margin-left:8px;
}
.bgn-cta-link, a.bgn-cta-link{
  display:inline-flex;
  align-items:center;
  gap:8px;
  background:var(--go-blue);
  color:#0A1929;
  font-family:var(--font-sans);
  font-weight:600;
  font-size:14px;
  padding:9px 18px;
  border-radius:var(--radius-sm);
  text-decoration:none;
  transition:all 180ms ease-out;
  white-space:nowrap;
}
.bgn-nav-item--cta:hover .bgn-cta-link,
.bgn-nav-item--cta:focus-within .bgn-cta-link,
.bgn-cta-link:hover,
.bgn-cta-link.active{
  background:var(--br-yellow);
  color:#0A1929;
  transform:translateY(-1px);
}
/* Solo CTA-link (no submenu, e.g. mobile drawer) */
.bgn-mobile-cta::after{display:none}

/* Right-aligned submenu (so CTA at end doesn't push submenu off-screen) */
.bgn-submenu--right{
  left:auto;
  right:0;
}

/* Mobile secondary link styling */
.bgn-mobile-secondary{
  border-top:1px solid var(--border-color);
  margin-top:6px !important;
  padding-top:16px !important;
  color:var(--text-secondary) !important;
  font-size:13px !important;
}

/* Legacy CTA class kept for backwards compat (currently unused in nav) */
.bgn-cta{
  background:var(--go-blue);
  color:#0A1929 !important;
  font-family:var(--font-sans);
  font-weight:600;
  font-size:14px;
  padding:9px 18px;
  border-radius:var(--radius-sm);
  text-decoration:none;
  transition:all 180ms ease-out;
  white-space:nowrap;
  display:inline-flex;
  align-items:center;
  gap:8px;
}
.bgn-cta:hover{
  background:var(--br-yellow);
  color:#0A1929 !important;
  transform:translateY(-1px);
}

/* Icon button (search, mode) */
.bgn-icon-btn{
  background:transparent;
  border:1px solid var(--border-strong);
  color:var(--text-primary);
  width:36px;
  height:36px;
  border-radius:var(--radius-sm);
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  transition:all 150ms;
  margin-left:4px;
}
.bgn-icon-btn:hover{
  border-color:var(--go-blue);
  color:var(--go-blue);
}

/* Mobile menu toggle */
.bgn-mobile-btn{
  display:none;
  background:transparent;
  border:1px solid var(--border-strong);
  color:var(--text-primary);
  width:36px;
  height:36px;
  border-radius:var(--radius-sm);
  cursor:pointer;
  padding:0;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:3px;
}
.bgn-mobile-btn span{
  display:block;
  width:16px;
  height:2px;
  background:var(--text-primary);
  border-radius:1px;
}

/* Mobile drawer (hidden by default) */
.bgn-mobile-drawer{
  display:none;
  flex-direction:column;
  gap:2px;
  padding:14px 24px 20px;
  border-top:1px solid var(--border-color);
  background:var(--bg-secondary);
}
.bgn-mobile-drawer a{
  font-family:var(--font-sans);
  font-weight:500;
  font-size:15px;
  color:var(--text-primary);
  text-decoration:none;
  padding:12px 14px;
  border-radius:var(--radius-sm);
  transition:all 120ms;
}
.bgn-mobile-drawer a:hover,
.bgn-mobile-drawer a:focus{
  background:rgba(0,173,216,0.08);
  color:var(--go-blue);
}
.bgn-header.is-open .bgn-mobile-drawer{
  display:flex;
}

/* Hide legacy nav-links if it ever renders */
.header > nav.nav > ul.nav-links{display:none}
.header .search-toggle{display:none}

@media (max-width:1080px){
  .bgn-nav{gap:2px}
  .bgn-nav-link, a.bgn-nav-link{padding:8px 10px; font-size:13px}
  .bgn-cta-link, a.bgn-cta-link, .bgn-cta{padding:8px 14px; font-size:13px}
}
@media (max-width:880px){
  .bgn-nav-item:not(.bgn-nav-item--cta), a.bgn-nav-link.bgn-nav-solo, .bgn-icon-btn{display:none}
  .bgn-nav-item--cta{margin-left:auto}
  .bgn-mobile-btn{display:flex}
}
@media (max-width:480px){
  .bgn-cta-link, a.bgn-cta-link, .bgn-cta{padding:7px 12px; font-size:12px}
  .bgn-wordmark{font-size:18px}
  .bgn-logo-svg{width:30px; height:30px}
}

/* legacy aliases — keep working */
.logo{font-family:var(--font-display); font-weight:700; letter-spacing:-0.02em}
.logo-go, .logo-lang{color:var(--text-primary)}
.logo-br{color:var(--go-blue)}

/* ===== Hero ===== */
.hero{
  position:relative;
  overflow:hidden;
  padding:96px 0 80px;
}

.hero-eyebrow{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-family:var(--font-mono);
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:0.16em;
  color:var(--go-blue);
  background:rgba(0,173,216,0.08);
  padding:6px 12px;
  border:1px solid var(--go-blue);
  border-radius:var(--radius-pill);
  margin-bottom:24px;
}
.hero-eyebrow-dot{
  width:6px; height:6px;
  background:var(--br-green);
  border-radius:50%;
  display:inline-block;
  animation:bgn-pulse 2s infinite;
}
@keyframes bgn-pulse{0%,100%{opacity:1}50%{opacity:0.4}}

.hero h1{
  font-family:var(--font-display);
  font-weight:700;
  font-variation-settings:"wdth" 95,"opsz" 96;
  font-size:clamp(40px,6.5vw,84px);
  line-height:0.98;
  letter-spacing:-0.035em;
  margin-bottom:24px;
  color:var(--text-primary);
}

.hero h1 .accent-blue{color:var(--go-blue)}
.hero h1 .accent-yellow{color:var(--br-yellow)}
.hero h1 .accent-green{color:var(--br-green)}

/* Kill any legacy gradient text on hero */
.hero h1 .text-gradient{
  background:none;
  -webkit-text-fill-color:initial;
  color:var(--go-blue);
}

.hero-subtitle{
  font-family:var(--font-sans);
  font-size:19px;
  color:var(--text-secondary);
  line-height:1.55;
  max-width:560px;
  margin-bottom:32px;
}
.hero-subtitle strong{color:var(--text-primary); font-weight:600}

.hero-gopher img{
  max-width:420px;
  filter:drop-shadow(0 24px 60px rgba(0,173,216,0.25));
  animation:bgn-gopher-float 6s ease-in-out infinite;
}
@keyframes bgn-gopher-float{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-10px)}
}

/* ===== Buttons ===== */
.btn{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-family:var(--font-sans);
  font-weight:600;
  font-size:15px;
  padding:14px 24px;
  border-radius:var(--radius-sm);
  border:2px solid transparent;
  text-decoration:none;
  transition:all 180ms ease-out;
  cursor:pointer;
  white-space:nowrap;
}
.btn-primary{
  background:var(--go-blue);
  color:#0A1929;
  border-color:var(--go-blue);
}
.btn-primary:hover{
  background:var(--br-yellow);
  border-color:var(--br-yellow);
  color:#0A1929;
  transform:translateY(-1px);
}
.btn-secondary{
  background:transparent;
  color:var(--text-primary);
  border-color:var(--border-strong);
}
.btn-secondary:hover{
  border-color:var(--go-blue);
  color:var(--go-blue);
}
.btn-outline{
  background:transparent;
  color:var(--go-blue);
  border-color:var(--go-blue);
}
.btn-outline:hover{
  background:var(--go-blue);
  color:#0A1929;
}

/* ===== Stats bar — flush 4-column row, no gap, no centered text ===== */
.stats-bar{
  background:var(--bg-secondary);
  border-top:1px solid var(--border-color);
  border-bottom:1px solid var(--border-color);
  padding:0 !important;       /* override legacy 2rem padding */
}
.stats-bar > .container{
  padding-left:0 !important;
  padding-right:0 !important;
  max-width:none !important;
}
.stats-grid{
  display:grid !important;
  grid-template-columns:repeat(4,1fr) !important;
  gap:0 !important;            /* override legacy 1.5rem gap */
  text-align:left !important;  /* override legacy center */
  max-width:var(--max) !important;   /* center within 1280px like finalized.html */
  margin:0 auto !important;
  padding:0 32px !important;
}
.stats-item{
  padding:36px 24px !important;
  border-right:1px solid var(--border-color);
  display:flex !important;
  flex-direction:row !important;
  align-items:center !important;
  gap:18px !important;
  text-decoration:none;
  text-align:left !important;
  transition:background 150ms;
  border-radius:0 !important;
  transform:none !important;
}
.stats-item:last-child{border-right:none}
.stats-item:hover{
  background:rgba(0,173,216,0.04) !important;
  transform:none !important;
}

.stats-number{
  font-family:var(--font-display);
  font-weight:700;
  font-variation-settings:"wdth" 90;
  font-size:48px;
  line-height:1;
  color:var(--go-blue);
  letter-spacing:-0.04em;
  font-feature-settings:"tnum";
  flex-shrink:0;
  display:inline-flex;
  align-items:baseline;
}
/* Main label — bold sans, regular case, white text */
.stats-label{
  font-family:var(--font-sans) !important;
  font-weight:600 !important;
  font-size:14px !important;
  color:var(--text-primary) !important;
  text-transform:none !important;
  letter-spacing:0 !important;
  margin-bottom:2px;
  white-space:nowrap;
}

/* ===== Section heads ===== */
.section-title, .section-header h2{
  font-family:var(--font-display);
  font-weight:700;
  font-variation-settings:"wdth" 100,"opsz" 72;
  font-size:clamp(28px,4vw,44px);
  line-height:1.05;
  letter-spacing:-0.025em;
  color:var(--text-primary);
}
.section-link{
  font-family:var(--font-mono);
  font-size:13px;
  color:var(--go-blue);
  font-weight:500;
}
.section-link:hover{color:var(--br-yellow)}
.section-desc{
  font-family:var(--font-sans);
  color:var(--text-secondary);
  max-width:680px;
}

/* ===== Job cards ===== */
.job-card{
  background:var(--bg-secondary);
  border:1px solid var(--border-color);
  border-left:4px solid var(--go-blue);
  border-radius:var(--radius-md);
  padding:24px;
  transition:all 200ms ease-out;
}
.job-card:hover{
  transform:translateY(-3px);
  border-left-color:var(--br-yellow);
  box-shadow:var(--shadow-go);
}
.job-title{
  font-family:var(--font-display);
  font-weight:600;
  font-variation-settings:"wdth" 100,"opsz" 32;
  font-size:20px;
  line-height:1.2;
  color:var(--text-primary);
  letter-spacing:-0.015em;
}
.job-company{
  font-family:var(--font-mono);
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:0.12em;
  color:var(--text-secondary);
}
.job-logo, .job-logo-placeholder{
  border-radius:var(--radius-sm);
}
.job-logo-placeholder{
  background:var(--bg-tertiary);
  color:var(--go-blue);
  font-family:var(--font-display);
  font-weight:700;
}
.job-badge{
  font-family:var(--font-mono);
  font-size:11px;
  font-weight:500;
  letter-spacing:0.04em;
  padding:4px 10px;
  border-radius:var(--radius-pill);
  border:1px solid var(--border-strong);
}
.job-badge.remote{
  background:rgba(0,156,59,0.12);
  color:var(--br-green);
  border-color:rgba(0,156,59,0.3);
}
.job-badge.hybrid{
  background:rgba(255,223,0,0.12);
  color:var(--br-yellow);
  border-color:rgba(255,223,0,0.35);
}

/* ===== Tutorial cards ===== */
.tutorial-card{
  background:var(--bg-secondary);
  border:1px solid var(--border-color);
  border-radius:var(--radius-md);
  transition:all 200ms;
}
.tutorial-card:hover{
  border-color:var(--go-blue);
  transform:translateY(-2px);
}
.tutorial-card h3{
  font-family:var(--font-display);
  font-weight:600;
  letter-spacing:-0.015em;
}
.tutorial-icon{
  font-family:var(--font-display);
  font-weight:700;
  color:var(--go-blue);
  font-feature-settings:"tnum";
}

/* ===== Blog cards ===== */
.blog-card{
  background:var(--bg-secondary);
  border:1px solid var(--border-color);
  border-radius:var(--radius-md);
  transition:all 200ms;
}
.blog-card:hover{
  border-color:var(--go-blue);
  transform:translateY(-2px);
}
.blog-title{
  font-family:var(--font-display);
  font-weight:600;
  letter-spacing:-0.015em;
  color:var(--text-primary);
}
.blog-date{
  font-family:var(--font-mono);
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:0.12em;
  color:var(--br-yellow);
}
.blog-excerpt{
  font-family:var(--font-sans);
  color:var(--text-secondary);
}

/* ===== Version highlight (matches finalized.html magazine card) ===== */
.version-card{
  background:linear-gradient(135deg,rgba(0,173,216,0.10),rgba(255,223,0,0.05)) !important;
  border:1px solid var(--go-blue) !important;
  border-radius:var(--radius-lg) !important;
  padding:48px !important;
  position:relative;
  overflow:hidden;
}
.version-badge{
  display:inline-block !important;
  background:var(--br-yellow) !important;
  color:#0A1929 !important;
  font-family:var(--font-mono) !important;
  font-weight:700 !important;
  font-size:11px !important;
  padding:5px 12px !important;
  text-transform:uppercase !important;
  letter-spacing:0.16em !important;
  border-radius:var(--radius-pill) !important;
  margin-bottom:16px !important;
}
.version-info{
  display:flex !important;
  align-items:baseline !important;
  gap:16px !important;
  flex-wrap:wrap !important;
  margin-bottom:32px !important;
}
.version-info h2{
  font-family:var(--font-display) !important;
  font-weight:800 !important;
  font-variation-settings:"wdth" 90 !important;
  font-size:clamp(40px,6vw,72px) !important;
  letter-spacing:-0.04em !important;
  color:var(--go-blue) !important;
  line-height:1 !important;
  margin:0 !important;
  font-feature-settings:"tnum" !important;
}
.version-date{
  font-family:var(--font-mono) !important;
  color:var(--text-secondary) !important;
  font-size:13px !important;
  text-transform:uppercase !important;
  letter-spacing:0.14em !important;
}
.version-features h3{
  font-family:var(--font-display) !important;
  font-weight:700 !important;
  font-size:24px !important;
  letter-spacing:-0.015em !important;
  color:var(--text-primary) !important;
  margin-bottom:24px !important;
}
.version-features ul{
  display:grid !important;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr)) !important;
  gap:24px !important;
  list-style:none !important;
  padding:0 !important;
  margin:0 0 32px 0 !important;
}
.version-features li{
  border-left:3px solid var(--go-blue);
  padding-left:18px !important;
  background:none !important;
  list-style:none !important;
  position:relative;
}
.version-features li::before, .version-features li::marker{display:none !important; content:none !important}
.version-features li strong{
  display:block !important;
  font-family:var(--font-display) !important;
  font-weight:700 !important;
  font-size:16px !important;
  letter-spacing:-0.01em !important;
  margin-bottom:4px !important;
}
.version-features li p{
  color:var(--text-secondary) !important;
  font-size:14px !important;
  margin-top:4px !important;
  line-height:1.5 !important;
}
/* Cycle through 5 flag-aligned accent colors */
.version-features li:nth-child(5n+1){border-left-color:var(--br-green)}
.version-features li:nth-child(5n+1) strong{color:var(--br-green) !important}
.version-features li:nth-child(5n+2){border-left-color:var(--br-yellow)}
.version-features li:nth-child(5n+2) strong{color:var(--br-yellow) !important}
.version-features li:nth-child(5n+3){border-left-color:var(--go-blue)}
.version-features li:nth-child(5n+3) strong{color:var(--go-blue) !important}
.version-features li:nth-child(5n+4){border-left-color:var(--accent-coral)}
.version-features li:nth-child(5n+4) strong{color:var(--accent-coral) !important}
.version-features li:nth-child(5n+5){border-left-color:var(--go-blue-2)}
.version-features li:nth-child(5n+5) strong{color:var(--go-blue-2) !important}

.version-features .btn,
.version-features a.btn-outline{
  background:var(--go-blue) !important;
  color:#0A1929 !important;
  border-color:var(--go-blue) !important;
}
.version-features .btn:hover,
.version-features a.btn-outline:hover{
  background:var(--br-yellow) !important;
  border-color:var(--br-yellow) !important;
  color:#0A1929 !important;
}

/* ===== Newsletter form — fix clipped button ===== */
.newsletter-form{
  display:grid !important;
  grid-template-columns:1fr 1fr auto !important;
  gap:10px !important;
  margin-top:16px !important;
  align-items:stretch !important;
}
.newsletter-form input{
  padding:14px 16px !important;
  font-family:var(--font-sans) !important;
  font-size:15px !important;
  background:var(--bg-secondary) !important;
  border:1px solid var(--border-strong) !important;
  border-radius:var(--radius-sm) !important;
  color:var(--text-primary) !important;
  outline:none !important;
  width:100% !important;
}
.newsletter-form input:focus{border-color:var(--go-blue) !important}
.newsletter-form button{
  white-space:nowrap !important;
  padding:14px 24px !important;
}
@media (max-width:680px){
  .newsletter-form{
    grid-template-columns:1fr !important;
  }
  .newsletter-form button{padding:12px 18px !important; font-size:14px !important}
  .version-card{padding:28px !important}
  .version-info h2{font-size:48px !important}
  .version-features ul{grid-template-columns:1fr !important; gap:18px !important}
}

/* ===== Features grid ===== */
.feature-card{
  background:var(--bg-secondary);
  border:1px solid var(--border-color);
  border-radius:var(--radius-md);
  transition:all 200ms;
}
.feature-card:hover{border-color:var(--go-blue); transform:translateY(-2px)}
.feature-card h3{
  font-family:var(--font-display);
  font-weight:700;
  letter-spacing:-0.015em;
}
.feature-icon{
  font-family:var(--font-display);
  font-weight:800;
  font-size:28px;
  color:var(--go-blue);
  font-feature-settings:"tnum";
}

/* ===== Use cases ===== */
.use-case-card{
  background:var(--bg-secondary);
  border:1px solid var(--border-color);
  border-radius:var(--radius-md);
  transition:all 200ms;
}
.use-case-card:hover{border-color:var(--go-blue); transform:translateY(-2px)}
.use-case-card h3{
  font-family:var(--font-display);
  font-weight:700;
  letter-spacing:-0.015em;
}
.use-case-icon{
  background:rgba(0,173,216,0.12);
  color:var(--go-blue);
  border-radius:var(--radius-md);
}
.use-case-examples span{
  font-family:var(--font-mono);
  font-size:11px;
  background:rgba(0,173,216,0.1);
  color:var(--go-blue-2);
  border:1px solid rgba(0,173,216,0.25);
  padding:3px 8px;
  border-radius:var(--radius-pill);
}

/* ===== Comparisons ===== */
.comparison-card{
  background:var(--bg-secondary);
  border:1px solid var(--border-color);
  border-radius:var(--radius-md);
  transition:all 200ms;
}
.comparison-card:hover{
  border-color:var(--go-blue);
  transform:translateY(-2px);
}
.comparison-lang{
  font-family:var(--font-display);
  font-weight:700;
  font-variation-settings:"wdth" 95;
  letter-spacing:-0.02em;
  color:var(--text-primary);
}
.comparison-divider{
  font-family:var(--font-mono);
  color:var(--br-yellow);
  font-weight:500;
}
.comparisons-extra a{
  font-family:var(--font-mono);
  font-size:13px;
  color:var(--go-blue);
  border:1px solid var(--border-strong);
  padding:8px 14px;
  border-radius:var(--radius-pill);
  text-decoration:none;
  transition:all 150ms;
}
.comparisons-extra a:hover{
  border-color:var(--go-blue);
  background:rgba(0,173,216,0.06);
}

/* ===== Code example ===== */
.code-card{
  background:var(--bg-surface-3);
  border:1px solid var(--border-color);
  border-radius:var(--radius-md);
  overflow:hidden;
  position:relative;
}
.code-card::before{
  content:'';
  position:absolute; top:0; left:0; right:0;
  height:3px;
  background:linear-gradient(90deg,var(--go-blue),var(--br-green),var(--br-yellow));
  z-index:1;
}
.code-header{
  background:var(--bg-secondary);
  border-bottom:1px solid var(--border-color);
}
.code-dot{
  width:10px; height:10px;
  border-radius:50%;
  display:inline-block;
}
.code-dot.red{background:#F76C6C}
.code-dot.yellow{background:var(--br-yellow)}
.code-dot.green{background:var(--br-green)}
.code-filename{
  font-family:var(--font-mono);
  font-size:12px;
  color:var(--text-secondary);
}
.code-caption{
  font-family:var(--font-sans);
  color:var(--text-secondary);
  font-size:14px;
  text-align:center;
  margin-top:14px;
}

/* ===== CTA ===== */
.cta{
  background:linear-gradient(135deg,rgba(0,173,216,0.08),rgba(255,223,0,0.04));
  border-top:1px solid var(--border-color);
  border-bottom:1px solid var(--border-color);
}
.cta-content h2{
  font-family:var(--font-display);
  font-weight:800;
  font-variation-settings:"wdth" 95;
  font-size:clamp(40px,5vw,64px);
  letter-spacing:-0.035em;
  color:var(--go-blue);
}

/* ===== Newsletter ===== */
.newsletter-card{
  background:linear-gradient(135deg,rgba(0,173,216,0.08),rgba(255,223,0,0.04));
  border:1px solid var(--go-blue);
  border-radius:var(--radius-lg);
  position:relative;
  overflow:hidden;
}
.newsletter-card h2{
  font-family:var(--font-display);
  font-weight:700;
  letter-spacing:-0.02em;
}
.newsletter-form input{
  background:var(--bg-secondary);
  border:1px solid var(--border-strong);
  border-radius:var(--radius-sm);
  color:var(--text-primary);
  font-family:var(--font-sans);
}
.newsletter-form input:focus{
  border-color:var(--go-blue);
  outline:none;
}
.newsletter-status.success{
  color:var(--br-green);
  font-family:var(--font-sans);
}
.newsletter-status.error{
  color:var(--accent-coral);
  font-family:var(--font-sans);
}
.newsletter-privacy{
  font-family:var(--font-mono);
  font-size:11px;
  color:var(--text-muted);
  text-transform:uppercase;
  letter-spacing:0.1em;
}

/* ===== Footer ===== */
.site-footer{
  background:var(--bg-surface-3);
  border-top:1px solid var(--border-color);
  margin-top:80px;
  padding-top:64px;
  position:relative;
}
.footer-logo{
  font-family:var(--font-display);
  font-weight:700;
  font-size:22px;
  letter-spacing:-0.02em;
  color:var(--text-primary);
}
.footer-brand p{
  font-family:var(--font-sans);
  color:var(--text-secondary);
  font-size:14px;
  line-height:1.6;
}
.footer-links h4{
  font-family:var(--font-display);
  font-weight:700;
  font-size:14px;
  text-transform:uppercase;
  letter-spacing:0.12em;
  color:var(--go-blue);
}
.footer-links a{
  font-family:var(--font-sans);
  color:var(--text-primary);
  font-size:14px;
}
.footer-links a:hover{color:var(--go-blue)}
.footer-bottom{
  font-family:var(--font-mono);
  font-size:12px;
  color:var(--text-secondary);
  border-top:1px solid var(--border-color);
}
.footer-bottom a{color:var(--go-blue)}

/* Sister sites — re-themed for dark mode */
.footer-sister-sites{
  border-bottom:1px solid var(--border-color) !important;
}
.sister-sites-title{
  font-family:var(--font-display) !important;
  color:var(--text-primary) !important;
  font-weight:700 !important;
}
.sister-site-card{
  background:var(--bg-secondary) !important;
  border:1px solid var(--border-color) !important;
}
.sister-site-card:hover{
  border-color:var(--go-blue) !important;
  transform:translateY(-2px);
}
.sister-site-info h5{
  font-family:var(--font-display) !important;
  color:var(--text-primary) !important;
  font-weight:600 !important;
}
.sister-site-info p{
  font-family:var(--font-sans) !important;
  color:var(--text-secondary) !important;
}
.sister-site-card.zig:hover{background:var(--bg-tertiary) !important}
.sister-site-card.claw:hover{background:var(--bg-tertiary) !important}
.sister-site-card.ai:hover{background:var(--bg-tertiary) !important}

/* ===== Breadcrumbs ===== */
.breadcrumbs{
  border-bottom:1px solid var(--border-color);
}
.breadcrumb-list, .breadcrumb-list a, .breadcrumb-current{
  font-family:var(--font-mono);
  font-size:12px;
  letter-spacing:0.08em;
  color:var(--text-secondary);
}
.breadcrumb-list a{color:var(--go-blue)}
.breadcrumb-list a:hover{color:var(--br-yellow)}
.breadcrumb-separator{color:var(--text-muted)}

/* ===== Search ===== */
.search-toggle, .mobile-menu-btn{
  background:transparent;
  border:1px solid var(--border-strong);
  border-radius:var(--radius-sm);
  color:var(--text-primary);
  transition:all 150ms;
}
.search-toggle:hover, .mobile-menu-btn:hover{
  border-color:var(--go-blue);
  color:var(--go-blue);
}
.search-modal{
  background:var(--bg-secondary);
  border:1px solid var(--border-strong);
  border-radius:var(--radius-md);
}
.search-input{
  font-family:var(--font-sans);
  background:transparent;
  color:var(--text-primary);
}
.search-shortcut, .search-footer{
  font-family:var(--font-mono);
  color:var(--text-secondary);
  font-size:11px;
  letter-spacing:0.08em;
}

/* ===== Aprenda / channel / community / blog hero, generic content pages ===== */
.aprenda-hero, .blog-hero, .community-hero, .cheatsheet-hero, .anunciar-hero, .cadastrar-hero{
  position:relative;
}
.aprenda-hero h1, .blog-hero h1, .community-hero h1, .cheatsheet-hero h1, .anunciar-hero h1, .cadastrar-hero h1{
  font-family:var(--font-display);
  font-weight:700;
  font-variation-settings:"wdth" 95,"opsz" 96;
  letter-spacing:-0.035em;
}

.channel-card, .article-card, .content-card, .cheat-card, .destaque-card, .benefit-card, .conference{
  background:var(--bg-secondary);
  border:1px solid var(--border-color);
  border-radius:var(--radius-md);
  transition:all 200ms;
}
.channel-card:hover, .article-card:hover, .content-card:hover, .cheat-card:hover, .destaque-card:hover{
  border-color:var(--go-blue);
  transform:translateY(-2px);
}
.channel-card h3, .article-card h3, .content-card h3, .cheat-card h3, .destaque-card h3, .benefit-card h3, .conference h3{
  font-family:var(--font-display);
  font-weight:700;
  letter-spacing:-0.015em;
}

/* ===== RESPONSIVE ===== */
@media (max-width:1080px){
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .stats-item{border-right:none; border-bottom:1px solid var(--border-color)}
  .stats-item:nth-child(odd){border-right:1px solid var(--border-color)}
}
@media (max-width:768px){
  .hero{padding:48px 0 40px}
  .hero h1{font-size:clamp(34px,9vw,52px); line-height:1.02}
  .hero-subtitle{font-size:16px}
  .stats-grid{grid-template-columns:1fr}
  .stats-item:nth-child(odd){border-right:none}
  .stats-item:last-child{border-bottom:none}
  .stats-number{font-size:36px}
  .section-title, .section-header h2{font-size:clamp(24px,7vw,32px)}
  .job-title{font-size:17px}
  .footer-bottom{flex-direction:column; gap:12px; text-align:center}
}

/* ===== Reduced motion ===== */
@media (prefers-reduced-motion: reduce){
  .hero-gopher img{animation:none !important}
  .hero-eyebrow-dot{animation:none !important}
  *, *::before, *::after{
    animation-duration:0.01ms !important;
    transition-duration:0.01ms !important;
  }
}

/* ===== Focus rings ===== */
:focus-visible{
  outline:2px solid var(--go-blue);
  outline-offset:3px;
  border-radius:4px;
}

/* ===== Hero confetti ===== */
.hero{position:relative}
.hero .confetti{
  position:absolute; inset:0; pointer-events:none;
  opacity:0.7; z-index:0;
}
.hero .confetti span{
  position:absolute; border-radius:50%;
  animation: bgn-float 8s ease-in-out infinite;
}
@keyframes bgn-float{
  0%,100%{transform:translateY(0) rotate(0deg)}
  50%{transform:translateY(-12px) rotate(8deg)}
}
.hero > .container{position:relative; z-index:2}

/* ===== Stats sub-labels + plus + info column ===== */
.stats-item{
  flex-direction:row !important;
  align-items:center !important;
  gap:18px !important;
}
.stats-info{
  display:flex; flex-direction:column;
}
.stats-plus{
  font-size:0.6em;
  color:var(--br-yellow);
  font-weight:700;
  vertical-align:top;
  margin-left:2px;
}
.stats-sub{
  font-family:var(--font-mono);
  font-size:11px;
  color:var(--text-muted);
  text-transform:uppercase;
  letter-spacing:0.1em;
  margin-top:2px;
}

/* ===== Section pill (in section title) ===== */
.section-pill{
  display:inline-block;
  vertical-align:middle;
  background:var(--br-yellow);
  color:#0A1929;
  font-family:var(--font-display);
  font-weight:700;
  font-size:14px;
  padding:4px 12px;
  border-radius:var(--radius-pill);
  margin-left:12px;
  letter-spacing:0;
  font-variation-settings:"wdth" 100;
}

/* ===== Refactored job cards ===== */
.job-card{
  display:flex !important;
  flex-direction:column !important;
  gap:14px !important;
  padding:24px !important;
  background:var(--bg-secondary);
  border:1px solid var(--border-color);
  border-left:4px solid var(--go-blue);
  border-radius:var(--radius-md);
  transition:all 200ms ease-out;
  position:relative;
  overflow:hidden;
}
.job-card.featured{border-left-color:var(--br-yellow)}
.job-card:hover{
  transform:translateY(-3px);
  border-left-color:var(--br-yellow);
  box-shadow:var(--shadow-go);
}
.job-card .job-company{
  display:flex !important;
  align-items:center;
  gap:10px;
  font-family:var(--font-mono);
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:0.12em;
  color:var(--text-secondary);
}
.job-card .logo-dot{
  width:24px; height:24px;
  border-radius:6px;
  background:var(--bg-tertiary);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  color:var(--go-blue);
  font-weight:700;
  font-size:11px;
  font-family:var(--font-display);
  flex-shrink:0;
}
.job-card .logo-dot.logo-img{
  padding:0;
  background:transparent;
  object-fit:contain;
}
.job-card .job-title{
  font-family:var(--font-display);
  font-weight:600;
  font-variation-settings:"wdth" 100,"opsz" 32;
  font-size:20px;
  line-height:1.2;
  color:var(--text-primary);
  letter-spacing:-0.015em;
  margin:0;
}
.job-card:hover .job-title{color:var(--go-blue)}
.job-pills{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
}
.pill{
  display:inline-block;
  padding:4px 10px;
  border-radius:var(--radius-pill);
  font-family:var(--font-mono);
  font-size:11px;
  font-weight:500;
  letter-spacing:0.04em;
  border:1px solid var(--border-strong);
}
.pill.location{
  background:transparent;
  color:var(--text-primary);
  border-color:var(--border-strong);
}
.pill.remote{
  background:rgba(0,156,59,0.12);
  color:var(--br-green);
  border-color:rgba(0,156,59,0.3);
}
.pill.senior{
  background:rgba(255,223,0,0.12);
  color:var(--br-yellow);
  border-color:rgba(255,223,0,0.35);
}
.pill.tech{
  background:rgba(0,173,216,0.1);
  color:var(--go-blue-2);
  border-color:rgba(0,173,216,0.25);
}
.job-bottom{
  display:flex;
  align-items:center;
  justify-content:space-between;
  margin-top:auto;
  padding-top:14px;
  border-top:1px solid var(--border-color);
}
.job-when{
  font-family:var(--font-mono);
  font-size:11px;
  color:var(--text-muted);
  text-transform:uppercase;
  letter-spacing:0.08em;
}
.job-featured-mark{
  font-family:var(--font-mono);
  font-size:10px;
  font-weight:600;
  color:var(--br-yellow);
  letter-spacing:0.16em;
  text-transform:uppercase;
}

/* ===== Aprenda Go em pt-BR (3 colored Gopher mini cards) ===== */
.aprenda-home{
  padding:80px 0;
  background:var(--bg-surface-3);
  border-top:1px solid var(--border-color);
  border-bottom:1px solid var(--border-color);
}
.aprenda-cards{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
  margin-top:32px;
}
.aprenda-card{
  background:var(--bg-secondary);
  border:1px solid var(--border-color);
  border-radius:var(--radius-md);
  padding:32px;
  display:flex;
  flex-direction:column;
  gap:14px;
  text-decoration:none;
  transition:all 200ms ease-out;
  position:relative;
}
.aprenda-card:hover{
  transform:translateY(-3px);
  border-color:var(--go-blue);
  box-shadow:var(--shadow-go);
}
.aprenda-mini{
  width:64px;
  height:64px;
  margin-bottom:8px;
}
.aprenda-card h3{
  font-family:var(--font-display);
  font-weight:700;
  font-variation-settings:"wdth" 100;
  font-size:24px;
  line-height:1.15;
  letter-spacing:-0.02em;
  color:var(--text-primary);
  margin:0;
}
.aprenda-accent{color:var(--go-blue)}
.aprenda-card--yellow .aprenda-accent{color:var(--br-yellow)}
.aprenda-card--green .aprenda-accent{color:var(--br-green)}
.aprenda-card--blue:hover{border-color:var(--go-blue)}
.aprenda-card--yellow:hover{border-color:var(--br-yellow)}
.aprenda-card--green:hover{border-color:var(--br-green)}

.aprenda-card p{
  color:var(--text-secondary);
  font-size:15px;
  line-height:1.55;
  margin:0;
}
.aprenda-cta{
  font-family:var(--font-mono);
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:0.16em;
  color:var(--go-blue);
  margin-top:auto;
  padding-top:12px;
  font-weight:500;
}
.aprenda-card--yellow .aprenda-cta{color:var(--br-yellow)}
.aprenda-card--green .aprenda-cta{color:var(--br-green)}

@media (max-width:880px){
  .aprenda-cards{grid-template-columns:1fr; gap:16px}
  .aprenda-home{padding:56px 0}
  .aprenda-card{padding:24px}
  .aprenda-card h3{font-size:20px}
}

/* ===== Empresas home section ===== */
.empresas-home .empresas-card{
  background:var(--bg-secondary);
  border:1px solid var(--border-color);
  border-radius:var(--radius-lg);
  padding:48px 32px;
  position:relative;
  overflow:hidden;
}
.empresas-home .empresas-card::before{
  content:'';
  position:absolute; top:0; left:0; right:0;
  height:4px;
  background:linear-gradient(90deg,
    var(--br-green) 0,    var(--br-green) 33%,
    var(--br-yellow) 33%, var(--br-yellow) 66%,
    var(--br-blue) 66%
  );
}
.empresas-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
  margin-bottom:24px;
  flex-wrap:wrap;
}
.empresas-head .section-title{margin:0; font-size:32px}
.empresas-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(140px,1fr));
  gap:14px;
}
.company-chip{
  background:var(--bg-tertiary);
  border:1px solid var(--border-color);
  border-radius:var(--radius-sm);
  padding:14px 16px;
  font-family:var(--font-display);
  font-weight:700;
  font-size:15px;
  color:var(--text-primary);
  text-align:center;
  text-decoration:none;
  transition:all 150ms;
  letter-spacing:-0.005em;
  font-variation-settings:"wdth" 100;
}
.company-chip:hover{
  border-color:var(--go-blue);
  transform:translateY(-2px);
  color:var(--go-blue);
}
.company-chip.more{
  background:transparent;
  color:var(--text-secondary);
  font-style:italic;
  font-family:var(--font-sans);
  font-weight:500;
}

/* ===== Mobile tweaks for new components ===== */
@media (max-width:768px){
  .hero .confetti span{width:8px !important; height:8px !important}
  .stats-item{padding:24px 18px !important}
  .stats-number{font-size:36px}
  .stats-info{gap:0}
  .stats-sub{font-size:10px}
  .section-pill{font-size:11px; padding:3px 10px}
  .job-card{padding:18px !important}
  .job-card .job-title{font-size:17px !important}
  .pill{font-size:10px; padding:3px 8px}
  .empresas-home .empresas-card{padding:32px 20px}
  .empresas-head{flex-direction:column; align-items:flex-start; gap:14px}
  .empresas-head .section-title{font-size:24px}
  .empresas-grid{grid-template-columns:repeat(2,1fr); gap:8px}
  .company-chip{font-size:13px; padding:12px 10px}
  .job-bottom{font-size:10px}
}
