/* ===== MajorCity • FiveM Regelwerke – Modern Blue UI (banner + logo-bg) ===== */
:root{
  --bg:#070a0f;
  --bg-2:#0a0f16;
  --panel:#0d1118;
  --panel-2:#101625;
  --text:#e7ecf6;
  --muted:#9aa3b9;
  --border:#1b2234;
  --accent: rgb(0,170,255);
  --ring: color-mix(in oklab, var(--accent) 45%, transparent);
  --shadow: 0 14px 40px rgba(0,0,0,.45);
  --radius:14px;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,'Apple Color Emoji','Segoe UI Emoji','Segoe UI Symbol',sans-serif;
  color:var(--text);
  background:
    radial-gradient(80vmax 50vmax at 10% -10%, color-mix(in oklab, var(--accent), transparent 80%), transparent 60%),
    radial-gradient(80vmax 50vmax at 120% 10%, rgba(0,170,255,.18), transparent 55%),
    linear-gradient(180deg, var(--bg), var(--bg-2));
}

/* Topbar */
.topbar{
  position:sticky;top:0;z-index:50;
  display:grid;grid-template-columns:1fr auto;gap:1rem;
  padding:.8rem 1rem;
  background:linear-gradient(180deg, color-mix(in oklab, var(--panel), transparent 0%), transparent);
  backdrop-filter:saturate(1.1) blur(8px);
  border-bottom:1px solid var(--border);
}
.brand{display:flex;align-items:center;gap:.8rem}
.brand-logo{
  width:48px;height:48px;border-radius:0; /* square corners as requested */
  object-fit:contain;
}
.meta h1{margin:0;font-size:1.15rem;font-weight:800;letter-spacing:.2px}
.meta .muted{font-size:.92rem;color:var(--muted)}

.actions{display:flex;align-items:center;gap:.75rem}
.search{
  display:flex;align-items:center;gap:.5rem;min-width:260px;
  background:linear-gradient(180deg, var(--panel-2), var(--panel));
  border:1px solid var(--border);border-radius:12px;padding:.45rem .6rem;
}
.search input{flex:1;background:transparent;border:0;color:var(--text);outline:none}
.search button{background:transparent;border:0;color:var(--muted);cursor:pointer}
.btns{display:flex;align-items:center;gap:.5rem}
.btn{
  background:linear-gradient(135deg, var(--panel-2), var(--panel));
  border:1px solid var(--border);
  color:var(--text);padding:.5rem .8rem;border-radius:10px;
  cursor:pointer;font-weight:600;
  transition:border-color .2s ease, box-shadow .2s ease, transform .05s ease;
}
.btn:hover{border-color:var(--accent);box-shadow:0 6px 16px var(--ring)}
.btn:active{transform:translateY(1px)}

/* Shell layout */
.shell{
  display:grid;grid-template-columns:300px 1fr;gap:1rem;
  max-width:1400px;margin:0 auto;padding:1rem;
}
@media (max-width:1080px){ .shell{grid-template-columns:1fr} }

