/* ===== RESET docs UI elements from library globals ===== */
.docs-topbar button,
.docs-topbar a,
.docs-sidebar button,
.docs-sidebar a,
.docs-main .code-tabs button,
.docs-main .pg-controls button,
.docs-color-menu button {
  width: auto;
  border: none;
  box-shadow: none;
  background: none;
  border-bottom: none;
}

.docs-sidebar a {
  border-bottom: none;
  text-decoration: none;
  color: var(--font-color);
}

.docs-main .pg-controls label {
  display: inline;
  padding: 0;
  border: none;
  box-shadow: none;
  font-weight: normal;
  font-size: 13px;
}

/* ===== TOPBAR ===== */
.docs-topbar {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  height: 56px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 20px;
  background-color: var(--primary-color);
  border-bottom: 3px solid var(--border-color);
  box-shadow: 0 4px 0 var(--border-color);
  z-index: 300;
  gap: 12px;
}

.docs-topbar .logo {
  font-weight: bold;
  font-size: 16px;
  color: var(--font-color);
  display: flex;
  align-items: center;
  gap: 8px;
  white-space: nowrap;
}

.docs-topbar .logo svg { width: 20px; height: 20px; }

.docs-topbar .actions {
  display: flex;
  align-items: center;
  gap: 4px;
}

.docs-topbar .actions button,
.docs-topbar .actions a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px !important;
  height: 36px;
  cursor: pointer;
  color: var(--font-color);
  border-radius: var(--default-rounded-square);
  padding: 0;
}

.docs-topbar .actions button:hover,
.docs-topbar .actions a:hover {
  background-color: var(--secondary-color);
  transform: none;
}

.docs-topbar .actions svg { width: 20px; height: 20px; }

.docs-hamburger {
  display: none;
  align-items: center;
  justify-content: center;
  width: 36px !important;
  height: 36px;
  cursor: pointer;
  color: var(--font-color);
  padding: 0;
}

.docs-hamburger svg { width: 22px; height: 22px; }

/* ===== SIDEBAR ===== */
.docs-sidebar {
  position: fixed;
  top: 63px;
  left: 0;
  width: 260px;
  height: calc(100vh - 63px);
  background-color: var(--background-color);
  border-right: 3px solid var(--border-color);
  overflow-y: auto;
  z-index: 200;
  padding-bottom: 40px;
}

.docs-search {
  position: sticky;
  top: 0;
  z-index: 2;
  padding: 16px;
  background-color: var(--background-color);
  border-bottom: 3px solid var(--border-color);
}

.docs-search-label {
  display: block;
  margin-bottom: 8px;
  font-size: 10px;
  font-weight: bold;
  text-transform: uppercase;
  letter-spacing: 1.2px;
  color: var(--secondary-color);
}

.docs-search-input-wrap {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 0 10px;
  background-color: var(--background-color);
  border: 3px solid var(--border-color);
  box-shadow: 3px 3px 0 var(--border-color);
  border-radius: var(--default-rounded-square);
}

.docs-search-input-wrap svg {
  width: 16px;
  height: 16px;
  flex-shrink: 0;
  color: var(--secondary-color);
}

.docs-search input {
  width: 100%;
  padding: 10px 0;
  border: none;
  background: transparent;
  color: var(--font-color);
  font-size: 13px;
}

.docs-search input::placeholder {
  color: color-mix(in srgb, var(--font-color) 55%, transparent);
}

.docs-search-clear {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px !important;
  height: 28px;
  flex-shrink: 0;
  color: var(--font-color);
  cursor: pointer;
}

.docs-search-clear:hover {
  background-color: var(--none-color);
  transform: none;
}

.docs-search-results {
  margin-top: 12px;
  border: 3px solid var(--border-color);
  box-shadow: 4px 4px 0 var(--border-color);
  background-color: var(--background-color);
  border-radius: var(--default-rounded-square);
  overflow: hidden;
}

.docs-search-result {
  display: block;
  width: 100% !important;
  padding: 10px 12px;
  text-align: left;
  color: var(--font-color);
  border-bottom: 2px dashed var(--border-color) !important;
  cursor: pointer;
}

.docs-search-result:last-child {
  border-bottom: none !important;
}

.docs-search-result:hover {
  background-color: var(--none-color);
  transform: none;
}

.docs-search-result-title {
  display: block;
  font-size: 13px;
  font-weight: bold;
}

