/*
Theme Name: SGR - Sociedade Goiana de Reumatologia
Theme URI: https://reumatologiago.com.br
Author: SGR / Desenvolvimento
Description: Tema WordPress institucional da Sociedade Goiana de Reumatologia (SGR). Layout moderno na área de saúde, com diretório de reumatologistas, eventos, notícias, artigos e conteúdo científico. Conteúdo pré-cadastrado e editável pelo painel (Personalizar + editor de páginas + tipos de conteúdo).
Version: 1.0.0
Requires at least: 6.0
Requires PHP: 7.4
License: GPL-2.0-or-later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: sgr
*/

/* =========================================================
   Design tokens
   ========================================================= */
:root{
  --sgr-petrol:#15616D;     /* primário - teal profundo (saúde/confiança) */
  --sgr-petrol-dark:#0E454E;
  --sgr-teal:#2A9D8F;       /* teal claro - links/realces */
  --sgr-clay:#E07A5F;       /* acento quente - cerrado (CTAs, destaques) */
  --sgr-clay-dark:#C9603F;
  --sgr-ink:#13212A;        /* texto */
  --sgr-slate:#4A5A63;      /* texto secundário */
  --sgr-line:#E4EAEA;       /* divisórias */
  --sgr-mist:#F2F6F6;       /* fundo de seção */
  --sgr-sand:#FBF7F2;       /* superfície quente alternativa */
  --sgr-white:#ffffff;

  --sgr-radius:16px;
  --sgr-radius-sm:10px;
  --sgr-shadow:0 18px 40px -22px rgba(19,33,42,.28);
  --sgr-shadow-sm:0 8px 22px -16px rgba(19,33,42,.35);
  --sgr-container:1180px;
  --sgr-font-display:"Spectral", Georgia, "Times New Roman", serif;
  --sgr-font-body:"Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
}

/* =========================================================
   Reset / base
   ========================================================= */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--sgr-font-body);
  color:var(--sgr-ink);
  background:var(--sgr-white);
  font-size:17px;
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--sgr-petrol);text-decoration:none;transition:color .2s ease,opacity .2s ease}
a:hover{color:var(--sgr-clay)}
h1,h2,h3,h4,h5{font-family:var(--sgr-font-display);color:var(--sgr-ink);line-height:1.18;font-weight:600;margin:0 0 .5em}
h1{font-size:clamp(2.1rem,4.6vw,3.5rem)}
h2{font-size:clamp(1.7rem,3.2vw,2.5rem)}
h3{font-size:clamp(1.25rem,2vw,1.6rem)}
p{margin:0 0 1.1em}
ul,ol{margin:0 0 1.1em;padding-left:1.2em}
li{margin:.25em 0}
:focus-visible{outline:3px solid var(--sgr-teal);outline-offset:2px;border-radius:4px}

