:root {
  --bg: #0a0f1c;
  --panel: #102750;
  --panel-2: #132f5f;
  --text: #e6f1ff;
  --muted: #a8b7d0;
  --line: rgba(230, 241, 255, .14);
  --accent: #34f5c5;
  --accent-2: #00e5ff;
  --danger: #ff6b6b;
  --radius: 22px;
}
* { box-sizing: border-box; }
body {
  margin: 0;
  font-family: Inter, Poppins, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  background: radial-gradient(circle at top left, rgba(0, 229, 255, .14), transparent 34%), var(--bg);
  color: var(--text);
  min-height: 100vh;
}
a { color: inherit; }
.ls-shell { width: min(1120px, calc(100% - 32px)); margin: 0 auto; }
.ls-header { padding: 28px 0; display: flex; align-items: center; justify-content: space-between; gap: 16px; }
.ls-brand { display: flex; flex-direction: column; gap: 2px; text-decoration: none; }
.ls-brand strong { font-size: 1.05rem; letter-spacing: .02em; }
.ls-brand span { color: var(--muted); font-size: .86rem; }
.ls-card {
  background: linear-gradient(180deg, rgba(16,39,80,.94), rgba(10,15,28,.92));
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: 0 20px 80px rgba(0,0,0,.32);
}
.ls-login-wrap { min-height: calc(100vh - 100px); display: grid; place-items: center; padding: 24px 0 56px; }
.ls-login-card { width: min(520px, 100%); padding: clamp(24px, 5vw, 42px); }
.ls-kicker { color: var(--accent); font-weight: 700; font-size: .88rem; text-transform: uppercase; letter-spacing: .08em; }
h1 { font-size: clamp(1.8rem, 5vw, 3rem); line-height: 1.06; margin: 10px 0 12px; }
p { color: var(--muted); line-height: 1.65; }
.ls-form { display: grid; gap: 16px; margin-top: 24px; }
.ls-field label { display: block; color: var(--text); font-size: .92rem; margin-bottom: 8px; }
.ls-field input {
  width: 100%; min-height: 52px; border-radius: 16px; border: 1px solid var(--line);
  background: rgba(255,255,255,.06); color: var(--text); padding: 0 16px; font-size: 1rem;
  outline: none;
}
.ls-field input:focus { border-color: var(--accent-2); box-shadow: 0 0 0 3px rgba(0,229,255,.14); }
.ls-button {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  min-height: 52px; border: 0; border-radius: 999px; padding: 0 22px;
  background: linear-gradient(90deg, var(--accent), var(--accent-2));
  color: #07111e; font-weight: 800; cursor: pointer; text-decoration: none; font-size: 1rem;
}
.ls-button.secondary { background: rgba(255,255,255,.08); color: var(--text); border: 1px solid var(--line); }
.ls-error { background: rgba(255,107,107,.12); border: 1px solid rgba(255,107,107,.35); color: #ffd7d7; padding: 12px 14px; border-radius: 14px; }
.ls-success { background: rgba(52,245,197,.12); border: 1px solid rgba(52,245,197,.35); color: #d9fff6; padding: 12px 14px; border-radius: 14px; }
.ls-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 18px; margin: 24px 0 52px; }
.ls-dashboard-title { margin: 30px 0 10px; }
.ls-dashboard-card { padding: 24px; }
.ls-dashboard-card h2 { margin: 0 0 8px; font-size: 1.1rem; }
.ls-dashboard-card p { margin: 0 0 18px; }
.ls-meta { display: flex; flex-wrap: wrap; gap: 10px; color: var(--muted); font-size: .9rem; }
.ls-pill { padding: 7px 11px; border: 1px solid var(--line); border-radius: 999px; background: rgba(255,255,255,.05); }
.ls-footer-actions { display: flex; gap: 10px; flex-wrap: wrap; margin-top: 16px; }
@media (max-width: 760px) {
  .ls-shell { width: min(100% - 24px, 1120px); }
  .ls-header { align-items: flex-start; }
  .ls-grid { grid-template-columns: 1fr; }
  .ls-login-wrap { place-items: start; padding-top: 12px; }
}

/* Ajustes do painel administrativo */
.ls-header-actions { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.ls-grid-4 { grid-template-columns: repeat(4, 1fr); }
.ls-section-space { margin: 18px 0 30px; }
.ls-form-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; }
.ls-field select,
.ls-field textarea {
  width: 100%; border-radius: 16px; border: 1px solid var(--line);
  background: rgba(255,255,255,.06); color: var(--text); padding: 14px 16px; font-size: 1rem;
  outline: none; font-family: inherit;
}
.ls-field textarea { min-height: 120px; resize: vertical; }
.ls-field select:focus,
.ls-field textarea:focus { border-color: var(--accent-2); box-shadow: 0 0 0 3px rgba(0,229,255,.14); }
.ls-table-wrap { overflow-x: auto; border: 1px solid var(--line); border-radius: 18px; }
.ls-table { width: 100%; border-collapse: collapse; min-width: 850px; }
.ls-table th,
.ls-table td { padding: 14px 16px; text-align: left; vertical-align: top; border-bottom: 1px solid var(--line); }
.ls-table th { color: var(--text); font-size: .85rem; text-transform: uppercase; letter-spacing: .06em; background: rgba(255,255,255,.04); }
.ls-table td { color: var(--muted); }
.ls-table td strong { color: var(--text); }
.ls-table tr:last-child td { border-bottom: 0; }
.ls-inline-form { margin: 0; }
.ls-button.compact { min-height: 40px; padding: 0 14px; font-size: .9rem; }
.ls-copy-box { display: grid; grid-template-columns: 1fr auto; gap: 10px; align-items: center; }
.ls-copy-box input {
  width: 100%; min-height: 52px; border-radius: 16px; border: 1px solid var(--line);
  background: rgba(255,255,255,.06); color: var(--text); padding: 0 16px; font-size: .95rem;
}
.ls-small { font-size: .9rem; color: var(--muted); }
@media (max-width: 900px) {
  .ls-grid-4 { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 760px) {
  .ls-header-actions { width: 100%; justify-content: flex-start; }
  .ls-grid-4 { grid-template-columns: 1fr; }
  .ls-form-grid { grid-template-columns: 1fr; }
  .ls-copy-box { grid-template-columns: 1fr; }
}

/* Passo 7: ações administrativas e leitura mobile */
.ls-table-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}
.ls-table-actions .ls-inline-form { display: inline-flex; }
@media (max-width: 760px) {
  .ls-table-actions { flex-direction: column; align-items: stretch; }
  .ls-table-actions .ls-button,
  .ls-table-actions .ls-inline-form,
  .ls-table-actions .ls-inline-form button { width: 100%; }
}



/* Menu principal padrão Lisboa Santos */
#navbar{
  position:fixed;
  top:0;left:0;right:0;
  z-index:10000;
  padding:0 5%;
  height:80px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  background:rgba(6,16,30,0.92);
  backdrop-filter:blur(14px);
  border-bottom:1px solid rgba(255,255,255,0.06);
}
#navbar .nav-logo{display:flex;align-items:center;text-decoration:none;}
#navbar .nav-logo img{height:56px;width:auto;object-fit:contain;filter:brightness(0) invert(1);}
#navbar .nav-links{display:flex;align-items:center;gap:28px;list-style:none;margin:0;padding:0;}
#navbar .nav-links a{color:#E8EBF0;text-decoration:none;font-size:13px;font-weight:500;letter-spacing:.5px;transition:color .25s;text-shadow:0 1px 10px rgba(0,0,0,.28);}
#navbar .nav-links a:hover,#navbar .nav-links a:focus,#navbar .nav-links a.active{color:#fff;}
#navbar .btn-portal{background:transparent;border:1px solid #00C98A;color:#00C98A;padding:8px 18px;border-radius:4px;font-size:11px;font-weight:500;letter-spacing:1px;text-transform:uppercase;text-decoration:none;text-shadow:none;transition:background .25s,color .25s;}
#navbar .btn-portal:hover,#navbar .btn-portal:focus,#navbar .btn-portal.active{background:#00C98A;color:#06101E;}
#navbar .nav-toggle{display:none;background:none;border:none;cursor:pointer;color:#F5F7FA;}
#navbar .has-dropdown{position:relative;}
#navbar .nav-dropdown{display:none;position:absolute;top:calc(100% + 12px);left:50%;transform:translateX(-50%);background:#0C1A2E;border:1px solid rgba(255,255,255,.1);border-radius:10px;padding:8px 0;min-width:260px;z-index:200;box-shadow:0 16px 40px rgba(0,0,0,.4);}
#navbar .nav-dropdown::before{content:'';position:absolute;top:-6px;left:50%;width:12px;height:12px;background:#0C1A2E;border-left:1px solid rgba(255,255,255,.1);border-top:1px solid rgba(255,255,255,.1);transform:translateX(-50%) rotate(45deg);}
#navbar .has-dropdown:hover .nav-dropdown,#navbar .has-dropdown:focus-within .nav-dropdown,#navbar .has-dropdown.open .nav-dropdown{display:block;}
#navbar .nav-dropdown a{display:block;padding:10px 20px;font-size:13px;color:#DDE6EF!important;white-space:nowrap;text-shadow:none;}
#navbar .nav-dropdown a:hover,#navbar .nav-dropdown a:focus{background:rgba(0,201,138,.10);color:#fff!important;}
#navbar .nav-dropdown-sep{height:1px;background:rgba(255,255,255,.06);margin:6px 0;}
#navbar .nav-eco{display:inline-flex;align-items:center;gap:6px;}
#navbar .nav-badge{display:inline-flex;align-items:center;justify-content:center;padding:2px 5px;border-radius:999px;background:rgba(0,201,138,.14);border:1px solid rgba(0,201,138,.38);color:#00C98A;font-size:8px;font-weight:600;line-height:1;letter-spacing:.7px;transform:translateY(-1px);}
.site-nav-spacer{height:80px;}
@media(max-width:1180px){#navbar .nav-links{gap:18px;}#navbar .nav-links a{font-size:12px;}#navbar .btn-portal{padding:8px 14px;}}
@media(max-width:768px){
  #navbar{height:80px;padding:0 5%;}
  #navbar .nav-logo img{max-height:48px;}
  #navbar .nav-toggle{display:inline-flex!important;align-items:center;justify-content:center;min-width:42px;min-height:42px;border:1px solid rgba(255,255,255,.12);border-radius:999px;background:rgba(255,255,255,.04);color:#F5F7FA;z-index:10002;}
  #navbar .nav-links{display:none!important;}
  #navbar .nav-links.open{display:flex!important;flex-direction:column;align-items:stretch;position:absolute;top:80px;left:5%;right:5%;max-height:calc(100vh - 96px);overflow-y:auto;-webkit-overflow-scrolling:touch;background:#071323;border:1px solid rgba(255,255,255,.10);border-radius:18px;padding:14px;gap:0;box-shadow:0 22px 60px rgba(0,0,0,.38);z-index:10001;}
  #navbar .nav-links.open li{width:100%;}
  #navbar .nav-links.open>li>a,#navbar .nav-links.open .has-dropdown>a{width:100%;min-height:46px;display:flex!important;align-items:center;justify-content:center;text-align:center;padding:11px 12px;line-height:1.18;border-radius:10px;color:#F5F7FA!important;}
  #navbar .nav-links.open>li>a:hover,#navbar .nav-links.open .has-dropdown>a:hover{background:rgba(255,255,255,.04);}
  #navbar .nav-links.open .btn-portal,#navbar .nav-links.open .nav-contrate{width:100%;max-width:280px;margin:8px auto 0;min-height:42px;}
  #navbar .has-dropdown:hover .nav-dropdown,#navbar .has-dropdown:focus-within .nav-dropdown{display:none;}
  #navbar .nav-links.open .has-dropdown .nav-dropdown{display:none;position:static;left:auto;top:auto;transform:none;width:100%;min-width:0;max-width:320px;margin:8px auto 10px;padding:8px;background:rgba(255,255,255,.035);border:1px solid rgba(255,255,255,.08);border-radius:14px;box-shadow:none;z-index:auto;}
  #navbar .nav-links.open .has-dropdown.open .nav-dropdown{display:block!important;}
  #navbar .nav-links.open .nav-dropdown::before{display:none!important;}
  #navbar .nav-links.open .nav-dropdown a{display:flex;justify-content:center;align-items:center;min-height:42px;width:100%;padding:10px 14px;text-align:center;white-space:normal;border-radius:10px;color:#DDE6EF!important;}
  #navbar .nav-links.open .nav-dropdown a:hover,#navbar .nav-links.open .nav-dropdown a:focus{background:rgba(0,201,138,.10);color:#fff!important;}
  #navbar .has-dropdown>a::after{content:'▾';font-size:10px;margin-left:8px;opacity:.75;}
  #navbar .nav-badge{font-size:8px;}
}

