/*
Theme Name: Guia de Linhares
Theme URI: https://guiadelinhares.com.br
Description: Tema premium, clean, minimalista e performático para o Guia de Linhares, integrado ao Ecossistema Digital Guinar Online.
Version: 2.0.0 - PREMIUM CLEAN SYSTEM
Author: Guinar Online
Text Domain: guia-de-linhares
*/

/* ==========================================================================
   GUIA DE LINHARES — STYLE.CSS PREMIUM 10/10
   Sistema único, limpo e consolidado.
   Sem herança visual de Guarapari.
   Sem azul antigo.
   Sem excesso de !important.
   Foco: Linhares como cidade polo regional, negócios, serviços,
   empregos, eventos, lagoas, agro, indústria, comércio e utilidade local.
   ========================================================================== */


/* ==========================================================================
   01. TOKENS — PALETA, TIPOGRAFIA, ESPAÇAMENTO
   ========================================================================== */

:root{
  /* Base */
  --lin-bg:#f6f1e8;
  --lin-bg-soft:#efe5d3;
  --lin-paper:#fffdf8;
  --lin-paper-soft:#fbf5e8;

  /* Texto */
  --lin-ink:#101713;
  --lin-text:#2f3934;
  --lin-muted:#68716c;
  --lin-soft:#8a918c;
  --lin-line:rgba(16,23,19,.11);

  /* Identidade */
  --lin-forest:#123b31;
  --lin-forest-dark:#0b211c;
  --lin-forest-soft:#e8f1ed;
  --lin-lake:#3f6f7d;
  --lin-clay:#9d6847;

  /* Destaque */
  --lin-gold:#c79b45;
  --lin-gold-soft:#f2ddb0;
  --lin-gold-pale:#fff3d4;

  /* Estado */
  --lin-success:#174837;
  --lin-danger:#7c2d12;
  --lin-warning:#7b5515;

  /* Medidas */
  --lin-container:1180px;
  --lin-container-wide:1320px;

  /* Radius */
  --lin-radius-xs:10px;
  --lin-radius-sm:14px;
  --lin-radius:20px;
  --lin-radius-lg:28px;
  --lin-radius-xl:36px;
  --lin-pill:999px;

  /* Sombras */
  --lin-shadow-xs:0 4px 14px rgba(20,35,28,.035);
  --lin-shadow-sm:0 10px 28px rgba(20,35,28,.045);
  --lin-shadow:0 18px 48px rgba(20,35,28,.075);
  --lin-shadow-lg:0 26px 78px rgba(20,35,28,.115);
  --lin-shadow-dark:0 24px 70px rgba(0,0,0,.20);

  /* Tipografia */
  --lin-font:Inter,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,sans-serif;
  --lin-display:Inter,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,sans-serif;

  --lin-h1:clamp(3rem,5.4vw,5.55rem);
  --lin-h2:clamp(2.05rem,3.7vw,3.75rem);
  --lin-h3:clamp(1.24rem,1.45vw,1.55rem);
  --lin-lead:clamp(1.06rem,1.25vw,1.25rem);

  /* Motion */
  --lin-ease:cubic-bezier(.22,.61,.36,1);
  --lin-transition:180ms var(--lin-ease);
}


/* ==========================================================================
   02. RESET E BASE
   ========================================================================== */

*,
*::before,
*::after{
  box-sizing:border-box;
}

html{
  scroll-behavior:smooth;
  scroll-padding-top:90px;
  -webkit-text-size-adjust:100%;
}