.docs-search-result-meta {
  display: block;
  margin-top: 3px;
  font-size: 11px;
  opacity: 0.7;
}

.docs-search-empty {
  padding: 12px;
  font-size: 12px;
  opacity: 0.7;
}

.docs-sidebar .nav-group {
  padding: 14px 16px 6px;
  font-size: 10px;
  font-weight: bold;
  text-transform: uppercase;
  color: var(--secondary-color);
  letter-spacing: 1.5px;
}

.docs-sidebar .nav-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 9px 16px;
  font-weight: bold;
  font-size: 13px;
  color: var(--font-color);
  cursor: pointer;
  transition: background-color 0.15s, padding-left 0.15s;
  border-bottom: none !important;
}

.docs-sidebar .nav-item:hover {
  background-color: var(--none-color);
  padding-left: 22px;
  transform: none;
}

.docs-sidebar .nav-item.active {
  background-color: var(--primary-color);
  border-left: 4px solid var(--border-color);
  padding-left: 12px;
}

.docs-sidebar .nav-item svg {
  width: 16px;
  height: 16px;
  flex-shrink: 0;
}

/* ===== OVERLAY ===== */
.docs-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: var(--modal-neubrutalis);
  z-index: 150;
}

/* ===== MAIN ===== */
.docs-main {
  margin-left: 263px;
  margin-top: 63px;
  padding: 32px 40px 60px;
  max-width: 900px;
}

/* ===== SECTION ===== */
.docs-section {
  margin-bottom: 48px;
  padding-bottom: 48px;
  border-bottom: 3px dashed var(--none-color);
  position: relative;
}

.docs-section:last-child { border-bottom: none; }

.docs-section > h2 {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 26px;
  margin: 0 0 6px;
}

.docs-section > h2 svg {
  width: 26px;
  height: 26px;
  color: var(--secondary-color);
}

.docs-section > .desc {
  margin: 0 0 24px;
  font-size: 14px;
  line-height: 1.6;
  opacity: 0.8;
}

/* ===== PREVIEW BOX ===== */
.preview-box {
  border: 3px solid var(--border-color);
  box-shadow: 4px 4px 0 var(--border-color);
  border-radius: var(--default-rounded-square);
  margin-bottom: 16px;
  overflow: hidden;
}

.preview-box .preview-header {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 8px 14px;
  font-size: 12px;
  font-weight: bold;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  background-color: var(--none-color);
  border-bottom: 3px solid var(--border-color);
}

.preview-box .preview-header svg { width: 14px; height: 14px; }

.preview-box .preview-content {
  padding: 24px;
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: center;
  justify-content: center;
  min-height: 60px;
}

.preview-box .preview-content.stack {
  flex-direction: column;
  align-items: stretch;
}

.preview-box.allow-overflow,
article[window].allow-overflow {
  overflow: visible;
  position: relative;
  z-index: 40;
}

.preview-box.allow-overflow:hover,
article[window].allow-overflow:hover,
.preview-box.allow-overflow:focus-within,
article[window].allow-overflow:focus-within {
  z-index: 100;
}

.preview-box.allow-overflow:has(nb-datetime[open]),
article[window].allow-overflow:has(nb-datetime[open]),
.preview-box.allow-overflow:has(.dropdown:hover),
article[window].allow-overflow:has(.dropdown:hover) {
  z-index: 200;
}

.preview-box.allow-overflow .preview-content,
article[window].allow-overflow .pg-result {
  overflow: visible;
}

/* ===== CODE BLOCK ===== */
.code-box {
  border: 3px solid var(--border-color);
  box-shadow: 4px 4px 0 var(--border-color);
  border-radius: var(--default-rounded-square);
  margin-bottom: 16px;
  overflow: hidden;
  position: relative;
}

.code-box .code-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 6px 14px;
  font-size: 11px;
  font-weight: bold;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  background-color: var(--primary-color);
  color: var(--border-color);
}

.code-box .copy-btn {
  display: flex;
  align-items: center;
  gap: 4px;
  width: fit-content;
  cursor: pointer;
  color: var(--border-color) !important;
  font-size: 11px;
  font-weight: bold;
  padding: 2px 8px;
  border-radius: 3px;
  transition: background-color 0.15s;
}

.code-box .copy-btn:hover {
  background-color: rgba(76, 61, 61, 0.08);
}

.code-box .copy-btn svg { width: 13px; height: 13px; }