.container{max-width:var(--sgr-container);margin:0 auto;padding:0 22px}
.section{padding:84px 0}
.section--mist{background:var(--sgr-mist)}
.section--sand{background:var(--sgr-sand)}
.section--petrol{background:var(--sgr-petrol);color:#eaf3f3}
.section--petrol h1,.section--petrol h2,.section--petrol h3{color:#fff}
.text-center{text-align:center}
.skip-link{position:absolute;left:-999px}
.skip-link:focus{left:16px;top:12px;background:#fff;padding:10px 16px;border-radius:8px;z-index:1000}

/* =========================================================
   Signature: vertebra eyebrow (coluna vertebral)
   ========================================================= */
.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--sgr-font-body);
  text-transform:uppercase;letter-spacing:.16em;font-size:.74rem;font-weight:700;
  color:var(--sgr-teal);margin-bottom:14px;
}
.eyebrow::before{
  content:"";width:26px;height:14px;
  background-image:radial-gradient(circle,currentColor 38%,transparent 42%);
  background-size:7px 7px;background-repeat:repeat-x;background-position:center;
  opacity:.9;
}
.section--petrol .eyebrow{color:#7fd1c6}
.section-head{max-width:720px;margin:0 auto 52px}
.section-head.left{margin-left:0;text-align:left}
.section-head p{color:var(--sgr-slate);font-size:1.05rem;margin:0}
.section--petrol .section-head p{color:#bcd9d7}

/* spine divider */
.spine-rule{display:flex;justify-content:center;gap:6px;margin:0 auto 8px}
.spine-rule span{width:8px;height:8px;border-radius:50%;background:var(--sgr-clay);opacity:.55}
.spine-rule span:nth-child(2){opacity:.8;transform:scale(1.15)}
.spine-rule span:nth-child(3){opacity:1;transform:scale(1.3)}

/* =========================================================
   Buttons
   ========================================================= */
.btn{
  display:inline-flex;align-items:center;gap:9px;
  font-family:var(--sgr-font-body);font-weight:600;font-size:.98rem;
  padding:14px 26px;border-radius:999px;border:2px solid transparent;cursor:pointer;
  transition:transform .15s ease,background .2s ease,color .2s ease,border-color .2s ease;
}
.btn:hover{transform:translateY(-2px)}
.btn--primary{background:var(--sgr-clay);color:#fff}
.btn--primary:hover{background:var(--sgr-clay-dark);color:#fff}
.btn--petrol{background:var(--sgr-petrol);color:#fff}
.btn--petrol:hover{background:var(--sgr-petrol-dark);color:#fff}
.btn--ghost{background:transparent;border-color:currentColor;color:var(--sgr-petrol)}
.btn--ghost:hover{background:var(--sgr-petrol);color:#fff;border-color:var(--sgr-petrol)}
.btn--light{background:#fff;color:var(--sgr-petrol)}
.btn--light:hover{background:var(--sgr-sand);color:var(--sgr-petrol-dark)}
.btn--on-petrol.btn--ghost{color:#fff}
.btn--on-petrol.btn--ghost:hover{background:#fff;color:var(--sgr-petrol)}

/* =========================================================
   Topbar + Header
   ========================================================= */
.topbar{background:var(--sgr-petrol-dark);color:#cfe6e4;font-size:.86rem}
.topbar .container{display:flex;flex-wrap:wrap;gap:8px 26px;align-items:center;justify-content:space-between;padding-top:9px;padding-bottom:9px}
.topbar a{color:#cfe6e4}
.topbar a:hover{color:#fff}
.topbar__info{display:flex;flex-wrap:wrap;gap:6px 22px}
.topbar__info span{display:inline-flex;align-items:center;gap:7px}
.topbar__social{display:flex;gap:14px}

.site-header{position:sticky;top:0;z-index:90;background:rgba(255,255,255,.92);backdrop-filter:blur(8px);border-bottom:1px solid var(--sgr-line)}
.site-header .container{display:flex;align-items:center;justify-content:space-between;gap:20px;min-height:78px}
.brand{display:flex;align-items:center;gap:14px;color:var(--sgr-ink)}
.brand img{height:52px;width:auto}
.brand__text strong{display:block;font-family:var(--sgr-font-display);font-size:1.02rem;line-height:1.1}
.brand__text small{display:block;color:var(--sgr-slate);font-size:.72rem;letter-spacing:.06em;text-transform:uppercase}

.main-nav ul{list-style:none;display:flex;align-items:center;gap:6px;margin:0;padding:0}
.main-nav a{display:block;padding:10px 14px;border-radius:8px;color:var(--sgr-ink);font-weight:500;font-size:.96rem}
.main-nav a:hover,.main-nav .current-menu-item>a,.main-nav .current_page_item>a{color:var(--sgr-petrol);background:var(--sgr-mist)}
.main-nav li{position:relative}
.main-nav .sub-menu{position:absolute;top:100%;left:0;min-width:236px;background:#fff;border:1px solid var(--sgr-line);border-radius:12px;box-shadow:var(--sgr-shadow);padding:8px;display:none;flex-direction:column;gap:2px;z-index:50}
.main-nav li:hover>.sub-menu,.main-nav li:focus-within>.sub-menu{display:flex}
.main-nav .sub-menu a{font-size:.9rem}
.header-actions{display:flex;align-items:center;gap:12px}
.nav-toggle{display:none;background:none;border:0;cursor:pointer;padding:8px;color:var(--sgr-ink)}
.nav-toggle svg{width:26px;height:26px}

/* =========================================================
   Hero
   ========================================================= */
.hero{position:relative;overflow:hidden;background:
  radial-gradient(1100px 540px at 85% -10%, rgba(42,157,143,.16), transparent 60%),
  linear-gradient(180deg,var(--sgr-sand),#fff 70%);
}
.hero .container{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center;padding-top:74px;padding-bottom:74px}
.hero__title{margin:.1em 0 .35em}
.hero__lead{font-size:1.12rem;color:var(--sgr-slate);max-width:33ch}
.hero__actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:26px}
.hero__media{position:relative}
.hero__media img{border-radius:24px;box-shadow:var(--sgr-shadow);width:100%;object-fit:cover}
.hero__badge{
  position:absolute;left:-18px;bottom:26px;background:#fff;border-radius:16px;
  box-shadow:var(--sgr-shadow);padding:16px 20px;display:flex;align-items:center;gap:14px;max-width:260px;
}
.hero__badge .num{font-family:var(--sgr-font-display);font-size:2rem;color:var(--sgr-petrol);line-height:1}
.hero__badge small{color:var(--sgr-slate);font-size:.82rem}
.hero__seal{position:absolute;right:-14px;top:-14px;width:96px;opacity:.95}

/* =========================================================
   Quick cards (3 atalhos)
   ========================================================= */
.quick{margin-top:-44px;position:relative;z-index:5}
.quick__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.qcard{background:#fff;border:1px solid var(--sgr-line);border-radius:var(--sgr-radius);padding:30px 26px;box-shadow:var(--sgr-shadow-sm);transition:transform .2s ease,box-shadow .2s ease}
.qcard:hover{transform:translateY(-6px);box-shadow:var(--sgr-shadow)}
.qcard__ico{width:54px;height:54px;border-radius:14px;display:grid;place-items:center;background:var(--sgr-mist);color:var(--sgr-petrol);margin-bottom:16px}
.qcard__ico svg{width:28px;height:28px}
.qcard h3{margin-bottom:.4em}
.qcard p{color:var(--sgr-slate);font-size:.96rem;margin-bottom:1em}
.qcard a.more{font-weight:600;color:var(--sgr-clay)}

/* =========================================================
   About
   ========================================================= */
.about__grid{display:grid;grid-template-columns:.95fr 1.05fr;gap:54px;align-items:center}
.about__media{position:relative}
.about__media img{border-radius:22px;box-shadow:var(--sgr-shadow)}
.about__since{position:absolute;right:-16px;bottom:-16px;background:var(--sgr-petrol);color:#fff;border-radius:18px;padding:18px 22px;text-align:center;box-shadow:var(--sgr-shadow)}
.about__since .num{font-family:var(--sgr-font-display);font-size:2.1rem;line-height:1}
.about__since small{font-size:.8rem;color:#bfe0dc}
.about__list{list-style:none;padding:0;margin:18px 0 26px}
.about__list li{display:flex;gap:12px;align-items:flex-start;margin:.5em 0;color:var(--sgr-slate)}
.about__list li::before{content:"";flex:0 0 auto;width:22px;height:22px;border-radius:50%;background:var(--sgr-mist);position:relative;margin-top:3px;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%2315616D' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:center}

/* =========================================================
   Cards grid genérico (serviços / conteúdo profissional)
   ========================================================= */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:24px}
.card{background:#fff;border:1px solid var(--sgr-line);border-radius:var(--sgr-radius);padding:30px 26px;transition:transform .2s ease,box-shadow .2s ease,border-color .2s}
.card:hover{transform:translateY(-5px);box-shadow:var(--sgr-shadow);border-color:transparent}
.card__ico{width:52px;height:52px;border-radius:14px;display:grid;place-items:center;background:var(--sgr-petrol);color:#fff;margin-bottom:16px}
.card__ico svg{width:26px;height:26px}
.card h3{font-size:1.18rem}
.card p{color:var(--sgr-slate);font-size:.95rem;margin-bottom:.8em}
.card a.more{font-weight:600;color:var(--sgr-clay)}
.card--patient .card__ico{background:var(--sgr-clay)}

/* =========================================================
   Doctors / Diretoria
   ========================================================= */
.docs{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:26px}
.doc{background:#fff;border:1px solid var(--sgr-line);border-radius:var(--sgr-radius);overflow:hidden;transition:transform .2s ease,box-shadow .2s}
.doc:hover{transform:translateY(-5px);box-shadow:var(--sgr-shadow)}
.doc__photo{aspect-ratio:1/1;background:var(--sgr-mist);overflow:hidden}
.doc__photo img{width:100%;height:100%;object-fit:cover}
.doc__ph-fallback{width:100%;height:100%;display:grid;place-items:center;color:var(--sgr-petrol);background:linear-gradient(160deg,var(--sgr-mist),#fff)}
.doc__ph-fallback svg{width:64px;height:64px;opacity:.5}
.doc__body{padding:20px 22px}
.doc__body h3{font-size:1.15rem;margin-bottom:.15em}
.doc__role{color:var(--sgr-clay);font-weight:600;font-size:.9rem;margin-bottom:.5em}
.doc__meta{color:var(--sgr-slate);font-size:.88rem}

/* directory filters */
.dir-filter{display:flex;flex-wrap:wrap;gap:12px;align-items:flex-end;background:#fff;border:1px solid var(--sgr-line);border-radius:var(--sgr-radius);padding:20px;margin-bottom:34px;box-shadow:var(--sgr-shadow-sm)}
.dir-filter label{display:block;font-size:.8rem;font-weight:600;color:var(--sgr-slate);margin-bottom:5px}
.dir-filter input,.dir-filter select{padding:11px 14px;border:1px solid var(--sgr-line);border-radius:10px;font:inherit;font-size:.95rem;min-width:200px;background:#fff}
.dir-filter .field{flex:1 1 220px}

/* =========================================================
   CTA band
   ========================================================= */
.cta-band{background:linear-gradient(120deg,var(--sgr-petrol),var(--sgr-petrol-dark));color:#fff;border-radius:24px;padding:48px;display:grid;grid-template-columns:1.4fr auto;gap:28px;align-items:center;box-shadow:var(--sgr-shadow)}
.cta-band h2{color:#fff;margin-bottom:.25em}
.cta-band p{color:#cfe6e4;margin:0;max-width:60ch}

/* =========================================================
   Posts (notícias / artigos)
   ========================================================= */
.posts{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:26px}
.post-card{background:#fff;border:1px solid var(--sgr-line);border-radius:var(--sgr-radius);overflow:hidden;display:flex;flex-direction:column;transition:transform .2s ease,box-shadow .2s}
.post-card:hover{transform:translateY(-5px);box-shadow:var(--sgr-shadow)}
.post-card__thumb{aspect-ratio:16/10;background:var(--sgr-mist);overflow:hidden}
.post-card__thumb img{width:100%;height:100%;object-fit:cover}
.post-card__thumb-fallback{width:100%;height:100%;display:grid;place-items:center;background:linear-gradient(150deg,var(--sgr-petrol),var(--sgr-teal))}
.post-card__thumb-fallback svg{width:54px;height:54px;color:#fff;opacity:.85}
.post-card__body{padding:22px 24px;display:flex;flex-direction:column;gap:8px;flex:1}
.post-card__cat{font-size:.74rem;text-transform:uppercase;letter-spacing:.1em;font-weight:700;color:var(--sgr-teal)}
.post-card__body h3{font-size:1.15rem;margin:0}
.post-card__date{color:var(--sgr-slate);font-size:.84rem}
.post-card__excerpt{color:var(--sgr-slate);font-size:.93rem;margin:0}
.post-card .more{margin-top:auto;font-weight:600;color:var(--sgr-clay)}

/* =========================================================
   Page banner + content (single & page)
   ========================================================= */
.page-banner{background:
  radial-gradient(900px 400px at 80% -30%, rgba(42,157,143,.22), transparent 60%),
  linear-gradient(120deg,var(--sgr-petrol),var(--sgr-petrol-dark));color:#fff;padding:64px 0}
.page-banner h1{color:#fff;margin:0 0 .3em}
.page-banner .crumbs{color:#bcd9d7;font-size:.9rem}
.page-banner .crumbs a{color:#fff}

.content-wrap{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:48px;align-items:start}
.entry{font-size:1.05rem}
.entry h2{margin-top:1.4em}
.entry h3{margin-top:1.2em;color:var(--sgr-petrol)}
.entry table{width:100%;border-collapse:collapse;margin:1.4em 0;font-size:.95rem}
.entry th,.entry td{border:1px solid var(--sgr-line);padding:10px 12px;text-align:left}
.entry th{background:var(--sgr-mist)}
.entry img{border-radius:14px;margin:1em 0}
.entry a{text-decoration:underline;text-underline-offset:3px}
.entry ul li::marker{color:var(--sgr-clay)}

.sidebar{position:sticky;top:96px;display:flex;flex-direction:column;gap:22px}
.widget{background:#fff;border:1px solid var(--sgr-line);border-radius:var(--sgr-radius);padding:24px}
.widget h4{font-family:var(--sgr-font-display);font-size:1.12rem;margin:0 0 .7em;padding-bottom:.5em;border-bottom:2px solid var(--sgr-mist)}
.widget ul{list-style:none;padding:0;margin:0}
.widget li{padding:8px 0;border-bottom:1px solid var(--sgr-line)}
.widget li:last-child{border-bottom:0}
.agenda-empty{color:var(--sgr-slate);font-size:.95rem}
.agenda-item{display:flex;gap:12px;align-items:flex-start}
.agenda-item .date{flex:0 0 auto;background:var(--sgr-petrol);color:#fff;border-radius:10px;text-align:center;padding:8px 10px;min-width:54px}
.agenda-item .date b{display:block;font-family:var(--sgr-font-display);font-size:1.2rem;line-height:1}
.agenda-item .date small{font-size:.68rem;text-transform:uppercase}

/* =========================================================
   Forms
   ========================================================= */
.sgr-form{display:grid;gap:16px;max-width:640px}
.sgr-form .row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.sgr-form label{display:block;font-size:.85rem;font-weight:600;color:var(--sgr-slate);margin-bottom:6px}
.sgr-form input,.sgr-form textarea{width:100%;padding:13px 15px;border:1px solid var(--sgr-line);border-radius:10px;font:inherit;font-size:1rem;background:#fff}
.sgr-form textarea{min-height:150px;resize:vertical}
.sgr-form .hp{position:absolute;left:-9999px}
.form-notice{padding:14px 18px;border-radius:10px;margin-bottom:20px;font-size:.96rem}
.form-notice.ok{background:#e6f4ef;color:#1d6b54;border:1px solid #b9e2d3}
.form-notice.err{background:#fcebe6;color:#b1442a;border:1px solid #f3c6ba}

/* FAQ accordion */
.faq{max-width:840px;margin:0 auto;display:flex;flex-direction:column;gap:14px}
.faq__item{background:#fff;border:1px solid var(--sgr-line);border-radius:var(--sgr-radius);overflow:hidden}
.faq__q{width:100%;text-align:left;background:none;border:0;cursor:pointer;padding:20px 24px;font:inherit;font-weight:600;font-size:1.05rem;color:var(--sgr-ink);display:flex;justify-content:space-between;align-items:center;gap:16px}
.faq__q::after{content:"+";font-size:1.5rem;color:var(--sgr-clay);transition:transform .2s}
.faq__item.open .faq__q::after{transform:rotate(45deg)}
.faq__a{padding:0 24px;max-height:0;overflow:hidden;transition:max-height .3s ease,padding .3s ease;color:var(--sgr-slate)}
.faq__item.open .faq__a{padding:0 24px 22px;max-height:600px}

/* =========================================================
   Footer
   ========================================================= */
.site-footer{background:var(--sgr-ink);color:#aebcc2;padding-top:70px}
.site-footer a{color:#cdd8dc}
.site-footer a:hover{color:#fff}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1.2fr 1fr;gap:40px;padding-bottom:50px;border-bottom:1px solid rgba(255,255,255,.1)}
.footer-grid h4{color:#fff;font-size:1.05rem;margin:0 0 1em}
.footer-brand img{height:64px;background:#fff;border-radius:12px;padding:8px;margin-bottom:16px}
.footer-grid ul{list-style:none;padding:0;margin:0}
.footer-grid li{padding:6px 0}
.footer-contact span{display:block;margin-bottom:12px;color:#aebcc2}
.footer-social{display:flex;gap:14px;margin-top:14px}
.footer-social a{width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.08);display:grid;place-items:center}
.footer-social a:hover{background:var(--sgr-clay)}
.footer-social svg{width:18px;height:18px}
.footer-bottom{display:flex;flex-wrap:wrap;gap:10px 20px;justify-content:space-between;padding:22px 0;font-size:.86rem}

/* =========================================================
   Pagination & misc
   ========================================================= */
.pagination{display:flex;gap:8px;justify-content:center;margin-top:46px}
.pagination .page-numbers{padding:10px 16px;border:1px solid var(--sgr-line);border-radius:10px;color:var(--sgr-ink)}
.pagination .current{background:var(--sgr-petrol);color:#fff;border-color:var(--sgr-petrol)}
.tag-pill{display:inline-block;background:var(--sgr-mist);color:var(--sgr-petrol);border-radius:999px;padding:5px 14px;font-size:.82rem;font-weight:600;margin:3px 4px 3px 0}

/* =========================================================
   Responsive
   ========================================================= */
@media(max-width:960px){
  .hero .container{grid-template-columns:1fr;padding-top:48px;padding-bottom:56px}
  .hero__media{order:-1}
  .quick__grid{grid-template-columns:1fr}
  .about__grid{grid-template-columns:1fr;gap:36px}
  .content-wrap{grid-template-columns:1fr}
  .sidebar{position:static}
  .footer-grid{grid-template-columns:1fr 1fr}
  .cta-band{grid-template-columns:1fr;padding:34px;text-align:center}
  .section{padding:60px 0}
}
@media(max-width:760px){
  .main-nav{position:fixed;inset:78px 0 auto 0;background:#fff;border-bottom:1px solid var(--sgr-line);padding:14px 22px;display:none;box-shadow:var(--sgr-shadow)}
  .main-nav.open{display:block}
  .main-nav ul{flex-direction:column;align-items:stretch;gap:2px}
  .main-nav .sub-menu{position:static;box-shadow:none;border:0;padding:0 0 0 14px;display:flex}
  .nav-toggle{display:block}
  .topbar__info{display:none}
  .sgr-form .row{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .header-actions .btn{display:none}
}
