/* ==========================================================
   SADOJRP THEME — Unified Stylesheet (Homepage, Application, Coming Soon, Components)
   ========================================================== */

/* ---------- Root palette ---------- */
:root{
  --ink:#0e1b25;
  --gold:#e1a81f;
  --teal:#12b3b3;
  --sun:#f36c3d;
  --cream:#f2eddc;
  --card:#142634;
  --muted:#9fb2bf;
  --err:#ff6a6a;
  --police:#12b3ff;
  --fire:#ff6a3d;
  --civ:#f2c744;

  /* semantic roles */
  --ok:var(--teal);
  --warn:var(--gold);
  --bad:var(--sun);

  /* borders & shadows */
  --bd-weak:rgba(255,255,255,.08);
  --bd-mid:rgba(225,168,31,.25);
  --shadow-1:0 6px 14px rgba(0,0,0,.22);
  --shadow-2:0 10px 24px rgba(0,0,0,.30);
  --shadow-3:0 14px 34px rgba(0,0,0,.42);
}

/* ---------- Global layout ---------- */
html,body{
  height:100%;
  background:var(--ink);
  color:var(--cream);
  font-family:system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,"Helvetica Neue",Arial,sans-serif;
  line-height:1.5;
  margin:0;
  padding:0;
  display:flex;
  flex-direction:column;
}
*{box-sizing:border-box}

/* ---------- Utilities ---------- */
.section{padding:64px 20px}
.wrap{width:min(1200px,94vw); margin-inline:auto}
.title{display:flex;align-items:center;gap:10px;margin:0 0 18px;font-size:clamp(1.15rem,2vw,1.6rem);font-weight:900;letter-spacing:.5px}
.title i{color:var(--gold)}
.lead{color:var(--muted);max-width:950px;margin:0 0 18px}

.mt-4{margin-top:4px}.mt-8{margin-top:8px}.mt-12{margin-top:12px}.mt-16{margin-top:16px}.mt-24{margin-top:24px}.mt-32{margin-top:32px}
.mb-8{margin-bottom:8px}.mb-12{margin-bottom:12px}.mb-16{margin-bottom:16px}.mb-24{margin-bottom:24px}.mb-32{margin-bottom:32px}
.pt-16{padding-top:16px}.pb-16{padding-bottom:16px}.px-16{padding-inline:16px}
.text-muted{color:var(--muted)} .text-gold{color:var(--gold)} .text-teal{color:var(--teal)} .text-sun{color:var(--sun)}
.d-flex{display:flex}.flex-wrap{flex-wrap:wrap}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.items-center{align-items:center}
.w-100{width:100%}
.rounded{border-radius:12px}

