﻿/* ====== Design System / Tokens ====== */
:root{
  --bg:#f0f4ff; --bg-accent:#e3ebff; --surface:#ffffff;
  --text:#0a1e42; --muted:#4a5f8a; --border:#d0deff;
  --shadow:0 10px 25px rgba(10,30,66,.08);

  --primary-50:#e6f0ff; --primary-100:#cce0ff;
  --primary-600:#1e40af; --primary-700:#1a3694; --primary-800:#152d7a;

  --danger-50:#fff1f2; --danger-600:#ef4444; --danger-700:#dc2626;

  --tag:#e6f0ff; --tag-border:#b3d1ff;

  --radius-lg:16px; --radius-sm:10px;
  --pad:22px; --gap:16px;

  /* header */
  --header-h:100px;           /* ajuste de altura do topo */
  --sidebar-w:clamp(250px, 22vw, 360px); /* largura adapt├ível do menu lateral */
  --page-bg:#f0f4ff;
}

/* ====== Reset suave ====== */
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0; color:var(--text);
  font:16px/1.45 ui-sans-serif,-apple-system,system-ui,Segoe UI,Roboto,"Helvetica Neue",Arial,"Apple Color Emoji","Segoe UI Emoji";
  background:
    radial-gradient(800px 300px at -10% -10%, rgba(30,64,175,.12), transparent 60%),
    radial-gradient(900px 340px at 110% 120%, rgba(59,130,246,.10), transparent 65%),
    var(--bg);
  -webkit-font-smoothing:antialiased; -moz-osx-font-smoothing:grayscale;
  padding-top:0;
  padding-left:var(--sidebar-w);
}
img{max-width:100%;display:block}
a{color:var(--primary-700);text-decoration:none}
a:hover{text-decoration:underline}

/* ====== Layout ====== */
.container{
  width:calc(100vw - var(--sidebar-w) - 48px);
  max-width:1600px;
  min-width:280px;
  margin-inline:auto;
}

