/* SPORK CA Documentation - shared stylesheet */
body {
  font-family: monospace;
  max-width: 800px;
  margin: 40px auto;
  padding: 0 20px;
  line-height: 1.6;
  color: #333;
}
h1 { border-bottom: 2px solid #333; padding-bottom: 8px; }
h2 { border-bottom: 1px solid #ddd; padding-bottom: 4px; margin-top: 2em; }
h3 { margin-top: 1.5em; }
table { border-collapse: collapse; width: 100%; margin: 1em 0; }
th, td { text-align: left; padding: 8px; border-bottom: 1px solid #ddd; }
th { background: #f5f5f5; }
a { color: #0066cc; }
code { background: #f0f0f0; padding: 2px 6px; border-radius: 2px; }
pre { background: #f0f0f0; padding: 12px; overflow-x: auto; border-radius: 4px; }
pre code { background: none; padding: 0; }
nav { margin-bottom: 2em; padding: 8px 0; border-bottom: 1px solid #ddd; font-size: 0.95em; }
nav a { margin-right: 1em; text-decoration: none; }
nav a:hover { text-decoration: underline; }
.note { background: #fffde7; border-left: 4px solid #ffd600; padding: 12px; margin: 1em 0; }
.warn { background: #fff3e0; border-left: 4px solid #ff9800; padding: 12px; margin: 1em 0; }
.info { background: #e3f2fd; border-left: 4px solid #2196f3; padding: 12px; margin: 1em 0; }
.warning { background: #fce4ec; border-left: 4px solid #e53935; padding: 12px; margin: 1em 0; }
footer { margin-top: 3em; padding-top: 1em; border-top: 1px solid #ddd; font-size: 0.85em; color: #666; }

/* ============================================================
   Sidebar layout (opt-in via body.with-sidebar)
   ============================================================ */
html { scroll-behavior: smooth; }

body.with-sidebar {
  max-width: none;
  display: flex;
  flex-direction: row;
  margin: 0;
  padding: 0;
}

body.with-sidebar nav.top-nav {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 100;
  background: #fff;
  border-bottom: 1px solid #ddd;
  margin-bottom: 0;
  padding: 8px 20px;
}

body.with-sidebar aside.sidebar {
  position: fixed;
  left: 0;
  top: 40px;
  width: 260px;
  height: calc(100vh - 40px);
  overflow-y: auto;
  border-right: 1px solid #ddd;
  padding: 1em 0.75em;
  background: #fafafa;
  font-size: 0.82em;
  line-height: 1.5;
  box-sizing: border-box;
}

body.with-sidebar aside.sidebar a {
  display: block;
  padding: 2px 8px;
  text-decoration: none;
  color: #333;
  border-radius: 3px;
}
body.with-sidebar aside.sidebar a:hover {
  background: #e8e8e8;
  text-decoration: none;
}
body.with-sidebar aside.sidebar a.active {
  font-weight: bold;
  background: #e3f2fd;
  color: #0066cc;
}

body.with-sidebar aside.sidebar details {
  margin-bottom: 0.3em;
}
body.with-sidebar aside.sidebar details[open] {
  margin-bottom: 0.5em;
}
body.with-sidebar aside.sidebar summary {
  cursor: pointer;
  font-weight: bold;
  padding: 3px 8px;
  border-radius: 3px;
  list-style: none;
  user-select: none;
}
body.with-sidebar aside.sidebar summary::-webkit-details-marker { display: none; }
body.with-sidebar aside.sidebar summary::before {
  content: "\25b6  ";
  font-size: 0.7em;
  display: inline-block;
  transition: transform 0.15s;
}
body.with-sidebar aside.sidebar details[open] > summary::before {
  transform: rotate(90deg);
}
body.with-sidebar aside.sidebar summary:hover {
  background: #e8e8e8;
}
body.with-sidebar aside.sidebar .sub-links {
  padding-left: 1.2em;
}

body.with-sidebar aside.sidebar .sidebar-title {
  font-weight: bold;
  font-size: 1.1em;
  padding: 4px 8px 8px;
  border-bottom: 1px solid #ddd;
  margin-bottom: 0.5em;
}

body.with-sidebar main {
  margin-left: 260px;
  margin-top: 40px;
  max-width: 840px;
  padding: 20px 40px 40px;
  min-height: calc(100vh - 40px);
}

body.with-sidebar main h2 {
  scroll-margin-top: 60px;
}
body.with-sidebar main h3 {
  scroll-margin-top: 60px;
}

body.with-sidebar footer {
  margin-left: 0;
}

/* Mobile: collapse sidebar */
@media (max-width: 900px) {
  body.with-sidebar aside.sidebar {
    display: none;
  }
  body.with-sidebar main {
    margin-left: 0;
    padding: 20px;
  }
}
