/* ============================================================
   Dentistas SJC — preset-A teal · MOBILE-FIRST
   CSS compartilhado: index, ficha de clínica, diretório, landings.
   Tokens, header, topbar, footer, cards, badges, sec-head.
   Base = celular; @media(min-width:860px) escala pro desktop.
   ============================================================ */
:root{
  --cream:#f3f8fc; --cream2:#e8f1f9; --surface:#ffffff; --moss:#0f2233; --moss2:#54677a;
  --clay:#0a6ebd; --clay-d:#075089; --charcoal:#0f2233; --estrela:#f5a623;
  --teal:#16b8a6; --teal-d:#11a292; --teal-cl:#e6f7f5; --teal-fg:#0c8676;
  --linha:#dce6ef; --soft:rgba(15,34,51,.05); --clay-soft:rgba(10,110,189,.10);
  --sombra:0 14px 38px rgba(10,60,110,.13); --ease:cubic-bezier(.25,.46,.45,.94);
  /* aliases legados (usados inline nos geradores) */
  --azul:#0a6ebd; --azul-esc:#075089; --tinta:#0f2233; --cinza:#54677a;
  --fundo:#f3f8fc; --branco:#ffffff; --ok:#16a34a;
}
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:'Plus Jakarta Sans',sans-serif;color:var(--charcoal);background:var(--cream);line-height:1.55;-webkit-font-smoothing:antialiased}
body::before{content:"";position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.04;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:'Outfit',sans-serif;letter-spacing:-.02em;line-height:1.1}
.wrap{max-width:1140px;margin:0 auto;padding:0 20px;position:relative;z-index:2}