/* Header fixo (sem fundo branco) */
.site-header{
  position:fixed; top:0; bottom:0; left:0; width:var(--sidebar-w); z-index:1000;
  box-sizing:border-box;
  padding:28px 22px 32px; display:flex; align-items:flex-start;
  background:
    radial-gradient(120% 95% at 15% 0%, rgba(255,255,255,.18) 0%, rgba(255,255,255,0) 62%),
    radial-gradient(140% 120% at 85% 15%, rgba(56,189,248,.35) 0%, rgba(37,99,235,0) 70%),
    linear-gradient(130deg,#020617 0%, #0f1b4c 38%, #1c3faa 68%, #60a5fa 100%);
  box-shadow:0 25px 60px rgba(15,23,42,.45); border-right:3px solid rgba(3,7,18,.65);
}
.site-header .container,
.site-header .header-container{
  width:100%; height:100%; margin:0;
  display:flex; flex-direction:column; align-items:stretch; justify-content:flex-start;
  gap:24px; padding:0; background:transparent;
}
/* Busca no Header */
.header-search {
  position: relative;
  width: 100%;
  margin: 0;
}
.header-search .search-icon {
  position: absolute;
  left: 14px;
  top: 50%;
  transform: translateY(-50%);
  color: #4a5f8a;
  pointer-events: none;
  z-index: 1;
}
.header-search input {
  width: 100%;
  padding: 10px 16px 10px 44px;
  background: rgba(255, 255, 255, 0.95);
  backdrop-filter: blur(10px);
  border: 2px solid rgba(255, 255, 255, 0.9);
  border-radius: 12px;
  font-size: 0.9rem;
  font-weight: 500;
  color: #0a1e42;
  transition: all 0.3s ease;
  box-shadow: 0 2px 8px rgba(30, 64, 175, 0.12);
}
.header-search input::placeholder {
  color: #6b7fb8;
}
.header-search input:focus {
  outline: none;
  background: #ffffff;
  border-color: #3b82f6;
  box-shadow: 0 4px 16px rgba(59, 130, 246, 0.25);
}
.brand{display:flex; align-items:center; justify-content:flex-start; min-width:0; width:100%}
.brand img{
  width:100%; height:auto; max-width:100%; object-fit:contain;
  filter: hue-rotate(180deg) saturate(1.2) brightness(0.85);
}
.site-header nav{
  display:flex; flex-direction:column; width:100%; gap:10px;
}
.site-header nav a{
  display:flex; align-items:center; height:48px; padding:0 16px;
  border-radius:12px; color:#f7fbff; text-decoration:none;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.18);
  box-shadow:0 14px 30px rgba(2,6,23,.25);
  backdrop-filter:blur(6px);
  font-weight:700; letter-spacing:.02em;
  transition:background .2s ease, border-color .2s ease, transform .2s ease;
  width:100%;
}
.site-header nav a:hover{
  background:rgba(255,255,255,.18);
  border-color:rgba(255,255,255,.4);
  transform:translateY(-1px);
}
/* Estat├¡sticas: for├ºar texto azul escuro no bot├úo branco */
.site-header + .container,
.site-header + main.container { margin-top:14px; }

/* ====== Cards / Grid ====== */
.card{
  background:var(--surface); border:1px solid var(--border);
  border-radius:var(--radius-lg); box-shadow:var(--shadow); padding:var(--pad);
}
.grid{display:grid; gap:var(--gap)}
.grid.two{grid-template-columns:1fr 1fr}
@media (max-width:900px){ .grid.two{grid-template-columns:1fr} }

/* ====== Tipografia ====== */
h1,h2,h3{margin:0 0 .6rem}
h1{font-size:1.8rem; letter-spacing:-.02em}
h2{font-size:1.35rem}
h3{font-size:1.05rem}
.muted{color:var(--muted)}
.hr, hr{border:0; height:1px; background:var(--border); margin:16px 0}

/* ====== Formul├írios ====== */
.stack{display:flex; flex-direction:column; gap:12px}
label{font-weight:700; font-size:.95rem}
input,select,textarea{
  appearance:none; width:100%; background:#fff; color:var(--text);
  border:1px solid var(--border); border-radius:12px; padding:12px 14px; outline:0;
  transition:border .15s, box-shadow .15s, background .15s;
}
input::placeholder, textarea::placeholder{color:#9aa3af}
input:focus,select:focus,textarea:focus{border-color:var(--primary-600); box-shadow:0 0 0 4px var(--primary-100)}
select{
  padding-right:36px; background-image:
    linear-gradient(45deg, transparent 50%, #475569 50%),
    linear-gradient(135deg, #475569 50%, transparent 50%),
    linear-gradient(#fff 0 0);
  background-position:
    calc(100% - 20px) calc(1em + 2px),
    calc(100% - 15px) calc(1em + 2px),
    calc(100% - 2.5rem) .5rem;
  background-size:5px 5px,5px 5px,1px 2.5rem; background-repeat:no-repeat;
}

/* ====== Bot├╡es ====== */
.btn{
  border:1px solid var(--border); background:linear-gradient(to bottom,#ffffff,#f0f4ff);
  color:var(--text); padding:10px 14px; border-radius:12px; font-weight:700; cursor:pointer;
  transition:filter .2s, transform .02s, background .2s, border-color .2s;
}
.btn:hover{filter:brightness(.96)} .btn:active{transform:translateY(1px)}
.btn.primary{background:linear-gradient(to bottom,#2563eb,#1e40af); color:#fff; border-color:transparent}
.btn.danger{background:linear-gradient(to bottom,var(--danger-600),var(--danger-700)); color:#fff; border-color:transparent}
.btn.sm{padding:7px 10px; border-radius:10px; font-size:.88rem}

/* ====== Listagens (linha premium com t├¡tulo, copiar e cliques) ====== */
.list{list-style:none; padding:0; margin:0}
.list li{
  display:flex; align-items:stretch; justify-content:space-between; gap:10px;
  padding:10px 12px; border:1px solid var(--border); border-radius:14px;
  background:linear-gradient(to bottom,#ffffff,#f5f8ff);
  box-shadow:var(--shadow);
  transition:transform .04s ease, box-shadow .18s ease, border-color .18s ease, background .18s ease;
}
.list li + li{margin-top:10px}
.list li:hover, .list li:focus-within{
  border-color:#a3c0ff; box-shadow:0 12px 30px rgba(30,64,175,.12); transform:translateY(-1px);
}
.row-left{display:flex; align-items:center; gap:10px; min-width:0}
.row-title{
  display:inline-block; max-width:clamp(220px,46vw,640px);
  font-weight:800; letter-spacing:-.01em; white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
  color:#0a1e42; text-decoration:none; position:relative;
}
.row-title::after{
  content:""; position:absolute; left:0; right:0; bottom:-3px; height:2px; border-radius:2px;
  background:linear-gradient(90deg,#2563eb,#1e40af);
  transform:scaleX(0); transform-origin:left; transition:transform .18s ease; opacity:.9;
}
.row-title:hover::after, .row-title:focus-visible::after{transform:scaleX(1)}
.tag{
  display:inline-block; padding:4px 10px; font-size:.8rem; font-weight:800;
  background:var(--tag); border:1px solid var(--tag-border); border-radius:999px; color:#1e40af;
}
.row-right{display:flex; align-items:center; gap:10px; margin-left:auto; white-space:nowrap}
.btn.sm.copy-link{border-color:var(--border); background:linear-gradient(to bottom,#ffffff,#e8f0ff); font-weight:800}
.btn.sm.copy-link:hover{filter:brightness(.98)} .btn.sm.copy-link:active{transform:translateY(1px)}
.badge{
  display:inline-block; padding:3px 8px; font-size:.75rem; font-weight:900; letter-spacing:.2px;
  background:linear-gradient(to bottom,#e3ebff,#d4e3ff); color:#1e40af; border:1px solid var(--border);
  border-radius:999px;
}

/* meta/data ao lado do t├¡tulo */
.row-meta{
  font-size:.82rem; color:var(--muted); white-space:nowrap;
  border:1px solid var(--border); background:var(--bg-accent); padding:2px 8px; border-radius:999px;
}
.row-left .row-title + .row-meta{margin-left:8px}
@media (max-width:560px){ .row-left{flex-wrap:wrap} .row-left .row-meta{margin-left:0} }

/* ====== Hero + KPI ====== */
.hero .muted{margin-top:4px}
.kpi{display:flex; gap:10px; flex-wrap:wrap; margin-top:10px}
.kpi .chip{background:#ffffff; border:1px solid var(--border); border-radius:12px; padding:8px 12px; font-weight:800; color:var(--text)}

/* ====== Separador de seção ====== */
.section-divider{
  border:none;
  height:1px;
  background:linear-gradient(90deg, transparent, var(--border), transparent);
  margin:20px 0;
}

/* ====== Mega Footer ====== */
.mega-footer{
  margin-top:24px; background:var(--surface); border-top:1px solid var(--border); box-shadow:var(--shadow);
}
.mega-footer .container{padding:28px 10px}
.mega-footer .columns{display:grid; grid-template-columns:repeat(4,minmax(0,1fr)); gap:26px}
@media (max-width:900px){ .mega-footer .columns{grid-template-columns:repeat(2,minmax(0,1fr))} }
@media (max-width:560px){ .mega-footer .columns{grid-template-columns:1fr} }
.mega-footer h4{margin:0 0 10px; font-size:1rem; font-weight:800; color:var(--text)}
.mega-footer ul{list-style:none; padding:0; margin:0; display:grid; gap:8px}
.mega-footer a{
  display:inline-block; padding:6px 7px; color:#1e40af; text-decoration:none; border-radius:10px;
}
.mega-footer a:hover{background:var(--bg-accent)}
.mega-footer .footnote{
  margin-top:18px; padding-top:16px; border-top:1px solid var(--border);
  color:var(--muted); font-size:.92rem; text-align:center;
}
/* t├¡tulo com ├¡cone opcional */
.mega-footer h4.with-ico{display:flex; align-items:center; gap:8px}
.mega-footer h4.with-ico svg{width:18px; height:18px; flex:0 0 18px; opacity:.9}

/* ====== T├¡tulo CTA 2026 (.row-title.t-massa) ====== */
.row-title.t-massa{
  display:inline-flex; align-items:center; gap:16px; max-width:100%; text-decoration:none;
  font-family:'Poppins',system-ui,sans-serif; text-transform:uppercase; font-weight:900; letter-spacing:.06em;
  font-size:clamp(16px,2.4vw,24px); line-height:1; color:#fff;
  padding:12px 28px; background:#1e40af; transform:skewX(-15deg);
  border-radius:16px; box-shadow:6px 6px 0 #0a1e42;
  transition:box-shadow .45s ease, transform .2s ease, background .45s ease; position:relative;
}
.row-title.t-massa .title-text{
  display:inline-block; max-width:clamp(220px,48vw,720px); overflow:hidden; text-overflow:ellipsis; white-space:nowrap;
  transform:skewX(15deg);
}
.row-title.t-massa .arrow{display:inline-flex; align-items:center; transform:skewX(15deg); width:28px; height:20px; margin-left:6px}
.row-title.t-massa:hover{box-shadow:10px 10px 0 #60a5fa; background:#2563eb; transform:skewX(-15deg) translateY(-1px)}
.row-title.t-massa:focus{outline:2px solid #60a5fa; outline-offset:4px}
.row-title.t-massa path.one{transition:.4s; transform:translateX(-60%)}
.row-title.t-massa path.two{transition:.5s; transform:translateX(-30%)}
.row-title.t-massa:hover path.one{transform:translateX(0); animation:color_anim 1s infinite .6s}
.row-title.t-massa:hover path.two{transform:translateX(0); animation:color_anim 1s infinite .4s}
.row-title.t-massa:hover path.three{animation:color_anim 1s infinite .2s}
@keyframes color_anim{
  0%{color:#fff; fill:#fff} 50%{color:#60a5fa; fill:#60a5fa} 100%{color:#fff; fill:#fff}
}

/* ====== Acessibilidade ====== */
:focus-visible{outline:3px solid var(--primary-100); outline-offset:2px}
@media (prefers-reduced-motion:no-preference){
  *{transition:background-color .2s, color .2s, border-color .2s}
}

/* ====== Dark mode (autom├ítico + for├ºado via atributo) ====== */
@media (prefers-color-scheme: dark){
  :root{
    --bg:#0b1220; --bg-accent:#0c1627; --surface:#0f172a;
    --text:#e5e7eb; --muted:#94a3b8; --border:#1f2937; --shadow:0 10px 25px rgba(0,0,0,.45);
    --tag:#0b1931; --tag-border:#15233a;
  }
  .site-header{background:rgba(15,23,42,.8)}
  a{color:#93c5fd}
  .btn{background:linear-gradient(to bottom,#0b1220,#101826); color:#e5e7eb; border-color:#1f2937}
  .btn.primary{background:linear-gradient(to bottom,#2563eb,#1d4ed8)}
  .btn.danger{background:linear-gradient(to bottom,#ef4444,#dc2626)}
  .list li{background:linear-gradient(to bottom,#0f172a,#0b1220); border-color:var(--border); box-shadow:var(--shadow)}
  .badge{background:linear-gradient(to bottom,#0c1627,#0b1220); border-color:#1f2937}
  .row-title{color:#e5e7eb}
  .mega-footer a{color:#e5e7eb}
}
:root[data-theme="dark"]{
  --bg:#0b1220; --bg-accent:#0c1627; --surface:#0f172a;
  --text:#e5e7eb; --muted:#94a3b8; --border:#1f2937; --shadow:0 10px 25px rgba(0,0,0,.45);
  --tag:#0b1931; --tag-border:#15233a;
}
:root[data-theme="dark"] a{color:#93c5fd}
:root[data-theme="dark"] .btn{background:linear-gradient(to bottom,#0b1220,#101826); color:#e5e7eb; border-color:#1f2937}
:root[data-theme="dark"] .mega-footer a{color:#e5e7eb}

/* ====== Responsivo ====== */
@media (max-width:1024px){
  body{
    padding-left:0;
    padding-top:var(--header-h);
  }
  .container{width:min(1100px,92vw)}
  .site-header{
    top:0; left:0; right:0; bottom:auto; width:100%; height:var(--header-h);
    padding:0; border-right:none; border-bottom:3px solid #1a3694;
  }
  .site-header .header-container{
    height:100%;
    display:grid; grid-template-columns:auto 1fr auto; align-items:center;
    gap:20px; padding:0 16px;
  }
  .header-search{
    max-width:500px;
    margin:0 auto;
  }
  .brand img{
    height:calc(var(--header-h) - 20px);
    width:auto; max-width:min(437px,70vw);
  }
  .site-header nav{
    flex-direction:row; width:auto; gap:6px;
  }
  .site-header nav a{
    width:auto; margin-left:6px; border-radius:10px; height:42px;
  }
}
@media (max-width:640px){
  .header-search input {
    font-size: 0.85rem;
    padding: 9px 14px 9px 40px;
  }
  .header-search .search-icon {
    left: 12px;
    width: 18px;
    height: 18px;
  }
}
@media (max-width:560px){
  :root{ --header-h:72px }
  .brand img{ height:calc(var(--header-h) - 14px); max-width:62vw }
}
@media (max-width:640px){
  .list li{padding:10px}
  .row-left{min-width:60%}
  .row-title{max-width:100%}
  .row-right{gap:8px}
}

/* ===== BARRA DA CATEGORIA (top) ===== */

/* remove o marcador nativo do summary */
summary.cat-bar::-webkit-details-marker{ display:none }
summary.cat-bar{ list-style:none }

/* cont├¬iner da barra */
.cat-bar{
  display:flex; align-items:center; gap:10px; flex-wrap:wrap;
  padding:12px 14px;
/* troca onde hoje est├í seu background: linear-gradient(...) */
background: linear-gradient(
  135deg,
  #60a5fa 0%,
  #3b82f6 35%,
  #2563eb 70%,
  #1e40af 100%
);

  border:1px solid #1e40af;
  border-radius:14px;
  box-shadow:var(--shadow);
  margin-bottom:16px;          /* respiro antes da lista */
}

/* caret (abre/fecha) ΓÇô s├│ aparece se estiver em <summary> */
.cat-bar .caret{
  width:0; height:0;
  border-left:6px solid currentColor;
  border-top:5px solid transparent;
  border-bottom:5px solid transparent;
  opacity:.85;
  transition:transform .18s ease;
}
details[open] > summary.cat-bar .caret{ transform:rotate(90deg) }

/* t├¡tulo e contador */
.cat-title{
  font-weight:900; letter-spacing:.2px; color:#ffffff;
}
.cat-meta{
  color:var(--muted);
  padding:2px 8px; border:1px solid var(--border);
  background:var(--bg-accent);
  border-radius:999px; font-size:.82rem; font-weight:700;
}

/* empurra os filtros pra direita */
.cat-bar .spacer{ margin-left:auto }

/* p├¡lulas de ordena├º├úo */
.sort-pills{ display:flex; gap:8px; flex-wrap:wrap }
.pill{
  display:inline-flex; align-items:center; gap:6px;
  height:34px; padding:0 12px;
  background:#ffffff;
  border:1px solid rgba(255,255,255,.3);
  border-radius:999px;
  font-weight:800; font-size:.9rem; color:#1e40af; text-decoration:none;
  transition:filter .2s, transform .02s, border-color .2s, background .2s;
}
.pill:hover{ filter:brightness(.96) }
.pill:active{ transform:translateY(1px) }
.pill.is-active{
  background:linear-gradient(to bottom,#1e40af,#152d7a);
  color:#fff; border-color:transparent;
}

/* vers├úo compacta no mobile */
@media (max-width:640px){
  .cat-bar{ padding:10px 12px }
  .cat-title{ font-size:1rem }
  .cat-meta{ font-size:.78rem }
  .sort-pills{ width:100% }           /* quebra linha bonitinho */
  .cat-bar .spacer{ flex-basis:100%; height:0 } /* empurra os filtros pra baixo */
}

/* Dark mode */
@media (prefers-color-scheme: dark){
  .cat-bar{ background:linear-gradient(to bottom,#0f172a,#0b1220); border-color:var(--border) }
  .cat-title{ color:#e5e7eb }
  .pill{ background:#0b1220; color:#e5e7eb; border-color:#1f2937 }
}
:root[data-theme="dark"] .cat-bar{ background:linear-gradient(to bottom,#0f172a,#0b1220) }
:root[data-theme="dark"] .pill{ background:#0b1220; color:#e5e7eb; border-color:#1f2937 }

/* Garante que nada dentro da p├¡lula receba sublinhado */
.sort-pills .pill, 
.sort-pills .pill *, 
.sort-pills .pill:hover, 
.sort-pills .pill:focus {
  text-decoration: none !important;
}

/* ====== Socials admin specific styling (adicionado) ====== */
.socials-list{margin-top:10px}
.social-item{display:flex;gap:12px;align-items:flex-start;padding:14px;border:1px solid var(--border);border-radius:12px;background:linear-gradient(to bottom,#ffffff,#f5f8ff)}
.social-meta{flex:1;min-width:0;display:flex;flex-direction:column;gap:10px}
.social-meta .row{display:flex;gap:10px;align-items:center}
.social-meta input[type="text"], .social-meta input[type="url"], .social-meta input[type="email"]{
  padding:10px 12px; border-radius:10px; border:1px solid var(--border); background:#ffffff; box-shadow:none
}
.social-meta .name{font-weight:800; color:var(--text)}
.social-actions{display:flex;flex-direction:column;gap:8px;align-items:flex-end}

/* Toggle / chip style for checkboxes (target_blank + visible) */
.toggle-group{display:flex;gap:8px;align-items:center}
.toggle-group label{
  display:inline-flex;align-items:center;gap:8px;padding:6px 10px;border-radius:999px;border:1px solid var(--border);
  background:linear-gradient(to bottom,#ffffff,#f0f4ff);font-weight:700;color:var(--muted);cursor:pointer;font-size:.9rm
}
.toggle-group input[type="checkbox"]{appearance:none;-webkit-appearance:none;width:18px;height:18px;border-radius:6px;border:1px solid var(--border);background:#ffffff;display:inline-block;position:relative}
.toggle-group input[type="checkbox"]:checked{background:linear-gradient(180deg,#2563eb,#1e40af);border-color:transparent;box-shadow:0 2px 6px rgba(30,64,175,.15)}
.toggle-group input[type="checkbox"]:focus{outline:2px solid var(--primary-100);outline-offset:2px}
.toggle-group label span.label-text{color:var(--text);font-weight:700}

@media (max-width:720px){
  .social-item{flex-direction:column}
  .social-actions{width:100%;flex-direction:row;justify-content:space-between}
}

/* details/summary styles para itens collapsibles (socials) */
details.social-item{border:1px solid var(--border); border-radius:12px; margin-bottom:12px; background:linear-gradient(to bottom,#ffffff,#f5f8ff); padding:0}
details.social-item summary.social-summary{list-style:none; cursor:pointer; padding:12px 14px; display:block; border-radius:12px}
details.social-item summary.social-summary::-webkit-details-marker{display:none}
details.social-item summary.social-summary{display:flex;align-items:center;gap:10px}
details.social-item summary.social-summary .badge{flex:0 0 auto}
details.social-item .social-body{padding:12px 14px 18px}
details.social-item[open] summary.social-summary{border-bottom:1px solid var(--border)}

/* melhorar apar├¬ncia do bot├úo Salvar / Apagar quando full width */
.social-actions .btn{border-radius:10px}

@media (prefers-color-scheme: dark){
  details.social-item{background:linear-gradient(to bottom,#0f172a,#0b1220)}
  details.social-item summary.social-summary{color:var(--text)}
}

/* ====================================================================
   ESTILOS ESPECÍFICOS POR PÁGINA
   ==================================================================== */

/* ==================== INDEX.PHP ==================== */
.visually-hidden {
    position: absolute !important;
    width: 1px !important;
    height: 1px !important;
    padding: 0 !important;
    margin: -1px !important;
    overflow: hidden !important;
    clip: rect(0, 0, 0, 0) !important;
    white-space: nowrap !important;
    border: 0 !important;
}

@keyframes fadeInUp {
    from { opacity: 0; transform: translateY(20px); }
    to { opacity: 1; transform: translateY(0); }
}

.card, details.category { animation: fadeInUp 0.4s ease-out backwards; }
details.category:nth-child(1) { animation-delay: 0.05s; }
details.category:nth-child(2) { animation-delay: 0.10s; }
details.category:nth-child(3) { animation-delay: 0.15s; }

html { scroll-behavior: smooth; }

/* Hero Enhanced */
.hero-enhanced {
    padding: 36px 42px 40px;
    border: 1px solid #e2e8f0;
    border-radius: 28px;
    background: linear-gradient(145deg, #ffffff 0%, #f8fafc 55%, #eef2ff 100%);
    position: relative;
    overflow: hidden;
}
.hero-enhanced:before {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(circle at 15% 20%, rgba(99,102,241,0.18), transparent 60%),
                radial-gradient(circle at 85% 75%, rgba(14,165,233,0.15), transparent 65%);
    pointer-events: none;
}
.hero-header { display: flex; align-items: center; gap: 22px; }
.hero-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 72px;
    height: 72px;
    font-size: 34px;
    border-radius: 20px;
    background: linear-gradient(135deg,#60a5fa 0%, #2563eb 60%, #1e40af 100%);
    box-shadow: 0 10px 25px -8px rgba(30,64,175,0.35);
    transition: transform .35s cubic-bezier(.4,0,.2,1);
}
.hero-enhanced:hover .hero-icon { transform: translateY(-6px); }
.hero-text h1 {
    margin: 0 0 6px;
    font-size: 2.35rem;
    font-weight: 800;
    letter-spacing: -0.5px;
    background: linear-gradient(90deg,#1e293b 0%, #334155 40%, #6366f1 85%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}
.hero-subtitle {
    margin: 0;
    font-size: 0.95rem;
    font-weight: 600;
    color: #475569;
}

/* Grid de Documentos */
.links-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    gap: 20px;
    padding: 20px 0;
}

.doc-card {
    background: #ffffff;
    border: 2px solid #e5e7eb;
    border-left: 4px solid #4F46E5;
    border-radius: 12px;
    padding: 0;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    display: flex;
    flex-direction: column;
    position: relative;
    box-shadow: 0 2px 8px rgba(15, 23, 42, 0.06);
    overflow: hidden;
    min-height: 320px;
}

.doc-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 12px 32px rgba(79, 70, 229, 0.15);
    border-color: #4F46E5;
}

.doc-content {
    position: relative;
    z-index: 2;
    display: flex;
    flex-direction: column;
    gap: 16px;
    padding: 24px;
    flex: 1;
}

.doc-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 64px;
    height: 64px;
    background: linear-gradient(135deg, #EEF2FF 0%, #E0E7FF 100%);
    border-radius: 12px;
    margin-bottom: 8px;
    transition: all 0.3s ease;
}

.doc-card:hover .doc-icon {
    transform: scale(1.05);
    background: linear-gradient(135deg, #E0E7FF 0%, #C7D2FE 100%);
}

.doc-title {
    margin: 0;
    font-size: 1.05rem;
    font-weight: 800;
    line-height: 1.4;
    color: #1e293b;
    min-height: 56px;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.doc-title a {
    color: #1e293b;
    text-decoration: none;
    transition: color 0.2s ease;
}

.doc-title a:hover { color: #4F46E5; }

.doc-meta {
    display: flex;
    flex-direction: column;
    gap: 8px;
    padding-top: 8px;
    border-top: 1px solid #f1f5f9;
    flex: 1;
}

.doc-info {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 0.8rem;
    color: #64748b;
    font-weight: 500;
}

.doc-info svg { flex-shrink: 0; opacity: 0.6; }

.doc-actions {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
    margin-top: auto;
}

.doc-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 10px 16px;
    font-size: 0.875rem;
    font-weight: 700;
    border-radius: 10px;
    border: none;
    cursor: pointer;
    transition: all 0.2s ease;
    text-decoration: none;
    white-space: nowrap;
}

.doc-btn-primary {
    background: linear-gradient(135deg, #4F46E5 0%, #4338ca 100%);
    color: #ffffff;
    box-shadow: 0 4px 12px rgba(79, 70, 229, 0.3);
}

.doc-btn-primary:hover {
    background: linear-gradient(135deg, #4338ca 0%, #3730a3 100%);
    box-shadow: 0 6px 20px rgba(79, 70, 229, 0.4);
    transform: translateY(-2px);
}

.doc-btn-secondary {
    background: #f8fafc;
    color: #475569;
    border: 2px solid #e2e8f0;
}

.doc-btn-secondary:hover {
    background: #f1f5f9;
    border-color: #cbd5e1;
    transform: translateY(-2px);
}

/* Barra de Categoria Moderna */
summary.cat-bar-modern {
    display: grid;
    grid-template-columns: 1fr auto;
    align-items: center;
    gap: 24px;
    padding: 18px 24px;
    background: linear-gradient(135deg, rgba(255,255,255,0.98) 0%, rgba(255,255,255,0.95) 100%);
    backdrop-filter: blur(20px);
    border: 1px solid rgba(226, 232, 240, 0.8);
    border-radius: 14px;
    margin-bottom: 16px;
    cursor: pointer;
    box-shadow: 0 2px 8px rgba(15, 23, 42, 0.04);
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    list-style: none;
}

summary.cat-bar-modern::-webkit-details-marker { display: none; }

summary.cat-bar-modern:hover {
    border-color: rgba(139, 92, 246, 0.3);
    box-shadow: 0 4px 16px rgba(139, 92, 246, 0.12);
    transform: translateY(-1px);
}

.cat-header-left {
    display: flex;
    align-items: center;
    gap: 14px;
    min-width: 0;
}

.caret-icon {
    flex-shrink: 0;
    width: 24px;
    height: 24px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #8b5cf6;
    transition: transform 0.3s ease;
}

details[open] > summary.cat-bar-modern .caret-icon { transform: rotate(90deg); }

.cat-info { display: flex; flex-direction: column; gap: 4px; }

.cat-title-modern {
    margin: 0;
    font-size: 1.05rem;
    font-weight: 800;
    color: #1e293b;
    display: flex;
    align-items: center;
    gap: 8px;
}

.cat-count {
    font-size: 0.8rem;
    color: #64748b;
    font-weight: 600;
    background: rgba(241, 245, 249, 0.8);
    padding: 2px 10px;
    border-radius: 6px;
    display: inline-block;
    width: fit-content;
}

.sort-controls-modern {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-shrink: 0;
}

.sort-label {
    font-size: 0.85rem;
    font-weight: 600;
    color: #64748b;
    white-space: nowrap;
}

.sort-buttons {
    display: flex;
    gap: 6px;
    background: rgba(241, 245, 249, 0.6);
    padding: 4px;
    border-radius: 10px;
    border: 1px solid rgba(226, 232, 240, 0.8);
}

.sort-btn {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 8px 14px;
    font-size: 0.85rem;
    font-weight: 700;
    color: #475569;
    background: transparent;
    border: none;
    border-radius: 8px;
    text-decoration: none;
    transition: all 0.2s ease;
    white-space: nowrap;
}

.sort-btn:hover {
    background: rgba(255, 255, 255, 0.9);
    color: #8b5cf6;
    box-shadow: 0 2px 6px rgba(139, 92, 246, 0.15);
}

.sort-btn.active {
    background: linear-gradient(135deg, #8b5cf6 0%, #7c3aed 100%);
    color: #ffffff;
    box-shadow: 0 4px 12px rgba(139, 92, 246, 0.35);
}

@media (max-width: 768px) {
    summary.cat-bar-modern { grid-template-columns: 1fr; gap: 16px; }
    .sort-controls-modern { width: 100%; justify-content: space-between; }
    .links-grid { grid-template-columns: 1fr; }
    .doc-actions { grid-template-columns: 1fr; }
}

@media (prefers-color-scheme: dark) {
    .hero-enhanced {
        background: linear-gradient(145deg, #1e293b 0%, #0f172a 55%, #1e293b 100%);
        border-color: #334155;
    }
    .hero-text h1 { 
        background: linear-gradient(90deg,#e2e8f0 0%, #cbd5e1 40%, #818cf8 85%); 
        -webkit-background-clip: text; 
        background-clip: text;
    }
    .hero-subtitle { color: #94a3b8; }
    .doc-card {
        background: #1e293b;
        border-color: #334155;
        border-left-color: #6366f1;
    }
    .doc-title, .doc-title a { color: #e2e8f0; }
    .doc-icon { background: linear-gradient(135deg, #312e81 0%, #3730a3 100%); }
    summary.cat-bar-modern {
        background: linear-gradient(135deg, rgba(30, 41, 59, 0.98) 0%, rgba(15, 23, 42, 0.95) 100%);
        border-color: rgba(71, 85, 105, 0.6);
    }
    .cat-title-modern { color: #e2e8f0; }
    .sort-buttons { background: rgba(15, 23, 42, 0.6); border-color: rgba(71, 85, 105, 0.6); }
    .sort-btn { color: #cbd5e1; }
}

/* ==================== STATS.PHP ==================== */
.stats-page .stats-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 16px;
    margin-bottom: 24px;
}
.stats-page .stat-card {
    text-align: center;
    padding: 24px;
}
.stats-page .stat-card .icon {
    font-size: 2rem;
    margin-bottom: 8px;
}
.stats-page .stat-card .value {
    font-size: 2rem;
    font-weight: 700;
    color: var(--accent, #2563eb);
}
.stats-page .stat-card .label {
    color: var(--muted);
    font-size: 0.9rem;
}
.top-links {
    list-style: none;
    padding: 0;
    margin: 0;
}
.top-links li {
    display: flex;
    justify-content: space-between;
    padding: 12px 0;
    border-bottom: 1px solid var(--border);
}
.top-links li:last-child {
    border-bottom: none;
}
.top-links .rank {
    color: var(--muted);
    margin-right: 12px;
}
.top-links .clicks {
    color: var(--accent, #2563eb);
    font-weight: 600;
}

/* ==================== SETUP.PHP ==================== */
.setup-wrap {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 20px;
}
.setup-card {
    width: 100%;
    max-width: 450px;
}
.setup-card h1 {
    text-align: center;
    margin-bottom: 8px;
}
.setup-card .subtitle {
    text-align: center;
    margin-bottom: 24px;
    color: var(--muted);
}
.setup-card .form-group {
    margin-bottom: 16px;
}
.setup-card .form-group label {
    display: block;
    margin-bottom: 6px;
    font-weight: 500;
}
.setup-card .form-group input {
    width: 100%;
    padding: 12px;
    border: 1px solid var(--border);
    border-radius: 8px;
    font-size: 1rem;
    background: var(--card, #fff);
    color: var(--txt, #333);
}
.setup-card .btn {
    width: 100%;
    padding: 12px;
    font-size: 1rem;
}
.error-msg {
    background: rgba(239, 68, 68, 0.1);
    color: #ef4444;
    padding: 12px;
    border-radius: 8px;
    margin-bottom: 16px;
}
.success-msg {
    background: rgba(34, 197, 94, 0.1);
    color: #22c55e;
    padding: 12px;
    border-radius: 8px;
    margin-bottom: 16px;
}

/* ==================== INSTALL.PHP ==================== */
.install-page {
    font-family: 'Segoe UI', system-ui, sans-serif;
    background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 20px;
}
.install-container {
    background: white;
    border-radius: 16px;
    padding: 40px;
    max-width: 600px;
    width: 100%;
    box-shadow: 0 20px 60px rgba(0,0,0,0.3);
}
.install-container h1 {
    color: #333;
    margin-bottom: 30px;
    font-size: 1.8rem;
    display: flex;
    align-items: center;
    gap: 12px;
}
.install-message {
    padding: 12px 16px;
    margin: 8px 0;
    border-radius: 8px;
    font-size: 0.95rem;
}
.install-message.success {
    background: #d4edda;
    color: #155724;
    border-left: 4px solid #28a745;
}
.install-message.error {
    background: #f8d7da;
    color: #721c24;
    border-left: 4px solid #dc3545;
}
.install-message.info {
    background: #e7f3ff;
    color: #0c5460;
    border-left: 4px solid #17a2b8;
}
.install-warning {
    background: #fff3cd;
    color: #856404;
    padding: 16px;
    border-radius: 8px;
    margin-top: 20px;
    border-left: 4px solid #ffc107;
}

/* ==================== DEPLOY.PHP ==================== */
.deploy-container {
    max-width: 900px;
    margin: 2rem auto;
    padding: 0 1rem;
}
.deploy-card {
    background: var(--glass-bg, rgba(255,255,255,0.1));
    border-radius: 16px;
    padding: 2rem;
    margin-bottom: 1.5rem;
    backdrop-filter: blur(10px);
    border: 1px solid rgba(255,255,255,0.1);
}
.deploy-card h2 {
    margin-top: 0;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}
.config-status {
    display: flex;
    gap: 1rem;
    flex-wrap: wrap;
    margin-bottom: 1rem;
}
.status-badge {
    padding: 0.5rem 1rem;
    border-radius: 20px;
    font-size: 0.875rem;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}
.status-ok { background: rgba(34, 197, 94, 0.2); color: #22c55e; }
.status-warn { background: rgba(234, 179, 8, 0.2); color: #eab308; }
.status-error { background: rgba(239, 68, 68, 0.2); color: #ef4444; }

.btn-deploy {
    background: linear-gradient(135deg, #3b82f6, #8b5cf6);
    color: white;
    border: none;
    padding: 1rem 2rem;
    border-radius: 12px;
    font-size: 1.1rem;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    transition: transform 0.2s, box-shadow 0.2s;
}
.btn-deploy:hover {
    transform: translateY(-2px);
    box-shadow: 0 10px 30px rgba(59, 130, 246, 0.3);
}
.btn-deploy:disabled {
    opacity: 0.5;
    cursor: not-allowed;
    transform: none;
}

.btn-secondary-deploy {
    background: rgba(255,255,255,0.1);
    color: inherit;
    border: 1px solid rgba(255,255,255,0.2);
    padding: 0.75rem 1.5rem;
    border-radius: 8px;
    cursor: pointer;
    transition: background 0.2s;
}
.btn-secondary-deploy:hover {
    background: rgba(255,255,255,0.2);
}

.deploy-actions {
    display: flex;
    gap: 1rem;
    flex-wrap: wrap;
    margin-top: 1rem;
}

.output-box-deploy {
    background: #1a1a2e;
    border-radius: 8px;
    padding: 1rem;
    font-family: 'Consolas', 'Monaco', monospace;
    font-size: 0.875rem;
    white-space: pre-wrap;
    word-break: break-all;
    max-height: 300px;
    overflow-y: auto;
    margin-top: 1rem;
    color: #a0a0a0;
}

.log-box {
    background: #0d1117;
    border-radius: 8px;
    padding: 1rem;
    font-family: 'Consolas', 'Monaco', monospace;
    font-size: 0.8rem;
    white-space: pre-wrap;
    max-height: 400px;
    overflow-y: auto;
    color: #8b949e;
    line-height: 1.6;
}

.deploy-alert {
    padding: 1rem;
    border-radius: 8px;
    margin-bottom: 1rem;
}
.deploy-alert-success { background: rgba(34, 197, 94, 0.2); color: #22c55e; }
.deploy-alert-error { background: rgba(239, 68, 68, 0.2); color: #ef4444; }

.webhook-url {
    background: #1a1a2e;
    padding: 0.75rem 1rem;
    border-radius: 8px;
    font-family: monospace;
    font-size: 0.9rem;
    word-break: break-all;
    margin: 1rem 0;
    border: 1px solid rgba(255,255,255,0.1);
}

.info-list {
    list-style: none;
    padding: 0;
    margin: 1rem 0;
}
.info-list li {
    padding: 0.5rem 0;
    border-bottom: 1px solid rgba(255,255,255,0.1);
    display: flex;
    gap: 0.5rem;
}
.info-list li:last-child { border-bottom: none; }

.back-link {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    color: inherit;
    text-decoration: none;
    margin-bottom: 1rem;
    opacity: 0.7;
}
.back-link:hover { opacity: 1; }

/* ==================== ATUALIZACOES.PHP - Premium Light Design ==================== */
.atualizacoes-page,
.atualizacoes-page body {
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif !important;
    background: #f8fafc !important;
    color: #1e293b;
    min-height: 100vh;
    padding: 30px 20px;
    /* Reset global styles */
    padding-left: 30px !important;
    margin: 0 !important;
    position: relative;
    overflow-x: hidden;
}

.atualizacoes-page::before {
    content: '';
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: 
        /* Mesh gradient orbs - Light theme */
        radial-gradient(ellipse 80% 50% at 20% -20%, rgba(99, 102, 241, 0.12) 0%, transparent 50%),
        radial-gradient(ellipse 60% 40% at 85% 10%, rgba(168, 85, 247, 0.1) 0%, transparent 45%),
        radial-gradient(ellipse 50% 80% at 10% 90%, rgba(34, 211, 238, 0.08) 0%, transparent 50%),
        radial-gradient(ellipse 70% 50% at 90% 80%, rgba(99, 102, 241, 0.08) 0%, transparent 50%),
        radial-gradient(ellipse 40% 60% at 50% 50%, rgba(168, 85, 247, 0.05) 0%, transparent 60%);
    pointer-events: none;
    z-index: 0;
}

/* Subtle Grid Pattern Overlay - Light theme */
.atualizacoes-page::after {
    content: '';
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-image: 
        linear-gradient(rgba(99, 102, 241, 0.03) 1px, transparent 1px),
        linear-gradient(90deg, rgba(99, 102, 241, 0.03) 1px, transparent 1px);
    background-size: 50px 50px;
    pointer-events: none;
    z-index: 0;
    opacity: 0.5;
}

.atualizacoes-page .container {
    max-width: 1200px;
    margin: 0 auto;
    position: relative;
    z-index: 1;
}

.atualizacoes-page .header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 40px;
    padding: 24px 30px;
    background: rgba(255, 255, 255, 0.9);
    backdrop-filter: blur(20px);
    border-radius: 20px;
    border: 1px solid rgba(99, 102, 241, 0.15);
    box-shadow: 0 8px 32px rgba(99, 102, 241, 0.1);
}

.atualizacoes-page .header h1 {
    font-size: 1.8rem;
    font-weight: 800;
    display: flex;
    align-items: center;
    gap: 12px;
    background: linear-gradient(135deg, #1e293b 0%, #6366f1 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.atualizacoes-page .btn {
    padding: 12px 24px;
    border: none;
    border-radius: 12px;
    cursor: pointer;
    font-size: 0.9rem;
    font-weight: 600;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    position: relative;
    overflow: hidden;
}

.atualizacoes-page .btn::before {
    content: '';
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255,255,255,0.2), transparent);
    transition: left 0.5s;
}

.atualizacoes-page .btn:hover::before {
    left: 100%;
}

.atualizacoes-page .btn-primary { 
    background: linear-gradient(135deg, #4f46e5 0%, #7c3aed 100%); 
    color: white;
    box-shadow: 0 4px 15px rgba(79, 70, 229, 0.4);
}
.atualizacoes-page .btn-primary:hover { 
    transform: translateY(-2px);
    box-shadow: 0 8px 25px rgba(79, 70, 229, 0.5);
}

.atualizacoes-page .btn-success { 
    background: linear-gradient(135deg, #10b981 0%, #059669 100%); 
    color: white;
    box-shadow: 0 4px 15px rgba(16, 185, 129, 0.4);
}
.atualizacoes-page .btn-success:hover { 
    transform: translateY(-2px);
    box-shadow: 0 8px 25px rgba(16, 185, 129, 0.5);
}

.atualizacoes-page .btn-warning { 
    background: linear-gradient(135deg, #f59e0b 0%, #d97706 100%); 
    color: #000;
    box-shadow: 0 4px 15px rgba(245, 158, 11, 0.4);
}
.atualizacoes-page .btn-warning:hover { 
    transform: translateY(-2px);
    box-shadow: 0 8px 25px rgba(245, 158, 11, 0.5);
}

.atualizacoes-page .btn-danger { 
    background: linear-gradient(135deg, #ef4444 0%, #dc2626 100%); 
    color: white;
    box-shadow: 0 4px 15px rgba(239, 68, 68, 0.4);
}
.atualizacoes-page .btn-danger:hover { 
    transform: translateY(-2px);
    box-shadow: 0 8px 25px rgba(239, 68, 68, 0.5);
}

.atualizacoes-page .btn-ghost { 
    background: rgba(99, 102, 241, 0.08); 
    color: #6366f1; 
    border: 1px solid rgba(99, 102, 241, 0.2);
    backdrop-filter: blur(10px);
}
.atualizacoes-page .btn-ghost:hover { 
    background: rgba(99, 102, 241, 0.15); 
    color: #4f46e5;
    border-color: rgba(99, 102, 241, 0.3);
}

.atualizacoes-page .alert {
    padding: 18px 24px;
    border-radius: 16px;
    margin-bottom: 24px;
    display: flex;
    align-items: center;
    gap: 12px;
    font-weight: 500;
    backdrop-filter: blur(10px);
    animation: slideIn 0.3s ease-out;
}

@keyframes slideIn {
    from {
        opacity: 0;
        transform: translateY(-10px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.atualizacoes-page .alert-success { 
    background: rgba(16, 185, 129, 0.1); 
    border: 1px solid rgba(16, 185, 129, 0.4); 
    color: #059669;
    box-shadow: 0 4px 20px rgba(16, 185, 129, 0.1);
}
.atualizacoes-page .alert-warning { 
    background: rgba(245, 158, 11, 0.1); 
    border: 1px solid rgba(245, 158, 11, 0.4); 
    color: #d97706;
    box-shadow: 0 4px 20px rgba(245, 158, 11, 0.1);
}
.atualizacoes-page .alert-error { 
    background: rgba(239, 68, 68, 0.1); 
    border: 1px solid rgba(239, 68, 68, 0.4); 
    color: #dc2626;
    box-shadow: 0 4px 20px rgba(239, 68, 68, 0.1);
}
.atualizacoes-page .alert-info { 
    background: rgba(79, 70, 229, 0.1); 
    border: 1px solid rgba(79, 70, 229, 0.4); 
    color: #4f46e5;
    box-shadow: 0 4px 20px rgba(79, 70, 229, 0.1);
}

.atualizacoes-page .card {
    background: rgba(255, 255, 255, 0.9);
    backdrop-filter: blur(20px);
    border-radius: 20px;
    border: 1px solid rgba(99, 102, 241, 0.12);
    margin-bottom: 24px;
    overflow: hidden;
    box-shadow: 0 8px 32px rgba(99, 102, 241, 0.08);
    transition: all 0.3s ease;
}

.atualizacoes-page .card:hover {
    border-color: rgba(99, 102, 241, 0.25);
    box-shadow: 0 12px 40px rgba(99, 102, 241, 0.12);
}

.atualizacoes-page .card-header {
    background: linear-gradient(135deg, rgba(99, 102, 241, 0.08) 0%, rgba(168, 85, 247, 0.04) 100%);
    padding: 20px 24px;
    border-bottom: 1px solid rgba(99, 102, 241, 0.1);
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.atualizacoes-page .card-header h2 {
    font-size: 1.15rem;
    font-weight: 700;
    display: flex;
    align-items: center;
    gap: 10px;
    color: #1e293b;
}

.atualizacoes-page .card-body {
    padding: 24px;
}

.atualizacoes-page .grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(350px, 1fr));
    gap: 24px;
}

.atualizacoes-page .stat-box {
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.95) 0%, rgba(248, 250, 252, 0.95) 100%);
    border-radius: 16px;
    padding: 24px;
    display: flex;
    align-items: center;
    gap: 20px;
    border: 1px solid rgba(99, 102, 241, 0.12);
    transition: all 0.3s ease;
}

.atualizacoes-page .stat-box:hover {
    transform: translateY(-4px);
    border-color: rgba(99, 102, 241, 0.25);
    box-shadow: 0 12px 30px rgba(99, 102, 241, 0.1);
}

.atualizacoes-page .stat-icon {
    width: 60px;
    height: 60px;
    border-radius: 16px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.8rem;
    flex-shrink: 0;
}

.atualizacoes-page .stat-icon.blue { 
    background: linear-gradient(135deg, rgba(79, 70, 229, 0.3) 0%, rgba(139, 92, 246, 0.2) 100%);
    box-shadow: 0 4px 15px rgba(79, 70, 229, 0.3);
}
.atualizacoes-page .stat-icon.green { 
    background: linear-gradient(135deg, rgba(16, 185, 129, 0.3) 0%, rgba(5, 150, 105, 0.2) 100%);
    box-shadow: 0 4px 15px rgba(16, 185, 129, 0.3);
}
.atualizacoes-page .stat-icon.orange { 
    background: linear-gradient(135deg, rgba(245, 158, 11, 0.3) 0%, rgba(217, 119, 6, 0.2) 100%);
    box-shadow: 0 4px 15px rgba(245, 158, 11, 0.3);
}

.atualizacoes-page .stat-info h3 { 
    font-size: 1.4rem; 
    font-weight: 700;
    margin-bottom: 4px; 
    color: #1e293b;
}
.atualizacoes-page .stat-info p { 
    color: #64748b; 
    font-size: 0.9rem;
    font-weight: 500;
}

.atualizacoes-page .commit-list {
    max-height: 420px;
    overflow-y: auto;
}

.atualizacoes-page .commit-list::-webkit-scrollbar {
    width: 6px;
}
.atualizacoes-page .commit-list::-webkit-scrollbar-track {
    background: rgba(99, 102, 241, 0.05);
    border-radius: 3px;
}
.atualizacoes-page .commit-list::-webkit-scrollbar-thumb {
    background: rgba(99, 102, 241, 0.3);
    border-radius: 3px;
}

.atualizacoes-page .commit-item {
    padding: 16px 20px;
    border-bottom: 1px solid rgba(99, 102, 241, 0.08);
    transition: all 0.2s ease;
}

.atualizacoes-page .commit-item:hover { 
    background: rgba(99, 102, 241, 0.06);
}
.atualizacoes-page .commit-item:last-child { border-bottom: none; }

.atualizacoes-page .commit-item.current {
    background: linear-gradient(90deg, rgba(16, 185, 129, 0.1) 0%, transparent 100%);
    border-left: 4px solid #10b981;
    padding-left: 16px;
}

.atualizacoes-page .commit-message {
    font-weight: 600;
    margin-bottom: 8px;
    word-break: break-word;
    color: #1e293b;
    line-height: 1.5;
}

.atualizacoes-page .commit-meta {
    font-size: 0.8rem;
    color: #64748b;
    display: flex;
    gap: 16px;
    flex-wrap: wrap;
    align-items: center;
}

.atualizacoes-page .commit-sha {
    font-family: 'JetBrains Mono', 'Consolas', monospace;
    background: rgba(99, 102, 241, 0.12);
    color: #6366f1;
    padding: 4px 10px;
    border-radius: 6px;
    font-size: 0.75rem;
    font-weight: 600;
}

.atualizacoes-page .badge {
    display: inline-block;
    padding: 4px 12px;
    border-radius: 20px;
    font-size: 0.75rem;
    font-weight: 600;
}

.atualizacoes-page .badge-success { 
    background: linear-gradient(135deg, rgba(16, 185, 129, 0.2) 0%, rgba(5, 150, 105, 0.15) 100%);
    color: #059669;
}
.atualizacoes-page .badge-warning { 
    background: linear-gradient(135deg, rgba(245, 158, 11, 0.2) 0%, rgba(217, 119, 6, 0.15) 100%);
    color: #d97706;
}

.atualizacoes-page .update-form {
    text-align: center;
    padding: 40px 20px;
}

.atualizacoes-page .update-form p { 
    color: #64748b; 
    margin-bottom: 24px;
    font-size: 1rem;
}

.atualizacoes-page .update-log {
    background: rgba(248, 250, 252, 0.9);
    border-radius: 12px;
    padding: 20px;
    max-height: 300px;
    overflow-y: auto;
    font-family: 'JetBrains Mono', 'Consolas', monospace;
    font-size: 0.85rem;
    border: 1px solid rgba(99, 102, 241, 0.1);
}

.atualizacoes-page .log-entry {
    padding: 6px 0;
    display: flex;
    gap: 12px;
}

.atualizacoes-page .log-time { color: #64748b; }
.atualizacoes-page .log-info { color: #3b82f6; }
.atualizacoes-page .log-success { color: #059669; }
.atualizacoes-page .log-warning { color: #d97706; }
.atualizacoes-page .log-error { color: #dc2626; }

.atualizacoes-page .backup-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 16px 20px;
    border-bottom: 1px solid rgba(99, 102, 241, 0.08);
    transition: background 0.2s;
}

.atualizacoes-page .backup-item:hover {
    background: rgba(99, 102, 241, 0.06);
}

.atualizacoes-page .backup-item:last-child { border-bottom: none; }

.atualizacoes-page .backup-info h4 { 
    font-size: 0.95rem; 
    font-weight: 600;
    margin-bottom: 4px;
    color: #1e293b;
}
.atualizacoes-page .backup-info p { 
    font-size: 0.8rem; 
    color: #64748b;
}

.atualizacoes-page .empty-state {
    text-align: center;
    padding: 50px 20px;
    color: #64748b;
}

.atualizacoes-page .empty-state .icon { 
    font-size: 4rem; 
    margin-bottom: 16px;
    opacity: 0.5;
}

.atualizacoes-page .config-alert {
    background: linear-gradient(135deg, rgba(245, 158, 11, 0.9) 0%, rgba(217, 119, 6, 0.9) 100%);
    color: #000;
    padding: 30px;
    border-radius: 20px;
    margin-bottom: 24px;
    box-shadow: 0 8px 30px rgba(245, 158, 11, 0.3);
}

.atualizacoes-page .config-alert h3 { 
    margin-bottom: 12px;
    font-weight: 700;
    font-size: 1.2rem;
}
.atualizacoes-page .config-alert p {
    margin-bottom: 8px;
    line-height: 1.6;
}
.atualizacoes-page .config-alert code { 
    background: rgba(0, 0, 0, 0.2); 
    padding: 3px 8px; 
    border-radius: 6px;
    font-weight: 600;
}
.atualizacoes-page .config-alert ol {
    margin-top: 15px;
    margin-left: 20px;
    line-height: 1.8;
}

.atualizacoes-page .checkbox-group {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 20px;
    justify-content: center;
    padding: 12px 20px;
    background: rgba(255, 255, 255, 0.05);
    border-radius: 12px;
    border: 1px solid rgba(255, 255, 255, 0.08);
}

.atualizacoes-page .checkbox-group input[type="checkbox"] {
    width: 20px;
    height: 20px;
    accent-color: #4f46e5;
    cursor: pointer;
}

.atualizacoes-page .checkbox-group label {
    color: #a5b4fc;
    font-weight: 500;
    cursor: pointer;
}

/* Responsive */
@media (max-width: 768px) {
    .atualizacoes-page {
        padding: 15px;
    }
    
    .atualizacoes-page .header {
        flex-direction: column;
        gap: 16px;
        text-align: center;
        padding: 20px;
    }
    
    .atualizacoes-page .header h1 {
        font-size: 1.4rem;
    }
    
    .atualizacoes-page .grid {
        grid-template-columns: 1fr;
    }
    
    .atualizacoes-page .stat-box {
        padding: 18px;
    }
    
    .atualizacoes-page .stat-icon {
        width: 50px;
        height: 50px;
        font-size: 1.5rem;
    }
}

@media (max-width: 768px) {
    .atualizacoes-page .grid { grid-template-columns: 1fr; }
    .atualizacoes-page .header { flex-direction: column; gap: 15px; }
}

/* ==================== ADMIN.PHP - Premium Light Design ==================== */
body.admin-page {
    /* Reset global styles that interfere with admin layout */
    padding-left: 0 !important;
    padding-top: 0 !important;
    margin: 0 !important;
    
    /* Admin CSS Variables - Light Theme */
    --bg: #f8fafc;
    --bg-card: rgba(255, 255, 255, 0.9);
    --bg-card-hover: rgba(248, 250, 252, 0.95);
    --bg-input: rgba(255, 255, 255, 0.95);
    --border: rgba(99, 102, 241, 0.15);
    --border-focus: #6366f1;
    --text: #1e293b;
    --text-muted: #64748b;
    --primary: #6366f1;
    --primary-hover: #4f46e5;
    --success: #16a34a;
    --success-bg: rgba(34, 197, 94, 0.1);
    --warning: #d97706;
    --warning-bg: rgba(245, 158, 11, 0.1);
    --danger: #dc2626;
    --danger-bg: rgba(239, 68, 68, 0.1);
    --purple: #9333ea;
    --cyan: #0891b2;
    --radius: 14px;
    --radius-lg: 20px;
    --shadow: 0 8px 32px rgba(99, 102, 241, 0.1);
    --transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    
    font-family: 'Inter', system-ui, -apple-system, sans-serif !important;
    background: #f8fafc !important;
    color: var(--text);
    line-height: 1.6;
    min-height: 100vh;
    position: relative;
    overflow-x: hidden;
}

/* Mesh Gradient Background - Professional Light Theme */
.admin-page::before {
    content: '';
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: 
        /* Mesh gradient orbs - Light theme */
        radial-gradient(ellipse 80% 50% at 20% -20%, rgba(99, 102, 241, 0.12) 0%, transparent 50%),
        radial-gradient(ellipse 60% 40% at 85% 10%, rgba(168, 85, 247, 0.1) 0%, transparent 45%),
        radial-gradient(ellipse 50% 80% at 10% 90%, rgba(34, 211, 238, 0.08) 0%, transparent 50%),
        radial-gradient(ellipse 70% 50% at 90% 80%, rgba(99, 102, 241, 0.08) 0%, transparent 50%),
        radial-gradient(ellipse 40% 60% at 50% 50%, rgba(168, 85, 247, 0.05) 0%, transparent 60%);
    pointer-events: none;
    z-index: 0;
}

/* Subtle Grid Pattern Overlay - Light theme */
.admin-page::after {
    content: '';
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-image: 
        linear-gradient(rgba(99, 102, 241, 0.03) 1px, transparent 1px),
        linear-gradient(90deg, rgba(99, 102, 241, 0.03) 1px, transparent 1px);
    background-size: 50px 50px;
    pointer-events: none;
    z-index: 0;
    opacity: 0.5;
}

.admin-page a { color: var(--primary); text-decoration: none; transition: var(--transition); }
.admin-page a:hover { color: var(--cyan); }

/* Sidebar Admin - Light Theme */
.admin-sidebar {
    position: fixed;
    top: 0;
    left: 0;
    width: 280px;
    height: 100vh;
    background: 
        linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(248, 250, 252, 0.95) 100%);
    backdrop-filter: blur(24px);
    border-right: 1px solid rgba(99, 102, 241, 0.12);
    padding: 24px 16px;
    display: flex;
    flex-direction: column;
    z-index: 100;
    overflow-y: auto;
    box-shadow: 4px 0 30px rgba(99, 102, 241, 0.08);
}

.admin-sidebar-brand {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 12px 16px;
    margin-bottom: 28px;
    background: #ffffff;
    border-radius: var(--radius);
    box-shadow: 
        0 4px 20px rgba(99, 102, 241, 0.25),
        inset 0 1px 0 rgba(255, 255, 255, 0.15);
    transition: var(--transition);
    border: 1px solid rgba(255, 255, 255, 0.15);
}

.admin-sidebar-brand:hover {
    transform: translateY(-2px);
    box-shadow: 
        0 8px 30px rgba(99, 102, 241, 0.4),
        inset 0 1px 0 rgba(255, 255, 255, 0.2);
}

.admin-sidebar-brand .brand-logo {
    width: 100%;
    max-width: 200px;
    height: auto;
    object-fit: contain;
}

.admin-nav-section {
    margin-bottom: 12px;
}

.admin-nav-section-title {
    font-size: 0.7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--text-muted);
    padding: 10px 16px;
    margin-top: 20px;
    margin-bottom: 8px;
}

.admin-nav-link {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 14px 18px;
    border-radius: var(--radius);
    color: var(--text-muted);
    font-weight: 500;
    transition: var(--transition);
    margin-bottom: 4px;
}

.admin-nav-link:hover {
    background: rgba(99, 102, 241, 0.12);
    color: var(--text);
    text-decoration: none;
}

.admin-nav-link.active {
    background: linear-gradient(135deg, rgba(99, 102, 241, 0.18), rgba(168, 85, 247, 0.12));
    color: var(--primary);
    border-left: 3px solid var(--primary);
    box-shadow: 0 2px 12px rgba(99, 102, 241, 0.15);
}

.admin-nav-link .icon {
    font-size: 1.2rem;
    width: 24px;
    text-align: center;
}

.admin-nav-link .badge {
    margin-left: auto;
    background: rgba(99, 102, 241, 0.18);
    color: var(--primary);
    padding: 3px 10px;
    border-radius: 20px;
    font-size: 0.75rem;
    font-weight: 600;
}

.admin-sidebar-footer {
    margin-top: auto;
    padding-top: 16px;
    border-top: 1px solid var(--border);
}

/* Main Content Admin - Classes genéricas */
.admin-page .main {
    margin-left: 280px;
    min-height: 100vh;
    padding: 32px 40px;
    position: relative;
    z-index: 1;
}

/* Header Admin */
.admin-page .page-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 32px;
    padding: 24px 28px;
    background: var(--bg-card);
    backdrop-filter: blur(20px);
    border-radius: var(--radius-lg);
    border: 1px solid var(--border);
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.2);
}

.admin-page .page-title {
    font-size: 1.75rem;
    font-weight: 800;
    background: linear-gradient(135deg, #fff 0%, #a5b4fc 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.admin-page .header-actions {
    display: flex;
    gap: 12px;
}

/* Stats Grid Admin */
.admin-page .stats-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 20px;
    margin-bottom: 32px;
}

.admin-page .stat-card {
    background: 
        linear-gradient(145deg, rgba(18, 18, 38, 0.9) 0%, rgba(12, 12, 28, 0.85) 100%);
    backdrop-filter: blur(24px);
    border: 1px solid rgba(99, 102, 241, 0.1);
    border-radius: var(--radius-lg);
    padding: 24px;
    transition: var(--transition);
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    position: relative;
    z-index: 1;
    box-shadow: 
        0 4px 20px rgba(0, 0, 0, 0.2),
        inset 0 1px 0 rgba(255, 255, 255, 0.05);
}

.admin-page .stat-card:hover {
    transform: translateY(-4px);
    border-color: var(--primary);
    box-shadow: 
        0 12px 35px rgba(99, 102, 241, 0.25),
        inset 0 1px 0 rgba(255, 255, 255, 0.1);
}

.admin-page .stat-icon {
    font-size: 2.5rem;
    margin-bottom: 12px;
    filter: drop-shadow(0 4px 8px rgba(0, 0, 0, 0.3));
}

.admin-page .stat-value {
    font-size: 2.2rem;
    font-weight: 800;
    color: var(--text);
    background: linear-gradient(135deg, #fff 0%, #a5b4fc 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.admin-page .stat-label {
    font-size: 0.9rem;
    color: var(--text-muted);
    font-weight: 500;
    margin-top: 4px;
}

/* Cards Admin */
.admin-page .card {
    background: 
        linear-gradient(135deg, rgba(18, 18, 38, 0.9) 0%, rgba(15, 15, 32, 0.85) 100%);
    backdrop-filter: blur(24px);
    border: 1px solid rgba(99, 102, 241, 0.1);
    border-radius: var(--radius-lg);
    margin-bottom: 24px;
    overflow: hidden;
    box-shadow: 
        0 8px 32px rgba(0, 0, 0, 0.25),
        inset 0 1px 0 rgba(255, 255, 255, 0.05);
    position: relative;
    z-index: 1;
}

.admin-page .card-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 20px 24px;
    border-bottom: 1px solid rgba(99, 102, 241, 0.1);
    background: linear-gradient(135deg, rgba(99, 102, 241, 0.08) 0%, rgba(168, 85, 247, 0.04) 100%);
}

.admin-page .card-title {
    font-size: 1.15rem;
    font-weight: 700;
    display: flex;
    align-items: center;
    gap: 10px;
    color: #fff;
}

.admin-page .card-title .icon {
    font-size: 1.3rem;
}

.admin-page .card-body {
    padding: 24px;
}

/* Buttons Admin */
.admin-page .btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 12px 22px;
    border: none;
    border-radius: var(--radius);
    font-family: inherit;
    font-size: 0.9rem;
    font-weight: 600;
    cursor: pointer;
    transition: var(--transition);
    position: relative;
    overflow: hidden;
}

.admin-page .btn::before {
    content: '';
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255,255,255,0.2), transparent);
    transition: left 0.5s;
}

.admin-page .btn:hover::before {
    left: 100%;
}

.admin-page .btn-primary {
    background: linear-gradient(135deg, var(--primary), var(--purple));
    color: #fff;
    box-shadow: 0 4px 15px rgba(59, 130, 246, 0.4);
}

.admin-page .btn-primary:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 25px rgba(59, 130, 246, 0.5);
}

.admin-page .btn-success {
    background: linear-gradient(135deg, var(--success), #16a34a);
    color: #fff;
    box-shadow: 0 4px 15px rgba(34, 197, 94, 0.4);
}

.admin-page .btn-success:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 25px rgba(34, 197, 94, 0.5);
}

.admin-page .btn-danger {
    background: linear-gradient(135deg, var(--danger), #dc2626);
    color: #fff;
    box-shadow: 0 4px 15px rgba(239, 68, 68, 0.4);
}

.admin-page .btn-danger:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 25px rgba(239, 68, 68, 0.5);
}

.admin-page .btn-ghost {
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid var(--border);
    color: var(--text-muted);
    backdrop-filter: blur(10px);
}

.admin-page .btn-ghost:hover {
    background: rgba(255, 255, 255, 0.1);
    color: var(--text);
    border-color: rgba(255, 255, 255, 0.2);
}

.admin-page .btn-sm {
    padding: 8px 14px;
    font-size: 0.8rem;
}

/* Alerts Admin */
.admin-page .alert {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 16px 20px;
    border-radius: var(--radius);
    margin-bottom: 20px;
    font-weight: 500;
    backdrop-filter: blur(10px);
}

.admin-page .alert-success {
    background: var(--success-bg);
    border: 1px solid var(--success);
    color: var(--success);
}

.admin-page .alert-error {
    background: var(--danger-bg);
    border: 1px solid var(--danger);
    color: var(--danger);
}

.admin-page .alert-warning {
    background: var(--warning-bg);
    border: 1px solid var(--warning);
    color: var(--warning);
}

/* Lists Admin */
.admin-page .list {
    list-style: none;
}

.admin-page .list-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 16px 20px;
    background: rgba(15, 15, 30, 0.5);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    margin-bottom: 10px;
    transition: var(--transition);
}

.admin-page .list-item:hover {
    border-color: var(--primary);
    background: rgba(59, 130, 246, 0.08);
    transform: translateX(4px);
}

.admin-page .list-item-content {
    flex: 1;
    min-width: 0;
}

.admin-page .list-item-title {
    font-weight: 600;
    color: var(--text);
    margin-bottom: 4px;
}

.admin-page .list-item-meta {
    font-size: 0.85rem;
    color: var(--text-muted);
}

.admin-page .list-item-actions {
    display: flex;
    gap: 8px;
}

/* Badges Admin */
.admin-page .badge {
    display: inline-flex;
    align-items: center;
    padding: 5px 12px;
    border-radius: 20px;
    font-size: 0.75rem;
    font-weight: 600;
}

.admin-page .badge-success {
    background: linear-gradient(135deg, rgba(34, 197, 94, 0.2) 0%, rgba(16, 185, 129, 0.1) 100%);
    color: var(--success);
}

.admin-page .badge-warning {
    background: linear-gradient(135deg, rgba(245, 158, 11, 0.2) 0%, rgba(217, 119, 6, 0.1) 100%);
    color: var(--warning);
}

/* Forms Admin */
.admin-page .form-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 16px;
}

.admin-page .form-group {
    margin-bottom: 16px;
}

.admin-page .form-group label {
    display: block;
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--text-muted);
    margin-bottom: 12px;
    letter-spacing: 0.02em;
}

.admin-page input, 
.admin-page select, 
.admin-page textarea {
    width: 100%;
    padding: 12px 16px;
    background: var(--bg-input);
    border: 2px solid var(--border);
    border-radius: var(--radius);
    color: var(--text);
    font-family: inherit;
    font-size: 0.95rem;
    transition: var(--transition);
}

.admin-page input:focus, 
.admin-page select:focus, 
.admin-page textarea:focus {
    outline: none;
    border-color: var(--primary);
    box-shadow: 0 0 0 4px rgba(59, 130, 246, 0.15);
}

.admin-page input::placeholder, 
.admin-page textarea::placeholder {
    color: var(--text-muted);
}

.admin-page select {
    cursor: pointer;
}

.admin-page textarea {
    resize: vertical;
    min-height: 100px;
}

/* Quick Add Form */
.admin-page .quick-add {
    background: linear-gradient(135deg, rgba(59, 130, 246, 0.08) 0%, rgba(139, 92, 246, 0.04) 100%);
    border: 2px dashed var(--border);
    border-radius: var(--radius-lg);
    padding: 28px;
    margin-bottom: 24px;
}

.admin-page .quick-add-title {
    font-size: 1.05rem;
    font-weight: 600;
    margin-bottom: 28px;
    padding-bottom: 16px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
    color: var(--text-muted);
}

/* Form Row */
.admin-page .form-row {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
    align-items: flex-end;
}

.admin-page .form-row .form-group {
    flex: 1;
    min-width: 150px;
    margin-bottom: 0;
}

/* Empty State */
.admin-page .empty-state {
    text-align: center;
    padding: 48px 24px;
    color: var(--text-muted);
}

.admin-page .empty-state .icon {
    font-size: 3rem;
    margin-bottom: 16px;
    opacity: 0.5;
}

/* Details / Accordion */
.admin-page details {
    border: 1px solid var(--border);
    border-radius: var(--radius);
    margin-bottom: 12px;
    overflow: hidden;
    background: var(--bg-card);
}

.admin-page details summary {
    padding: 16px 20px;
    background: rgba(15, 15, 30, 0.5);
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 12px;
    font-weight: 600;
    transition: var(--transition);
    list-style: none;
}

.admin-page details summary::-webkit-details-marker { display: none; }

.admin-page details summary:hover {
    background: rgba(59, 130, 246, 0.08);
}

.admin-page details[open] summary {
    border-bottom: 1px solid var(--border);
}

.admin-page details .content {
    padding: 20px;
}

/* Table Admin */
.admin-page table {
    width: 100%;
    border-collapse: collapse;
}

.admin-page th, 
.admin-page td {
    padding: 14px 16px;
    text-align: left;
    border-bottom: 1px solid var(--border);
}

.admin-page th {
    background: rgba(15, 15, 30, 0.5);
    font-weight: 600;
    font-size: 0.85rem;
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.admin-page tr:hover td {
    background: rgba(59, 130, 246, 0.05);
}

/* Responsive Admin */
@media (max-width: 1024px) {
    .admin-sidebar {
        width: 80px;
        padding: 16px 8px;
    }
    
    .admin-sidebar-brand span,
    .admin-nav-section-title,
    .admin-nav-link span:not(.icon),
    .admin-nav-link .badge {
        display: none;
    }
    
    .admin-nav-link {
        justify-content: center;
        padding: 14px;
    }
    
    .admin-page .main {
        margin-left: 80px;
    }
}

@media (max-width: 768px) {
    .admin-sidebar {
        position: fixed;
        bottom: 0;
        top: auto;
        left: 0;
        right: 0;
        width: 100%;
        height: auto;
        flex-direction: row;
        padding: 8px 16px;
        border-right: none;
        border-top: 1px solid var(--border);
    }
    
    .admin-sidebar-brand,
    .admin-nav-section-title,
    .admin-sidebar-footer {
        display: none;
    }
    
    .admin-nav-section {
        display: flex;
        gap: 4px;
        margin: 0;
        overflow-x: auto;
    }
    
    .admin-nav-link {
        padding: 12px;
        flex-direction: column;
        gap: 4px;
        font-size: 0.7rem;
    }
    
    .admin-nav-link .icon {
        font-size: 1.4rem;
    }
    
    .admin-nav-link span:not(.icon) {
        display: block;
    }
    
    .admin-page .main {
        margin-left: 0;
        margin-bottom: 80px;
        padding: 16px;
    }
    
    .admin-page .page-header {
        flex-direction: column;
        gap: 16px;
        align-items: flex-start;
    }
    
    .admin-page .stats-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

/* Scrollbar Admin */
.admin-page ::-webkit-scrollbar {
    width: 8px;
    height: 8px;
}

.admin-page ::-webkit-scrollbar-track {
    background: var(--bg);
}

.admin-page ::-webkit-scrollbar-thumb {
    background: var(--border);
    border-radius: 4px;
}

.admin-page ::-webkit-scrollbar-thumb:hover {
    background: var(--text-muted);
}

/* Form Inline Admin */
.admin-form-inline {
    display: inline-flex;
    margin: 0;
}

.admin-form-row {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
    align-items: flex-end;
}

.admin-form-row .admin-form-group {
    flex: 1;
    min-width: 150px;
    margin-bottom: 0;
}

/* Empty State Admin */
.admin-empty-state {
    text-align: center;
    padding: 48px 24px;
    color: var(--text-muted);
}

.admin-empty-state .icon {
    font-size: 3rem;
    margin-bottom: 16px;
    opacity: 0.5;
}

/* Quick Add Form Admin */
.admin-quick-add {
    background: linear-gradient(135deg, rgba(59, 130, 246, 0.1), rgba(139, 92, 246, 0.05));
    border: 2px dashed var(--border);
    border-radius: var(--radius-lg);
    padding: 24px;
    margin-bottom: 24px;
}

.admin-quick-add-title {
    font-size: 1rem;
    font-weight: 600;
    margin-bottom: 16px;
    color: var(--text-muted);
}

/* ==================== LOGIN.PHP ==================== */
.login-page body {
    min-height: 100vh;
    display: flex;
    font-family: 'Inter', 'Segoe UI', system-ui, -apple-system, sans-serif !important;
    background: #0f172a !important;
    /* Reset global styles */
    padding-left: 0 !important;
    padding-top: 0 !important;
    margin: 0 !important;
}

/* Painel Esquerdo - Branding */
.login-branding {
    flex: 1.2;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    padding: 60px 80px;
    position: relative;
    background: linear-gradient(165deg, #0f172a 0%, #1e1b4b 40%, #312e81 70%, #3730a3 100%);
    overflow: hidden;
}

.login-branding::before {
    content: '';
    position: absolute;
    width: 800px;
    height: 800px;
    background: radial-gradient(circle, rgba(99, 102, 241, 0.15) 0%, transparent 60%);
    top: -300px;
    left: -300px;
    animation: login-float-slow 20s ease-in-out infinite;
}

.login-branding::after {
    content: '';
    position: absolute;
    width: 600px;
    height: 600px;
    background: radial-gradient(circle, rgba(139, 92, 246, 0.12) 0%, transparent 60%);
    bottom: -200px;
    right: -200px;
    animation: login-float-slow 15s ease-in-out infinite reverse;
}

@keyframes login-float-slow {
    0%, 100% { transform: translate(0, 0) scale(1); }
    50% { transform: translate(30px, -30px) scale(1.05); }
}

/* Partículas decorativas */
.particles {
    position: absolute;
    inset: 0;
    overflow: hidden;
    pointer-events: none;
}

.particle {
    position: absolute;
    width: 4px;
    height: 4px;
    background: rgba(255, 255, 255, 0.3);
    border-radius: 50%;
    animation: particle-float 8s ease-in-out infinite;
}

.particle:nth-child(1) { left: 10%; top: 20%; animation-delay: 0s; }
.particle:nth-child(2) { left: 20%; top: 80%; animation-delay: 1s; }
.particle:nth-child(3) { left: 60%; top: 40%; animation-delay: 2s; }
.particle:nth-child(4) { left: 80%; top: 60%; animation-delay: 3s; }
.particle:nth-child(5) { left: 40%; top: 10%; animation-delay: 4s; }
.particle:nth-child(6) { left: 90%; top: 30%; animation-delay: 5s; }

@keyframes particle-float {
    0%, 100% { transform: translateY(0) scale(1); opacity: 0.3; }
    50% { transform: translateY(-20px) scale(1.5); opacity: 0.8; }
}

.branding-content {
    position: relative;
    z-index: 1;
    text-align: center;
    max-width: 520px;
}

/* Logo animado */
.branding-logo {
    width: 100px;
    height: 100px;
    background: linear-gradient(135deg, #6366f1 0%, #8b5cf6 50%, #a855f7 100%);
    border-radius: 28px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 36px;
    box-shadow: 
        0 25px 50px -12px rgba(99, 102, 241, 0.4),
        0 0 80px rgba(139, 92, 246, 0.3);
    animation: logo-float 5s ease-in-out infinite;
    position: relative;
}

.branding-logo::before {
    content: '';
    position: absolute;
    inset: -3px;
    border-radius: 30px;
    background: linear-gradient(135deg, #818cf8 0%, #a78bfa 50%, #c084fc 100%);
    z-index: -1;
    opacity: 0.5;
    animation: pulse-ring 3s ease-in-out infinite;
}

.branding-logo svg {
    width: 50px;
    height: 50px;
    stroke: white;
    stroke-width: 2;
    fill: none;
}

@keyframes logo-float {
    0%, 100% { transform: translateY(0) rotate(0deg); }
    50% { transform: translateY(-12px) rotate(2deg); }
}

@keyframes pulse-ring {
    0%, 100% { transform: scale(1); opacity: 0.5; }
    50% { transform: scale(1.08); opacity: 0.8; }
}

.branding-title {
    font-size: 2.75rem;
    font-weight: 800;
    color: #ffffff;
    margin-bottom: 16px;
    letter-spacing: -1px;
    text-shadow: 0 4px 30px rgba(99, 102, 241, 0.3);
}

.branding-subtitle {
    font-size: 1.1rem;
    color: rgba(255, 255, 255, 0.65);
    line-height: 1.8;
    margin-bottom: 50px;
    max-width: 420px;
    margin-left: auto;
    margin-right: auto;
}

/* Features Cards */
.branding-features {
    display: flex;
    flex-direction: column;
    gap: 14px;
}

.feature-item {
    display: flex;
    align-items: center;
    gap: 18px;
    padding: 18px 24px;
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 18px;
    backdrop-filter: blur(20px);
    transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

.feature-item:hover {
    background: rgba(255, 255, 255, 0.08);
    border-color: rgba(255, 255, 255, 0.15);
    transform: translateX(10px);
    box-shadow: 0 10px 40px -10px rgba(99, 102, 241, 0.3);
}

.feature-icon {
    width: 48px;
    height: 48px;
    background: linear-gradient(135deg, rgba(99, 102, 241, 0.2) 0%, rgba(139, 92, 246, 0.3) 100%);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 14px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.feature-icon svg {
    width: 24px;
    height: 24px;
    stroke: #a5b4fc;
    stroke-width: 2;
    fill: none;
}

.feature-text {
    color: rgba(255, 255, 255, 0.85);
    font-size: 0.95rem;
    font-weight: 500;
    letter-spacing: 0.2px;
}

/* Painel Direito - Formulário */
.login-form-panel {
    width: 480px;
    min-width: 480px;
    min-height: 100vh;
    background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%);
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: 60px 56px;
    position: relative;
    box-shadow: -20px 0 60px rgba(0, 0, 0, 0.15);
}

.login-form-panel::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 5px;
    height: 100%;
    background: linear-gradient(180deg, #6366f1 0%, #8b5cf6 40%, #a855f7 70%, #c084fc 100%);
}

.login-form-panel::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 200px;
    background: linear-gradient(180deg, rgba(99, 102, 241, 0.03) 0%, transparent 100%);
    pointer-events: none;
}

.form-content {
    position: relative;
    z-index: 1;
    max-width: 360px;
    margin: 0 auto;
    width: 100%;
}

/* Header do formulário */
.form-header {
    margin-bottom: 36px;
    text-align: center;
}

.form-header-icon {
    width: 64px;
    height: 64px;
    background: linear-gradient(135deg, #eef2ff 0%, #e0e7ff 100%);
    border: 2px solid #c7d2fe;
    border-radius: 20px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 20px;
    animation: bounce-subtle 3s ease-in-out infinite;
}

.form-header-icon svg {
    width: 32px;
    height: 32px;
    stroke: #6366f1;
    stroke-width: 2;
    fill: none;
}

@keyframes bounce-subtle {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(-5px); }
}

.form-header h1 {
    font-size: 1.75rem;
    font-weight: 800;
    color: #1e293b;
    margin-bottom: 8px;
    letter-spacing: -0.5px;
}

.form-header p {
    color: #64748b;
    font-size: 0.95rem;
    line-height: 1.5;
}

/* Mensagem de erro */
.error-message {
    display: flex;
    align-items: center;
    gap: 14px;
    background: linear-gradient(135deg, #fef2f2 0%, #fee2e2 100%);
    border: 1px solid #fecaca;
    color: #dc2626;
    padding: 16px 20px;
    border-radius: 16px;
    margin-bottom: 28px;
    font-weight: 500;
    font-size: 0.9rem;
    animation: shake 0.5s ease-in-out, fade-in 0.3s ease;
}

@keyframes shake {
    0%, 100% { transform: translateX(0); }
    20%, 60% { transform: translateX(-6px); }
    40%, 80% { transform: translateX(6px); }
}

.error-icon {
    width: 40px;
    height: 40px;
    background: linear-gradient(135deg, #dc2626 0%, #ef4444 100%);
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.error-icon svg {
    width: 20px;
    height: 20px;
    stroke: white;
    stroke-width: 2.5;
    fill: none;
}

/* Grupos de formulário - Login */
.login-page .form-group {
    margin-bottom: 22px;
}

.login-page .form-group label {
    display: block;
    font-size: 0.8rem;
    font-weight: 700;
    color: #475569;
    margin-bottom: 10px;
    text-transform: uppercase;
    letter-spacing: 0.8px;
}

.input-wrapper {
    position: relative;
}

.input-icon {
    position: absolute;
    left: 18px;
    top: 50%;
    transform: translateY(-50%);
    pointer-events: none;
    transition: all 0.3s ease;
    z-index: 2;
}

.input-icon svg {
    width: 20px;
    height: 20px;
    stroke: #94a3b8;
    stroke-width: 2;
    fill: none;
    transition: stroke 0.3s ease;
}

.form-input {
    width: 100%;
    padding: 18px 18px 18px 54px;
    font-size: 1rem;
    font-family: inherit;
    font-weight: 500;
    border: 2px solid #e2e8f0;
    border-radius: 16px;
    background: #ffffff;
    color: #1e293b;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    outline: none;
}

.form-input:hover {
    border-color: #cbd5e1;
}

.form-input:focus {
    border-color: #6366f1;
    background: #ffffff;
    box-shadow: 0 0 0 4px rgba(99, 102, 241, 0.12), 0 4px 20px rgba(99, 102, 241, 0.1);
}

.input-wrapper:focus-within .input-icon svg {
    stroke: #6366f1;
}

.form-input::placeholder {
    color: #94a3b8;
    font-weight: 400;
}

/* Toggle de senha */
.password-toggle {
    position: absolute;
    right: 14px;
    top: 50%;
    transform: translateY(-50%);
    background: transparent;
    border: none;
    cursor: pointer;
    padding: 8px;
    border-radius: 10px;
    transition: all 0.3s ease;
    display: flex;
    align-items: center;
    justify-content: center;
}

.password-toggle svg {
    width: 22px;
    height: 22px;
    stroke: #94a3b8;
    stroke-width: 2;
    fill: none;
    transition: stroke 0.3s ease;
}

.password-toggle:hover {
    background: #f1f5f9;
}

.password-toggle:hover svg {
    stroke: #6366f1;
}

/* Botão de submit - Login */
.submit-btn {
    width: 100%;
    padding: 18px 32px;
    margin-top: 8px;
    font-size: 1rem;
    font-weight: 700;
    font-family: inherit;
    color: #ffffff;
    background: linear-gradient(135deg, #6366f1 0%, #8b5cf6 100%);
    border: none;
    border-radius: 16px;
    cursor: pointer;
    transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 12px;
    text-transform: uppercase;
    letter-spacing: 1.2px;
    box-shadow: 0 8px 30px -8px rgba(99, 102, 241, 0.5);
    position: relative;
    overflow: hidden;
}

.submit-btn::before {
    content: '';
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.25), transparent);
    transition: left 0.6s ease;
}

.submit-btn:hover::before {
    left: 100%;
}

.submit-btn:hover {
    transform: translateY(-3px);
    box-shadow: 0 14px 40px -8px rgba(99, 102, 241, 0.6);
}

.submit-btn:active {
    transform: translateY(-1px);
}

.submit-btn svg {
    width: 20px;
    height: 20px;
    stroke: currentColor;
    stroke-width: 2.5;
    fill: none;
    transition: transform 0.3s ease;
}

.submit-btn:hover svg {
    transform: translateX(4px);
}

/* Footer do formulário - Login */
.form-footer {
    margin-top: 32px;
    text-align: center;
}

.divider {
    display: flex;
    align-items: center;
    gap: 16px;
    margin-bottom: 24px;
    color: #94a3b8;
    font-size: 0.85rem;
}

.divider::before,
.divider::after {
    content: '';
    flex: 1;
    height: 1px;
    background: #e2e8f0;
}

.login-page .back-link {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    color: #64748b;
    text-decoration: none;
    font-weight: 600;
    font-size: 0.95rem;
    padding: 14px 28px;
    border-radius: 14px;
    border: 2px solid #e2e8f0;
    transition: all 0.3s ease;
    background: #ffffff;
}

.login-page .back-link svg {
    width: 18px;
    height: 18px;
    stroke: currentColor;
    stroke-width: 2;
    fill: none;
    transition: transform 0.3s ease;
}

.login-page .back-link:hover {
    color: #6366f1;
    border-color: #c7d2fe;
    background: #eef2ff;
}

.login-page .back-link:hover svg {
    transform: translateX(-4px);
}

/* Responsivo - Login */
@media (max-width: 1100px) {
    .login-branding {
        padding: 40px 50px;
    }
    
    .branding-title {
        font-size: 2.25rem;
    }
}

@media (max-width: 900px) {
    .login-branding {
        display: none;
    }

    .login-page body {
        background: linear-gradient(180deg, #f8fafc 0%, #ffffff 100%);
    }

    .login-form-panel {
        width: 100%;
        min-width: unset;
        box-shadow: none;
        background: transparent;
    }

    .login-form-panel::before {
        display: none;
    }

    .form-content {
        max-width: 400px;
    }
}

@media (max-width: 480px) {
    .login-form-panel {
        padding: 40px 24px;
    }

    .form-header h1 {
        font-size: 1.5rem;
    }

    .form-input {
        padding: 16px 16px 16px 50px;
    }

    .submit-btn {
        padding: 16px 24px;
    }
}

/* Tema Escuro - Login */
@media (prefers-color-scheme: dark) {
    .login-form-panel {
        background: linear-gradient(180deg, #0f172a 0%, #1e293b 100%);
    }

    .login-form-panel::after {
        background: linear-gradient(180deg, rgba(99, 102, 241, 0.05) 0%, transparent 100%);
    }

    .form-header-icon {
        background: linear-gradient(135deg, #312e81 0%, #3730a3 100%);
        border-color: #4f46e5;
    }

    .form-header-icon svg {
        stroke: #a5b4fc;
    }

    .form-header h1 {
        color: #f1f5f9;
    }

    .form-header p {
        color: #94a3b8;
    }

    .login-page .form-group label {
        color: #cbd5e1;
    }

    .form-input {
        background: #1e293b;
        border-color: #334155;
        color: #f1f5f9;
    }

    .form-input:hover {
        border-color: #475569;
    }

    .form-input:focus {
        background: #1e293b;
        border-color: #6366f1;
    }

    .password-toggle:hover {
        background: #334155;
    }

    .login-page .back-link {
        color: #94a3b8;
        background: #1e293b;
        border-color: #334155;
    }

    .login-page .back-link:hover {
        color: #a5b4fc;
        background: #312e81;
        border-color: #4f46e5;
    }

    .divider {
        color: #64748b;
    }

    .divider::before,
    .divider::after {
        background: #334155;
    }

    @media (max-width: 900px) {
        .login-page body {
            background: linear-gradient(180deg, #0f172a 0%, #1e293b 100%);
        }
    }
}