.code-box pre {
  margin: 0;
  padding: 16px;
  overflow-x: auto;
  font-family: var(--font-family);
  font-size: 13px;
  line-height: 1.65;
  color: var(--font-color);
  background-color: var(--background-color);
  border: none;
  box-shadow: none;
  border-radius: 0;
}

.code-box code {
  font-family: var(--font-family);
  font-size: 13px;
  background: none;
  border: none;
  box-shadow: none;
}

/* ===== CODE TABS ===== */
.code-tabs {
  margin-bottom: 16px;
}

.code-tabs .tab-bar {
  display: flex;
  gap: 0;
}

.code-tabs .tab-btn {
  padding: 7px 18px !important;
  font-size: 12px !important;
  font-weight: bold;
  cursor: pointer;
  color: var(--font-color);
  background-color: var(--none-color) !important;
  border: 3px solid var(--border-color) !important;
  border-bottom: none !important;
  border-radius: 5px 5px 0 0 !important;
  transition: background-color 0.15s;
}

.code-tabs .tab-btn.active {
  background-color: var(--primary-color) !important;
  color: var(--border-color);
}

.code-tabs .tab-btn:hover { transform: none; }

.code-tabs .tab-panel { display: none; }
.code-tabs .tab-panel.active { display: block; }

.code-tabs .code-box {
  border-radius: 0 5px 5px 5px;
  margin-bottom: 0;
}

.code-tabs .code-box .code-header { display: none; }

/* ===== PLAYGROUND ===== */
.docs-section article[window] {
  margin-bottom: 16px;
}

.pg-controls {
  padding: 16px;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 12px;
  border-bottom: 2px dashed var(--border-color);
}

.pg-controls .ctrl {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.pg-controls .ctrl-label {
  font-size: 11px;
  font-weight: bold;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--secondary-color);
}

.pg-controls .ctrl input[type="text"],
.pg-controls .ctrl input[type="number"] {
  padding: 6px 10px;
  font-size: 13px;
  box-shadow: 2px 2px 0 var(--border-color);
}

.pg-controls .ctrl select {
  width: 100%;
  padding: 6px 10px;
  font-size: 13px;
  font-family: var(--font-family);
  color: var(--font-color);
  background-color: var(--background-color);
  border: 3px solid var(--border-color);
  box-shadow: 2px 2px 0 var(--border-color);
  border-radius: var(--default-rounded-square);
  cursor: pointer;
}

.pg-controls .ctrl-check {
  flex-direction: row;
  align-items: center;
  gap: 8px;
  padding-top: 6px;
}

.pg-controls .ctrl-check input[type="checkbox"] {
  width: 18px;
  height: 18px;
  box-shadow: 2px 2px 0 var(--border-color);
  cursor: pointer;
}

.pg-controls .ctrl-check input[type="checkbox"]:checked::after {
  top: 0px;
  left: 4px;
  width: 5px;
  height: 10px;
  border-width: 0 2px 2px 0;
}

.pg-result {
  padding: 20px;
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: center;
  justify-content: center;
  min-height: 60px;
}

.pg-result.stack {
  flex-direction: column;
  align-items: stretch;
}

.pg-code pre {
  margin: 0;
  padding: 12px 16px;
  overflow-x: auto;
  font-family: var(--font-family);
  font-size: 12px;
  line-height: 1.5;
  color: var(--font-color);
  background-color: var(--background-color);
  border: none;
  box-shadow: none;
  border-radius: 0;
}

/* ===== COLOR PALETTE (getting started) ===== */
.color-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
  gap: 10px;
  margin: 16px 0;
}

.color-swatch {
  padding: 28px 10px 10px;
  border: 3px solid var(--border-color);
  box-shadow: 3px 3px 0 var(--border-color);
  border-radius: var(--default-rounded-square);
  text-align: center;
  font-size: 11px;
  font-weight: bold;
}