body{
  margin:0;
  min-height:100vh;
  font-family:var(--lin-font);
  font-size:16px;
  line-height:1.65;
  color:var(--lin-text);
  background:
    radial-gradient(circle at 12% 8%,rgba(18,59,49,.055),transparent 28%),
    radial-gradient(circle at 90% 12%,rgba(199,155,69,.105),transparent 30%),
    linear-gradient(180deg,#fffdf8 0%,var(--lin-bg) 54%,var(--lin-bg-soft) 100%);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
}

img,
svg,
video,
canvas{
  max-width:100%;
  height:auto;
  display:block;
}

img{
  opacity:1;
  visibility:visible;
}

button,
input,
select,
textarea{
  font:inherit;
}

button{
  cursor:pointer;
}

a{
  color:var(--lin-forest);
  text-decoration-thickness:1px;
  text-underline-offset:3px;
  transition:
    color var(--lin-transition),
    background var(--lin-transition),
    border-color var(--lin-transition),
    transform var(--lin-transition),
    box-shadow var(--lin-transition);
}

a:hover{
  color:var(--lin-forest-dark);
}

::selection{
  background:rgba(199,155,69,.32);
  color:var(--lin-ink);
}

:focus-visible{
  outline:3px solid rgba(199,155,69,.55);
  outline-offset:3px;
}


/* ==========================================================================
   03. TIPOGRAFIA
   ========================================================================== */

h1,h2,h3,h4,h5,h6{
  margin:0 0 1rem;
  font-family:var(--lin-display);
  color:var(--lin-ink);
  font-weight:740;
  line-height:1.04;
  letter-spacing:-.055em;
  text-wrap:balance;
}

h1{
  font-size:var(--lin-h1);
  line-height:.98;
}

h2{
  font-size:var(--lin-h2);
  line-height:1.01;
}

h3{
  font-size:var(--lin-h3);
  line-height:1.14;
  letter-spacing:-.038em;
}

p{
  margin:0 0 1rem;
  color:var(--lin-text);
}

strong{
  color:var(--lin-ink);
  font-weight:760;
}


/* ==========================================================================
   04. LAYOUT
   ========================================================================== */

.site-wrapper{
  min-height:100vh;
  display:flex;
  flex-direction:column;
}

.site-main{
  flex:1;
}

.container,
.guia-container{
  width:min(var(--lin-container),calc(100% - 40px));
  margin-inline:auto;
}

.container-wide,
.guia-container-wide{
  width:min(var(--lin-container-wide),calc(100% - 40px));
  margin-inline:auto;
}

.section,
.lin-section,
.gl-section{
  padding:clamp(58px,7vw,96px) 0;
}

.section.alt,
.lin-section.alt,
.gl-section.alt{
  background:rgba(255,253,248,.42);
  border-block:1px solid rgba(16,23,19,.06);
}


/* ==========================================================================
   05. HEADER
   ========================================================================== */

.site-header{
  position:sticky;
  top:0;
  left:0;
  right:0;
  z-index:10000;
  width:100%;
  background:rgba(255,253,248,.94);
  border-bottom:1px solid var(--lin-line);
  box-shadow:0 8px 30px rgba(20,35,28,.055);
  backdrop-filter:blur(18px);
}

.admin-bar .site-header{
  top:32px;
}

.header-inner,
.site-header .container,
.site-header .guia-container{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:22px;
  min-height:76px;
}

.site-branding{
  flex:0 0 auto;
  display:flex;
  align-items:center;
}

.site-branding a{
  display:flex;
  align-items:center;
  text-decoration:none;
}

.custom-logo,
.site-logo,
.site-branding img{
  width:auto;
  height:auto;
  max-height:58px;
  max-width:214px;
  object-fit:contain;
}

.main-navigation{
  flex:1 1 auto;
}

.main-navigation ul{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:4px;
  margin:0;
  padding:0;
  list-style:none;
}

.main-navigation li{
  position:relative;
  margin:0;
}

.main-navigation a{
  display:flex;
  align-items:center;
  min-height:42px;
  padding:9px 14px;
  border-radius:14px;
  color:rgba(16,23,19,.80);
  font-weight:660;
  font-size:.96rem;
  text-decoration:none;
  white-space:nowrap;
}

.main-navigation a:hover,
.main-navigation .current-menu-item > a,
.main-navigation .current_page_item > a{
  color:var(--lin-forest);
  background:rgba(18,59,49,.075);
}

.main-navigation .sub-menu{
  position:absolute;
  top:calc(100% + 8px);
  left:0;
  display:block;
  min-width:230px;
  padding:8px;
  border-radius:18px;
  background:rgba(255,253,248,.98);
  border:1px solid var(--lin-line);
  box-shadow:var(--lin-shadow-lg);
  opacity:0;
  visibility:hidden;
  transform:translateY(8px);
  transition:opacity var(--lin-transition),transform var(--lin-transition),visibility var(--lin-transition);
  z-index:10001;
}

.main-navigation li:hover > .sub-menu,
.main-navigation li:focus-within > .sub-menu{
  opacity:1;
  visibility:visible;
  transform:translateY(0);
}

.main-navigation .sub-menu a{
  justify-content:flex-start;
  border-radius:12px;
  white-space:normal;
}

.header-login,
.guia-user-menu{
  flex:0 0 auto;
}

.header-login a,
.guia-user-link{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:44px;
  padding:10px 16px;
  border-radius:14px;
  background:#f4f8fb;
  border:1px solid rgba(63,111,125,.16);
  color:#26312d;
  font-weight:700;
  text-decoration:none;
  box-shadow:none;
}


/* ==========================================================================
   06. MOBILE MENU
   ========================================================================== */

.mobile-menu-toggle,
.menu-toggle,
.nav-toggle,
button[aria-controls="primary-menu"]{
  display:none;
  align-items:center;
  justify-content:center;
  width:48px;
  height:48px;
  min-width:48px;
  min-height:48px;
  border:1px solid rgba(240,211,139,.42);
  border-radius:16px;
  background:var(--lin-forest-dark);
  color:#fffaf1;
  box-shadow:0 12px 28px rgba(17,24,21,.16);
  position:relative;
  overflow:hidden;
  font-size:0;
}

.mobile-menu-toggle::before,
.mobile-menu-toggle::after,
.menu-toggle::before,
.menu-toggle::after,
.nav-toggle::before,
.nav-toggle::after,
button[aria-controls="primary-menu"]::before,
button[aria-controls="primary-menu"]::after{
  content:"";
  position:absolute;
  left:50%;
  width:22px;
  height:2px;
  background:#fffaf1;
  border-radius:999px;
  transform:translateX(-50%);
  transition:transform var(--lin-transition),top var(--lin-transition),bottom var(--lin-transition),opacity var(--lin-transition);
}

.mobile-menu-toggle::before,
.menu-toggle::before,
.nav-toggle::before,
button[aria-controls="primary-menu"]::before{
  top:16px;
}

.mobile-menu-toggle::after,
.menu-toggle::after,
.nav-toggle::after,
button[aria-controls="primary-menu"]::after{
  bottom:16px;
}

.mobile-menu-toggle span:not(.screen-reader-text),
.menu-toggle span:not(.screen-reader-text),
.nav-toggle span:not(.screen-reader-text),
button[aria-controls="primary-menu"] span:not(.screen-reader-text){
  position:absolute;
  left:50%;
  top:50%;
  width:22px;
  height:2px;
  background:#fffaf1;
  border-radius:999px;
  transform:translate(-50%,-50%);
  transition:opacity var(--lin-transition);
}

.mobile-menu-toggle[aria-expanded="true"]::before,
.menu-toggle[aria-expanded="true"]::before,
.nav-toggle[aria-expanded="true"]::before,
button[aria-controls="primary-menu"][aria-expanded="true"]::before{
  top:23px;
  transform:translateX(-50%) rotate(45deg);
}

.mobile-menu-toggle[aria-expanded="true"]::after,
.menu-toggle[aria-expanded="true"]::after,
.nav-toggle[aria-expanded="true"]::after,
button[aria-controls="primary-menu"][aria-expanded="true"]::after{
  bottom:23px;
  transform:translateX(-50%) rotate(-45deg);
}

.mobile-menu-toggle[aria-expanded="true"] span:not(.screen-reader-text),
.menu-toggle[aria-expanded="true"] span:not(.screen-reader-text),
.nav-toggle[aria-expanded="true"] span:not(.screen-reader-text),
button[aria-controls="primary-menu"][aria-expanded="true"] span:not(.screen-reader-text){
  opacity:0;
}


/* ==========================================================================
   07. HERO / HOME PREMIUM
   ========================================================================== */

.gl-home-premium{
  color:var(--lin-text);
}

.gl-hero,
.lin-hero,
.guia-hero-section{
  position:relative;
  overflow:hidden;
  padding:clamp(74px,8vw,118px) 0 clamp(56px,7vw,88px);
  color:#fffaf1;
  background:
    radial-gradient(circle at 78% 18%,rgba(199,155,69,.20),transparent 30%),
    radial-gradient(circle at 23% 86%,rgba(63,111,125,.18),transparent 28%),
    linear-gradient(135deg,#0c1714 0%,#123b31 52%,#34281f 100%);
}

.gl-hero-bg,
.gl-hero::before,
.lin-hero::before,
.guia-hero-section::before{
  content:"";
  position:absolute;
  inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.035) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.035) 1px,transparent 1px);
  background-size:84px 84px;
  mask-image:linear-gradient(90deg,rgba(0,0,0,.38),rgba(0,0,0,.94));
  pointer-events:none;
  opacity:.72;
}