/* topbar */
.topbar{background:var(--moss);color:#c3d2df;font-size:12.5px;position:relative;z-index:2}
.topbar .wrap{display:flex;justify-content:center;align-items:center;gap:10px;min-height:38px;padding-top:6px;padding-bottom:6px}
.topbar a{color:#7fd8cd;font-weight:600}

/* header */
header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.88);backdrop-filter:blur(16px);border-bottom:1px solid var(--linha)}
.nav{display:flex;align-items:center;gap:16px;height:62px}
.logo{display:flex;align-items:center;gap:9px;font-family:'Outfit';font-weight:800;font-size:19px;color:var(--moss)}
.logo .mark{width:34px;height:34px;border-radius:10px;background:var(--teal-cl);color:var(--teal-fg);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.logo .mark svg{width:20px;height:20px}
.logo b{color:var(--clay)}
.menu{display:none;gap:22px;margin-left:8px;font-weight:600;font-size:14.5px;color:var(--moss)}
.menu a:hover{color:var(--clay)}
.nav .cta{margin-left:auto;background:var(--teal);color:#fff;padding:10px 16px;border-radius:999px;font-family:'Outfit';font-weight:700;font-size:13.5px;transition:.25s var(--ease);white-space:nowrap}
.nav .cta:hover{background:var(--teal-d);transform:scale(1.03)}

/* breadcrumb */
.crumb{font-size:13px;color:var(--moss2);padding:18px 0 0}
.crumb a:hover{color:var(--clay)}
.crumb b{color:var(--moss)}

/* sec-head */
.sec-head{text-align:center;max-width:640px;margin:0 auto 30px}
.sec-head .kicker{font-family:'IBM Plex Mono';color:var(--teal-fg);font-weight:500;font-size:12px;letter-spacing:.14em;text-transform:uppercase}
.sec-head h2{font-size:clamp(24px,5.4vw,38px);margin-top:9px;color:var(--moss);font-weight:700}
.sec-head p{color:var(--moss2);margin-top:10px}

/* badges / chips */
.badge{font-size:11px;font-weight:700;padding:4px 10px;border-radius:20px;background:var(--teal-cl);color:var(--teal-fg)}
.badge.dest{background:#fff3da;color:#b07d14}
.badge.uni{background:var(--teal-cl);color:var(--teal-fg);border:1px solid #bfe6e2}
.chip{background:var(--cream);border:1px solid var(--linha);border-radius:20px;padding:7px 14px;font-size:13px;font-weight:600;color:var(--moss2)}
.chip.conv{background:var(--teal-cl);border-color:#bfe6e2;color:var(--teal-fg)}

/* footer */
footer{background:#0c1c2b;color:#90a6b8;font-size:13.5px;padding:42px 0 26px;margin-top:14px;position:relative;z-index:2}
footer .wrap{line-height:1.6}
footer a{color:#9fc7c0;font-weight:600}
footer a:hover{color:#fff}
.fcols{display:grid;grid-template-columns:1fr 1fr;gap:26px}
footer h4{color:#fff;font-family:'Outfit';font-size:15px;margin-bottom:12px}
footer .logo{color:#fff}
footer .logo .mark{background:rgba(22,184,166,.16);color:#6fcabe}
footer .fcols p{color:#90a6b8;font-weight:400;font-size:13.5px}
footer .fcols>div>a:not(.logo){display:block;padding:4px 0}
.fbar{border-top:1px solid #1c3043;margin-top:30px;padding-top:18px;font-size:12.5px;color:#5f7384;display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px}

/* páginas institucionais / conteúdo */
.doc{max-width:760px;margin:0 auto;padding:26px 0 18px}
.doc-card{background:var(--surface);border:1px solid var(--linha);border-radius:20px;padding:26px 22px;box-shadow:var(--sombra)}
.doc h1{font-size:clamp(26px,5.4vw,38px);color:var(--moss);font-weight:800}
.doc .lede{color:var(--moss2);font-size:16px;margin-top:10px}
.doc h2{font-size:19px;color:var(--moss);font-weight:700;margin-top:26px}
.doc p{color:var(--moss2);margin-top:11px;font-size:15.5px;line-height:1.65}
.doc ul,.doc ol{margin-top:12px;padding:0;list-style:none}
.doc li{color:var(--moss2);font-size:15.5px;line-height:1.6;padding-left:22px;position:relative;margin-top:12px}
.doc li::before{content:"";position:absolute;left:2px;top:9px;width:7px;height:7px;border-radius:50%;background:var(--teal)}
.doc li b{color:var(--moss)}
.doc a.inline{color:var(--clay);font-weight:600}
.doc .btn-row{display:flex;gap:12px;flex-wrap:wrap;margin-top:22px}
.doc .btn{display:inline-flex;align-items:center;gap:9px;padding:13px 22px;border-radius:12px;font-family:'Outfit';font-weight:700;font-size:15px;transition:.25s var(--ease)}
.doc .btn svg{width:19px;height:19px}
.doc .btn.wpp{background:var(--teal);color:#fff}
.doc .btn.wpp:hover{background:var(--teal-d)}
.doc .btn.mail{background:var(--cream2);color:var(--moss);border:1px solid var(--linha)}
.doc .btn.mail:hover{border-color:var(--clay);color:var(--clay)}
.doc .note{margin-top:24px;padding:14px 16px;background:var(--cream2);border-radius:12px;font-size:13.5px;color:var(--moss2);line-height:1.6}

/* desktop scale-up */
@media(min-width:860px){
  .wrap{padding:0 22px}
  .topbar{font-size:13px}
  .nav{gap:30px;height:72px}
  .logo{font-size:21px;gap:10px}
  .logo .mark{width:36px;height:36px;border-radius:11px}
  .logo .mark svg{width:21px;height:21px}
  .menu{display:flex}
  .nav .cta{padding:11px 20px;font-size:14px}
  .sec-head{margin:0 auto 38px}
  .sec-head .kicker{font-size:12.5px}
  footer{padding:54px 0 28px;font-size:14px}
  .fcols{grid-template-columns:2fr 1fr 1fr 1fr;gap:30px}
  .fbar{margin-top:34px;padding-top:20px}
  .doc-card{padding:38px 36px}
}
