/*
====================================================================
BattleScore API Docs
File: /var/www/battlescore.net/dev/api/docs/assets/stylesheet.css

Purpose:
  Shared stylesheet for BattleScore API documentation pages.

Notes:
  - Used by all endpoint documentation pages under /api/docs
  - Provides shared layout for header, footer, left navigation and content
  - Designed to be cleaner, more professional and easier to scan
  - Standard page shell:
      .docShell
        .docSidebar
        .docMain
          #docHeader
          .docContent
          #docFooter

Change Log:
  2026-04-15 - Initial shared stylesheet for API documentation.
  2026-04-15 - Expanded to support shared header/footer/nav includes and
               improved professional layout.
  2026-04-15 - Normalised layout so all endpoint pages use the same shell.
====================================================================
*/

:root{
  --bg:#f4f6f8;
  --panel:#ffffff;
  --panel-soft:#f8fafc;
  --border:#e2e8f0;
  --border-strong:#cbd5e1;
  --text:#0f172a;
  --muted:#64748b;
  --link:#1d4ed8;
  --link-hover:#1e40af;
  --accent:#f57c00;
  --accent-hover:#e46f00;
  --ok-bg:#ecfdf3;
  --ok-border:#abefc6;
  --ok-text:#067647;
  --warn-bg:#fff7ed;
  --warn-border:#fed7aa;
  --warn-text:#9a3412;
  --auth-bg:#eef2ff;
  --auth-border:#c7d2fe;
  --auth-text:#3730a3;
  --danger-bg:#fff1f2;
  --danger-border:#fecdd3;
  --danger-text:#b42318;
  --code-bg:#0f172a;
  --code-fg:#f8fafc;
  --shadow:0 8px 24px rgba(15, 23, 42, 0.06);
  --radius:16px;
}

*{box-sizing:border-box}

html,body{
  margin:0;
  padding:0;
  background:var(--bg);
  color:var(--text);
  font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
}

body{
  line-height:1.55;
}

a{
  color:var(--link);
  text-decoration:none;
}

a:hover{
  color:var(--link-hover);
  text-decoration:underline;
}

.docShell{
  min-height:100vh;
  max-width:1400px;
  margin:0 auto;
  display:grid;
  grid-template-columns:300px minmax(0, 1fr);
}

.docSidebar{
  background:var(--panel);
  border-right:1px solid var(--border);
  padding:18px 16px;
  min-width:0;
}

.docMain{
  min-width:0;
  display:flex;
  flex-direction:column;
}