.gl-hero-grid{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(280px,360px);
  gap:clamp(32px,6vw,78px);
  align-items:center;
}

.gl-hero-content,
.guia-hero-content,
.lin-hero .guia-container{
  position:relative;
  z-index:1;
}

.gl-kicker,
.gl-label,
.lin-kicker,
.section-label{
  display:inline-flex;
  align-items:center;
  gap:8px;
  color:#f5d990;
  font-size:.76rem;
  font-weight:820;
  letter-spacing:.155em;
  text-transform:uppercase;
}

.gl-kicker::before,
.gl-label::before,
.lin-kicker::before,
.section-label::before{
  content:"✦";
  color:#f5d990;
}

.gl-title,
.lin-hero h1,
.guia-hero-title{
  max-width:880px;
  margin:.7rem 0 1.1rem;
  color:#fffaf1;
  font-size:var(--lin-h1);
  line-height:.96;
  letter-spacing:-.073em;
  font-weight:760;
}

.gl-title span{
  color:var(--lin-gold-soft);
}

.gl-subtitle,
.lin-hero p,
.guia-hero-subtitle{
  max-width:760px;
  margin:0;
  color:rgba(255,250,241,.82);
  font-size:var(--lin-lead);
  line-height:1.72;
}


/* ==========================================================================
   08. BUSCA / FORMULÁRIOS
   ========================================================================== */

