:root{
  --brand:#12363d;
  --brand-2:#0d2a30;
  --brand-3:#1f4b54;
  --accent:#2e6671;
  --bg:#f5f7f8;
  --bg-elevated:#eef2f4;
  --surface:#ffffff;
  --surface-soft:#f8fafb;
  --surface-muted:#f2f5f6;
  --text:#11161a;
  --text-soft:#5b6772;
  --text-muted:#73808c;
  --border:#d8e0e5;
  --border-strong:#c7d1d8;
  --shadow-soft:0 18px 45px rgba(10,19,24,.08);
  --shadow-card:0 22px 56px rgba(10,19,24,.09);
  --radius-lg:18px;
  --radius-xl:26px;
  --radius-2xl:32px;
  --container:1200px;
  --content:1120px;
  --reading:72ch;
  --font-sans:"Inter",system-ui,-apple-system,"Segoe UI",Roboto,Arial,sans-serif;
  --fz-body:16.5px;
  --lh-body:1.72;
  --fz-small:.92rem;
  --fz-h1:clamp(2.5rem,4.6vw,4.55rem);
  --fz-h2:clamp(1.85rem,3.1vw,2.85rem);
  --fz-h3:clamp(1.2rem,1.5vw,1.45rem);
  --fz-hero-copy:clamp(1rem,1.08vw,1.1rem);
  --grad-hero:linear-gradient(135deg,#0d252b 0%,#12363d 48%,#1f4b54 100%);
  --grad-subtle:linear-gradient(180deg,rgba(255,255,255,.88) 0%,rgba(244,247,248,.94) 100%);
}

html{overflow-x:hidden;scroll-padding-top:96px;color-scheme:light dark}
body{
  overflow-x:hidden;
  font-family:var(--font-sans);
  font-size:var(--fz-body);
  line-height:var(--lh-body);
  letter-spacing:-.01em;
  color:var(--text);
  background:
    radial-gradient(circle at top right, rgba(18,54,61,.08), transparent 22%),
    radial-gradient(circle at bottom left, rgba(31,75,84,.05), transparent 20%),
    linear-gradient(180deg,#fafcfc 0%, var(--bg) 100%);
  text-rendering:optimizeLegibility;
  -webkit-font-smoothing:antialiased;
}

body, input, button, textarea, select{font-family:var(--font-sans)}
a{color:var(--brand);text-decoration:none}
a:hover,a:focus-visible{color:var(--brand-3)}
p, li{color:var(--text-soft)}
p{margin:0 0 1rem}
small,.text-muted{color:var(--text-muted)}

h1,h2,h3,h4,h5,h6{
  color:var(--text);
  margin:0 0 .8rem;
  line-height:1.08;
  letter-spacing:-.035em;
  font-weight:800;
}
h1{font-size:var(--fz-h1)}
h2{font-size:var(--fz-h2)}
h3{font-size:var(--fz-h3)}
.section-title,.page-hero-inner h1,.hero-copy h1,.commercial-copy h1{max-width:14ch}
.hero-copy p,.commercial-copy p,.page-hero-inner p,.section-head p,.content-card p,.feature-card p,.card p,.sidebar-card p,.metric-card p,.spotlight-card p,.brand-bucket p,.journey-choice-card p{max-width:var(--reading)}
.lead,.hero-lead,.page-hero-inner p,.commercial-copy p{font-size:var(--fz-hero-copy);line-height:1.72}

.container{width:min(calc(100% - 40px), var(--container));max-width:var(--container);margin-inline:auto}
.narrow,.content-narrow{max-width:var(--content);margin-inline:auto}
main section{scroll-margin-top:108px}
section, .page-section{position:relative}
.page-section{padding-block:clamp(2.25rem,4vw,4.25rem)}
.page-section.compact{padding-block:clamp(1.8rem,3vw,2.8rem)}
.stack-lg > * + *{margin-top:1.5rem}
.stack-xl > * + *{margin-top:2rem}

.site-header{
  position:sticky;
  top:0;
  z-index:100;
  background:color-mix(in srgb, var(--surface) 88%, transparent);
  backdrop-filter:blur(14px);
  border-bottom:1px solid rgba(17,22,26,.06);
}
.topbar{
  background:#101518;
  color:#dae4e8;
  font-size:.88rem;
  line-height:1.45;
}
.topbar a{color:#f3f7f8}
.topbar-content{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.6rem 0}
.nav-shell{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:1.25rem;padding:1rem 0}
.brand{display:flex;align-items:center;gap:.9rem;min-width:0}
.brand-mark{
  width:52px;height:52px;flex:0 0 52px;
  border-radius:18px;
  display:grid;place-items:center;
  background:linear-gradient(135deg,var(--brand),var(--brand-3));
  color:#fff;
  box-shadow:0 12px 26px rgba(18,54,61,.22);
  font-weight:800;
  letter-spacing:.04em;
}
.brand-copy strong{display:block;font-size:1rem;letter-spacing:.08em}
.brand-copy small{display:block;font-size:.8rem;color:var(--text-muted);text-transform:lowercase}
.site-nav{display:flex;align-items:center;justify-content:center;gap:1.15rem;flex-wrap:wrap}
.site-nav a{color:var(--text);font-weight:600;font-size:.96rem;padding:.35rem 0;position:relative}
.site-nav a:hover,.site-nav a:focus-visible{color:var(--brand)}
.site-nav a::after{content:"";position:absolute;left:0;bottom:-.25rem;width:100%;height:2px;background:var(--brand);transform:scaleX(0);transform-origin:left;transition:transform .2s ease}
.site-nav a:hover::after,.site-nav a:focus-visible::after{transform:scaleX(1)}
.nav-cta{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;justify-content:flex-end}
.menu-toggle{display:none;border:1px solid var(--border);background:var(--surface);width:48px;height:48px;border-radius:16px;padding:0 !important;box-shadow:none}
.menu-toggle span:not(.sr-only){display:block;width:18px;height:2px;background:var(--text);margin:3px auto;border-radius:999px}

.btn,button,input[type=submit],input[type=button],.button{
  appearance:none;
  border-radius:14px !important;
  min-height:46px;
  padding:11px 18px !important;
  font-size:.96rem;
  font-weight:700 !important;
  letter-spacing:-.01em;
  transition:transform .18s ease, box-shadow .18s ease, background-color .18s ease, color .18s ease, border-color .18s ease;
}
.btn:hover,button:hover,input[type=submit]:hover,input[type=button]:hover{transform:translateY(-1px)}
.btn:focus-visible,button:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible,a:focus-visible{
  outline:none;
  box-shadow:0 0 0 4px rgba(18,54,61,.14);
}
.btn-primary,button[type=submit],input[type=submit]{
  background:var(--brand);
  border:1px solid var(--brand);
  color:#fff;
  box-shadow:0 12px 24px rgba(18,54,61,.14);
}
.btn-primary:hover,button[type=submit]:hover,input[type=submit]:hover{background:var(--brand-2);border-color:var(--brand-2)}
.btn-outline{
  background:color-mix(in srgb, var(--surface) 86%, transparent);
  color:var(--text);
  border:1px solid var(--border);
}
.btn-outline:hover{border-color:var(--brand);color:var(--brand);background:var(--surface)}
.btn-outline.light{
  background:rgba(255,255,255,.14);
  color:#fff;
  border-color:rgba(255,255,255,.3);
}
.btn-outline.light:hover,
.btn-outline.light:focus-visible{
  background:rgba(255,255,255,.2);
  color:#fff;
  border-color:rgba(255,255,255,.55);
}
.btn-outline.btn-soft{
  background:rgba(18,54,61,.08);
  border-color:rgba(18,54,61,.18);
  color:var(--brand);
}
.btn-outline.btn-soft:hover{background:rgba(18,54,61,.12);color:var(--brand-3);}
.btn-dark{background:#111418;border:1px solid #111418;color:#fff}
.btn-link{background:transparent;border:none;color:var(--brand);padding:0 !important;min-height:auto;box-shadow:none}
.btn-sm{min-height:38px;padding:9px 14px !important;font-size:.88rem}

.hero-commercial{padding:2rem 0 1.2rem}
.hero-commercial-grid{display:grid;grid-template-columns:minmax(0,1.18fr) minmax(300px,.82fr);gap:1.5rem;align-items:stretch}
.commercial-copy,.hero-copy,.foco-hero-main,.dark-band,.spotlight-card.page-hero-vagas{
  background:var(--grad-hero) !important;
  color:#fff !important;
  border-radius:var(--radius-2xl) !important;
  box-shadow:var(--shadow-card) !important;
}
.commercial-copy{
  min-height:clamp(420px,54vh,560px);
  padding:clamp(1.8rem,3vw,3rem);
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
}
.commercial-copy h1,.hero-copy h1,.foco-hero-main h1{margin-bottom:1rem;color:#fff}
.commercial-copy p,.hero-copy p,.foco-hero-main p,.dark-band p{color:rgba(255,255,255,.82)}
.hero-eyebrow,.section-eyebrow,.section-tag{
  display:inline-flex;
  align-items:center;
  gap:.45rem;
  letter-spacing:.12em;
  text-transform:uppercase;
  font-size:.76rem;
  font-weight:800;
  color:var(--text-muted);
}
.hero-commercial .hero-eyebrow,.dark-band .section-eyebrow{color:rgba(255,255,255,.7)}
.hero-actions,.inline-actions,.empty-state__actions,.chatbot-lead-actions{display:flex;flex-wrap:wrap;gap:.75rem}
.hero-quick-links{display:flex;flex-wrap:wrap;gap:.9rem;margin-top:1.1rem}
.hero-quick-links a{color:#fff;opacity:.92;border-bottom:1px solid rgba(255,255,255,.22)}
.hero-commercial-aside{display:grid;gap:1rem}
.page-hero{padding:1.4rem 0 .25rem}
.page-hero-inner{
  padding:clamp(1.6rem,2.5vw,2.4rem);
  border-radius:var(--radius-xl) !important;
  background:linear-gradient(180deg,rgba(255,255,255,.86) 0%,rgba(245,248,249,.92) 100%) !important;
  border:1px solid rgba(17,22,26,.06) !important;
  box-shadow:var(--shadow-soft) !important;
}
.page-hero-inner h1{font-size:clamp(2.15rem,3.5vw,3.2rem);line-height:1.02;margin-bottom:.85rem}
.page-hero-inner p{margin:0;max-width:62ch}

.section-surface,
.journey-choice-card,
.brand-bucket,
.content-card,
.feature-card,
.card,
.metric-card,
.sidebar-card,
.filters-card,
.form-card,
.spotlight-card,
.vaga-mural-card,
.job-board-card,
.page-hero-inner,
.empty-state,
.contact-card,
.table-card,
.dashboard-card{
  background:var(--grad-subtle) !important;
  border:1px solid rgba(17,22,26,.06) !important;
  border-radius:var(--radius-xl) !important;
  box-shadow:var(--shadow-soft) !important;
}
.journey-choice-card,.brand-bucket,.content-card,.feature-card,.card,.metric-card,.sidebar-card,.filters-card,.form-card,.spotlight-card,.vaga-mural-card,.job-board-card{padding:clamp(1.2rem,2vw,1.75rem)}
.section-head{display:flex;justify-content:space-between;align-items:flex-end;gap:1rem;margin-bottom:1.25rem}
.section-title{font-size:clamp(1.75rem,2.6vw,2.6rem);margin:0}
.badge,.tag,.chip{display:inline-flex;align-items:center;gap:.45rem;padding:.5rem .8rem;border-radius:999px;font-size:.8rem;font-weight:700}
.badge{background:#edf3f5;color:var(--brand);border:1px solid rgba(18,54,61,.08)}
.badge.accent{background:#e6eff2;color:var(--brand-3)}
.metric-card strong,.highlight-value{color:var(--brand)}
.table-card table,.table table{width:100%}

.brand-buckets{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem}
.grid-form,.form-grid,.search-bar,.stack,.stats-strip,.hero-strip{display:grid;gap:1rem}
.form-card,.filters-card,.sidebar-card{padding:clamp(1.2rem,2vw,1.75rem)}
.field{display:grid;gap:.45rem}
.field label,label.form-label{font-size:.95rem;font-weight:700;color:var(--text)}
.field-help,.form-text{font-size:.84rem;color:var(--text-muted)}
input,select,textarea{
  width:100%;
  min-height:48px;
  background:rgba(255,255,255,.94);
  border:1px solid var(--border);
  border-radius:14px;
  padding:12px 14px;
  color:var(--text);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.45);
}
textarea{min-height:120px;resize:vertical}
.field-required{color:var(--brand);font-weight:700}
.form-intro{margin-bottom:1rem}
.form-intro .field-help{margin:0;}
input::placeholder,textarea::placeholder{color:#8a98a4}
.check,.checkbox-card{background:var(--surface-muted);border:1px solid var(--border);border-radius:14px;padding:.9rem 1rem}
.form-actions{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:.25rem}
.form-section-title{font-size:1.08rem;margin-bottom:.4rem}

.site-footer{
  background:linear-gradient(135deg,#0e1317 0%, #12363d 100%);
  color:#fff;
  margin-top:clamp(2.5rem,4vw,4rem);
}
.site-footer p,.site-footer li,.site-footer a,.site-footer small{color:rgba(255,255,255,.78)}
.site-footer a:hover,.site-footer a:focus-visible{color:#fff}
.footer-grid{display:grid;grid-template-columns:1.3fr .8fr .8fr;gap:2rem;padding:2.6rem 0}
.footer-brand{font-size:1.1rem;font-weight:800;letter-spacing:.08em;color:#fff;margin-bottom:.65rem}
.footer-bottom{background:rgba(0,0,0,.12);padding:.95rem 0;font-size:.9rem}

.chatbot-widget{position:fixed;right:20px;bottom:20px;z-index:60;display:flex;flex-direction:column;align-items:flex-end;gap:12px;max-width:min(420px,calc(100vw - 24px))}
.chatbot-toggle{
  display:flex;align-items:center;gap:12px;
  width:min(350px,calc(100vw - 24px));
  background:#101518;color:#fff;
  border:1px solid rgba(255,255,255,.08);
  border-radius:18px !important;
  box-shadow:0 18px 42px rgba(0,0,0,.18);
  justify-content:flex-start;
}
.chatbot-toggle-icon{width:40px;height:40px;flex:0 0 40px;border-radius:14px;display:grid;place-items:center;background:linear-gradient(135deg,var(--brand),var(--brand-3));font-size:1.05rem}
.chatbot-toggle-copy strong,.chatbot-header strong{display:block;color:#fff}
.chatbot-toggle-copy small,.chatbot-header span{display:block;color:#c2cdd3}
.chatbot-panel{
  width:min(400px,calc(100vw - 24px));
  max-height:min(78vh,760px);
  background:var(--surface);
  border:1px solid rgba(17,22,26,.08);
  border-radius:24px;
  box-shadow:0 28px 70px rgba(16,20,24,.2);
  overflow:hidden;
}
.chatbot-header{display:flex;justify-content:space-between;align-items:flex-start;gap:.8rem;padding:1rem 1rem .85rem;background:linear-gradient(135deg,#0f1518 0%, #12363d 100%);color:#fff}
.chatbot-header-actions{display:flex;align-items:center;gap:.25rem}
.chatbot-close,.chatbot-minimize{background:transparent;border:none;color:#fff;box-shadow:none;min-height:auto;padding:.2rem .45rem !important;font-size:1.25rem;line-height:1}
.chatbot-body{padding:1rem;display:grid;gap:.9rem;background:var(--surface-soft)}
.chatbot-status-row{display:flex;justify-content:space-between;align-items:center;gap:.75rem}
.chatbot-status-pill{display:inline-flex;align-items:center;padding:.45rem .7rem;border-radius:999px;background:#edf3f5;color:var(--brand);font-size:.78rem;font-weight:800}
.chatbot-link-btn{background:none;border:none;color:var(--brand);padding:0 !important;min-height:auto;box-shadow:none;font-size:.88rem}
.chatbot-messages{display:grid;gap:.7rem;max-height:240px;overflow:auto;padding-right:2px}
.chatbot-msg{padding:.82rem .95rem;border-radius:18px;display:grid;gap:.35rem}
.chatbot-msg strong{font-size:.86rem;letter-spacing:-.01em}
.chatbot-msg p{margin:0;font-size:.92rem;line-height:1.58}
.chatbot-msg-user{background:#14181b;color:#fff;margin-left:22px}
.chatbot-msg-user p,.chatbot-msg-user strong{color:#fff}
.chatbot-msg-bot{background:#eef4f5;border:1px solid rgba(18,54,61,.08);margin-right:22px}
.chatbot-quick-actions,.chatbot-faq{display:grid;gap:.65rem}
.chatbot-chip,.chatbot-faq-item{width:100%;text-align:left;background:var(--surface);color:var(--text);border:1px solid var(--border);border-radius:14px !important;padding:.8rem .95rem !important;box-shadow:none}
.chatbot-faq-item strong{display:block;margin-bottom:.15rem;color:var(--text)}
.chatbot-faq-item span{display:block;font-size:.88rem;color:var(--text-soft)}
.chatbot-lead-card{border:1px solid var(--border);background:var(--surface);border-radius:18px;padding:.95rem;display:grid;gap:.75rem}
.chatbot-lead-copy span,.chatbot-footer small{color:var(--text-soft)}
.chatbot-mini-grid,.chatbot-lead-actions{display:grid;gap:.65rem}
.chatbot-mini-grid{grid-template-columns:1fr 1fr}
.chatbot-footer{padding:.95rem 1rem;border-top:1px solid rgba(17,22,26,.08);background:var(--surface)}
.chatbot-form{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:.65rem}
.chatbot-form input{min-height:44px}

.empty-state{padding:clamp(1.4rem,2.4vw,2rem);position:relative;overflow:hidden}
.empty-state__bg{position:absolute;right:-18px;bottom:-10px;font-size:4rem;font-weight:900;opacity:.04;letter-spacing:.08em;color:var(--brand)}
.empty-state__media{position:relative;display:flex;align-items:center;justify-content:center;margin-bottom:1rem}
.empty-state__icon{width:76px;height:76px;border-radius:22px;background:linear-gradient(135deg,var(--brand),var(--brand-3));color:#fff;display:grid;place-items:center;font-size:1.15rem;font-weight:800;position:relative;z-index:1}
.empty-state__pulse{position:absolute;width:96px;height:96px;border-radius:999px;background:rgba(18,54,61,.08);animation:pulse-soft 2.6s infinite}
.empty-state__content{text-align:center;max-width:640px;margin:0 auto}
.empty-state__badge{display:inline-flex;padding:.48rem .8rem;border-radius:999px;background:#edf3f5;color:var(--brand);font-size:.78rem;font-weight:800;margin-bottom:.85rem}
.empty-state__content h3{margin:0 0 .55rem;font-size:clamp(1.32rem,2vw,1.65rem)}
.empty-state__content p{margin:0 auto;max-width:58ch}
.empty-state__footer{display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;margin-top:1.1rem;padding-top:1rem;border-top:1px solid rgba(17,22,26,.06);font-size:.9rem;color:var(--text-soft)}
.fade-in-up{animation:fade-up .45s ease}
@keyframes fade-up{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
@keyframes pulse-soft{0%,100%{transform:scale(.95);opacity:.7}50%{transform:scale(1.08);opacity:.22}}

/* Breadcrumb Navigation */
.breadcrumb{
  display:flex;
  align-items:center;
  gap:.45rem;
  padding:.85rem 0;
  font-size:.9rem;
  color:var(--text-soft);
  flex-wrap:wrap;
}
.breadcrumb a{
  color:var(--brand);
  font-weight:500;
  transition:color .2s ease;
}
.breadcrumb a:hover{color:var(--brand-3)}
.breadcrumb .breadcrumb-item::before{
  content:"/";
  margin:0 .35rem;
  color:var(--border-strong);
}
.breadcrumb .breadcrumb-item:first-child::before{display:none}
.breadcrumb .breadcrumb-item.active{
  color:var(--text);
  font-weight:600;
  pointer-events:none;
}

/* Page Title Section */
.page-title-section{
  padding:.85rem 0 1rem;
  border-bottom:1px solid rgba(17,22,26,.06);
  margin-bottom:1.5rem;
}
.page-title-section h1{
  margin:0;
  font-size:clamp(1.5rem,2.5vw,2rem);
  color:var(--text);
}
.page-title-section p{
  margin:.35rem 0 0;
  font-size:.95rem;
  color:var(--text-soft);
}

/* Empty State - sem resultados */
.empty-state.no-results{
  padding:clamp(2rem,4vw,3rem);
  text-align:center;
}

@media (max-width:480px){
  .breadcrumb{font-size:.8rem;gap:.3rem}
  .breadcrumb .breadcrumb-item::before{margin:0 .2rem}
  .page-title-section{padding:.6rem 0 .8rem;margin-bottom:1rem}
  .page-title-section h1{font-size:clamp(1.3rem,5vw,1.6rem)}
}

@media (max-width:1140px){
  .hero-commercial-grid,.brand-buckets,.footer-grid,.detail-layout,.two-col,.cta-panel{grid-template-columns:1fr}
  .nav-shell{grid-template-columns:auto auto;justify-content:space-between}
  .site-nav{
    position:absolute;left:20px;right:20px;top:calc(100% + 8px);
    display:none;flex-direction:column;align-items:stretch;justify-content:flex-start;gap:.6rem;
    background:var(--surface);padding:1rem;border-radius:20px;border:1px solid var(--border);box-shadow:var(--shadow-card)
  }
  .site-nav.is-open{display:flex}
  .site-nav a{padding:.55rem 0}
  .menu-toggle{display:inline-grid;place-items:center}
  .nav-cta{display:none}
}

@media (max-width:780px){
  :root{--fz-body:15.8px;--lh-body:1.68;--fz-h1:clamp(2.1rem,8vw,3rem);--fz-h2:clamp(1.65rem,6vw,2.2rem)}
  .container{width:min(calc(100% - 28px), var(--container))}
  .topbar-content,.nav-shell,.section-head,.inline-actions,.form-actions{flex-direction:column;align-items:flex-start}
  .topbar-actions{display:flex;flex-wrap:wrap;gap:.75rem}
  .nav-shell{padding:.9rem 0}
  .brand-mark{width:48px;height:48px;flex-basis:48px}
  .commercial-copy,.page-hero-inner,.journey-choice-card,.brand-bucket,.content-card,.feature-card,.card,.metric-card,.sidebar-card,.filters-card,.form-card,.spotlight-card,.vaga-mural-card,.job-board-card,.empty-state{padding:1.15rem}
  
  /* Buttons responsivos - não ocupam 100% sempre */
  .hero-actions,.empty-state__actions,.chatbot-lead-actions,.form-actions{
    width:100%;
    display:flex;
    flex-wrap:wrap;
    gap:.75rem;
  }
  .btn,.btn-primary,.btn-outline,.btn-dark,button,input[type=submit]{
    min-width:auto;
    flex:1 1 clamp(160px, 45%, 100%);
  }
  
  .brand-buckets,.grid,.form-grid,.grid-form,.search-bar,.stats-strip,.hero-strip,.form-steps,.chatbot-mini-grid,.chatbot-form{grid-template-columns:1fr !important}
  .chatbot-widget{left:14px;right:14px;bottom:14px;align-items:stretch;max-width:none}
  .chatbot-toggle,.chatbot-panel{width:100%;max-width:none}
  .chatbot-panel{max-height:min(72vh,680px)}
  .empty-state__footer{flex-direction:column}
  
  /* Forms melhor em mobile */
  .candidate-form-grid,.executive-form-grid,.form-grid {
    grid-template-columns:1fr !important;
  }
  .input-with-action {
    grid-template-columns:1fr !important;
  }
}

/* Extra-small phones (320px - 480px) */
@media (max-width:480px){
  :root{--fz-body:15px;--fz-h1:clamp(1.8rem,6vw,2.4rem);--fz-h2:clamp(1.4rem,4.5vw,1.8rem);--fz-h3:clamp(1rem,2vw,1.2rem)}
  
  .container{width:min(calc(100% - 24px), var(--container));margin-inline:auto}
  .page-section{padding-block:clamp(1.5rem,2.5vw,2rem)}
  .page-section.compact{padding-block:clamp(1.2rem,2vw,1.5rem)}
  
  /* Hero mais compacto */
  .commercial-copy,.page-hero-inner{padding:1rem;border-radius:16px}
  .hero-eyebrow,.section-eyebrow{font-size:.7rem}
  
  /* Spacing mais apertado */
  .commercial-copy p,.page-hero-inner p,.lead{font-size:clamp(.95rem,1.5vw,1rem)}
  
  /* Hero actions verticais */
  .hero-actions,.inline-actions,.form-actions,.button-row{
    width:100%;
    flex-direction:column;
  }
  .btn,.btn-primary,.btn-outline,.btn-dark,button,input[type=submit]{
    width:100%;
    min-height:44px;
  }
  
  /* Inputs melhor em toque */
  input,select,textarea{
    min-height:44px;
    font-size:16px; /* Evita zoom em iOS */
    padding:12px;
  }
  
  /* Navigation mais compacta */
  .topbar{font-size:.8rem}
  .topbar-content{padding:.45rem 0}
  .site-nav{border-radius:12px;padding:.8rem}
  .site-nav a{padding:.4rem 0;font-size:.95rem}
  
  /* Cards menos padding */
  .card,.content-card,.feature-card,.journey-choice-card,.spotlight-card,.brand-bucket{padding:.9rem}
  
  /* Badge e pills menores */
  .badge,.tag,.chip{padding:.35rem .65rem;font-size:.75rem}
  .vaga-pill{padding:.35rem .65rem;font-size:.72rem}
  
  /* Checklist e components */
  .checkpoint{padding:.8rem .85rem;gap:.65rem}
  .checkpoint strong{font-size:.9rem}
  
  /* Forms mais compactas */
  .form-grid,.candidate-form-grid,.executive-form-grid{gap:.8rem}
  .field-help,.form-text{font-size:.8rem}
  .field label{font-size:.9rem}
  
  /* Chatbot ajustado */
  .chatbot-toggle-copy strong,.chatbot-header strong{font-size:.9rem}
  .chatbot-toggle-copy small,.chatbot-header span{font-size:.75rem}
  .chatbot-body{padding:.85rem}
  .chatbot-msg{padding:.7rem .8rem}
  .chatbot-msg strong{font-size:.8rem}
  .chatbot-msg p{font-size:.88rem}
  
  /* Sidebar não visível em extra-small */
  .candidate-register-sidebar,.sidebar-card:not(.featured){
    display:none;
  }
  
  /* Remove step indicators em muito pequeno */
  .form-steps{
    flex-wrap:wrap;
    gap:.5rem;
  }
  .step-pill{
    padding:.65rem .85rem;
    font-size:.8rem;
  }
  .step-pill span{font-size:.7rem}
  
  /* Empty state mais compacto */
  .empty-state__icon{width:60px;height:60px;font-size:1rem}
  .empty-state__content h3{font-size:1.2rem;margin-bottom:.4rem}
}

@media (prefers-color-scheme: dark){
  :root{
    --bg:#0b1013;
    --bg-elevated:#11171b;
    --surface:#121a1f;
    --surface-soft:#10161a;
    --surface-muted:#161f24;
    --text:#eef4f6;
    --text-soft:#b3c0c8;
    --text-muted:#91a1ab;
    --border:#233139;
    --border-strong:#31414b;
    --shadow-soft:0 18px 45px rgba(0,0,0,.28);
    --shadow-card:0 24px 60px rgba(0,0,0,.34);
    --grad-subtle:linear-gradient(180deg,rgba(18,26,31,.96) 0%,rgba(14,20,24,.98) 100%);
  }

  body{
    background:
      radial-gradient(circle at top right, rgba(31,75,84,.17), transparent 24%),
      radial-gradient(circle at bottom left, rgba(18,54,61,.14), transparent 20%),
      linear-gradient(180deg,#0a0f12 0%, var(--bg) 100%);
  }

  .site-header{background:color-mix(in srgb, #10161a 88%, transparent);border-bottom-color:rgba(255,255,255,.05)}
  .topbar{background:#091014;color:#c7d4da}
  .brand-copy small{color:var(--text-muted)}
  .site-nav a{color:var(--text)}
  .page-hero-inner,
  .journey-choice-card,
  .brand-bucket,
  .content-card,
  .feature-card,
  .card,
  .metric-card,
  .sidebar-card,
  .filters-card,
  .form-card,
  .spotlight-card,
  .vaga-mural-card,
  .job-board-card,
  .empty-state,
  .section-surface,
  .chatbot-panel,
  .chatbot-lead-card,
  .chatbot-chip,
  .chatbot-faq-item{border-color:rgba(255,255,255,.06) !important}

  .page-hero-inner,.section-surface,.journey-choice-card,.brand-bucket,.content-card,.feature-card,.card,.metric-card,.sidebar-card,.filters-card,.form-card,.spotlight-card,.vaga-mural-card,.job-board-card,.empty-state,.chatbot-panel,.chatbot-lead-card{background:var(--grad-subtle) !important}
  .badge,.empty-state__badge,.chatbot-status-pill{background:rgba(31,75,84,.22);color:#cbe4ea;border-color:rgba(115,174,187,.16)}
  input,select,textarea{background:rgba(18,26,31,.96);border-color:var(--border);color:var(--text);box-shadow:inset 0 1px 0 rgba(255,255,255,.02)}
  input::placeholder,textarea::placeholder{color:#7d8c96}
  .btn-outline{background:rgba(18,26,31,.82);border-color:var(--border);color:var(--text)}
  .btn-outline:hover{background:rgba(18,26,31,.96);color:#fff;border-color:#47646d}
  .site-nav{background:var(--surface)}
  .chatbot-body,.chatbot-footer{background:var(--surface-soft)}
  .chatbot-msg-bot{background:rgba(31,75,84,.16);border-color:rgba(77,123,134,.22)}
  .chatbot-msg-user{background:#0b1013}
  .empty-state__pulse{background:rgba(31,75,84,.16)}
  .site-footer{background:linear-gradient(135deg,#05080a 0%, #102c32 100%)}
  .site-footer p,.site-footer li,.site-footer a,.site-footer small{color:rgba(255,255,255,.72)}
}

/* Executive form layout */
.executive-form{display:grid;gap:1.1rem}
.executive-form-section{
  display:grid;
  gap:1rem;
  padding:1.15rem;
  border:1px solid rgba(17,22,26,.08);
  border-radius:20px;
  background:linear-gradient(180deg,rgba(255,255,255,.94) 0%, rgba(245,248,249,.96) 100%);
}
.executive-form-header{display:grid;grid-template-columns:auto 1fr;gap:.9rem;align-items:start}
.executive-form-header h2{font-size:1.15rem;margin:0 0 .25rem;color:var(--brand)}
.executive-form-header p{margin:0;color:var(--text-muted);max-width:58ch;font-size:.93rem}
.executive-step{
  width:42px;height:42px;display:grid;place-items:center;flex:0 0 42px;
  border-radius:14px;background:linear-gradient(135deg,var(--brand),var(--brand-3));
  color:#fff;font-weight:800;font-size:.88rem;box-shadow:0 10px 24px rgba(18,54,61,.18)
}
.executive-form-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem 1rem}
.executive-field-full,.form-grid-single{grid-column:1/-1}
.executive-form .check-row{margin-top:.15rem}
.executive-form-actions{display:flex;flex-wrap:wrap;gap:.75rem;justify-content:flex-start}
.auth-form{max-width:760px}
.auth-form .executive-form-grid,.form-grid-single{grid-template-columns:1fr}
.candidate-register-layout{display:grid;grid-template-columns:minmax(0,1.35fr) minmax(320px,390px);gap:2rem;align-items:start}
.candidate-register-sidebar{position:sticky;top:1.75rem;align-self:start}
.form-page-layout{display:grid;grid-template-columns:minmax(0,1.35fr) minmax(320px,390px);gap:2rem;align-items:start}
.form-steps{display:grid;grid-auto-flow:column;grid-auto-columns:minmax(140px,1fr);gap:.75rem;align-items:center;overflow:auto;padding-bottom:.65rem;margin-bottom:1rem}
.step-pill{display:grid;gap:.3rem;padding:.85rem 1rem;border-radius:999px;border:1px solid rgba(17,22,26,.1);background:var(--surface);color:var(--text);font-weight:700;font-size:.92rem;}
.step-pill span{display:block;font-size:.78rem;font-weight:500;color:var(--text-soft);line-height:1.3}
.step-pill.is-active{background:linear-gradient(135deg,var(--brand),var(--brand-3));border-color:transparent;color:#fff;}
.step-pill.is-active span{color:rgba(255,255,255,.9)}
.section-header-inline{display:grid;grid-template-columns:1fr auto;gap:1rem;align-items:flex-start;margin-bottom:1.2rem}
.resume-dropzone{display:grid;gap:.85rem;padding:1.35rem 1.25rem;border:2px dashed rgba(18,54,61,.24);border-radius:24px;background:rgba(18,54,61,.03);cursor:pointer;position:relative}
.resume-dropzone.is-dragging{background:rgba(18,54,61,.08);border-color:var(--brand)}
.resume-dropzone input[type=file]{position:absolute;inset:0;width:100%;height:100%;opacity:0;cursor:pointer}
.resume-dropzone-copy{display:grid;gap:.35rem}
.resume-dropzone-copy strong{font-size:1rem}
.resume-meta{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.85rem;padding:1rem 1.1rem;border-radius:22px;background:var(--surface-muted);border:1px solid var(--border)}
.resume-meta span{font-size:.95rem;color:var(--text-soft)}
.resume-meta button{white-space:nowrap}
.input-with-action{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:.75rem}
.input-with-action .btn{white-space:nowrap}
.candidate-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem}
.candidate-section{margin-top:1.75rem}
.candidate-actions{display:flex;flex-wrap:wrap;gap:.85rem;margin-top:1rem}
.candidate-actions button,.candidate-actions .btn{min-width:180px}
.button-row{display:flex;flex-wrap:wrap;gap:.85rem;justify-content:flex-start}
.auto-fill-status{padding:.85rem 1rem;border-radius:18px;background:var(--surface);border:1px solid rgba(17,22,26,.08);font-weight:700;color:var(--text);text-align:right}

@media(max-width:980px){
  .candidate-register-layout,.form-page-layout{grid-template-columns:1fr}
  .candidate-register-sidebar{position:static;top:auto}
  .form-steps{grid-auto-columns:minmax(0,1fr)}
  .input-with-action{grid-template-columns:1fr}
  .candidate-form-grid,.executive-form-grid{grid-template-columns:1fr !important;gap:.9rem}
}

@media (max-width: 860px){
  .executive-form-grid{grid-template-columns:1fr}
  .executive-form-section,.candidate-register-form .candidate-step{padding:1rem}
  .executive-form-header{grid-template-columns:1fr}
  .executive-step,.candidate-register-form .candidate-step-header > span{width:38px;height:38px}
  .candidate-form-grid{grid-template-columns:1fr !important}
}

@media (max-width:600px){
  .candidate-form-grid,.executive-form-grid,.form-grid {
    grid-template-columns:1fr !important;
  }
  .input-with-action {
    grid-template-columns:1fr !important;
  }
}

.page-hero-inner.with-media{
  display:grid;
  grid-template-columns:minmax(0,1.05fr) minmax(260px,.95fr);
  gap:1.25rem;
  align-items:center;
}
.page-hero-media,
.hero-friendly-media-card,
.content-card-photo{
  position:relative;
  overflow:hidden;
  border-radius:22px;
  min-height:260px;
}
.page-hero-media img,
.hero-friendly-media-card img,
.content-card-photo img,
.friendly-photo-card img,
.spotlight-photo-card img,
.blog-card-media img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.hero-friendly-media-card{
  min-height:240px;
  border-radius:24px;
  box-shadow:var(--shadow-soft);
}
.image-story-grid{
  display:grid;
  grid-template-columns:minmax(0,1.35fr) minmax(0,.65fr);
  gap:1rem;
}
.friendly-photo-card{
  display:grid;
  grid-template-columns:minmax(260px,.95fr) minmax(0,1.05fr);
  gap:1rem;
  align-items:stretch;
  padding:1rem;
  background:var(--grad-subtle);
  border:1px solid rgba(17,22,26,.06);
  border-radius:var(--radius-xl);
  box-shadow:var(--shadow-soft);
}
.friendly-photo-card.compact{grid-template-columns:1fr}
.friendly-photo-card img{border-radius:18px;min-height:220px}
.friendly-photo-copy{display:flex;flex-direction:column;justify-content:center;gap:.65rem;padding:.35rem .25rem}
.spotlight-photo-card{display:grid;gap:1rem;overflow:hidden}
.spotlight-photo-card img{border-radius:18px;max-height:280px}
.with-photo-panel{display:grid;grid-template-columns:minmax(0,.9fr) minmax(0,1.1fr);gap:1rem;align-items:stretch}
.content-card-photo img{border-radius:18px;min-height:260px}
.blog-card-friendly{overflow:hidden;padding:0 !important}
.blog-card-media{height:220px;overflow:hidden}
.blog-card-body{padding:1.15rem 1.2rem 1.25rem}
.radar-grid{align-items:stretch}
.radar-card{display:grid;gap:.85rem}
.radar-source{display:grid;gap:.25rem;font-size:.95rem}
.radar-source a{font-weight:700}

@media (max-width: 980px){
  .page-hero-inner.with-media,
  .friendly-photo-card,
  .with-photo-panel,
  .image-story-grid{grid-template-columns:1fr}
  .page-hero-media,
  .hero-friendly-media-card{min-height:220px}
}

@media (max-width: 720px){
  .blog-card-media{height:190px}
  .friendly-photo-card{padding:.85rem}
  .friendly-photo-card img,
  .content-card-photo img,
  .spotlight-photo-card img{min-height:180px;max-height:none}
}

/* ===== Visual stability patch: contrast, overflow and form consistency ===== */
html, body { max-width: 100%; }
body { word-break: normal; overflow-wrap: anywhere; }

.container > *,
.page-section > *,
.grid > *,
.form-grid > *,
.grid-form > *,
.hero-commercial-grid > *,
.page-hero-inner > *,
.section-surface > *,
.card > *,
.feature-card > *,
.metric-card > *,
.sidebar-card > *,
.filters-card > *,
.form-card > *,
.spotlight-card > *,
.content-card > *,
.journey-choice-card > *,
.brand-bucket > *,
.vaga-mural-card > *,
.job-board-card > *,
.empty-state > * {
  min-width: 0;
}

h1, h2, h3, h4, h5, h6,
p, a, span, strong, small, li, label,
.card-title, .section-title, .page-title, .hero-title {
  overflow-wrap: anywhere;
}

/* Light surfaces must always have dark text */
.page-hero-inner,
.section-surface,
.journey-choice-card,
.brand-bucket,
.content-card,
.feature-card,
.card,
.metric-card,
.sidebar-card,
.filters-card,
.form-card,
.spotlight-card:not(.page-hero-vagas),
.vaga-mural-card,
.job-board-card,
.empty-state,
.contact-card,
.table-card,
.dashboard-card,
.hero-side,
.info-item,
.hero-friendly-media-card,
.friendly-photo-card,
.blog-card-friendly,
.blog-card-body,
.radar-card,
.executive-form-section,
.candidate-register-form .candidate-step {
  color: var(--text) !important;
}

.page-hero-inner h1,
.page-hero-inner h2,
.page-hero-inner h3,
.section-surface h1,
.section-surface h2,
.section-surface h3,
.journey-choice-card h1,
.journey-choice-card h2,
.journey-choice-card h3,
.brand-bucket h1,
.brand-bucket h2,
.brand-bucket h3,
.content-card h1,
.content-card h2,
.content-card h3,
.feature-card h1,
.feature-card h2,
.feature-card h3,
.card h1,
.card h2,
.card h3,
.metric-card h1,
.metric-card h2,
.metric-card h3,
.sidebar-card h1,
.sidebar-card h2,
.sidebar-card h3,
.filters-card h1,
.filters-card h2,
.filters-card h3,
.form-card h1,
.form-card h2,
.form-card h3,
.spotlight-card:not(.page-hero-vagas) h1,
.spotlight-card:not(.page-hero-vagas) h2,
.spotlight-card:not(.page-hero-vagas) h3,
.vaga-mural-card h1,
.vaga-mural-card h2,
.vaga-mural-card h3,
.job-board-card h1,
.job-board-card h2,
.job-board-card h3,
.empty-state h1,
.empty-state h2,
.empty-state h3,
.contact-card h1,
.contact-card h2,
.contact-card h3,
.table-card h1,
.table-card h2,
.table-card h3,
.dashboard-card h1,
.dashboard-card h2,
.dashboard-card h3,
.hero-side h1,
.hero-side h2,
.hero-side h3,
.executive-form-section h1,
.executive-form-section h2,
.executive-form-section h3,
.candidate-register-form .candidate-step h1,
.candidate-register-form .candidate-step h2,
.candidate-register-form .candidate-step h3 {
  color: var(--text) !important;
}

.page-hero-inner p,
.page-hero-inner li,
.page-hero-inner label,
.section-surface p,
.section-surface li,
.section-surface label,
.journey-choice-card p,
.journey-choice-card li,
.journey-choice-card label,
.brand-bucket p,
.brand-bucket li,
.brand-bucket label,
.content-card p,
.content-card li,
.content-card label,
.feature-card p,
.feature-card li,
.feature-card label,
.card p,
.card li,
.card label,
.metric-card p,
.metric-card li,
.metric-card label,
.sidebar-card p,
.sidebar-card li,
.sidebar-card label,
.filters-card p,
.filters-card li,
.filters-card label,
.form-card p,
.form-card li,
.form-card label,
.spotlight-card:not(.page-hero-vagas) p,
.spotlight-card:not(.page-hero-vagas) li,
.spotlight-card:not(.page-hero-vagas) label,
.vaga-mural-card p,
.vaga-mural-card li,
.vaga-mural-card label,
.job-board-card p,
.job-board-card li,
.job-board-card label,
.empty-state p,
.empty-state li,
.empty-state label,
.contact-card p,
.contact-card li,
.contact-card label,
.table-card p,
.table-card li,
.table-card label,
.dashboard-card p,
.dashboard-card li,
.dashboard-card label,
.hero-side p,
.hero-side li,
.hero-side label,
.executive-form-section p,
.executive-form-section li,
.executive-form-section label,
.candidate-register-form .candidate-step p,
.candidate-register-form .candidate-step li,
.candidate-register-form .candidate-step label {
  color: var(--text-soft) !important;
}

.page-hero-inner a,
.section-surface a,
.journey-choice-card a,
.brand-bucket a,
.content-card a,
.feature-card a,
.card a,
.metric-card a,
.sidebar-card a,
.filters-card a,
.form-card a,
.spotlight-card:not(.page-hero-vagas) a,
.vaga-mural-card a,
.job-board-card a,
.empty-state a,
.contact-card a,
.table-card a,
.dashboard-card a,
.hero-side a,
.executive-form-section a,
.candidate-register-form .candidate-step a {
  color: var(--brand) !important;
}

/* Keep truly dark hero/CTA sections readable */
.dark-band,
.dark-band *,
.commercial-copy,
.commercial-copy *,
.hero-copy,
.hero-copy *,
.foco-hero-main,
.foco-hero-main *,
.spotlight-card.page-hero-vagas,
.spotlight-card.page-hero-vagas * {
  color: #fff;
}
.dark-band p,
.commercial-copy p,
.hero-copy p,
.foco-hero-main p,
.spotlight-card.page-hero-vagas p {
  color: rgba(255,255,255,.84) !important;
}

/* Safer forms */
input,
select,
textarea {
  width: 100%;
  max-width: 100%;
  background: #fff;
  color: var(--text);
  border: 1px solid var(--border);
}
select option { color: var(--text); background: #fff; }
.field label,
.form-card .field label,
.executive-form label,
.candidate-register-form label {
  color: var(--text) !important;
}
.validation-summary-errors,
.field-validation-error,
.text-danger { color: #9f1d1d !important; }

/* Tables, code and long strings */
.table-responsive,
.table-card,
.table-wrap { overflow-x: auto; }
code, pre, td, th, .badge, .pill, .chip { overflow-wrap: anywhere; }

/* Responsive media and cards */
img, svg, iframe, video { max-width: 100%; height: auto; }
.blog-card-media,
.page-hero-media,
.hero-friendly-media-card,
.content-card-photo,
.friendly-photo-card img,
.spotlight-photo-card img { overflow: hidden; }

/* Dark mode contrast patch */
@media (prefers-color-scheme: dark) {
  .page-hero-inner,
  .section-surface,
  .journey-choice-card,
  .brand-bucket,
  .content-card,
  .feature-card,
  .card,
  .metric-card,
  .sidebar-card,
  .filters-card,
  .form-card,
  .spotlight-card:not(.page-hero-vagas),
  .vaga-mural-card,
  .job-board-card,
  .empty-state,
  .contact-card,
  .table-card,
  .dashboard-card,
  .hero-side,
  .info-item,
  .hero-friendly-media-card,
  .friendly-photo-card,
  .blog-card-body,
  .radar-card,
  .executive-form-section,
  .candidate-register-form .candidate-step {
    color: var(--text) !important;
  }

  .page-hero-inner h1,
  .page-hero-inner h2,
  .page-hero-inner h3,
  .section-surface h1,
  .section-surface h2,
  .section-surface h3,
  .journey-choice-card h1,
  .journey-choice-card h2,
  .journey-choice-card h3,
  .brand-bucket h1,
  .brand-bucket h2,
  .brand-bucket h3,
  .content-card h1,
  .content-card h2,
  .content-card h3,
  .feature-card h1,
  .feature-card h2,
  .feature-card h3,
  .card h1,
  .card h2,
  .card h3,
  .metric-card h1,
  .metric-card h2,
  .metric-card h3,
  .sidebar-card h1,
  .sidebar-card h2,
  .sidebar-card h3,
  .filters-card h1,
  .filters-card h2,
  .filters-card h3,
  .form-card h1,
  .form-card h2,
  .form-card h3,
  .spotlight-card:not(.page-hero-vagas) h1,
  .spotlight-card:not(.page-hero-vagas) h2,
  .spotlight-card:not(.page-hero-vagas) h3,
  .hero-side h1,
  .hero-side h2,
  .hero-side h3,
  .executive-form-section h1,
  .executive-form-section h2,
  .executive-form-section h3,
  .candidate-register-form .candidate-step h1,
  .candidate-register-form .candidate-step h2,
  .candidate-register-form .candidate-step h3 {
    color: var(--text) !important;
  }

  input,
  select,
  textarea,
  select option {
    background: rgba(18,26,31,.96);
    color: var(--text);
    border-color: var(--border);
  }
}


/* Footer contrast hardening */
.site-footer,
.site-footer .footer-grid,
.site-footer .footer-bottom{
  color:#eef4f6 !important;
}
.site-footer h1,
.site-footer h2,
.site-footer h3,
.site-footer h4,
.site-footer h5,
.site-footer h6,
.site-footer .footer-brand,
.site-footer strong,
.site-footer .brand-copy strong{
  color:#ffffff !important;
}
.site-footer p,
.site-footer li,
.site-footer a,
.site-footer small,
.site-footer span,
.site-footer .muted,
.site-footer .text-muted{
  color:rgba(255,255,255,.82) !important;
}
.site-footer a:hover,
.site-footer a:focus-visible{
  color:#ffffff !important;
}
.site-footer ul,
.site-footer li{
  overflow-wrap:anywhere;
  word-break:break-word;
}

/* Final dark-surface readability and navigation polish */
.site-footer,
.site-footer .container,
.site-footer .footer-grid,
.site-footer .footer-grid > div,
.site-footer .footer-bottom,
.site-footer ul,
.site-footer li,
.site-footer a,
.site-footer p,
.site-footer span,
.site-footer small,
.site-footer strong,
.site-footer h1,
.site-footer h2,
.site-footer h3,
.site-footer h4,
.site-footer h5,
.site-footer h6{
  text-shadow:none !important;
}
.site-footer .footer-grid > div > h3,
.site-footer .footer-grid > div > .footer-brand,
.site-footer .footer-grid > div > strong{
  color:#ffffff !important;
  opacity:1 !important;
}
.site-footer .footer-grid > div > p,
.site-footer .footer-grid > div li,
.site-footer .footer-grid > div a,
.site-footer .footer-grid > div span,
.site-footer .footer-grid > div small{
  color:rgba(255,255,255,.86) !important;
}
.topbar,
.chatbot-toggle,
.chatbot-header,
.dark-band,
.hero-commercial,
.spotlight-card.page-hero-vagas{
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}
.chatbot-toggle{
  max-width:min(360px, calc(100vw - 24px));
}
@media (max-width: 768px){
  .chatbot-widget{
    right:12px;
    bottom:12px;
  }
  .chatbot-toggle{
    padding:.85rem .95rem;
  }
  .site-footer .footer-grid > div > h3{
    margin-top:.25rem;
  }
}


/* Consolidated legacy utility styles migrated from site.css */
.skip-link{
  position:absolute;
  left:1rem;
  top:-3rem;
  z-index:200;
  padding:.7rem 1rem;
  border-radius:12px;
  background:#0f1518;
  color:#fff;
  text-decoration:none;
  box-shadow:var(--shadow-soft);
}
.skip-link:focus{top:1rem}
.alert{
  margin:1rem 0;
  padding:.9rem 1rem;
  border-radius:16px;
  border:1px solid var(--border);
  background:var(--surface);
  color:var(--text);
  box-shadow:var(--shadow-soft);
}
.alert.success{background:#edf7f1;border-color:#b8dbc6;color:#144a25}
.alert.error{background:#fff1f1;border-color:#e4b4b4;color:#7a1d1d}
.badge-row{display:flex;flex-wrap:wrap;gap:.55rem}
.vaga-pill{
  display:inline-flex;
  align-items:center;
  gap:.35rem;
  padding:.42rem .78rem;
  border-radius:999px;
  background:#edf3f5;
  color:var(--brand);
  font-size:.78rem;
  font-weight:800;
}
.vaga-company{margin:.15rem 0 .1rem;font-weight:700;color:var(--text)}
.vaga-place{margin:0;color:var(--text-soft)}
.checkpoints{display:grid;gap:.85rem}
.checkpoint{
  display:grid;
  grid-template-columns:auto 1fr;
  gap:.8rem;
  align-items:flex-start;
  padding:1rem 1.05rem;
  border:1px solid var(--border);
  border-radius:18px;
  background:var(--surface);
}
.checkpoint strong{display:block;margin-bottom:.2rem;color:var(--text)}
.checkpoint span:last-child{color:var(--text-soft);font-size:.95rem;line-height:1.6}
.number-badge{
  width:34px;
  height:34px;
  border-radius:999px;
  display:grid;
  place-items:center;
  background:linear-gradient(135deg,var(--brand),var(--brand-3));
  color:#fff;
  font-weight:800;
  box-shadow:var(--shadow-soft);
}
.hero-home .hero-commercial-grid{align-items:center}
.chatbot-lead-form{display:grid;gap:.75rem}
.chatbot-lead-form input,
.chatbot-lead-form select,
.chatbot-lead-form textarea{width:100%}

/* Mobile WhatsApp widget: closed = bubble only; open = expanded panel */
@media (max-width:780px){
  .chatbot-widget{
    left:auto;
    right:12px;
    bottom:12px;
    width:auto;
    max-width:none;
    align-items:flex-end;
  }
  .chatbot-toggle{
    width:64px;
    max-width:64px;
    min-width:64px;
    height:64px;
    padding:0;
    border-radius:999px;
    justify-content:center;
  }
  .chatbot-toggle-copy{display:none}
  .chatbot-toggle-icon{
    width:64px;
    height:64px;
    border-radius:999px;
    display:grid;
    place-items:center;
    margin:0;
  }
  .chatbot-panel{
    width:min(420px,calc(100vw - 24px));
    max-width:none;
  }
  body.chatbot-open .chatbot-widget{
    left:12px;
    right:12px;
    width:auto;
    align-items:stretch;
  }
  body.chatbot-open .chatbot-toggle{
    width:100%;
    max-width:none;
    min-width:0;
    height:auto;
    padding:.85rem .95rem;
    border-radius:18px;
    justify-content:flex-start;
  }
  body.chatbot-open .chatbot-toggle-copy{display:block}
  body.chatbot-open .chatbot-toggle-icon{
    width:48px;
    height:48px;
    border-radius:14px;
  }
  body.chatbot-open .chatbot-panel{width:100%}
}
