*{margin:0;padding:0;box-sizing:border-box}
html,body{font-family:'Segoe UI',Tahoma,Arial,sans-serif;color:#1f2937}
.login-body{min-height:100vh;background:linear-gradient(135deg,#0c4a6e,#0369a1 50%,#0284c7);display:flex;align-items:center;justify-content:center;padding:20px}
.login-wrap{width:100%;max-width:420px}
.login-card{background:#fff;border-radius:18px;padding:40px 36px;box-shadow:0 25px 60px rgba(0,0,0,.3)}
.login-logo{font-size:48px;text-align:center;margin-bottom:8px}
.login-card h1{text-align:center;color:#0c4a6e;font-size:24px;margin-bottom:6px}
.login-sub{text-align:center;color:#64748b;font-size:14px;margin-bottom:28px}
.login-card label{display:block;font-size:13px;color:#374151;margin-top:14px;margin-bottom:6px;font-weight:600}
.login-card input{width:100%;padding:12px 14px;border:1.5px solid #cbd5e1;border-radius:8px;font-size:15px}
.login-card input:focus{outline:0;border-color:#0284c7;box-shadow:0 0 0 3px rgba(2,132,199,.15)}
.btn-login{width:100%;margin-top:22px;padding:13px;background:linear-gradient(135deg,#0369a1,#0284c7);color:#fff;border:0;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer}
.btn-login:hover{transform:translateY(-1px);box-shadow:0 8px 16px rgba(2,132,199,.3)}
.alert{padding:11px 14px;border-radius:8px;margin-bottom:14px;font-size:14px}
.alert-err{background:#fee2e2;color:#991b1b;border:1px solid #fecaca}
.alert-warn{background:#fef3c7;color:#92400e;border:1px solid #fde68a}
.alert-info{background:#dbeafe;color:#1e3a8a;border:1px solid #bfdbfe}
.login-foot{text-align:center;margin-top:24px;color:#94a3b8;font-size:12px}
.dash{background:#f1f5f9;min-height:100vh}
.topbar{background:linear-gradient(135deg,#0c4a6e,#0369a1);color:#fff;padding:14px 28px;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 8px rgba(0,0,0,.15)}
.brand{display:flex;align-items:center;gap:14px}
.brand .logo{font-size:32px}
.brand-name{font-weight:700;font-size:17px}
.brand-sub{font-size:12px;opacity:.85}
.user-area{display:flex;align-items:center;gap:14px;font-size:14px}
.badge{padding:4px 10px;border-radius:12px;font-size:11px;font-weight:700}
.badge.admin{background:#facc15;color:#713f12}
.badge.user{background:rgba(255,255,255,.2);color:#fff}
.btn{padding:7px 14px;border-radius:6px;text-decoration:none;font-size:13px;font-weight:600}
.btn-admin{background:#fbbf24;color:#7c2d12}
.btn-admin:hover{background:#f59e0b}
.btn-logout{background:#ef4444;color:#fff}
.btn-logout:hover{background:#dc2626}
.container{max-width:1200px;margin:0 auto;padding:30px 24px}
.container h1{color:#0c4a6e;font-size:28px;margin-bottom:6px}
.subtitle{color:#64748b;margin-bottom:24px}
.cat{color:#0369a1;font-size:18px;margin:24px 0 12px;padding-bottom:8px;border-bottom:2px solid #e0f2fe}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:18px}
.card{background:#fff;border-radius:14px;padding:22px;text-decoration:none;color:#1f2937;box-shadow:0 4px 12px rgba(0,0,0,.06);transition:.25s;border:1px solid #e2e8f0;display:block}
.card:hover{transform:translateY(-3px);box-shadow:0 12px 28px rgba(2,132,199,.18);border-color:#0284c7}
.card-icon{font-size:38px;margin-bottom:10px}
.card-title{font-size:17px;font-weight:700;color:#0c4a6e;margin-bottom:6px}
.card-desc{font-size:13px;color:#64748b;line-height:1.5;min-height:38px}
.card-action{margin-top:14px;color:#0284c7;font-weight:600;font-size:13px}
.empty{background:#fff;border-radius:14px;padding:40px;text-align:center;color:#64748b;border:2px dashed #cbd5e1}
.empty h2{color:#0c4a6e;margin-bottom:10px}
.foot{text-align:center;padding:24px;color:#94a3b8;font-size:13px}
.admin-nav{background:#fff;border-bottom:1px solid #e2e8f0;padding:0 28px;display:flex;gap:4px}
.admin-nav a{padding:14px 20px;color:#475569;text-decoration:none;font-size:14px;font-weight:600;border-bottom:3px solid transparent}
.admin-nav a:hover{color:#0369a1}
.admin-nav a.active{color:#0369a1;border-bottom-color:#0369a1}
.panel{background:#fff;border-radius:12px;padding:24px;box-shadow:0 2px 8px rgba(0,0,0,.05);margin-bottom:20px}
.panel h2{color:#0c4a6e;font-size:20px;margin-bottom:16px}
.btn-primary{background:#0284c7;color:#fff;padding:8px 16px;border:0;border-radius:6px;cursor:pointer;text-decoration:none;font-size:13px;font-weight:600;display:inline-block}
.btn-primary:hover{background:#0369a1}
.btn-danger{background:#ef4444;color:#fff;padding:6px 12px;border:0;border-radius:6px;cursor:pointer;font-size:12px}
.btn-edit{background:#facc15;color:#713f12;padding:6px 12px;border-radius:6px;text-decoration:none;font-size:12px;font-weight:600;display:inline-block}
.btn-edit:hover{background:#f59e0b}
table{width:100%;border-collapse:collapse;margin-top:8px}
table th{background:#f1f5f9;padding:11px 14px;text-align:left;font-size:13px;color:#475569;font-weight:700;border-bottom:2px solid #e2e8f0}
table td{padding:11px 14px;font-size:14px;border-bottom:1px solid #e2e8f0}
table tr:hover{background:#f8fafc}
.form-group{margin-bottom:14px}
.form-group label{display:block;font-size:13px;font-weight:600;margin-bottom:5px;color:#374151}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:9px 12px;border:1.5px solid #cbd5e1;border-radius:6px;font-size:14px;font-family:inherit}
.form-group textarea{font-family:Consolas,monospace;font-size:12px;min-height:80px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.checkbox-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:8px;margin-top:10px}
.checkbox-grid label{display:flex;align-items:center;gap:8px;background:#f1f5f9;padding:8px 12px;border-radius:6px;cursor:pointer;font-size:14px}
.checkbox-grid label:hover{background:#e0f2fe}
.tag{display:inline-block;padding:2px 8px;background:#e0f2fe;color:#0369a1;border-radius:4px;font-size:11px;font-weight:600}
.tag.role-admin{background:#fef3c7;color:#92400e}
.flash{padding:12px 16px;border-radius:8px;margin-bottom:16px;font-size:14px}
.flash.ok{background:#d1fae5;color:#065f46}
.flash.err{background:#fee2e2;color:#991b1b}


/* ============================================================
   Revitalização Portal Orla — UI moderna 2026
   ============================================================ */
:root{
  --orla-bg:#f8fafc;
  --orla-surface:#ffffff;
  --orla-text:#0f172a;
  --orla-muted:#64748b;
  --orla-border:#e2e8f0;
  --orla-primary:#0ea5e9;
  --orla-primary-dark:#1e3a8a;
  --orla-success:#16a34a;
  --orla-danger:#dc2626;
  --orla-warn:#ea580c;
}
html,body{font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Arial,sans-serif}
.login-body{
  background:
    radial-gradient(circle at 20% 10%, rgba(14,165,233,.32), transparent 30%),
    radial-gradient(circle at 80% 20%, rgba(30,58,138,.38), transparent 26%),
    linear-gradient(135deg,#020617,#0f172a 48%,#075985);
}
.login-card{
  border:1px solid rgba(255,255,255,.16);
  box-shadow:0 30px 90px rgba(2,6,23,.45);
}
.topbar{
  background:linear-gradient(135deg,#0f172a,#1e3a8a 55%,#0ea5e9);
  color:#fff;
  min-height:76px;
}
.logo img,.login-logo img{object-fit:contain}
.brand-name{letter-spacing:.01em}
.brand-sub{color:rgba(255,255,255,.78)}
.user-area .last-access b{color:#fff!important}
.user-area .last-access small{color:rgba(255,255,255,.74)!important}
.container{max-width:1320px}
.card,.panel,.empty{
  border-radius:18px;
  border:1px solid var(--orla-border);
  box-shadow:0 10px 30px rgba(15,23,42,.06);
}
.card:hover{
  transform:translateY(-4px);
  box-shadow:0 18px 45px rgba(14,165,233,.18);
}
.btn,.btn-primary,.btn-login,.btn-admin,.btn-logout,.btn-danger,.btn-edit{
  border-radius:12px;
  transition:transform .18s ease, box-shadow .18s ease, background .18s ease;
}
.btn:hover,.btn-primary:hover,.btn-login:hover,.btn-admin:hover,.btn-logout:hover{
  transform:translateY(-1px);
  box-shadow:0 10px 22px rgba(15,23,42,.14);
}
.admin-nav{
  background:rgba(255,255,255,.92);
  backdrop-filter:blur(14px);
  position:sticky;
  top:0;
  z-index:20;
}
input,select,textarea{
  border-radius:12px!important;
}
table th{
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:.04em;
}
.flash{
  padding:13px 16px;
  border-radius:14px;
  margin-bottom:16px;
  border:1px solid;
}
.flash.ok{background:#dcfce7;color:#166534;border-color:#86efac}
.flash.err{background:#fee2e2;color:#991b1b;border-color:#fecaca}
@media(max-width:760px){
  .topbar{align-items:flex-start;flex-direction:column;padding:18px}
  .user-area{width:100%;justify-content:flex-start;flex-wrap:wrap}
  .admin-nav{overflow-x:auto}
}


/* ===== Temas administráveis ===== */
.remember-check{display:flex!important;align-items:center;gap:8px;margin:14px 0 0!important;font-size:13px!important;color:#475569!important;font-weight:500!important;text-transform:none!important;letter-spacing:0!important}
.remember-check input{width:auto!important}

body.theme-dark,
body.theme-tech{
    color:#e2e8f0;
}
body.theme-dark{
    background:#0f172a;
}
body.theme-tech{
    background:
      radial-gradient(circle at 18% 12%, rgba(14,165,233,.20), transparent 28%),
      radial-gradient(circle at 82% 0%, rgba(147,51,234,.18), transparent 26%),
      linear-gradient(135deg,#020617 0%, #0f172a 48%, #082f49 100%);
    background-attachment:fixed;
}
body.theme-tech::before{
    content:"";position:fixed;inset:0;pointer-events:none;opacity:.18;z-index:-1;
    background-image:
      linear-gradient(rgba(14,165,233,.20) 1px, transparent 1px),
      linear-gradient(90deg, rgba(14,165,233,.20) 1px, transparent 1px);
    background-size:42px 42px;
}
body.theme-dark .topbar,
body.theme-tech .topbar{
    background:rgba(2,6,23,.78);
    border-bottom:1px solid rgba(148,163,184,.20);
    backdrop-filter:blur(16px);
}
body.theme-dark .admin-nav,
body.theme-tech .admin-nav{
    background:rgba(15,23,42,.86);
    border-bottom-color:rgba(148,163,184,.18);
    backdrop-filter:blur(12px);
}
body.theme-dark .admin-nav a,
body.theme-tech .admin-nav a{color:#94a3b8}
body.theme-dark .admin-nav a:hover,
body.theme-tech .admin-nav a:hover{color:#e2e8f0;background:rgba(30,41,59,.75)}
body.theme-dark .admin-nav a.active,
body.theme-tech .admin-nav a.active{color:#38bdf8;border-bottom-color:#38bdf8}
body.theme-dark .container h1,
body.theme-tech .container h1,
body.theme-dark .panel h2,
body.theme-tech .panel h2,
body.theme-dark .panel h3,
body.theme-tech .panel h3,
body.theme-dark .card-title,
body.theme-tech .card-title{color:#f8fafc}
body.theme-dark .subtitle,
body.theme-tech .subtitle,
body.theme-dark .card-desc,
body.theme-tech .card-desc{color:#94a3b8}
body.theme-dark .panel,
body.theme-tech .panel,
body.theme-dark .card,
body.theme-tech .card,
body.theme-dark .filter-bar,
body.theme-tech .filter-bar,
body.theme-dark .admin-kpi,
body.theme-tech .admin-kpi{
    background:rgba(15,23,42,.86);
    border-color:rgba(148,163,184,.18);
    box-shadow:0 18px 50px rgba(2,6,23,.30);
}
body.theme-dark table th,
body.theme-tech table th{background:rgba(2,6,23,.65);color:#94a3b8;border-bottom-color:rgba(148,163,184,.18)}
body.theme-dark table td,
body.theme-tech table td{color:#e2e8f0;border-bottom-color:rgba(148,163,184,.12)}
body.theme-dark table tr:hover td,
body.theme-tech table tr:hover td{background:rgba(30,41,59,.55)}
body.theme-dark .form-group label,
body.theme-tech .form-group label{color:#cbd5e1}
body.theme-dark .form-group input,
body.theme-dark .form-group select,
body.theme-dark .form-group textarea,
body.theme-tech .form-group input,
body.theme-tech .form-group select,
body.theme-tech .form-group textarea,
body.theme-dark .filter-bar input[type=text],
body.theme-dark .filter-bar select,
body.theme-tech .filter-bar input[type=text],
body.theme-tech .filter-bar select{
    background:rgba(2,6,23,.65);
    color:#e2e8f0;
    border-color:rgba(148,163,184,.30);
}
body.theme-dark .logo,
body.theme-tech .logo{
    background:#fff;
}
body.theme-dark .foot,
body.theme-tech .foot{
    background:rgba(2,6,23,.72);
    border-top-color:rgba(148,163,184,.18);
}
body.theme-dark .tag,
body.theme-tech .tag{background:rgba(30,41,59,.95);color:#cbd5e1}
body.theme-dark .btn-edit,
body.theme-tech .btn-edit{background:rgba(30,41,59,.95);color:#e2e8f0;border-color:rgba(148,163,184,.22)}


/* Correção de temas globais */
body.theme-light{
  background:#f1f5f9 !important;
  color:#1f2937 !important;
}
body.theme-dark{
  background:#020617 !important;
  color:#e2e8f0 !important;
}
body.theme-tech{
  background:
    radial-gradient(circle at 18% 12%, rgba(14,165,233,.24), transparent 30%),
    radial-gradient(circle at 85% 8%, rgba(147,51,234,.22), transparent 28%),
    linear-gradient(135deg,#020617 0%,#0f172a 48%,#111827 100%) !important;
  color:#e2e8f0 !important;
  background-attachment:fixed !important;
}
body.theme-tech:before{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  opacity:.18;
  background-image:
    linear-gradient(rgba(14,165,233,.18) 1px, transparent 1px),
    linear-gradient(90deg, rgba(14,165,233,.18) 1px, transparent 1px);
  background-size:42px 42px;
  z-index:-1;
}
body.theme-dark .topbar,
body.theme-tech .topbar{
  background:linear-gradient(135deg,#020617,#0f172a 54%,#0ea5e9) !important;
}
body.theme-dark .admin-nav,
body.theme-tech .admin-nav{
  background:rgba(2,6,23,.88) !important;
  border-bottom-color:rgba(148,163,184,.18) !important;
}
body.theme-dark .admin-nav a,
body.theme-tech .admin-nav a{color:#cbd5e1 !important}
body.theme-dark .admin-nav a.active,
body.theme-tech .admin-nav a.active{color:#38bdf8 !important;border-bottom-color:#38bdf8 !important}
body.theme-dark .container h1,
body.theme-tech .container h1,
body.theme-dark .panel h2,
body.theme-tech .panel h2,
body.theme-dark .panel h3,
body.theme-tech .panel h3,
body.theme-dark .card-title,
body.theme-tech .card-title{color:#f8fafc !important}
body.theme-dark .subtitle,
body.theme-tech .subtitle,
body.theme-dark .card-desc,
body.theme-tech .card-desc,
body.theme-dark .user-area .last-access,
body.theme-tech .user-area .last-access,
body.theme-dark .user-area .last-access small,
body.theme-tech .user-area .last-access small{color:#94a3b8 !important}
body.theme-dark .user-area .last-access b,
body.theme-tech .user-area .last-access b{color:#e2e8f0 !important}
body.theme-dark .panel,
body.theme-tech .panel,
body.theme-dark .card,
body.theme-tech .card,
body.theme-dark .filter-bar,
body.theme-tech .filter-bar,
body.theme-dark .admin-kpi,
body.theme-tech .admin-kpi{
  background:rgba(15,23,42,.88) !important;
  border-color:rgba(148,163,184,.18) !important;
  box-shadow:0 18px 50px rgba(2,6,23,.30) !important;
}
body.theme-dark table th,
body.theme-tech table th{background:rgba(2,6,23,.70) !important;color:#94a3b8 !important;border-bottom-color:rgba(148,163,184,.18) !important}
body.theme-dark table td,
body.theme-tech table td{color:#e2e8f0 !important;border-bottom-color:rgba(148,163,184,.12) !important}
body.theme-dark table tr:hover,
body.theme-tech table tr:hover,
body.theme-dark table tr:hover td,
body.theme-tech table tr:hover td{background:rgba(30,41,59,.55) !important}
body.theme-dark .form-group label,
body.theme-tech .form-group label{color:#cbd5e1 !important}
body.theme-dark .form-group input,
body.theme-dark .form-group select,
body.theme-dark .form-group textarea,
body.theme-tech .form-group input,
body.theme-tech .form-group select,
body.theme-tech .form-group textarea,
body.theme-dark .filter-bar input[type=text],
body.theme-dark .filter-bar select,
body.theme-tech .filter-bar input[type=text],
body.theme-tech .filter-bar select{
  background:rgba(2,6,23,.65) !important;
  color:#e2e8f0 !important;
  border-color:rgba(148,163,184,.30) !important;
}
body.theme-dark .login-card,
body.theme-tech .login-card{
  background:rgba(15,23,42,.94) !important;
  color:#e2e8f0 !important;
  border:1px solid rgba(148,163,184,.18) !important;
}
body.theme-dark .login-card h1,
body.theme-tech .login-card h1{color:#f8fafc !important}
body.theme-dark .login-sub,
body.theme-tech .login-sub{color:#94a3b8 !important}
body.theme-dark .login-card label,
body.theme-tech .login-card label{color:#cbd5e1 !important}
body.theme-dark .login-card input,
body.theme-tech .login-card input{
  background:#020617 !important;
  color:#e2e8f0 !important;
  border-color:#334155 !important;
}
body.theme-dark .foot,
body.theme-tech .foot{
  background:rgba(2,6,23,.72) !important;
  border-top-color:rgba(148,163,184,.18) !important;
}


/* ===== Configurações visuais aplicadas pelo Admin ===== */
body{
  --orla-primary: var(--orla-primary, #0ea5e9);
  --orla-primary-dark: var(--orla-primary-dark, #1e3a8a);
}
.topbar{background:linear-gradient(135deg,var(--orla-primary-dark),var(--orla-primary))!important}
.btn-login,.btn-primary{background:linear-gradient(135deg,var(--orla-primary-dark),var(--orla-primary))!important}
.btn-admin{background:var(--orla-primary)!important;color:#fff!important}
.admin-nav a:hover,.admin-nav a.active{color:var(--orla-primary-dark)!important}
.admin-nav a.active{border-bottom-color:var(--orla-primary)!important}
.container h1,.panel h2,.cat,.card-title,.empty h2{color:var(--orla-primary-dark)}
.card:hover{border-color:var(--orla-primary);box-shadow:0 18px 45px color-mix(in srgb, var(--orla-primary) 22%, transparent)}
.card-action{color:var(--orla-primary)}
.login-card h1{color:var(--orla-primary-dark)}
.login-card input:focus{border-color:var(--orla-primary);box-shadow:0 0 0 3px color-mix(in srgb, var(--orla-primary) 18%, transparent)}
body.theme-dark,
body.theme-tech{background-color:#0f172a}
body.theme-dark.dash{background:#0f172a!important}
body.theme-light.dash{background:#f1f5f9!important;color:#1f2937}
body.theme-light .panel,
body.theme-light .card,
body.theme-light .empty{background:#fff;color:#1f2937}
body.theme-light .foot{background:#f8fafc;color:#64748b}
body.theme-dark .btn-admin,
body.theme-tech .btn-admin{background:var(--orla-primary)!important;color:#fff!important}
body.theme-dark .container h1,
body.theme-tech .container h1,
body.theme-dark .panel h2,
body.theme-tech .panel h2,
body.theme-dark .cat,
body.theme-tech .cat{color:#f8fafc}
body.theme-dark .subtitle,
body.theme-tech .subtitle{color:#94a3b8}
.foot{
  text-align:center;
  padding:22px 24px;
  color:#64748b;
  font-size:13px;
  border-top:1px solid rgba(148,163,184,.22);
}
.admin-foot{margin-top:24px}


/* Ajustes de contraste e seletor visual de cores */
.color-field{display:flex;align-items:center;gap:10px}
.color-field input[type=color]{width:70px;min-height:46px;padding:4px;border-radius:10px;cursor:pointer}
.color-preview{min-height:42px;flex:1;border-radius:12px;border:1px solid rgba(148,163,184,.32);display:flex;align-items:center;padding:0 14px;font-size:13px;font-weight:700}
body.theme-dark label,body.theme-tech label,
body.theme-dark .form-group label,body.theme-tech .form-group label,
body.theme-dark .panel p,body.theme-tech .panel p,
body.theme-dark .panel p[style],body.theme-tech .panel p[style],
body.theme-dark .help,body.theme-tech .help,
body.theme-dark small,body.theme-tech small{color:#cbd5e1!important}
body.theme-dark .panel h1,body.theme-tech .panel h1,
body.theme-dark .panel h2,body.theme-tech .panel h2,
body.theme-dark .panel h3,body.theme-tech .panel h3,
body.theme-dark .card-title,body.theme-tech .card-title{color:#f8fafc!important}
body.theme-dark input,body.theme-dark select,body.theme-dark textarea,
body.theme-tech input,body.theme-tech select,body.theme-tech textarea{color:#e2e8f0!important}
