/* ============================================================
   Câmara Municipal de Novo Horizonte do Oeste
   Tema Azul Institucional - folha de estilo
   ============================================================ */
:root{
  --azul-escuro:#0b3c66;
  --azul:#13548f;
  --azul-claro:#2b73b8;
  --azul-bem-claro:#eaf2fb;
  --dourado:#c8a24a;
  --tinta:#1c2733;
  --cinza:#5d6b78;
  --linha:#dde6ef;
  --branco:#ffffff;
  --fundo:#f4f7fb;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:'Source Sans 3',Arial,sans-serif;
  color:var(--tinta);
  background:var(--fundo);
  line-height:1.6;
  font-size:16px;
  -webkit-font-smoothing:antialiased;
}
a{color:var(--azul);text-decoration:none}
a:hover{text-decoration:underline}
img{max-width:100%;height:auto}
h1,h2,h3,h4{font-family:'Lora',Georgia,serif;color:var(--azul-escuro);line-height:1.25}

#wrapper{max-width:1180px;margin:0 auto;background:var(--branco);box-shadow:0 0 40px rgba(11,60,102,.06)}

/* ---------- Cabeçalho ---------- */
header[role="banner"]{
  background:linear-gradient(135deg,var(--azul-escuro) 0%,var(--azul) 100%);
  border-bottom:4px solid var(--dourado);
}
#header-banner{position:relative;padding:22px 26px;display:flex;flex-wrap:wrap;align-items:center;gap:16px}
#portal-logo{display:inline-flex;align-items:center;flex:1 1 auto}
#portal-logo img{max-height:64px;width:auto}

/* ferramentas do topo */
#user{order:3;margin-left:auto}
#user ul{list-style:none;margin:0;padding:0;display:flex;gap:14px}
#user a{color:#dbe7f5;font-size:.86rem}
#user a:hover{color:#fff;text-decoration:none}
#siteactions{order:4;list-style:none;margin:0;padding:0;display:flex;gap:12px}
#siteactions li,#siteactions a{color:#cdddee;font-size:.82rem}

/* busca */
#search{order:5}
#search input[type="text"],#search input[type="search"]{
  border:none;border-radius:22px;padding:8px 14px;font-size:.9rem;outline:none;min-width:170px;
}
#search .searchButton{
  border:none;background:var(--dourado);color:#fff;border-radius:22px;
  padding:8px 14px;margin-left:-6px;cursor:pointer;font-family:FontAwesome;
}

/* menu principal */
#main-navigation{order:6;flex-basis:100%;margin-top:14px}
#main-navigation>ul{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap}
#main-navigation>ul>li{position:relative}
#main-navigation>ul>li>a{
  display:block;color:#eaf2fb;font-weight:600;font-size:.95rem;
  padding:12px 18px;border-radius:6px 6px 0 0;
}
#main-navigation>ul>li>a:hover{background:rgba(255,255,255,.12);color:#fff;text-decoration:none}
#main-navigation>ul>li.selected>a{background:var(--branco);color:var(--azul-escuro)}
/* submenus */
#main-navigation ul ul{
  list-style:none;margin:0;padding:6px 0;position:absolute;left:0;top:100%;
  background:var(--branco);min-width:230px;border:1px solid var(--linha);
  border-top:3px solid var(--dourado);box-shadow:0 12px 26px rgba(11,60,102,.16);
  z-index:50;display:none;
}
#main-navigation li:hover>ul{display:block}
#main-navigation ul ul a{display:block;color:var(--tinta);padding:9px 18px;font-size:.9rem}
#main-navigation ul ul a:hover{background:var(--azul-bem-claro);color:var(--azul);text-decoration:none}

