/* ===========================================================
   ATLÂNTICA — Sistema de design compartilhado
   Conectando talento · BR ⇄ PT
   =========================================================== */

@import url('https://fonts.googleapis.com/css2?family=Newsreader:ital,opsz,wght@0,6..72,400;0,6..72,500;0,6..72,600;1,6..72,400;1,6..72,500&family=Libre+Franklin:wght@400;500;600;700&display=swap');

:root{
  /* paper / ink */
  --paper:#ffffff;
  --paper-2:#f6f7f9;
  --paper-3:#eceff3;
  --ink:#17161d;
  --ink-soft:#56535f;
  --ink-faint:#8a8794;

  /* brand */
  --blue:#1700C2;
  --blue-700:#1300a0;
  --blue-tint:#e9e7fb;
  --indigo:#0b0926;      /* deep dark sections */
  --indigo-2:#120f33;

  /* accent */
  --gold:#c8a24a;
  --gold-deep:#a8852f;
  --gold-tint:#f0e7d2;

  /* lines */
  --line:rgba(23,22,29,.12);
  --line-2:rgba(23,22,29,.20);
  --line-light:rgba(255,255,255,.14);

  /* type */
  --serif:'Newsreader',Georgia,serif;
  --sans:'Libre Franklin',system-ui,sans-serif;

  /* radius / shadow */
  --r:5px;
  --r-lg:10px;
  --r-xl:16px;
  --sh-sm:0 1px 2px rgba(23,22,29,.06),0 2px 8px rgba(23,22,29,.05);
  --sh:0 4px 14px rgba(23,22,29,.08),0 12px 36px rgba(23,22,29,.07);
  --sh-lg:0 18px 50px rgba(11,9,38,.16);

  --maxw:1200px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--sans);
  background:var(--paper);
  color:var(--ink);
  font-size:17px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--serif);font-weight:500;letter-spacing:-.01em;line-height:1.08;margin:0}
p{margin:0}

/* ---------- layout helpers ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 32px}
.wrap-narrow{max-width:880px;margin:0 auto;padding:0 32px}
section{position:relative}
.eyebrow{
  font-family:var(--sans);font-weight:600;font-size:12.5px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--blue);display:inline-flex;align-items:center;gap:10px;
}
.eyebrow::before{content:"";width:22px;height:1.5px;background:var(--gold);display:inline-block}
.eyebrow.on-dark{color:var(--gold)}
.eyebrow.on-dark::before{background:var(--gold)}
.lead{font-size:20px;line-height:1.55;color:var(--ink-soft)}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  font-family:var(--sans);font-weight:600;font-size:15px;letter-spacing:.01em;
  padding:14px 24px;border-radius:var(--r);border:1px solid transparent;cursor:pointer;
  transition:transform .18s ease,background .18s ease,box-shadow .18s ease,color .18s ease;
  white-space:nowrap;
}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--blue);color:#fff;box-shadow:0 2px 0 var(--blue-700)}
.btn-primary:hover{background:var(--blue-700);box-shadow:0 6px 22px rgba(23,0,194,.28)}
.btn-dark{background:var(--ink);color:#fff}
.btn-dark:hover{background:#000}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line-2)}
.btn-ghost:hover{border-color:var(--ink);background:rgba(23,22,29,.03)}
.btn-gold{background:var(--gold);color:#231a05}
.btn-gold:hover{background:var(--gold-deep);color:#fff}
.btn-light{background:#fff;color:var(--ink)}
.btn-light:hover{background:var(--paper-2)}
.btn-on-dark{background:transparent;color:#fff;border-color:var(--line-light)}
.btn-on-dark:hover{border-color:#fff;background:rgba(255,255,255,.06)}
.btn .arr{transition:transform .18s ease}
.btn:hover .arr{transform:translateX(3px)}

/* ---------- navbar ---------- */
.nav{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.86);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.nav-inner{max-width:var(--maxw);margin:0 auto;padding:0 32px;height:74px;display:flex;align-items:center;gap:28px}
.nav-logo{display:flex;align-items:center}
.nav-logo img{height:26px;width:auto}
.nav-links{display:flex;align-items:center;gap:30px;margin-left:14px}
.nav-links a{font-size:15px;font-weight:500;color:var(--ink-soft);position:relative;padding:6px 0;transition:color .15s}
.nav-links a:hover{color:var(--ink)}
.nav-links a.active{color:var(--ink)}
.nav-links a.active::after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:2px;background:var(--blue)}
.nav-cta{margin-left:auto;display:flex;align-items:center;gap:14px}
.corridor-switch{
  display:inline-flex;align-items:center;gap:7px;
  font-size:13px;font-weight:600;color:var(--ink-soft);
  padding:8px 11px;border:1px solid var(--line);border-radius:100px;background:#fff;
  box-shadow:var(--sh-sm);white-space:nowrap;transition:border-color .15s,color .15s,transform .15s;
}
.corridor-switch:hover{color:var(--ink);border-color:var(--line-2);transform:translateY(-1px)}
.corridor-switch .flag{width:16px;height:11px}
.nav-toggle{display:none;background:none;border:1px solid var(--line-2);border-radius:var(--r);width:42px;height:42px;align-items:center;justify-content:center;cursor:pointer}
.nav-toggle span{display:block;width:18px;height:2px;background:var(--ink);position:relative}
.nav-toggle span::before,.nav-toggle span::after{content:"";position:absolute;left:0;width:18px;height:2px;background:var(--ink)}
.nav-toggle span::before{top:-6px}.nav-toggle span::after{top:6px}