/* Left rail */
.rail{
  align-self:start;position:sticky;top:82px;
  border:1px solid var(--border);border-radius:var(--radius);
  background:linear-gradient(180deg, var(--panel), var(--panel-2));
  box-shadow:var(--shadow);
  overflow:hidden;
}
.rail-head{padding:.85rem .9rem;border-bottom:1px solid var(--border)}
.label{font-size:.95rem;font-weight:800;letter-spacing:.3px}
.rail-nav{display:grid;padding:.5rem}
.rail-nav a{
  display:grid;grid-template-columns:1fr auto;align-items:center;
  gap:.6rem;padding:.6rem .7rem;margin:.25rem 0;
  color:var(--text);text-decoration:none;border-radius:10px;
  border:1px solid transparent;position:relative;isolation:isolate;overflow:hidden;
  transition:border-color .2s ease, box-shadow .2s ease;
}
.rail-nav a::before{
  content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(120deg, transparent, color-mix(in oklab, var(--accent), transparent 85%), transparent);
  opacity:0;transition:opacity .2s ease;
}
.rail-nav a:hover{border-color:var(--border)}
.rail-nav a:hover::before{opacity:1}
.rail-nav a.active{
  border-color:var(--accent);
  box-shadow:0 0 0 3px var(--ring), inset 0 0 40px color-mix(in oklab, var(--accent), transparent 92%);
}
.rail .badge{
  font-size:.75rem;font-weight:800;padding:.12rem .55rem;color:white;
  background:linear-gradient(135deg, var(--accent), color-mix(in oklab, var(--accent), #000 25%));
  border-radius:999px;border:1px solid color-mix(in oklab, var(--accent), #000 40%);
}
.rail-foot{border-top:1px solid var(--border);padding:.8rem .9rem;color:var(--muted);font-size:.92rem}

/* Stage */
.stage{
  min-height:60vh;
  border:1px solid var(--border);border-radius:var(--radius);
  background:
    radial-gradient(60vmax 32vmax at 0% -20%, color-mix(in oklab, var(--accent), transparent 90%), transparent 60%),
    linear-gradient(180deg, var(--panel), var(--panel-2));
  box-shadow:var(--shadow);
  padding:1rem;
  position:relative;overflow:hidden;
}
/* Watermark the logo-with-background softly in the content */
.alert{
  background:#e53935;color:white;padding:.75rem;border-radius:10px;
}
.section-title{
  display:flex;align-items:center;justify-content:space-between;
  font-size:1.1rem;margin:.25rem 0 1rem;
  padding-bottom:.5rem;border-bottom:1px solid var(--border);
}

/* Group (details) */
.group{
  border:1px solid color-mix(in oklab, var(--border), transparent 25%);
  border-radius:12px;margin:.8rem 0;overflow:hidden;
  background:linear-gradient(180deg, color-mix(in oklab, var(--panel-2), transparent 0%), color-mix(in oklab, var(--panel), transparent 0%));
  transition: border-color .2s ease, box-shadow .2s ease, transform .05s ease;
}
.group:hover{ border-color:var(--accent); box-shadow:0 8px 24px var(--ring) }
.group:active{ transform:translateY(1px) }
.group summary{
  list-style:none;display:flex;align-items:center;justify-content:space-between;
  gap:.6rem;cursor:pointer;padding:.9rem 1rem;user-select:none;
}
.group summary::-webkit-details-marker{display:none}
.summary-left{display:flex;align-items:center;gap:.65rem}
.group .chip{
  font-size:.72rem;font-weight:800;padding:.12rem .55rem;border-radius:999px;color:white;
  background:linear-gradient(135deg, var(--accent), color-mix(in oklab, var(--accent), #000 25%));
  border:1px solid color-mix(in oklab, var(--accent), #000 40%);
}
.chev{opacity:.9;transition:transform .22s ease}
details[open] .chev{ transform:rotate(180deg) }
.group .body{ padding:.85rem 1rem 1.05rem; border-top:1px dashed var(--border) }
.group .body p{ margin:.5rem 0 }
.group .body ul, .group .body ol{ padding-left:1.1rem }
.group .body code, code{
  background: color-mix(in oklab, var(--panel-2), #000 8%);
  border:1px solid var(--border);
  padding:.12rem .35rem;border-radius:6px;
}
.group .body pre{
  background: color-mix(in oklab, var(--panel-2), #000 8%);
  border:1px solid var(--border);
  padding:.8rem;border-radius:8px;overflow:auto;
}
.highlight{ background: color-mix(in oklab, var(--accent), transparent 88%); outline:2px dashed color-mix(in oklab, var(--accent), transparent 65%); border-radius:6px }

/* Footer */
.foot{ text-align:center;color:var(--muted);padding:1.2rem .75rem }

@media print{
  /* Print disabled button removed; keep clean sheet */
  .shell{ padding:0 }
  .stage{border:none;box-shadow:none;background:white;color:black}
  body{background:white}
}