.gl-search,
.lin-quick-search,
.guia-hero-search form,
form.search-form{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  align-items:center;
  gap:8px;
  width:min(760px,100%);
  margin-top:30px;
  padding:8px;
  border-radius:999px;
  background:rgba(255,253,248,.97);
  border:1px solid rgba(255,255,255,.44);
  box-shadow:0 22px 60px rgba(0,0,0,.20);
}

.gl-search input,
.lin-quick-search input,
.guia-hero-search input,
form.search-form input[type="search"]{
  min-width:0;
  width:100%;
  min-height:56px;
  border:0;
  border-radius:999px;
  background:transparent;
  color:var(--lin-ink);
  padding:0 18px;
  outline:none;
  box-shadow:none;
}

input[type="search"],
input[type="text"],
input[type="email"],
input[type="tel"],
input[type="url"],
input[type="password"],
select,
textarea,
.form-input,
.form-select,
.form-textarea{
  width:100%;
  min-height:48px;
  border:1px solid var(--lin-line);
  border-radius:16px;
  background:#fff;
  color:var(--lin-ink);
  padding:12px 14px;
  outline:none;
  transition:border-color var(--lin-transition),box-shadow var(--lin-transition);
}

textarea{
  min-height:136px;
  resize:vertical;
}

input:focus,
select:focus,
textarea:focus{
  border-color:rgba(199,155,69,.58);
  box-shadow:0 0 0 4px rgba(199,155,69,.13);
}


/* ==========================================================================
   09. BOTÕES
   ========================================================================== */

.gl-search button,
.lin-quick-search button,
.guia-hero-search button,
form.search-form button,
.search-submit,
.gl-btn,
.guia-btn,
.btn,
.button,
.wp-block-button__link,
button[type="submit"]{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:auto;
  min-width:132px;
  min-height:52px;
  margin:0;
  padding:13px 22px;
  border:1px solid rgba(16,23,19,.10);
  border-radius:999px;
  background:linear-gradient(135deg,var(--lin-gold-soft),var(--lin-gold));
  color:var(--lin-ink);
  font-weight:760;
  text-decoration:none;
  white-space:nowrap;
  box-shadow:0 12px 28px rgba(88,61,18,.13);
  transition:transform var(--lin-transition),box-shadow var(--lin-transition),filter var(--lin-transition);
}

.gl-search button:hover,
.lin-quick-search button:hover,
.search-submit:hover,
.gl-btn:hover,
.guia-btn:hover,
.btn:hover,
.button:hover,
.wp-block-button__link:hover,
button[type="submit"]:hover{
  transform:translateY(-1px);
  filter:brightness(.985);
  box-shadow:0 16px 36px rgba(88,61,18,.18);
}

.gl-btn.secondary,
.guia-btn.secondary{
  background:rgba(255,255,255,.095);
  color:#fffaf1;
  border:1px solid rgba(255,255,255,.24);
  box-shadow:none;
}

.gl-hero-actions{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin-top:18px;
}


/* ==========================================================================
   10. STATS
   ========================================================================== */

.gl-hero-side{
  display:grid;
  gap:14px;
}

.gl-stat-card{
  padding:22px;
  border-radius:26px;
  background:rgba(255,253,248,.115);
  border:1px solid rgba(255,255,255,.16);
  box-shadow:0 18px 44px rgba(0,0,0,.14);
  backdrop-filter:blur(14px);
}

.gl-stat-card strong{
  display:block;
  color:#fffaf1;
  font-size:clamp(1.8rem,2.7vw,2.55rem);
  line-height:1;
  letter-spacing:-.045em;
  font-weight:760;
}

.gl-stat-card span{
  display:block;
  margin-top:8px;
  color:rgba(255,250,241,.78);
  line-height:1.42;
}


/* ==========================================================================
   11. CABEÇALHOS DE SEÇÃO
   ========================================================================== */

.gl-section-head,
.lin-section-head,
.section-header{
  display:flex;
  justify-content:space-between;
  align-items:end;
  gap:28px;
  margin-bottom:30px;
}

.gl-section-head h2,
.lin-section-head h2,
.section-title,
.gl-editorial h2{
  margin:8px 0 0;
  color:var(--lin-ink);
  font-size:var(--lin-h2);
  line-height:1.01;
  font-weight:740;
  letter-spacing:-.064em;
}

.gl-section-head p,
.lin-section-head p,
.section-subtitle{
  max-width:560px;
  margin:0;
  color:var(--lin-muted);
  font-size:1.02rem;
  line-height:1.72;
}


/* ==========================================================================
   12. CARDS / GRIDS
   ========================================================================== */