.docHeader{
  background:linear-gradient(135deg, #0f172a 0%, #1e293b 100%);
  color:#fff;
  border-bottom:1px solid rgba(255,255,255,.08);
  box-shadow:0 4px 18px rgba(15, 23, 42, .18);
}

.docHeaderInner{
  padding:20px 24px;
}

.docHeaderTitle{
  margin:0;
  font-size:28px;
  line-height:1.15;
  font-weight:900;
  letter-spacing:.01em;
}

.docHeaderSub{
  margin-top:6px;
  color:rgba(255,255,255,.78);
  font-size:14px;
}

.docContent{
  padding:20px 24px;
  min-width:0;
}

.docFooter{
  border-top:1px solid var(--border);
  background:#fff;
  margin-top:auto;
}

.docFooterInner{
  padding:16px 24px 24px;
  font-size:13px;
  color:var(--muted);
}

.docSidebarTitle{
  margin:0 0 14px;
  font-size:14px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.06em;
  color:var(--muted);
}

.navGroup{
  margin-top:14px;
}

.navGroup:first-of-type{
  margin-top:0;
}

.navGroupLabel{
  display:block;
  font-size:13px;
  font-weight:800;
  color:#334155;
  margin-bottom:8px;
  text-transform:uppercase;
  letter-spacing:.04em;
}

.navList{
  list-style:none;
  margin:0;
  padding:0;
}

.navList li{
  margin:4px 0;
}

.navList a{
  display:block;
  padding:9px 10px;
  border-radius:10px;
  color:#1e293b;
  font-size:14px;
  text-decoration:none;
  transition:background .15s ease, color .15s ease, border-color .15s ease;
  border:1px solid transparent;
}

.navList a:hover{
  background:#f1f5f9;
  color:var(--link-hover);
  text-decoration:none;
}

.navList a.active{
  background:#fff7ed;
  border-color:#fed7aa;
  color:#9a3412;
  font-weight:700;
}

.docCard{
  background:var(--panel);
  border:1px solid var(--border);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  padding:24px;
  margin-bottom:18px;
}

.docCard.hero{
  background:linear-gradient(180deg, #ffffff 0%, #fbfdff 100%);
}

.docPageHeader{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:16px;
  flex-wrap:wrap;
  margin-bottom:18px;
}

.docEyebrow{
  margin:0 0 8px;
  font-size:12px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.06em;
  color:var(--accent);
}

.docLead{
  max-width:920px;
  font-size:14px;
  color:#475569;
}

.docPageHeaderBadges{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}

.docBadge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:5px 10px;
  border-radius:999px;
  border:1px solid var(--border-strong);
  background:#f8fafc;
  font-size:12px;
  font-weight:800;
  letter-spacing:.02em;
}

.docBadgeGet{
  background:var(--auth-bg);
  border-color:var(--auth-border);
  color:var(--auth-text);
}

.docBadgePost{
  background:var(--warn-bg);
  border-color:var(--warn-border);
  color:var(--warn-text);
}

.docBadgeAuth{
  background:var(--ok-bg);
  border-color:var(--ok-border);
  color:var(--ok-text);
}

.docBadgePublic{
  background:#f8fafc;
  border-color:#d8dee7;
  color:#334155;
}

h1{
  margin:0 0 8px;
  font-size:30px;
  line-height:1.15;
}

h2{
  margin:0 0 12px;
  font-size:20px;
  line-height:1.2;
}

h3{
  margin:18px 0 8px;
  font-size:15px;
  line-height:1.3;
}

p, li{
  font-size:14px;
  color:#334155;
}

ul{
  margin:8px 0 0 20px;
  padding:0;
}

.small{
  font-size:13px;
  color:var(--muted);
}

.endpointPath{
  margin-top:10px;
  font-size:16px;
  font-weight:800;
  color:#0f172a;
}

.pillRow{
  margin-top:14px;
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}

.pill{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:5px 10px;
  border-radius:999px;
  border:1px solid var(--border-strong);
  background:#f8fafc;
  font-size:12px;
  font-weight:800;
  letter-spacing:.02em;
}

.pill.get{
  background:var(--auth-bg);
  border-color:var(--auth-border);
  color:var(--auth-text);
}

.pill.post{
  background:var(--warn-bg);
  border-color:var(--warn-border);
  color:var(--warn-text);
}

.pill.auth{
  background:var(--ok-bg);
  border-color:var(--ok-border);
  color:var(--ok-text);
}

.pill.public{
  background:#f8fafc;
  border-color:#d8dee7;
  color:#334155;
}

.kv,
.docKeyValue{
  display:grid;
  grid-template-columns:180px minmax(0,1fr);
  gap:10px 14px;
  margin-top:12px;
}

.kvLabel,
.docKey{
  font-size:13px;
  font-weight:800;
  color:#475569;
}

.kvValue,
.docValue{
  font-size:14px;
  color:#1e293b;
}

table,
.docTable{
  width:100%;
  border-collapse:collapse;
  margin-top:10px;
  font-size:13px;
  overflow:hidden;
  border-radius:12px;
}

th, td{
  border:1px solid var(--border);
  padding:10px 12px;
  text-align:left;
  vertical-align:top;
}

th{
  background:#f8fafc;
  color:#334155;
  font-weight:900;
}

.left{
  text-align:left;
}

code, pre{
  font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;
}

code{
  background:#f1f5f9;
  border:1px solid #e2e8f0;
  padding:2px 6px;
  border-radius:8px;
  font-size:13px;
  color:#0f172a;
}

pre{
  margin:0;
  background:var(--code-bg);
  color:var(--code-fg);
  padding:16px;
  border-radius:14px;
  overflow:auto;
  font-size:13px;
  line-height:1.5;
  white-space:pre-wrap;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.04);
}

.note,
.docCallout{
  background:#f8fafc;
  border:1px solid var(--border);
  border-radius:12px;
  padding:14px;
  color:#334155;
}

.docCalloutSuccess{
  background:var(--ok-bg);
  border-color:var(--ok-border);
  color:var(--ok-text);
}

.docBullets{
  margin:8px 0 0 20px;
  padding:0;
}

.docLinkGrid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:12px;
}

.docLinkCard{
  display:block;
  background:#fff;
  border:1px solid var(--border);
  border-radius:12px;
  padding:14px;
  color:inherit;
  text-decoration:none;
}

.docLinkCard:hover{
  border-color:var(--border-strong);
  background:#fcfdff;
  text-decoration:none;
}

.docLinkCard strong{
  display:block;
  margin-bottom:4px;
  color:#0f172a;
}

.docLinkCard span{
  display:block;
  font-size:13px;
  color:var(--muted);
}

.docList{
  display:flex;
  flex-direction:column;
  gap:10px;
}

.docListItem{
  border:1px solid var(--border);
  border-radius:12px;
  padding:12px 14px;
  background:#fff;
}

@media (max-width: 980px){
  .docShell{
    grid-template-columns:1fr;
  }

  .docSidebar{
    border-right:0;
    border-bottom:1px solid var(--border);
  }
}

@media (max-width: 640px){
  .docHeaderInner,
  .docContent,
  .docFooterInner{
    padding-left:14px;
    padding-right:14px;
  }

  .docSidebar{
    padding:14px;
  }

  .docCard{
    padding:18px;
  }

  .kv,
  .docKeyValue{
    grid-template-columns:1fr;
  }

  h1{
    font-size:26px;
  }
}