/* ---------- Buttons ---------- */
.btn{
  position:relative;display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:12px 18px;border-radius:12px;font-weight:800;text-transform:uppercase;letter-spacing:.4px;
  background:var(--teal);color:#111;text-decoration:none;border:none;cursor:pointer;
  transition:transform .12s ease,filter .12s ease,box-shadow .12s ease;
  box-shadow:var(--shadow-1);
}
.btn i{font-size:1em}
.btn:hover{transform:translateY(-2px);filter:brightness(1.06);box-shadow:var(--shadow-2)}
.btn:disabled{opacity:.55;cursor:not-allowed}
.btn--alt{background:var(--sun);color:#111}
.btn-outline{background:transparent;border:2px solid var(--teal);color:var(--teal)}
.btn-outline:hover{background:var(--teal);color:#111}
.btn-gold{background:var(--gold);color:#111}
.btn-sun{background:var(--sun);color:#111}
.btn-ghost{background:transparent;border:1px solid var(--bd-weak);color:var(--cream)}
.btn-ghost:hover{border-color:var(--teal);color:#fff}

/* ---------- Pills ---------- */
.pill{
  display:inline-flex;align-items:center;gap:8px;padding:6px 10px;border-radius:999px;font-weight:700;
  border:1px solid rgba(18,179,179,.35);color:var(--cream);background:rgba(18,179,179,.12)
}
.pill--gold{border-color:rgba(225,168,31,.35);background:rgba(225,168,31,.12)}
.pill--sun{border-color:rgba(243,108,61,.35);background:rgba(243,108,61,.12)}

/* ---------- Footer (sticky) ---------- */
footer{
  border-top:2px solid var(--bd-mid);
  background:#0a141c;color:#b9c6d1;padding:22px 20px;text-align:center;font-size:.95rem;margin-top:auto
}

/* ==========================================================
   HERO / SUBHERO
   ========================================================== */
.hero{
  position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden;
  background:var(--ink);border-bottom:4px solid var(--gold)
}
.hero::before{
  content:"";position:absolute;inset:0;background:url("/assets/img/background-4k.svg") center/cover no-repeat;
  opacity:.5;transform:translateY(0) scale(1.02);animation:parallax 28s linear infinite alternate
}
@keyframes parallax{from{transform:translateY(0) scale(1.02)}to{transform:translateY(-40px) scale(1.06)}}
.light-sweep{position:absolute;top:0;left:-70%;width:50%;height:100%;background:linear-gradient(120deg,rgba(255,255,255,.05) 0%,rgba(255,255,255,.22) 50%,rgba(255,255,255,.05) 100%);transform:skewX(-20deg);animation:sweep 8s infinite linear;z-index:1;mix-blend-mode:screen}
@keyframes sweep{0%{left:-70%}100%{left:120%}}
.hero__content{position:relative;z-index:2;padding:24px;width:min(1100px,94vw)}
.logo{width:min(500px,80vw);height:auto;filter:drop-shadow(0 0 20px rgba(0,255,255,.45)) drop-shadow(0 0 10px rgba(243,108,61,.35));animation:glow 4s ease-in-out infinite}
@keyframes glow{0%,100%{filter:drop-shadow(0 0 18px rgba(0,255,255,.45)) drop-shadow(0 0 9px rgba(243,108,61,.35))}50%{filter:drop-shadow(0 0 36px rgba(0,255,255,.9)) drop-shadow(0 0 20px rgba(243,108,61,.7))}}
.hero-title{margin:18px 0 6px;font-size:clamp(1.5rem,2.8vw,2.6rem);font-weight:800;letter-spacing:.6px}
.hero-sub{margin:6px auto 22px;max-width:800px;color:var(--muted);font-size:clamp(1rem,1.8vw,1.2rem)}

/* Coming Soon accent */
.coming-soon{font-size:clamp(2rem,5vw,3.5rem);font-weight:900;color:var(--gold);text-transform:uppercase;margin-top:40px;animation:pulse 3s infinite ease-in-out}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.85;transform:scale(1.04)}}
.notify{margin-top:24px;color:var(--muted);font-size:clamp(1rem,2vw,1.15rem)}

/* Subhero */
.subhero{
  position:relative;display:flex;align-items:center;justify-content:center;text-align:center;min-height:50vh;overflow:hidden;background:var(--ink);border-bottom:4px solid var(--gold)
}
.subhero::before{
  content:"";position:absolute;inset:0;background:url("/assets/img/background-4k.svg") center/cover no-repeat;opacity:.45;transform:translateY(0) scale(1.02);animation:parallax 26s linear infinite alternate
}
.subhero__content{position:relative;z-index:2;padding:24px;width:min(1000px,94vw)}
.subhero h1{margin:12px 0 6px;font-size:clamp(1.6rem,3vw,2rem);font-weight:900;letter-spacing:.6px}
.subhero p{margin:0 auto;max-width:780px;color:var(--muted);font-size:clamp(.95rem,1.6vw,1.05rem)}
.subhero .logo{width:min(260px,60vw);height:auto;filter:drop-shadow(0 0 10px rgba(0,255,255,.35)) drop-shadow(0 0 6px rgba(243,108,61,.25))}

/* ==========================================================
   HOMEPAGE: Departments + Leadership
   ========================================================== */
.grid{display:grid;gap:16px;grid-template-columns:repeat(4,minmax(0,1fr))}
@media (max-width:1000px){.grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.grid{grid-template-columns:1fr}}

.card{
  background:var(--card);border:2px solid var(--bd-mid);border-radius:16px;padding:18px;
  box-shadow:0 8px 20px rgba(0,0,0,.25);transition:transform .12s ease, box-shadow .12s ease
}
.card:hover{transform:translateY(-2px);box-shadow:0 12px 24px rgba(0,0,0,.3)}

/* Leaders */
.leaders{display:grid;gap:24px}
.dept-group{display:grid;gap:14px}
.dept-head{display:flex;align-items:center;gap:10px;font-weight:900;letter-spacing:.4px}
.dept-badges{display:flex;gap:8px;margin-left:auto}

.tag{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;font-weight:800;font-size:.82rem;background:rgba(225,168,31,.14);color:#ffe9a8;border:1px solid rgba(225,168,31,.4)}
.tag--owner{background:rgba(18,179,179,.14);color:#ccffff;border-color:rgba(18,179,179,.5)}

.leader-grid{display:grid;gap:16px;grid-template-columns:repeat(2,minmax(0,1fr))}
@media (max-width:800px){.leader-grid{grid-template-columns:1fr}}
.leader-card{
  display:grid;grid-template-columns:220px 1fr;gap:16px;align-items:center;background:rgba(255,255,255,.03);
  border:1px solid var(--bd-weak);border-radius:16px;padding:14px 16px
}
@media (max-width:560px){.leader-card{grid-template-columns:1fr}}
.leader-logo-wrap{position:relative;padding:10px;border-radius:12px;background:rgba(0,0,0,.25);display:flex;align-items:center;justify-content:center;min-height:150px;height:150px}
.leader-logo-wrap img{width:auto;height:auto;max-width:180px;max-height:100px;object-fit:contain;display:block;margin:0 auto}
.glow--police{box-shadow:0 0 0 3px rgba(18,179,255,.25),0 0 24px rgba(18,179,255,.25)}
.glow--fire{box-shadow:0 0 0 3px rgba(255,106,61,.25),0 0 24px rgba(255,106,61,.25)}
.glow--civ{box-shadow:0 0 0 3px rgba(242,199,68,.25),0 0 24px rgba(242,199,68,.25)}
.leader-info{display:grid;gap:6px}
.leader-top{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.gamer{font-size:1.05rem;font-weight:900}
.owner-inline{display:inline-flex;align-items:center;gap:6px;padding:2px 8px;border-radius:999px;font-weight:800;font-size:.78rem;background:rgba(18,179,179,.18);color:#ccffff;border:1px solid rgba(18,179,179,.5)}
.role{font-weight:800;color:var(--gold)}
.dept-label{color:var(--muted)}

/* ==========================================================
   FORMS (site + bootstrap-like)
   ========================================================== */
form{display:grid;gap:18px}
label{font-weight:800;letter-spacing:.3px;display:block;margin-bottom:6px}
.input,.textarea,.select,.form-control{
  width:100%;background:#0f1d29;color:var(--cream);border:1px solid var(--bd-weak);border-radius:12px;padding:12px 14px;outline:none;transition:border .15s ease, box-shadow .15s ease
}
.input:focus,.textarea:focus,.select:focus,.form-control:focus{border-color:rgba(18,179,179,.7);box-shadow:0 0 0 3px rgba(18,179,179,.22)}
.textarea{min-height:110px;resize:vertical}
.row{display:grid;gap:12px}
.hint{color:var(--muted);font-size:.9rem}
.error{color:var(--err);font-size:.9rem;display:none}
.grid-2{display:grid;gap:16px;grid-template-columns:repeat(2,minmax(0,1fr))}
@media (max-width:720px){.grid-2{grid-template-columns:1fr}}
.input-sm{padding:8px 10px;border-radius:10px;font-size:.95rem}
.input-lg{padding:14px 16px;border-radius:14px;font-size:1.05rem}

/* Custom checks / radios (bootstrap-like) */
.form-check{display:flex;align-items:center;gap:10px}
.form-check input[type="checkbox"],.form-check input[type="radio"]{accent-color:var(--teal)}

/* Input group */
.input-group{display:flex;align-items:stretch;width:100%}
.input-group>.input,.input-group>.form-control{border-radius:12px 0 0 12px}
.input-group>.btn{border-radius:0 12px 12px 0}

/* Select */
.select{appearance:none;background-image:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="20" height="20"><path fill="%23b9c6d1" d="M5 7l5 6 5-6z"/></svg>');background-repeat:no-repeat;background-position:right 12px center;background-size:16px 16px;padding-right:40px}

/* ==========================================================
   MODALS (site + bootstrap-like)
   ========================================================== */
.modal{position:fixed;inset:0;display:none;place-items:center;background:rgba(0,0,0,.6);z-index:50}
.modal__card{width:min(900px,92vw);background:var(--card);border:2px solid var(--bd-mid);border-radius:16px;padding:18px;box-shadow:var(--shadow-3)}
.modal__head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}
.code{background:#0b1720;color:#e6fffb;border:1px solid var(--bd-weak);border-radius:10px;padding:12px;max-height:50vh;overflow:auto;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:.9rem}
.modal.show{display:grid}

/* Bootstrap-style modal aliases */
.modal-sample{position:fixed;inset:0;display:none;place-items:center;background:rgba(0,0,0,.7);z-index:100}
.modal-sample.active{display:grid}
.modal-sample__dialog{background:var(--card);border:2px solid var(--bd-mid);border-radius:16px;padding:20px;max-width:600px;width:92%;color:var(--cream);box-shadow:var(--shadow-3)}
.modal-sample__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}
.modal-sample__footer{display:flex;justify-content:flex-end;gap:10px;margin-top:18px}

/* ==========================================================
   NAVIGATION / TABS / PILLS / DROPDOWNS
   ========================================================== */  
.navbar{background:#0a141c;border-bottom:2px solid var(--bd-mid);padding:14px 20px;display:flex;justify-content:space-between;align-items:center}
.navbar a{color:var(--cream);text-decoration:none;font-weight:700;margin:0 10px;transition:color .2s ease}
.navbar a:hover{color:var(--gold)}

.nav-tabs{border-bottom:2px solid var(--bd-mid);display:flex;gap:10px;flex-wrap:wrap}
.nav-tabs .nav-link{color:var(--muted);padding:10px 16px;font-weight:700;border:1px solid transparent;border-radius:8px 8px 0 0;background:transparent;cursor:pointer;transition:all .2s ease}
.nav-tabs .nav-link.active{background:var(--card);color:var(--gold);border-color:var(--bd-mid)}

.nav-pills{display:flex;gap:10px;flex-wrap:wrap}
.nav-pills .nav-link{background:rgba(255,255,255,.05);color:var(--muted);border-radius:999px;padding:8px 16px;font-weight:700;border:1px solid var(--bd-weak);transition:all .15s ease}
.nav-pills .nav-link.active,.nav-pills .nav-link:hover{background:var(--teal);color:#111;border-color:var(--teal)}

.dropdown{position:relative;display:inline-block}
.dropdown-menu{display:none;position:absolute;z-index:20;background:var(--card);border:1px solid var(--bd-weak);border-radius:10px;min-width:180px;padding:6px 0;box-shadow:var(--shadow-2)}
.dropdown.open .dropdown-menu{display:block}
.dropdown-item{padding:10px 14px;color:var(--cream);display:block;text-decoration:none}
.dropdown-item:hover{background:rgba(255,255,255,.08)}

.nav-tabs,
.nav-pills {
  list-style: none !important;
  margin: 0;
  padding: 0;
}

.nav-tabs li,
.nav-pills li {
  list-style: none !important;
  margin: 0;
  padding: 0;
}

/* Ensure tab/pill containers align properly */
.nav-tabs .nav-item,
.nav-pills .nav-item {
  margin: 0;
  padding: 0;
}

/* Optional: Prevent stray bullets in nested ULs */
.nav-tabs ul,
.nav-pills ul {
  list-style: none !important;
  margin: 0;
  padding: 0;
}

/* Breadcrumbs */
.breadcrumb{display:flex;gap:8px;list-style:none;padding:0;margin:0}
.breadcrumb a{color:var(--teal);text-decoration:none}
.breadcrumb a:hover{color:var(--gold)}
.breadcrumb li::after{content:"/";color:var(--muted);margin-left:8px}
.breadcrumb li:last-child::after{content:""}

/* Pagination */
.pagination{display:flex;list-style:none;gap:6px;padding:0}
.page-item a{display:inline-block;padding:8px 14px;background:rgba(255,255,255,.05);border:1px solid var(--bd-weak);border-radius:8px;color:var(--muted);text-decoration:none;font-weight:700}
.page-item.active a{background:var(--teal);color:#111;border-color:var(--teal)}
.page-item a:hover{background:rgba(18,179,179,.25);color:#111}

/* ==========================================================
   TABLES / LISTS
   ========================================================== */
.table{width:100%;border-collapse:collapse;margin:16px 0;border:1px solid var(--bd-weak);border-radius:12px;overflow:hidden}
.table th,.table td{padding:12px 16px;border-bottom:1px solid var(--bd-weak)}
.table th{background:#122331;color:var(--gold);font-weight:800;text-align:left}
.table tr:hover td{background:rgba(255,255,255,.04)}

.list-group{display:grid;border:1px solid var(--bd-weak);border-radius:12px;overflow:hidden}
.list-group-item{padding:12px 16px;border-bottom:1px solid var(--bd-weak);color:var(--cream)}
.list-group-item:hover{background:rgba(255,255,255,.05)}
.list-group-item.active{background:var(--teal);color:#111}

/* Cards (alt) */
.card-sample{background:var(--card);border:1px solid var(--bd-weak);border-radius:16px;padding:18px;box-shadow:var(--shadow-1)}
.card-sample h3{color:var(--gold);margin-top:0}
.card-sample p{color:var(--muted);margin:0}

/* Badges */
.badge{display:inline-block;padding:4px 10px;border-radius:999px;font-weight:800;font-size:.8rem;letter-spacing:.3px;color:#111}
.badge-teal{background:var(--teal)}
.badge-gold{background:var(--gold)}
.badge-sun{background:var(--sun)}

/* Alerts */
.alert{border-radius:12px;padding:14px 18px;font-weight:700;margin:16px 0;border:1px solid transparent}
.alert-success{background:rgba(18,179,179,.12);border-color:rgba(18,179,179,.35);color:var(--ok)}
.alert-warning{background:rgba(225,168,31,.12);border-color:rgba(225,168,31,.35);color:var(--warn)}
.alert-danger{background:rgba(243,108,61,.12);border-color:rgba(243,108,61,.35);color:var(--bad)}

/* ==========================================================
   ACCORDION / PROGRESS / TOAST / POPOVER / TOOLTIP / CAROUSEL
   ========================================================== */
.accordion{border:1px solid var(--bd-weak);border-radius:12px;overflow:hidden}
.accordion-item{background:rgba(255,255,255,.03);border-bottom:1px solid var(--bd-weak)}
.accordion-header{background:rgba(255,255,255,.05);padding:12px 16px;cursor:pointer;font-weight:800;color:var(--cream)}
.accordion-header:hover{background:rgba(255,255,255,.08)}
.accordion-body{padding:14px 16px;background:rgba(0,0,0,.25);color:var(--muted)}

.progress{background:var(--bd-weak);border-radius:999px;overflow:hidden;height:20px}
.progress-bar{height:100%;background:var(--teal);width:50%;transition:width .3s ease}
.progress-bar.gold{background:var(--gold)}
.progress-bar.sun{background:var(--sun)}

.toast{background:var(--card);border:1px solid var(--bd-weak);border-radius:12px;color:var(--cream);padding:14px 18px;position:fixed;bottom:20px;right:20px;box-shadow:var(--shadow-3);z-index:60}

.tooltip{position:absolute;background:var(--card);color:var(--cream);border:1px solid var(--bd-weak);padding:6px 10px;border-radius:8px;font-size:.85rem;box-shadow:var(--shadow-1);z-index:200}
.popover{position:absolute;background:var(--card);border:1px solid var(--bd-weak);border-radius:12px;padding:14px 18px;color:var(--cream);box-shadow:var(--shadow-2);max-width:320px;z-index:150}

.carousel{position:relative;overflow:hidden;border-radius:12px;border:1px solid var(--bd-weak)}
.carousel-inner{display:flex;transition:transform .5s ease}
.carousel-item{min-width:100%;flex-shrink:0}
.carousel-controls{position:absolute;top:50%;left:0;right:0;display:flex;justify-content:space-between;transform:translateY(-50%);padding:0 8px}
.carousel-btn{background:rgba(0,0,0,.45);color:var(--cream);border:none;border-radius:50%;width:38px;height:38px;cursor:pointer}

/* Offcanvas */
.offcanvas{position:fixed;top:0;bottom:0;width:300px;background:var(--card);border-left:1px solid var(--bd-weak);transform:translateX(100%);right:0;z-index:120;transition:transform .25s ease}
.offcanvas.show{transform:translateX(0)}
.offcanvas-header{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;border-bottom:1px solid var(--bd-weak)}
.offcanvas-body{padding:16px;overflow:auto}

/* ==========================================================
   CODE & ANIMATIONS
   ========================================================== */
pre,code,kbd,samp{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace}
.code-inline{padding:.1rem .35rem;background:#0b1720;border:1px solid var(--bd-weak);border-radius:6px}

[data-aos]{opacity:0;transition:opacity .4s ease, transform .4s ease}
[data-aos].aos-animate{opacity:1;transform:none}


/* ==========================================================
   FIX: System Check / Specs Section (Application Page)
   ========================================================== */
.specs {
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  background: rgba(255,255,255,.03);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 12px;
  padding: 12px;
  margin-top: 12px;
}

.spec {
  background: #0f1d29;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 10px;
  padding: 12px 14px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.spec b {
  display: block;
  font-size: .95rem;
  font-weight: 800;
  color: var(--gold);
  margin-bottom: 4px;
}

.spec small {
  color: var(--muted);
  font-size: .9rem;
  word-break: break-word;
}

#checkStatus {
  font-weight: 700;
  color: var(--muted);
  margin-left: 8px;
}

.inline {
  display: flex;
  align-items: center;
  gap: 10px;
}

button#runCheck {
  background: var(--teal);
  color: #111;
  font-weight: 800;
}

button#runCheck:hover {
  filter: brightness(1.1);
}


/* ==========================================================
   END
   ========================================================== */