.gl-grid,
.gl-list-grid,
.lin-card-grid,
.lin-list-grid,
.guia-cards-grid,
.guia-empresas-grid,
.guia-empresas-destaque-grid,
.guia-eventos-grid,
.guia-blog-grid,
.guia-vagas-grid,
.guia-related-grid,
.guia-widget-grid,
.guinar-ecosystem-grid,
.gl-pricing-grid,
.gl-essential-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:18px;
}

.gl-card,
.gl-list-card,
.lin-card,
.lin-list-item,
.guia-card,
.gd-top-card,
.gd-event-card,
.empresa-card,
.empresa-card-home,
.evento-card,
.blog-card,
.vaga-card,
.related-card,
.widget-card,
.category-card,
.lazer-card,
.guinar-ecosystem-card,
.gl-pricing-card,
.gl-essential-card{
  display:flex;
  flex-direction:column;
  min-height:210px;
  padding:24px;
  border-radius:28px;
  background:rgba(255,253,248,.95);
  border:1px solid var(--lin-line);
  color:var(--lin-text);
  text-decoration:none;
  box-shadow:var(--lin-shadow-sm);
  transition:transform var(--lin-transition),box-shadow var(--lin-transition),border-color var(--lin-transition);
}

.gl-card:hover,
.gl-list-card:hover,
.lin-card:hover,
.lin-list-item:hover,
.guia-card:hover,
.gd-top-card:hover,
.gd-event-card:hover,
.empresa-card:hover,
.empresa-card-home:hover,
.evento-card:hover,
.blog-card:hover,
.vaga-card:hover,
.related-card:hover,
.widget-card:hover,
.category-card:hover,
.lazer-card:hover,
.guinar-ecosystem-card:hover,
.gl-pricing-card:hover,
.gl-essential-card:hover{
  transform:translateY(-3px);
  border-color:rgba(18,59,49,.22);
  box-shadow:var(--lin-shadow);
}

.gl-card span,
.lin-card span,
.guinar-ecosystem-tag,
.gl-essential-card span,
.guia-card-category,
.post-category,
.guia-categoria-badge{
  display:inline-flex;
  width:max-content;
  max-width:100%;
  margin-bottom:14px;
  padding:7px 11px;
  border-radius:999px;
  background:rgba(18,59,49,.085);
  color:var(--lin-forest);
  border:1px solid rgba(18,59,49,.08);
  font-size:.74rem;
  font-weight:820;
  letter-spacing:.08em;
  text-transform:uppercase;
}

.gl-card h3,
.gl-list-card h3,
.lin-card h3,
.lin-list-item h3,
.guia-card-title,
.gd-card-title,
.gd-event-title,
.blog-title,
.vaga-card .guia-card-title,
.related-card .guia-card-title,
.widget-card .guia-card-title{
  margin:0 0 10px;
  color:var(--lin-ink);
  font-size:var(--lin-h3);
  line-height:1.14;
  letter-spacing:-.038em;
  font-weight:740;
}

.gl-card p,
.gl-list-card p,
.lin-card p,
.lin-list-item p,
.guinar-ecosystem-card p,
.gl-essential-card p{
  margin:0;
  color:var(--lin-muted);
  line-height:1.68;
}

.gl-card strong,
.lin-card strong,
.gl-essential-card strong,
.guinar-ecosystem-card strong{
  margin-top:auto;
  padding-top:18px;
  color:var(--lin-forest);
  font-weight:760;
}

.gl-card strong a,
.lin-card strong a{
  color:inherit;
  text-decoration:none;
}

.gl-list-card,
.lin-list-item{
  min-height:174px;
}

.guia-card-header,
.gd-event-thumb,
.blog-image,
.guia-card-thumbnail{
  position:relative;
  overflow:hidden;
  border-radius:22px;
  margin:-6px -6px 16px;
  background:var(--lin-paper-soft);
}

.guia-card-thumbnail,
.gd-event-thumb,
.blog-image{
  height:170px;
}

.guia-card-thumbnail img,
.gd-event-image,
.blog-image img,
.wp-post-image{
  width:100%;
  height:100%;
  object-fit:cover;
}


/* ==========================================================================
   13. EDITORIAL / HUB
   ========================================================================== */

.gl-editorial{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(280px,420px);
  gap:clamp(26px,5vw,64px);
  align-items:center;
  padding:clamp(30px,5vw,56px);
  border-radius:34px;
  background:
    radial-gradient(circle at 90% 12%,rgba(199,155,69,.13),transparent 30%),
    rgba(255,253,248,.90);
  border:1px solid var(--lin-line);
  box-shadow:var(--lin-shadow);
}

.gl-editorial-content p{
  max-width:720px;
  color:var(--lin-muted);
  line-height:1.76;
  font-size:1.08rem;
}

.gl-editorial-box{
  display:grid;
  gap:12px;
}