/* ---------- footer ---------- */
.footer{background:var(--indigo);color:#cfcde0;padding:72px 0 32px}
.footer a{color:#cfcde0;transition:color .15s}
.footer a:hover{color:#fff}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px;padding-bottom:48px;border-bottom:1px solid var(--line-light)}
.foot-logo img{height:28px;margin-bottom:18px}
.foot-col h5{font-family:var(--sans);font-weight:600;font-size:12.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);margin:0 0 16px}
.foot-col ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:11px}
.foot-col a{font-size:15px}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:24px;font-size:13.5px;color:#8a87a8;flex-wrap:wrap;gap:12px}

/* ---------- tags / chips ---------- */
.tag{display:inline-flex;align-items:center;gap:7px;font-size:12.5px;font-weight:600;letter-spacing:.02em;padding:5px 11px;border-radius:100px;background:var(--paper-2);color:var(--ink-soft);border:1px solid var(--line)}
.tag.blue{background:var(--blue-tint);color:var(--blue-700);border-color:transparent}
.tag.gold{background:var(--gold-tint);color:var(--gold-deep);border-color:transparent}
.flag{width:18px;height:13px;border-radius:2px;display:inline-block;box-shadow:0 0 0 1px rgba(0,0,0,.06);background-size:cover}
.flag.br{background:linear-gradient(180deg,#229e45 0 100%);position:relative;overflow:hidden}
.flag.br::before{content:"";position:absolute;inset:2px;background:#f5d000;clip-path:polygon(50% 8%,92% 50%,50% 92%,8% 50%)}
.flag.br::after{content:"";position:absolute;left:50%;top:50%;width:6px;height:6px;border-radius:50%;background:#1b3a8a;transform:translate(-50%,-50%)}
.flag.pt{position:relative;overflow:hidden;background:#da291c}
.flag.pt::before{content:"";position:absolute;inset:0;width:40%;background:#046a38}
.flag.pt::after{content:"";position:absolute;left:40%;top:50%;width:5px;height:5px;border-radius:50%;background:#ffcf00;transform:translate(-50%,-50%)}
.flag.pe{background:linear-gradient(90deg,#d91023 0 33.33%,#fff 33.33% 66.66%,#d91023 66.66% 100%)}
.flag.es{background:linear-gradient(180deg,#aa151b 0 25%,#f1bf00 25% 75%,#aa151b 75% 100%)}

/* ---------- placeholder image ---------- */
.ph{
  position:relative;overflow:hidden;background:
    repeating-linear-gradient(135deg,rgba(23,22,29,.045) 0 10px,transparent 10px 20px),
    var(--paper-3);
  display:flex;align-items:center;justify-content:center;color:var(--ink-faint);
}
.ph .ph-label{font-family:'Libre Franklin',monospace;font-size:12px;letter-spacing:.06em;text-transform:uppercase;
  background:rgba(255,255,255,.92);padding:6px 12px;border-radius:100px;border:1px solid var(--line);font-weight:600}
.ph.on-blue{background:repeating-linear-gradient(135deg,rgba(255,255,255,.07) 0 10px,transparent 10px 20px),var(--blue);color:rgba(255,255,255,.7)}
.ph.on-blue .ph-label{background:rgba(11,9,38,.35);border-color:var(--line-light);color:#fff}
.ph img{width:100%;height:100%;object-fit:cover;display:block}
.ph.has-img{background:var(--paper-3);align-items:stretch;justify-content:stretch}
.ph.has-img::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(11,9,38,0) 54%,rgba(11,9,38,.18))}

/* ---------- cards ---------- */
.card{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh-sm)}

/* ---------- sections spacing ---------- */
.sec{padding:96px 0}
.sec-sm{padding:64px 0}
.dark{background:var(--indigo);color:#e9e8f2}
.dark h1,.dark h2,.dark h3{color:#fff}
.dark .lead{color:#b7b4cf}

/* ---------- reveal ---------- */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}

/* ---------- responsive ---------- */
@media(max-width:980px){
  .nav-links{display:none}
  .nav-cta .corridor-switch{display:none}
  .nav-toggle{display:flex}
  .foot-grid{grid-template-columns:1fr 1fr}
  .sec{padding:72px 0}
}
@media(max-width:620px){
  body{font-size:16px}
  .wrap,.wrap-narrow{padding:0 22px}
  .foot-grid{grid-template-columns:1fr}
  .sec{padding:56px 0}
}

/* ===========================================================
   SHARED COMPONENTS (used across pages)
   =========================================================== */
.section-head{max-width:660px;margin-bottom:48px}
.section-head h2{font-size:clamp(30px,3.6vw,44px);margin:18px 0 0}
.section-head .lead{margin-top:18px}
.section-head.center{margin-left:auto;margin-right:auto;text-align:center}
.headrow{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;margin-bottom:48px;flex-wrap:wrap}
.lk{font-weight:600;font-size:15px;color:var(--blue);display:inline-flex;gap:8px;align-items:center}
.lk .arr{transition:transform .18s}.lk:hover .arr{transform:translateX(3px)}
.lk.on-dark{color:var(--gold)}

/* page hero (interior pages) */
.phero{padding:64px 0 56px;border-bottom:1px solid var(--line)}
.phero.dark{border-bottom:none}
.phero h1{font-size:clamp(38px,5vw,62px);line-height:1.04;letter-spacing:-.02em;margin-top:20px}
.phero h1 em{font-style:italic;color:var(--blue);font-weight:400}
.phero.dark h1 em{color:var(--gold)}
.phero .lead{margin-top:22px;max-width:52ch}
.phero-cta{margin-top:32px;display:flex;gap:14px;flex-wrap:wrap}
.phero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center}
.phero-grid .ph{aspect-ratio:5/4;border-radius:var(--r-xl);box-shadow:var(--sh)}
.crumbs{font-size:13.5px;color:var(--ink-faint);display:flex;gap:9px;align-items:center}
.crumbs a:hover{color:var(--ink)}.crumbs .sep{opacity:.5}
.phero.dark .crumbs{color:#8a87a8}.phero.dark .crumbs a:hover{color:#fff}

/* feature grid */
.fgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.feat{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:30px;box-shadow:var(--sh-sm)}
.feat .fnum{font-family:var(--serif);font-size:15px;color:var(--gold-deep)}
.feat .ficon{width:46px;height:46px;border-radius:10px;background:var(--blue-tint);display:flex;align-items:center;justify-content:center;margin-bottom:20px;font-family:var(--serif);font-size:22px;color:var(--blue);font-weight:600}
.feat h3{font-size:21px;margin-bottom:10px}
.feat p{font-size:15px;color:var(--ink-soft)}

/* steps */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
.step{padding:28px 22px 26px;border-top:2px solid var(--line);position:relative}
.step .sn{font-family:var(--serif);font-size:16px;color:var(--gold-deep);font-weight:500}
.step h4{font-size:20px;margin:14px 0 8px}
.step p{font-size:14.5px;color:var(--ink-soft)}
.step.active{border-top-color:var(--blue)}

/* vertical timeline */
.timeline{display:flex;flex-direction:column;gap:0;position:relative}
.tline{display:grid;grid-template-columns:120px 1fr;gap:34px;padding:30px 0;border-bottom:1px solid var(--line);align-items:start}
.tline:last-child{border-bottom:none}
.tline .tnum{font-family:var(--serif);font-size:44px;font-weight:500;color:var(--blue);line-height:1;position:relative}
.tline .tnum .gold{color:var(--gold)}
.tline h3{font-size:24px;margin-bottom:10px}
.tline p{color:var(--ink-soft);max-width:60ch}
.tline .tmeta{margin-top:14px;display:flex;gap:8px;flex-wrap:wrap}

/* stat band */
.statband{display:grid;grid-template-columns:repeat(4,1fr);gap:30px}
.statband .s{padding-left:22px;border-left:1px solid var(--line-light)}
.statband .s b{font-family:var(--serif);font-size:clamp(38px,4vw,54px);font-weight:500;color:#fff;line-height:1;display:block}
.statband .s b .gold{color:var(--gold)}
.statband .s span{display:block;margin-top:10px;font-size:14.5px;color:#aaa7c6}

/* vagas card */
.vgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.vcard{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:26px;box-shadow:var(--sh-sm);display:flex;flex-direction:column;transition:transform .22s,box-shadow .22s,border-color .22s}
.vcard:hover{transform:translateY(-4px);box-shadow:var(--sh);border-color:var(--line-2)}
.vcard .vtop{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:16px}
.vcard .vlogo{width:46px;height:46px;border-radius:10px;background:var(--paper-2);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:20px;color:var(--blue);font-weight:600;flex:none}
.vcard h3{font-size:20px;line-height:1.2;margin-bottom:6px}
.vcard .vco{font-size:14px;color:var(--ink-soft)}
.vcard .vmeta{display:flex;flex-wrap:wrap;gap:8px;margin:16px 0 18px}
.vcard .vfoot{margin-top:auto;display:flex;align-items:center;justify-content:space-between;padding-top:16px;border-top:1px solid var(--line)}
.vcard .vapply{font-size:14px;font-weight:600;color:var(--blue);display:inline-flex;gap:6px;align-items:center}

/* cta band */
.ctaband{background:var(--blue);border-radius:var(--r-xl);padding:70px 56px;color:#fff;position:relative;overflow:hidden}
.ctaband h2{font-size:clamp(30px,3.6vw,46px);color:#fff;max-width:18ch}
.ctaband .lead{color:rgba(255,255,255,.85);margin-top:16px;max-width:46ch}
.ctaband .cbtns{margin-top:32px;display:flex;gap:14px;flex-wrap:wrap}
.ctaband .cmark{position:absolute;right:-50px;top:-40px;width:300px;opacity:.12}

/* quote */
.quote{display:grid;grid-template-columns:.8fr 1.2fr;gap:48px;align-items:center}
.quote .qimg{aspect-ratio:1/1;border-radius:var(--r-xl);box-shadow:var(--sh)}
.quote blockquote{margin:0;font-family:var(--serif);font-size:clamp(24px,2.6vw,32px);line-height:1.32;letter-spacing:-.01em}
.quote .qmark{font-family:var(--serif);font-size:60px;line-height:0;color:var(--gold);display:block;height:24px}
.quote .qby{margin-top:26px;display:flex;align-items:center;gap:12px;font-size:14.5px}
.quote .qby b{font-weight:600}.quote .qby span{color:var(--ink-soft)}

/* simple list with check */
.checklist{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:16px}
.checklist li{display:flex;gap:14px;font-size:16px;color:var(--ink-soft)}
.checklist li::before{content:"";flex:none;width:22px;height:22px;margin-top:1px;border-radius:50%;background:var(--blue-tint);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12'%3E%3Cpath d='M2.5 6.2l2 2 5-5.4' fill='none' stroke='%231700C2' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:center}
.checklist.gold li::before{background:var(--gold-tint);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12'%3E%3Cpath d='M2.5 6.2l2 2 5-5.4' fill='none' stroke='%23a8852f' stroke-width='1.7' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E")}

/* form */
.form{background:#fff;border:1px solid var(--line);border-radius:var(--r-xl);padding:38px;box-shadow:var(--sh)}
.form .frow{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}
.field{display:flex;flex-direction:column;gap:7px}
.field.full{grid-column:1/-1}
.field label{font-size:13px;font-weight:600;letter-spacing:.02em;color:var(--ink-soft)}
.field input,.field select,.field textarea{font-family:var(--sans);font-size:15px;padding:13px 14px;border:1px solid var(--line-2);border-radius:var(--r);background:var(--paper);color:var(--ink);transition:border .15s,box-shadow .15s}
.field input[type="file"]{background:var(--paper-2);padding:11px 14px}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(23,0,194,.12);background:#fff}
.field textarea{resize:vertical;min-height:96px}
.field small{font-size:12.5px;color:var(--ink-faint)}

/* faq */
.faq{border-top:1px solid var(--line)}
.faq details{border-bottom:1px solid var(--line)}
.faq summary{list-style:none;cursor:pointer;padding:24px 0;display:flex;justify-content:space-between;align-items:center;gap:20px;font-family:var(--serif);font-size:21px;font-weight:500}
.faq summary::-webkit-details-marker{display:none}
.faq summary .pm{flex:none;width:30px;height:30px;border:1px solid var(--line-2);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;transition:.2s;color:var(--blue)}
.faq details[open] summary .pm{transform:rotate(45deg);background:var(--blue);color:#fff;border-color:var(--blue)}
.faq .ans{padding:0 0 26px;color:var(--ink-soft);font-size:16px;max-width:70ch}

/* sectors (reused) */
.sectors{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.sector{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh-sm);transition:transform .25s,box-shadow .25s}
.sector:hover{transform:translateY(-4px);box-shadow:var(--sh)}
.sector .ph{height:170px}
.sector .sbody{padding:24px 24px 28px}
.sector h3{font-size:23px;margin-bottom:8px}
.sector p{font-size:15px;color:var(--ink-soft)}
.sector .scount{margin-top:16px;font-size:13px;font-weight:600;color:var(--blue);display:inline-flex;align-items:center;gap:7px}

@media(max-width:980px){
  .phero-grid{grid-template-columns:1fr;gap:40px}
  .fgrid{grid-template-columns:1fr 1fr}
  .steps{grid-template-columns:1fr 1fr}
  .statband{grid-template-columns:1fr 1fr;gap:36px 24px}
  .vgrid{grid-template-columns:1fr 1fr}
  .quote{grid-template-columns:1fr;gap:28px}
  .quote .qimg{max-width:280px}
  .sectors{grid-template-columns:1fr}
  .tline{grid-template-columns:64px 1fr;gap:22px}
  .tline .tnum{font-size:34px}
}
@media(max-width:620px){
  .fgrid,.steps,.vgrid,.statband,.sectors{grid-template-columns:1fr}
  .form{padding:24px}
  .form .frow{grid-template-columns:1fr}
  .ctaband{padding:48px 28px}
}

/* mobile menu panel */
.mobile-menu{display:none;position:fixed;inset:74px 0 0;background:var(--paper);z-index:49;padding:24px 28px;flex-direction:column;gap:4px}
.mobile-menu.open{display:flex}
.mobile-menu a{font-family:var(--serif);font-size:26px;padding:14px 0;border-bottom:1px solid var(--line)}
.mobile-menu .corridor-switch{font-family:var(--sans);font-size:14px;justify-content:center;margin-top:12px;padding:11px 14px;border-bottom:1px solid var(--line)}
.mobile-menu .btn{margin-top:18px}