.color-swatch span { display: block; }
.color-swatch .cv { font-size: 10px; opacity: 0.6; margin-top: 2px; }
.color-swatch[data-swatch-tone="light"] { color: var(--border-color); }
.color-swatch[data-swatch-tone="dark"] { color: #FFF8E3; }

/* ===== FLOATING COLOR MENU ===== */
.docs-color-menu {
  position: fixed;
  bottom: 20px;
  right: 20px;
  z-index: 400;
}

.docs-color-menu .color-toggle {
  width: 48px !important;
  height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: var(--primary-color) !important;
  border: 3px solid var(--border-color) !important;
  box-shadow: 4px 4px 0 var(--border-color);
  cursor: pointer;
  border-radius: var(--default-rounded-square);
  transition: transform 0.1s, box-shadow 0.1s;
}

.docs-color-menu .color-toggle:hover {
  transform: translate(-2px, -2px);
  box-shadow: 6px 6px 0 var(--border-color);
}

.docs-color-menu .color-toggle:active {
  transform: translate(2px, 2px);
  box-shadow: 1px 1px 0 var(--border-color);
}

.docs-color-menu .color-toggle svg { width: 22px; height: 22px; }

.color-panel {
  display: none;
  position: absolute;
  bottom: 56px;
  right: 0;
  width: 240px;
  background-color: var(--background-color);
  border: 3px solid var(--border-color);
  box-shadow: 4px 4px 0 var(--border-color);
  border-radius: var(--default-rounded-square);
  padding: 16px;
}

.color-panel.open { display: block; }

.color-panel h4 { margin: 0 0 12px; font-size: 13px; }

.color-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 10px;
  font-size: 12px;
  font-weight: bold;
}

.color-row input[type="color"] {
  width: 32px;
  height: 28px;
  border: 2px solid var(--border-color);
  border-radius: 4px;
  cursor: pointer;
  padding: 0;
  background: none;
  box-shadow: none;
}

.preset-row {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  margin-top: 12px;
  padding-top: 12px;
  border-top: 2px dashed var(--border-color);
}

.preset-label {
  width: 100%;
  font-size: 11px;
  font-weight: bold;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--secondary-color);
  margin-bottom: 4px;
}

.preset-btn {
  width: 28px !important;
  height: 28px;
  border: 2px solid var(--border-color) !important;
  border-radius: 50% !important;
  cursor: pointer;
  transition: transform 0.1s;
  box-shadow: 2px 2px 0 var(--border-color);
}

.preset-btn:hover { transform: scale(1.15); }

/* ===== SYNTAX HIGHLIGHT (manual) ===== */
.hl-tag { color: #e74c3c; }
.hl-attr { color: var(--secondary-color); }
.hl-str { color: #2ecc71; }
.hl-kw { color: var(--secondary-color); font-weight: bold; }
.hl-comment { opacity: 0.45; font-style: italic; }
.hl-func { color: #e67e22; }
.hl-num { color: #e67e22; }
.hl-punct { opacity: 0.6; }

.dark-mode .hl-tag { color: #ff6b6b; }
.dark-mode .hl-str { color: #51cf66; }
.dark-mode .hl-func { color: #ffa94d; }
.dark-mode .hl-comment { opacity: 0.4; }

/* ===== INFO BOX ===== */
.info-box {
  border: 3px solid var(--border-color);
  box-shadow: 4px 4px 0 var(--border-color);
  border-radius: var(--default-rounded-square);
  margin-bottom: 16px;
  padding: 20px;
}

.info-box h3 {
  margin: 0 0 12px;
  font-size: 18px;
  display: flex;
  align-items: center;
  gap: 8px;
}

.info-box h3 svg { width: 18px; height: 18px; }

/* ===== FOOTER ===== */
.docs-footer {
  text-align: center;
  padding: 30px 0 10px;
  font-size: 12px;
  opacity: 0.5;
}

/* ===== MOBILE ===== */
@media (max-width: 768px) {
  .docs-hamburger { display: flex; }

  .docs-sidebar {
    transform: translateX(-100%);
    transition: transform 0.3s ease;
  }

  body.sidebar-open .docs-sidebar {
    transform: translateX(0);
  }

  body.sidebar-open .docs-overlay {
    display: block;
  }

  .docs-main {
    margin-left: 0;
    padding: 20px 16px 60px;
  }

  .docs-section > h2 { font-size: 20px; }

  .preview-box .preview-content {
    flex-direction: column;
    align-items: stretch;
  }

  .preview-box .preview-content button,
  .preview-box .preview-content .nbtl-button,
  .preview-box .preview-content nb-datetime {
    width: 100%;
  }

  .docs-search {
    position: static;
  }

  .pg-controls { grid-template-columns: 1fr; }

  .color-grid {
    grid-template-columns: repeat(auto-fill, minmax(100px, 1fr));
  }

  .docs-topbar .logo { font-size: 13px; }

  .color-panel {
    right: -10px;
    width: 220px;
  }
}