.gl-editorial-box div{
  padding:18px;
  border-radius:22px;
  background:var(--lin-paper-soft);
  border:1px solid rgba(199,155,69,.18);
}

.gl-editorial-box strong{
  display:block;
  color:var(--lin-ink);
  font-weight:760;
}

.gl-editorial-box span{
  display:block;
  margin-top:4px;
  color:var(--lin-muted);
  line-height:1.45;
}


/* ==========================================================================
   14. STATUS / BADGES / EMPTY STATES
   ========================================================================== */

.empresa-status.aberto,
.status-aberto,
.badge-aberto{
  background:#e8f5ee;
  color:var(--lin-success);
  border:1px solid rgba(32,68,55,.18);
}

.empresa-status.fechado,
.status-fechado,
.badge-fechado{
  background:#fff0e8;
  color:var(--lin-danger);
  border:1px solid rgba(124,45,18,.16);
}

.plano-badge{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:7px 12px;
  border-radius:999px;
  background:#fff8e7;
  color:#3c2b0c;
  border:1px solid rgba(123,85,21,.16);
  font-size:.75rem;
  font-weight:700;
  box-shadow:var(--lin-shadow-xs);
}

.gl-empty,
.lin-empty,
.guia-sem-empresas-destaque,
.guia-sem-resultados{
  padding:22px;
  border:1px solid rgba(123,85,21,.24);
  border-radius:22px;
  background:#fff8e7;
  color:#3c2b0c;
  font-weight:700;
}


/* ==========================================================================
   15. FOOTER
   ========================================================================== */

.site-footer{
  background:#0b1512;
  color:rgba(255,250,241,.80);
  padding:clamp(42px,6vw,78px) 0 28px;
  border-top:1px solid rgba(255,255,255,.08);
}

.footer-content{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:28px;
}

.site-footer h3,
.site-footer h4,
.footer-section h3,
.footer-section h4{
  color:#fffaf1;
  margin-bottom:1rem;
  font-size:1.08rem;
  letter-spacing:-.025em;
}

.site-footer p,
.site-footer li,
.site-footer span{
  color:rgba(255,250,241,.74);
}

.site-footer ul{
  list-style:none;
  margin:0;
  padding:0;
}

.site-footer li{
  margin-bottom:.55rem;
}

.site-footer a{
  color:#f0d38b;
  text-decoration:none;
}

.site-footer a:hover{
  color:#fff1bd;
}

.footer-bottom,
.guinar-hub-footer{
  margin-top:28px;
  padding-top:24px;
  border-top:1px solid rgba(255,255,255,.10);
  text-align:center;
}


/* ==========================================================================
   16. DEBUG / LIMPEZA
   ========================================================================== */

.guia-debug,
.guia-debug-box,
#guia-debug,
#guia-debug-box,
.debug-box,
.debug-panel,
[class*="debug"]{
  display:none;
  visibility:hidden;
  opacity:0;
  pointer-events:none;
}


/* ==========================================================================
   17. WORDPRESS HELPERS
   ========================================================================== */

.alignwide{
  width:min(var(--lin-container-wide),calc(100% - 40px));
  margin-inline:auto;
}

.alignfull{
  width:100%;
  margin-inline:0;
}

.wp-caption{
  max-width:100%;
}

.wp-caption-text{
  color:var(--lin-muted);
  font-size:.9rem;
  margin-top:.5rem;
}

.screen-reader-text,
.sr-only{
  position:absolute;
  width:1px;
  height:1px;
  padding:0;
  margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap;
  border:0;
}


/* ==========================================================================
   18. RESPONSIVO
   ========================================================================== */

@media(max-width:1100px){
  .main-navigation a{
    padding-inline:10px;
    font-size:.92rem;
  }
}

@media(max-width:980px){
  .gl-hero-grid,
  .gl-editorial{
    grid-template-columns:1fr;
  }

  .gl-hero-side{
    grid-template-columns:repeat(3,minmax(0,1fr));
  }

  .gl-section-head,
  .lin-section-head,
  .section-header{
    display:block;
  }

  .gl-section-head p,
  .lin-section-head p,
  .section-subtitle{
    margin-top:12px;
  }
}

@media(max-width:900px){
  .gl-grid,
  .gl-list-grid,
  .lin-card-grid,
  .lin-list-grid,
  .guia-cards-grid,
  .guia-empresas-grid,
  .guia-empresas-destaque-grid,
  .guia-eventos-grid,
  .guia-blog-grid,
  .guia-vagas-grid,
  .guia-related-grid,
  .guia-widget-grid,
  .guinar-ecosystem-grid,
  .gl-pricing-grid,
  .gl-essential-grid{
    grid-template-columns:1fr;
  }
}