/* ---------- Migalhas ---------- */
#portal-breadcrumbs{
  background:var(--azul-bem-claro);padding:11px 26px;font-size:.86rem;color:var(--cinza);
  border-bottom:1px solid var(--linha);
}
#portal-breadcrumbs a{color:var(--azul)}
.breadcrumbSeparator{color:#9fb4c9;margin:0 2px}

/* ---------- Layout em colunas ---------- */
#main{display:flex;gap:26px;padding:30px 26px;align-items:flex-start}
#main-content{flex:1 1 auto;min-width:0}
#column-one{flex:0 0 230px;order:-1}
#column-two{flex:0 0 250px}
.visualPadding{padding:0}

/* portlets */
.portlet{
  background:var(--branco);border:1px solid var(--linha);border-radius:10px;
  margin-bottom:20px;overflow:hidden;
}
.portletHeader{
  background:var(--azul);color:#fff;padding:11px 15px;font-weight:600;font-size:.95rem;
}
.portletHeader a,.portletHeader .tile{color:#fff !important;text-decoration:none}
.portletItem,.portletContent{padding:6px 6px}
.portlet ul{list-style:none;margin:0;padding:0}
.navTree li a{
  display:block;padding:8px 12px;border-radius:6px;color:var(--tinta);font-size:.92rem;
}
.navTree li a:hover{background:var(--azul-bem-claro);color:var(--azul);text-decoration:none}
.navTreeCurrentItem{background:var(--azul-bem-claro);color:var(--azul) !important;font-weight:600}
.navTreeLevel1{padding-left:12px}
.navTreeLevel2{padding-left:20px}

/* ---------- Conteúdo ---------- */
#main-content h1{font-size:2rem;margin:0 0 14px;padding-bottom:12px;border-bottom:3px solid var(--dourado);display:inline-block}
#main-content h2{font-size:1.5rem;margin:26px 0 10px}
#main-content h3{font-size:1.2rem;margin:20px 0 8px}
#main-content p{margin:0 0 14px}
#main-content a{color:var(--azul);font-weight:500}
#main-content img{border-radius:8px}
#main-content table{border-collapse:collapse;width:100%;margin:16px 0}
#main-content th{background:var(--azul);color:#fff;padding:10px 12px;text-align:left}
#main-content td{padding:10px 12px;border-bottom:1px solid var(--linha)}
#main-content tr:nth-child(even) td{background:var(--fundo)}
.documentFirstHeading{font-size:2rem;border-bottom:3px solid var(--dourado);padding-bottom:12px}

/* botões padrão Plone */
.context input[type="submit"],input.standalone,button.standalone,
input.context,a.standalone{
  background:var(--azul);color:#fff;border:none;border-radius:6px;
  padding:9px 18px;cursor:pointer;font-weight:600;
}
input.standalone:hover,a.standalone:hover{background:var(--azul-claro)}

/* ---------- Rodapé ---------- */
#footer-total{background:var(--azul-escuro);color:#dfe9f4;padding:28px 26px;font-size:.9rem}
#footer-total a{color:#fff;border-bottom:1px solid rgba(255,255,255,.4)}
.footer-item{margin-bottom:10px}
.colophon-logo{display:inline-block;margin-right:16px;vertical-align:middle}
.colophon-logo img{max-height:40px;width:auto}

/* ---------- Responsivo ---------- */
@media(max-width:980px){
  #main{flex-wrap:wrap}
  #column-one,#column-two{flex-basis:100%;order:0}
  #main-content{order:-1;flex-basis:100%}
}
@media(max-width:680px){
  #header-banner{padding:16px}
  #main-navigation>ul{flex-direction:column}
  #main-navigation>ul>li>a{border-radius:6px}
  #main-navigation ul ul{position:static;box-shadow:none;border:none;background:rgba(255,255,255,.08)}
  #main-navigation ul ul a{color:#eaf2fb}
  #user{margin-left:0}
  #main{padding:18px 16px}
  #main-content h1{font-size:1.6rem}
}

/* Some elementos de demonstração do tema base que não vêm do Plone */
#user li, #siteactions li { white-space:nowrap; }
