/* ===== AOL Pós-Graduação — Lins/SP ===== */
:root{
  --navy:#002C4F;
  --navy-dark:#001E38;
  --navy-mid:#0A3D66;
  --laranja:#E84E1C;
  --laranja-hover:#FF5E26;
  --laranja-suave:#FDEAE2;
  --gelo:#F4F7FB;
  --branco:#FFFFFF;
  --cinza:#51606E;
  --linha:#E2E9F0;
  --radius:16px;
  --shadow:0 12px 32px rgba(0,44,79,.12);
  --font-display:"Archivo", system-ui, sans-serif;
  --font-body:"Figtree", system-ui, sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation:none!important;transition:none!important}
}
body{font-family:var(--font-body);color:var(--navy-dark);background:var(--gelo);line-height:1.6;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
:focus-visible{outline:3px solid var(--laranja);outline-offset:3px;border-radius:4px}
.container{width:min(1140px,92%);margin-inline:auto}

/* ===== Top bar ===== */
.topbar{background:var(--navy-dark);color:#A9C2D6;font-size:.82rem;padding:.5rem 0}
.topbar .container{display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap}
.topbar a{color:#fff;font-weight:600}
.topbar a:hover{color:var(--laranja-hover)}

/* ===== Header ===== */
header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.95);backdrop-filter:blur(10px);border-bottom:1px solid var(--linha)}
.nav{display:flex;align-items:center;justify-content:space-between;padding:.8rem 0;gap:1rem}
.brand img{height:52px;width:auto}
nav ul{display:flex;gap:1.4rem;list-style:none;align-items:center}
nav a{font-weight:600;font-size:.92rem;color:var(--navy)}
nav a:hover,nav a.ativo{color:var(--laranja)}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.78rem 1.5rem;border-radius:10px;font-weight:800;font-size:.92rem;font-family:var(--font-display);letter-spacing:.02em;transition:transform .15s ease, background .15s ease;border:0;cursor:pointer;text-transform:uppercase}
.btn-laranja{background:var(--laranja);color:#fff;box-shadow:0 8px 20px rgba(232,78,28,.35)}
.btn-laranja:hover{background:var(--laranja-hover);transform:translateY(-2px)}
.btn-contorno{border:2px solid var(--navy);color:var(--navy);background:transparent}
.btn-contorno:hover{background:var(--navy);color:#fff}
.menu-toggle{display:none;background:none;border:0;font-size:1.7rem;color:var(--navy);cursor:pointer}

/* ===== Hero (home) ===== */
.hero{background:linear-gradient(150deg,var(--navy-dark) 0%, var(--navy) 55%, var(--navy-mid) 100%);color:#fff;overflow:hidden;position:relative}
.hero::before{content:"";position:absolute;width:1200px;height:1200px;border-radius:50%;border:10px solid var(--laranja);border-color:var(--laranja) transparent transparent transparent;top:55%;left:-18%;transform:rotate(-16deg);opacity:.9;pointer-events:none}
.hero::after{content:"";position:absolute;width:1240px;height:1240px;border-radius:50%;border:3px solid rgba(255,255,255,.25);border-color:rgba(255,255,255,.25) transparent transparent transparent;top:57%;left:-19%;transform:rotate(-14deg);pointer-events:none}
.hero .container{display:grid;grid-template-columns:1.08fr .92fr;gap:3rem;align-items:center;padding:4.6rem 0 5rem;position:relative;z-index:1}
.selo{display:inline-flex;align-items:center;gap:.55rem;background:rgba(232,78,28,.16);border:1px solid rgba(232,78,28,.5);padding:.42rem 1rem;border-radius:999px;font-size:.78rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#FFB497}
.hero h1{font-family:var(--font-display);font-size:clamp(2.1rem,4.6vw,3.5rem);line-height:1.05;font-weight:900;margin:1.1rem 0;text-transform:uppercase}
.hero h1 em{font-style:normal;color:var(--laranja-hover)}
.hero p{color:#BBD0E2;max-width:33rem;font-size:1.06rem}
.hero p b{color:#fff}
.hero-cta{display:flex;gap:.9rem;margin-top:1.9rem;flex-wrap:wrap}
.hero-cta .btn-contorno{border-color:rgba(255,255,255,.55);color:#fff}
.hero-cta .btn-contorno:hover{background:#fff;color:var(--navy)}
.hero-img{position:relative;border-radius:20px;overflow:hidden;box-shadow:0 28px 60px rgba(0,0,0,.45);border:4px solid rgba(255,255,255,.1)}
.hero-img img{width:100%;height:400px;object-fit:cover}
.hero-faixa{position:absolute;bottom:0;left:0;right:0;background:var(--laranja);color:#fff;font-family:var(--font-display);font-weight:800;text-transform:uppercase;font-size:.85rem;letter-spacing:.06em;padding:.6rem 1rem;text-align:center}

/* ===== Page hero (páginas internas) ===== */
.page-hero{background:linear-gradient(135deg,var(--navy-dark) 0%, var(--navy) 70%, var(--navy-mid) 100%);color:#fff;padding:3.4rem 0;position:relative;overflow:hidden}
.page-hero::after{content:"";position:absolute;width:760px;height:760px;border-radius:50%;border:8px solid var(--laranja);border-color:var(--laranja) transparent transparent transparent;bottom:-560px;right:-160px;transform:rotate(28deg)}
.page-hero .trilha{font-size:.82rem;color:#8FB2CC;font-weight:600;letter-spacing:.06em;text-transform:uppercase}
.page-hero .trilha a:hover{color:var(--laranja-hover)}
.page-hero h1{font-family:var(--font-display);font-size:clamp(1.9rem,4vw,2.9rem);font-weight:900;text-transform:uppercase;line-height:1.08;margin-top:.5rem}
.page-hero p{color:#BBD0E2;max-width:40rem;margin-top:.6rem}

/* ===== Stats ===== */
.stats{background:#fff;border-bottom:1px solid var(--linha)}
.stats .container{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;padding:1.9rem 0}
.stat{text-align:center;padding:.4rem;border-right:1px solid var(--linha)}
.stat:last-child{border-right:0}
.stat b{font-family:var(--font-display);font-size:2.1rem;color:var(--navy);display:block;line-height:1.1;font-weight:900}
.stat b i{font-style:normal;color:var(--laranja)}
.stat span{font-size:.85rem;color:var(--cinza);font-weight:500}

/* ===== Sections ===== */
section{padding:4.4rem 0}
.sec-head{max-width:40rem;margin-bottom:2.6rem}
.sec-head .tag{color:var(--laranja);font-weight:800;font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;font-family:var(--font-display)}
.sec-head h2{font-family:var(--font-display);font-size:clamp(1.7rem,3.1vw,2.5rem);color:var(--navy);font-weight:900;line-height:1.12;margin:.45rem 0 .7rem;text-transform:uppercase}
.sec-head p{color:var(--cinza)}
.sec-branca{background:#fff}

/* ===== Banner destaque ===== */
.banner-destaque{background:linear-gradient(120deg,var(--navy) 0%, var(--navy-mid) 100%);border-radius:20px;color:#fff;display:grid;grid-template-columns:1.3fr .7fr;overflow:hidden;box-shadow:var(--shadow);position:relative;margin-bottom:2.6rem}
.banner-destaque::after{content:"";position:absolute;width:560px;height:560px;border-radius:50%;border:7px solid var(--laranja);border-color:var(--laranja) transparent transparent transparent;bottom:-340px;right:-120px;transform:rotate(28deg)}
.banner-txt{padding:2.4rem;position:relative;z-index:1}
.banner-txt .pill{background:var(--laranja);display:inline-block;padding:.3rem .9rem;border-radius:999px;font-family:var(--font-display);font-weight:800;font-size:.74rem;letter-spacing:.08em;text-transform:uppercase;margin-bottom:.9rem}
.banner-txt h3{font-family:var(--font-display);font-size:clamp(1.4rem,2.6vw,2rem);font-weight:900;text-transform:uppercase;line-height:1.1}
.banner-txt p{color:#BBD0E2;margin:.7rem 0 1.4rem;font-size:.95rem;max-width:32rem}
.banner-img{min-height:240px;background-position:center;background-size:cover}

/* ===== Cursos ===== */
.grid-cursos{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.curso{background:#fff;border-radius:var(--radius);padding:1.7rem;box-shadow:0 6px 20px rgba(0,44,79,.08);display:flex;flex-direction:column;gap:.8rem;border-top:5px solid var(--navy);transition:transform .18s ease, box-shadow .18s ease}
.curso:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.curso.destaque{border-top-color:var(--laranja)}
.curso .tipo{font-size:.7rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--navy);background:var(--gelo);align-self:flex-start;padding:.28rem .75rem;border-radius:999px;font-family:var(--font-display)}
.curso.destaque .tipo{color:var(--laranja);background:var(--laranja-suave)}
.curso h3{font-family:var(--font-display);font-size:1.3rem;color:var(--navy);font-weight:800;line-height:1.18;text-transform:uppercase}
.curso .prof{font-size:.88rem;color:var(--navy-dark);font-weight:600}
.curso .info{font-size:.85rem;color:var(--cinza);list-style:none}
.curso .info li{padding-left:1.15rem;position:relative;margin-bottom:.3rem}
.curso .info li::before{content:"";position:absolute;left:0;top:.5em;width:7px;height:7px;border-radius:2px;background:var(--laranja)}
.curso .btn{margin-top:auto;width:100%}

/* ===== Curso detalhado (página cursos) ===== */
.curso-full{background:#fff;border-radius:20px;box-shadow:0 6px 20px rgba(0,44,79,.08);display:grid;grid-template-columns:340px 1fr;overflow:hidden;margin-bottom:1.8rem}
.curso-full .capa{background:var(--navy);display:flex;align-items:center;justify-content:center;padding:2rem;position:relative;overflow:hidden}
.curso-full .capa::after{content:"";position:absolute;width:420px;height:420px;border-radius:50%;border:6px solid var(--laranja);border-color:var(--laranja) transparent transparent transparent;bottom:-260px;left:-90px;transform:rotate(40deg)}
.curso-full .capa h3{font-family:var(--font-display);color:#fff;font-weight:900;text-transform:uppercase;font-size:1.6rem;line-height:1.1;position:relative;z-index:1;text-align:center}
.curso-full .capa .tipo-capa{position:absolute;top:1.2rem;left:1.2rem;background:var(--laranja);color:#fff;font-family:var(--font-display);font-weight:800;font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;padding:.3rem .8rem;border-radius:999px;z-index:1}
.curso-full .corpo{padding:2rem 2.2rem}
.curso-full .corpo h4{font-family:var(--font-display);color:var(--laranja);font-size:.8rem;letter-spacing:.1em;text-transform:uppercase;margin-top:1.1rem;margin-bottom:.25rem}
.curso-full .corpo h4:first-child{margin-top:0}
.curso-full .corpo p{font-size:.93rem;color:var(--cinza)}
.curso-full .corpo p b{color:var(--navy)}
.curso-full .corpo .btn{margin-top:1.4rem}

/* ===== Pilares ===== */
.grid-pilares{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.pilar{background:var(--gelo);border-radius:var(--radius);padding:1.9rem;border-left:5px solid var(--laranja)}
.pilar .num{font-family:var(--font-display);font-weight:900;color:var(--laranja);font-size:.85rem;letter-spacing:.1em;text-transform:uppercase}
.pilar h3{font-family:var(--font-display);color:var(--navy);font-size:1.15rem;font-weight:800;margin:.4rem 0 .5rem;text-transform:uppercase}
.pilar p{font-size:.92rem;color:var(--cinza)}

/* ===== História / timeline ===== */
.historia{background:var(--navy);color:#fff;position:relative;overflow:hidden}
.historia::before{content:"";position:absolute;width:900px;height:900px;border-radius:50%;border:8px solid rgba(232,78,28,.55);border-color:rgba(232,78,28,.55) transparent transparent transparent;top:-560px;right:-260px;transform:rotate(150deg)}
.historia .sec-head h2{color:#fff}
.historia .sec-head p{color:#BBD0E2}
.historia .sec-head .tag{color:var(--laranja-hover)}
.timeline{display:grid;grid-template-columns:repeat(4,1fr);gap:1.4rem;position:relative;margin-top:1rem;z-index:1}
.timeline::before{content:"";position:absolute;top:11px;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--laranja),rgba(255,255,255,.35))}
.marco{position:relative;padding-top:2.2rem}
.marco::before{content:"";position:absolute;top:2px;left:0;width:20px;height:20px;border-radius:50%;background:var(--laranja);border:4px solid var(--navy);box-shadow:0 0 0 2px var(--laranja)}
.marco b{font-family:var(--font-display);font-size:1.35rem;color:var(--laranja-hover);font-weight:900}
.marco p{font-size:.9rem;color:#BBD0E2;margin-top:.35rem}

/* ===== Infra ===== */
.infra .container{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center}
.infra-img{border-radius:20px;overflow:hidden;box-shadow:var(--shadow);border-bottom:6px solid var(--laranja)}
.infra-img img{height:420px;width:100%;object-fit:cover}
.infra ul{list-style:none;display:grid;gap:.8rem;margin-top:1.4rem}
.infra li{display:flex;gap:.7rem;align-items:flex-start;font-size:.95rem}
.infra li::before{content:"✓";color:#fff;background:var(--laranja);min-width:22px;height:22px;border-radius:6px;display:grid;place-items:center;font-size:.75rem;font-weight:800;margin-top:.15rem}

/* ===== Docentes (cards resumo) ===== */
.grid-doc{display:grid;grid-template-columns:repeat(4,1fr);gap:1.4rem}
.doc{text-align:center}
.doc .foto{width:100%;aspect-ratio:1/1;border-radius:16px;overflow:hidden;box-shadow:0 6px 20px rgba(0,44,79,.12);margin-bottom:.9rem;background:var(--gelo);border-bottom:4px solid var(--laranja)}
.doc .foto img{width:100%;height:100%;object-fit:cover}
.doc h3{font-family:var(--font-display);font-size:1rem;color:var(--navy);font-weight:800;line-height:1.25}
.doc p{font-size:.84rem;color:var(--cinza)}

/* ===== Docente detalhado ===== */
.docente-full{background:#fff;border-radius:20px;box-shadow:0 6px 20px rgba(0,44,79,.08);display:grid;grid-template-columns:280px 1fr;gap:0;overflow:hidden;margin-bottom:1.8rem}
.docente-full .foto{aspect-ratio:1/1}
.docente-full .foto img{width:100%;height:100%;object-fit:cover}
.docente-full .bio{padding:1.9rem 2.2rem;align-self:center}
.docente-full .bio h3{font-family:var(--font-display);font-size:1.4rem;color:var(--navy);font-weight:900;text-transform:uppercase;line-height:1.15}
.docente-full .bio .cro{display:inline-block;background:var(--laranja-suave);color:var(--laranja);font-family:var(--font-display);font-weight:800;font-size:.74rem;letter-spacing:.06em;padding:.25rem .8rem;border-radius:999px;margin:.5rem 0 .9rem}
.docente-full .bio p{font-size:.92rem;color:var(--cinza)}
.docente-full .bio p b{color:var(--navy)}

/* ===== Depoimentos ===== */
.grid-depo{display:grid;grid-template-columns:1fr 1fr;gap:1.4rem}
.depo{background:#fff;border-radius:var(--radius);padding:2rem;box-shadow:0 6px 20px rgba(0,44,79,.08);position:relative;border-top:5px solid var(--laranja)}
.depo::before{content:"\201C";font-family:var(--font-display);font-size:4.5rem;color:var(--laranja-suave);position:absolute;top:.4rem;right:1.4rem;line-height:1;font-weight:900}
.depo p{font-size:1rem;color:var(--navy-dark);font-style:italic;position:relative;z-index:1}
.depo .autor{display:flex;align-items:center;gap:.9rem;margin-top:1.3rem}
.depo .autor img{width:54px;height:54px;border-radius:50%;object-fit:cover;border:3px solid var(--laranja)}
.depo .autor b{font-family:var(--font-display);color:var(--navy);display:block;line-height:1.2}
.depo .autor span{font-size:.82rem;color:var(--cinza)}

/* ===== Galeria ===== */
.galeria{display:grid;grid-template-columns:repeat(4,1fr);gap:.9rem}
.galeria a{display:block;border-radius:12px;overflow:hidden;box-shadow:0 6px 16px rgba(0,44,79,.12);aspect-ratio:4/3;transition:transform .15s ease}
.galeria a:hover{transform:scale(1.02)}
.galeria img{width:100%;height:100%;object-fit:cover}

/* ===== Instagram ===== */
.insta{background:linear-gradient(150deg,var(--navy-dark) 0%, var(--navy) 100%);color:#fff;position:relative;overflow:hidden}
.insta::after{content:"";position:absolute;width:800px;height:800px;border-radius:50%;border:8px solid var(--laranja);border-color:var(--laranja) transparent transparent transparent;bottom:-560px;left:-200px;transform:rotate(60deg)}
.insta .sec-head h2{color:#fff}
.insta .sec-head p{color:#BBD0E2}
.insta .sec-head .tag{color:var(--laranja-hover)}
.insta-widget{position:relative;z-index:1;background:rgba(255,255,255,.06);border:1px dashed rgba(255,255,255,.3);border-radius:16px;padding:1rem;min-height:120px}
.insta-widget iframe{border-radius:12px}
.insta-cta{margin-top:1.6rem;position:relative;z-index:1}

/* ===== CTA final ===== */
.cta-final{background:var(--laranja);color:#fff;text-align:center;padding:3.6rem 0}
.cta-final h2{font-family:var(--font-display);font-weight:900;font-size:clamp(1.6rem,3vw,2.4rem);text-transform:uppercase;line-height:1.12}
.cta-final p{margin:.7rem auto 1.6rem;max-width:34rem;color:#FFE3D7}
.cta-final .btn{background:#fff;color:var(--laranja)}
.cta-final .btn:hover{background:var(--navy);color:#fff}

/* ===== Contato ===== */
.contato .container{display:grid;grid-template-columns:1fr 1fr;gap:3rem}
.card-contato{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);padding:2rem;border-top:5px solid var(--navy)}
.card-contato h3{font-family:var(--font-display);color:var(--navy);font-size:1.3rem;margin-bottom:1rem;font-weight:800;text-transform:uppercase}
.card-contato p{margin-bottom:.7rem;font-size:.95rem}
.card-contato b{color:var(--navy)}
.mapa{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);min-height:380px}
.mapa iframe{width:100%;height:100%;border:0;min-height:380px}

/* ===== Footer ===== */
footer{background:var(--navy-dark);color:#8FA9BD;padding:2.8rem 0 1.6rem;font-size:.85rem}
footer .container{display:grid;grid-template-columns:2fr 1fr 1fr;gap:2rem;padding-bottom:1.8rem;border-bottom:1px solid #103352}
footer .logo-footer{height:54px;width:auto;margin-bottom:1rem}
footer h4{color:#fff;font-family:var(--font-display);margin-bottom:.7rem;text-transform:uppercase;font-size:.95rem;letter-spacing:.04em}
footer a:hover{color:var(--laranja-hover)}
.legal{text-align:center;padding-top:1.2rem;font-size:.78rem;color:#5F7A90}

/* ===== WhatsApp flutuante ===== */
.whats{position:fixed;bottom:1.4rem;right:1.4rem;z-index:60;background:#25D366;color:#fff;width:58px;height:58px;border-radius:50%;display:grid;place-items:center;box-shadow:0 10px 24px rgba(0,0,0,.3);transition:transform .15s ease}
.whats:hover{transform:scale(1.08)}

/* ===== Responsivo ===== */
@media (max-width:900px){
  .hero .container,.infra .container,.contato .container{grid-template-columns:1fr}
  .banner-destaque,.curso-full,.docente-full,.grid-depo{grid-template-columns:1fr}
  .banner-img{order:-1;min-height:200px}
  .curso-full .capa{min-height:160px}
  .docente-full .foto{max-height:380px}
  .grid-cursos,.grid-pilares{grid-template-columns:1fr 1fr}
  .grid-doc{grid-template-columns:1fr 1fr}
  .galeria{grid-template-columns:1fr 1fr}
  .stats .container{grid-template-columns:1fr 1fr}
  .stat{border-right:0}
  .timeline{grid-template-columns:1fr;gap:1.8rem}
  .timeline::before{top:0;bottom:0;left:9px;right:auto;width:3px;height:auto;background:linear-gradient(180deg,var(--laranja),rgba(255,255,255,.35))}
  .marco{padding-top:0;padding-left:2.4rem}
  nav ul{display:none;position:absolute;top:100%;left:0;right:0;background:#fff;flex-direction:column;padding:1.2rem;gap:1rem;border-bottom:1px solid var(--linha);box-shadow:var(--shadow)}
  nav ul.open{display:flex}
  .menu-toggle{display:block}
  .nav > .btn{display:none}
}
@media (max-width:560px){
  .grid-cursos,.grid-doc,.grid-pilares,.galeria{grid-template-columns:1fr}
  .topbar .container{justify-content:center;text-align:center}
  .brand img{height:42px}
}