@media(max-width:768px){
  html.menu-open,
  body.menu-open{
    overflow:hidden;
  }

  .admin-bar .site-header{
    top:46px;
  }

  .header-inner,
  .site-header .container,
  .site-header .guia-container{
    min-height:70px;
  }

  .main-navigation{
    display:none;
  }

  .mobile-menu-toggle,
  .menu-toggle,
  .nav-toggle,
  button[aria-controls="primary-menu"]{
    display:flex;
  }

  .main-navigation.active{
    display:block;
    position:fixed;
    top:70px;
    left:0;
    right:0;
    bottom:0;
    z-index:9999;
    padding:18px 22px 46px;
    background:rgba(255,253,248,.99);
    overflow-y:auto;
    overflow-x:hidden;
    -webkit-overflow-scrolling:touch;
    overscroll-behavior:contain;
    box-shadow:0 18px 52px rgba(17,24,21,.14);
  }

  .admin-bar .main-navigation.active{
    top:116px;
  }

  .main-navigation.active ul{
    display:block;
    margin:0;
    padding:0;
  }

  .main-navigation.active li{
    display:block;
  }

  .main-navigation.active a{
    display:flex;
    align-items:center;
    min-height:48px;
    padding:13px 0;
    border-bottom:1px solid var(--lin-line);
    color:var(--lin-ink);
    font-weight:760;
    border-radius:0;
  }

  .main-navigation.active .sub-menu{
    opacity:1;
    visibility:visible;
    transform:none;
    position:static;
    min-width:0;
    margin:0 0 6px 14px;
    padding:0 0 0 12px;
    border:0;
    border-left:1px solid rgba(199,155,69,.34);
    border-radius:0;
    box-shadow:none;
    background:transparent;
  }

  .main-navigation.active .sub-menu a{
    min-height:42px;
    color:#3f4a45;
    font-weight:700;
  }

  .header-login,
  .guia-user-menu{
    display:none;
  }

  .gl-title,
  .lin-hero h1,
  .guia-hero-title{
    font-size:clamp(2.65rem,13vw,4.35rem);
    line-height:.98;
  }

  .gl-search,
  .lin-quick-search,
  .guia-hero-search form,
  form.search-form{
    grid-template-columns:1fr;
    border-radius:26px;
  }

  .gl-search button,
  .lin-quick-search button,
  .guia-hero-search button,
  form.search-form button,
  .search-submit{
    width:100%;
  }

  .gl-hero-side{
    grid-template-columns:1fr;
  }

  .gl-hero,
  .lin-hero,
  .guia-hero-section{
    padding-top:54px;
  }
}

@media(max-width:640px){
  .container,
  .guia-container,
  .container-wide,
  .guia-container-wide{
    width:min(100% - 24px,var(--lin-container));
  }

  .custom-logo,
  .site-logo,
  .site-branding img{
    max-height:48px;
    max-width:174px;
  }

  .section,
  .lin-section,
  .gl-section{
    padding:48px 0;
  }

  .gl-card,
  .gl-list-card,
  .lin-card,
  .lin-list-item{
    padding:20px;
    border-radius:24px;
  }
}


/* ==========================================================================
   19. ACESSIBILIDADE / PERFORMANCE
   ========================================================================== */

@media(prefers-reduced-motion:reduce){
  *,
  *::before,
  *::after{
    animation-duration:.001ms;
    animation-iteration-count:1;
    scroll-behavior:auto;
    transition-duration:.001ms;
  }
}

@media print{
  .site-header,
  .site-footer,
  .mobile-menu-toggle,
  .gl-hero-actions{
    display:none;
  }

  body{
    background:#fff;
    color:#000;
  }
}



/* ==========================================================================
   FOOTER PREMIUM 10/10 — GUIA DE LINHARES
   Cole no style.css. Não usar CSS inline no footer.php.
   ========================================================================== */

.gl-footer{
  position:relative;
  overflow:hidden;
  margin-top:clamp(52px,7vw,88px);
  padding:clamp(54px,7vw,84px) 0 28px;
  background:
    radial-gradient(circle at 15% 0%,rgba(199,155,69,.10),transparent 28%),
    radial-gradient(circle at 90% 15%,rgba(63,111,125,.10),transparent 30%),
    linear-gradient(180deg,#0e1915 0%,#09110f 100%);
  color:rgba(255,250,241,.78);
  border-top:1px solid rgba(255,255,255,.08);
}

.gl-footer::before{
  content:"";
  position:absolute;
  inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.035) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);
  background-size:78px 78px;
  mask-image:linear-gradient(180deg,rgba(0,0,0,.55),rgba(0,0,0,.05));
  pointer-events:none;
}

.gl-footer .guia-container{
  position:relative;
  z-index:1;
}

.gl-footer-top{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  align-items:end;
  gap:28px;
  padding-bottom:34px;
  border-bottom:1px solid rgba(255,255,255,.10);
}

.gl-footer-kicker{
  display:inline-flex;
  margin-bottom:14px;
  color:#f0d38b;
  font-size:.74rem;
  font-weight:820;
  letter-spacing:.155em;
  text-transform:uppercase;
}

.gl-footer-brand h2{
  max-width:760px;
  margin:0 0 14px;
  color:#fffaf1;
  font-size:clamp(1.9rem,3.3vw,3.25rem);
  line-height:1.04;
  letter-spacing:-.055em;
  font-weight:740;
  text-wrap:balance;
}

.gl-footer-brand p{
  max-width:660px;
  margin:0;
  color:rgba(255,250,241,.70);
  line-height:1.72;
}

.gl-footer-cta{
  display:flex;
  flex-wrap:wrap;
  justify-content:flex-end;
  gap:10px;
}

.gl-footer-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:46px;
  padding:12px 18px;
  border-radius:999px;
  background:linear-gradient(135deg,#f2ddb0,#c79b45);
  color:#101713!important;
  font-weight:760;
  text-decoration:none!important;
  white-space:nowrap;
  border:1px solid rgba(255,255,255,.16);
  box-shadow:0 12px 30px rgba(0,0,0,.14);
}

.gl-footer-btn.secondary{
  background:rgba(255,255,255,.07);
  color:#fffaf1!important;
  border:1px solid rgba(255,255,255,.16);
  box-shadow:none;
}

.gl-footer-btn:hover{
  transform:translateY(-1px);
}

.gl-footer-grid{
  display:grid;
  grid-template-columns:1.05fr 1fr 1.05fr 1.35fr;
  gap:clamp(24px,4vw,46px);
  padding:34px 0;
}

.gl-footer-section h3{
  margin:0 0 15px;
  color:#fffaf1;
  font-size:1rem;
  line-height:1.2;
  letter-spacing:-.015em;
  font-weight:760;
}

.gl-footer-section p{
  margin:0;
  color:rgba(255,250,241,.68);
  font-size:.95rem;
  line-height:1.72;
}

.gl-footer-menu{
  display:grid;
  gap:9px;
  margin:0;
  padding:0;
  list-style:none;
}

.gl-footer-menu a,
.gl-footer-contact a,
.gl-footer-link,
.gl-footer-legal a{
  color:rgba(255,250,241,.72);
  text-decoration:none;
  transition:color .18s ease,transform .18s ease;
}

.gl-footer-menu a:hover,
.gl-footer-contact a:hover,
.gl-footer-link:hover,
.gl-footer-legal a:hover{
  color:#f0d38b;
}

.gl-footer-contact{
  display:grid;
  gap:8px;
  margin:0;
  font-style:normal;
  color:rgba(255,250,241,.72);
}

.gl-footer-contact span{
  color:rgba(255,250,241,.82);
  font-weight:700;
}

.gl-footer-social{
  margin-top:18px;
}

.gl-footer-social a{
  display:inline-flex;
  align-items:center;
  gap:9px;
  min-height:42px;
  padding:9px 14px;
  border-radius:999px;
  background:rgba(255,255,255,.065);
  color:rgba(255,250,241,.84);
  border:1px solid rgba(255,255,255,.10);
  text-decoration:none;
  font-size:.92rem;
  font-weight:700;
}

.gl-footer-social a:hover{
  color:#fffaf1;
  background:rgba(255,255,255,.095);
  border-color:rgba(240,211,139,.24);
  transform:translateY(-1px);
}

.gl-footer-ecosystem{
  padding:20px;
  border-radius:24px;
  background:rgba(255,255,255,.055);
  border:1px solid rgba(255,255,255,.10);
}

.gl-footer-ecosystem p{
  margin-bottom:14px;
}

.gl-footer-link{
  display:inline-flex;
  color:#f0d38b;
  font-weight:760;
}

.gl-footer-bottom{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  padding-top:24px;
  border-top:1px solid rgba(255,255,255,.10);
}

.gl-footer-bottom p{
  margin:0;
  color:rgba(255,250,241,.54);
  font-size:.88rem;
}

.gl-footer-legal{
  display:flex;
  flex-wrap:wrap;
  justify-content:flex-end;
  gap:14px;
}

.gl-footer-legal a{
  color:rgba(255,250,241,.58);
  font-size:.88rem;
}

@media(max-width:980px){
  .gl-footer-top{
    grid-template-columns:1fr;
  }

  .gl-footer-cta{
    justify-content:flex-start;
  }

  .gl-footer-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
}

@media(max-width:640px){
  .gl-footer{
    margin-top:48px;
    padding-top:44px;
  }

  .gl-footer-grid{
    grid-template-columns:1fr;
    gap:28px;
  }

  .gl-footer-bottom{
    display:grid;
    gap:12px;
  }

  .gl-footer-legal{
    justify-content:flex-start;
  }

  .gl-footer-btn{
    width:100%;
  }

  .gl-footer-cta{
    width:100%;
  }
}
