/* =========================================================================
 * Kips Template — Main Menu (hamburger)
 *
 * Slide-in panel from the left. Inherits the editor's theme tokens so
 * dark/light mode stay perfectly consistent. The menu is fixed-position
 * and only mounts when the user opens it, keeping the cold render budget
 * unchanged.
 * ========================================================================= */

.kips-mainmenu {
  position: fixed; inset: 0; z-index: 200;
  pointer-events: none;
  contain: strict;
}
.kips-mainmenu.is-open { pointer-events: auto; }

.kips-mainmenu__backdrop {
  position: absolute; inset: 0;
  background: rgba(0, 0, 0, 0);
  transition: background 240ms ease;
}
.kips-mainmenu.is-open .kips-mainmenu__backdrop {
  background: rgba(0, 0, 0, 0.45);
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);
}

.kips-mainmenu__panel {
  position: absolute; top: 0; bottom: 0; left: 0;
  width: min(340px, 86vw);
  background: var(--kt-surface-1, #fff);
  color: var(--kt-text-1, #0E1018);
  border-right: 1px solid var(--kt-border, rgba(0, 0, 0, 0.08));
  display: flex; flex-direction: column;
  transform: translateX(-100%);
  transition: transform 280ms cubic-bezier(0.2, 0.8, 0.2, 1);
  box-shadow: 16px 0 40px -16px rgba(0, 0, 0, 0.35);
  overflow: hidden;
}
.kips-mainmenu.is-open .kips-mainmenu__panel { transform: translateX(0); }

@media (prefers-reduced-motion: reduce) {
  .kips-mainmenu__panel,
  .kips-mainmenu__backdrop { transition: none; }
}

/* ---- Header ---- */
.kips-mainmenu__head {
  flex: 0 0 auto;
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 14px 10px;
  border-bottom: 1px solid var(--kt-border, rgba(0, 0, 0, 0.06));
}
.kips-mainmenu__brand {
  display: flex; align-items: center; gap: 10px;
  font-size: 14px; font-weight: 700; letter-spacing: 0.04em;
}
.kips-mainmenu__mark {
  width: 24px; height: 24px; border-radius: 7px;
  background: conic-gradient(from 220deg at 50% 50%, #6E5BFF, #00DCC8, #6E5BFF);
  box-shadow: inset 0 0 0 1.5px rgba(255, 255, 255, 0.10);
}
.kips-mainmenu__close { color: inherit; }

/* ---- User block ---- */
.kips-mainmenu__user { padding: 10px 12px 6px; }
.kips-mainmenu__cta,
.kips-mainmenu__profile {
  display: flex; align-items: center; gap: 12px;
  padding: 10px 12px; border-radius: 12px;
  text-decoration: none; color: inherit;
  background: linear-gradient(135deg, rgba(110, 91, 255, 0.10), rgba(0, 220, 200, 0.08));
  border: 1px solid var(--kt-border, rgba(0, 0, 0, 0.08));
}
.kips-mainmenu__cta { flex-direction: column; align-items: flex-start; gap: 2px; }
.kips-mainmenu__cta span:first-child { font-weight: 700; font-size: 14px; }
.kips-mainmenu__cta small { color: var(--kt-text-2, rgba(0, 0, 0, 0.6)); font-size: 12px; }
.kips-mainmenu__alt {
  display: block; padding: 8px 14px; margin-top: 6px;
  font-size: 13px; text-decoration: none;
  color: var(--kt-accent, #6E5BFF); font-weight: 600;
}

.kips-mainmenu__profile strong { display: block; font-size: 14px; }
.kips-mainmenu__profile small { display: block; color: var(--kt-text-2, rgba(0, 0, 0, 0.6)); font-size: 12px; }
.kips-mainmenu__avatar {
  width: 38px; height: 38px; border-radius: 50%;
  display: grid; place-items: center;
  background: linear-gradient(135deg, #6E5BFF, #00DCC8);
  color: white; font-weight: 700; font-size: 16px;
  box-shadow: 0 4px 12px -4px rgba(110, 91, 255, 0.6);
}

/* ---- List ---- */
.kips-mainmenu__list {
  flex: 1 1 auto;
  overflow-y: auto;
  padding: 8px 8px 16px;
  display: flex; flex-direction: column; gap: 2px;
  -webkit-overflow-scrolling: touch;
}

.kips-mainmenu__item {
  appearance: none; border: 0; background: transparent;
  width: 100%;
  display: flex; align-items: center; gap: 12px;
  padding: 10px 10px;
  text-align: left;
  font: inherit; color: inherit;
  border-radius: 10px;
  cursor: pointer;
  transition: background 140ms ease;
}
.kips-mainmenu__item:hover,
.kips-mainmenu__item:focus-visible {
  background: var(--kt-surface-2, rgba(0, 0, 0, 0.05));
  outline: none;
}
.kips-mainmenu__item:active { transform: scale(0.99); }

.kips-mainmenu__icon {
  width: 36px; height: 36px;
  flex: 0 0 auto;
  display: grid; place-items: center;
  border-radius: 10px;
  background: var(--kt-surface-2, rgba(0, 0, 0, 0.05));
  color: var(--kt-accent, #6E5BFF);
}
.kips-mainmenu__icon svg { width: 19px; height: 19px; fill: currentColor; }

.kips-mainmenu__label { display: flex; flex-direction: column; line-height: 1.25; flex: 1; min-width: 0; }
.kips-mainmenu__title { font-weight: 600; font-size: 14px; }
.kips-mainmenu__sub { color: var(--kt-text-2, rgba(0, 0, 0, 0.55)); font-size: 12px; margin-top: 2px; }

.kips-mainmenu__kbd {
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  font-size: 11px; padding: 2px 6px; border-radius: 6px;
  background: var(--kt-surface-2, rgba(0, 0, 0, 0.05));
  border: 1px solid var(--kt-border, rgba(0, 0, 0, 0.08));
  color: var(--kt-text-2, rgba(0, 0, 0, 0.6));
}
.kips-mainmenu__chev {
  color: var(--kt-text-3, rgba(0, 0, 0, 0.35));
  font-size: 18px;
  transform: translateY(-1px);
}

/* ---- Footer ---- */
.kips-mainmenu__foot {
  flex: 0 0 auto;
  display: flex; align-items: center; justify-content: space-between;
  gap: 8px;
  padding: 10px 12px;
  border-top: 1px solid var(--kt-border, rgba(0, 0, 0, 0.06));
}
.kips-mainmenu__theme {
  appearance: none; border: 0;
  display: inline-flex; align-items: center; gap: 8px;
  padding: 6px 10px; border-radius: 8px;
  background: var(--kt-surface-2, rgba(0, 0, 0, 0.05));
  color: inherit; font: inherit; font-size: 13px; cursor: pointer;
}
.kips-mainmenu__theme:hover { background: var(--kt-surface-3, rgba(0, 0, 0, 0.08)); }
.kips-mainmenu__theme .kips-mainmenu__icon {
  width: 22px; height: 22px; background: transparent;
}
.kips-mainmenu__theme .kips-mainmenu__icon svg { width: 16px; height: 16px; }

/* Language toggle — sits to the right of the Theme button in the footer
   (mirrors its capsule shape so they read as a paired control). The
   visible label is the 2-letter language code (EN / ID). */
.kips-mainmenu__lang {
  appearance: none; border: 0;
  display: inline-flex; align-items: center; gap: 8px;
  padding: 6px 10px; border-radius: 8px;
  background: var(--kt-surface-2, rgba(0, 0, 0, 0.05));
  color: inherit; font: inherit; font-size: 13px; cursor: pointer;
  font-variant-numeric: tabular-nums;
  letter-spacing: 0.04em;
}
.kips-mainmenu__lang:hover { background: var(--kt-surface-3, rgba(0, 0, 0, 0.08)); }
.kips-mainmenu__lang .kips-mainmenu__icon {
  width: 22px; height: 22px; background: transparent;
}
.kips-mainmenu__lang .kips-mainmenu__icon svg { width: 16px; height: 16px; color: currentColor; }
[data-theme="obsidian"] .kips-mainmenu__lang { background: rgba(255, 255, 255, 0.06); }
[data-theme="obsidian"] .kips-mainmenu__lang:hover { background: rgba(255, 255, 255, 0.10); }
.kips-mainmenu__build {
  font: 11px ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  color: var(--kt-text-3, rgba(0, 0, 0, 0.35));
}

/* ---- Dark theme tweaks ---- */
[data-theme="obsidian"] .kips-mainmenu__cta,
[data-theme="obsidian"] .kips-mainmenu__profile {
  background: linear-gradient(135deg, rgba(110, 91, 255, 0.18), rgba(0, 220, 200, 0.10));
  border-color: rgba(255, 255, 255, 0.06);
}
[data-theme="obsidian"] .kips-mainmenu__icon {
  background: rgba(255, 255, 255, 0.06);
}
[data-theme="obsidian"] .kips-mainmenu__theme {
  background: rgba(255, 255, 255, 0.06);
}
[data-theme="obsidian"] .kips-mainmenu__theme:hover {
  background: rgba(255, 255, 255, 0.10);
}
[data-theme="obsidian"] .kips-mainmenu__kbd {
  background: rgba(255, 255, 255, 0.06);
  border-color: rgba(255, 255, 255, 0.08);
}


/* ---- Help & About modal (mounted inside .kips-mainmenu) ---- */
.kips-mainmenu__help {
  position: absolute; inset: 0;
  z-index: 10;
  display: grid; place-items: center;
  pointer-events: none;
  opacity: 0;
  transition: opacity 200ms ease;
}
.kips-mainmenu__help.is-open { pointer-events: auto; opacity: 1; }
.kips-mainmenu__help-backdrop { position: absolute; inset: 0; background: rgba(0, 0, 0, 0.55); }
.kips-mainmenu__help-card {
  position: relative;
  width: min(420px, 92vw);
  max-height: 85vh; overflow-y: auto;
  background: var(--kt-surface-1, #fff);
  color: var(--kt-text-1, #0E1018);
  border: 1px solid var(--kt-border, rgba(0, 0, 0, 0.08));
  border-radius: 14px;
  padding: 18px;
  box-shadow: 0 20px 60px -20px rgba(0, 0, 0, 0.45);
}
.kips-mainmenu__help-head {
  display: flex; align-items: center; gap: 10px;
  margin: 0 0 10px;
}
.kips-mainmenu__help-head strong { flex: 1; font-size: 15px; }
.kips-mainmenu__help-tag {
  margin: 0 0 14px;
  color: var(--kt-text-2, rgba(0, 0, 0, 0.6));
  font-size: 13px;
}
.kips-mainmenu__help h4 {
  margin: 14px 0 8px;
  font-size: 12px; letter-spacing: 0.06em; text-transform: uppercase;
  color: var(--kt-text-2, rgba(0, 0, 0, 0.5));
}
.kips-mainmenu__help-kbd {
  display: grid; grid-template-columns: max-content 1fr;
  column-gap: 16px; row-gap: 8px;
  margin: 0;
  font-size: 13px;
}
.kips-mainmenu__help-kbd dt,
.kips-mainmenu__help-kbd kbd {
  display: inline-flex; align-items: center; gap: 4px;
}
.kips-mainmenu__help-kbd kbd {
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  font-size: 11px; padding: 2px 6px; border-radius: 6px;
  background: var(--kt-surface-2, rgba(0, 0, 0, 0.05));
  border: 1px solid var(--kt-border, rgba(0, 0, 0, 0.08));
}
.kips-mainmenu__help-kbd dd,
.kips-mainmenu__help-kbd span { margin: 0; color: var(--kt-text-2, rgba(0, 0, 0, 0.7)); }
.kips-mainmenu__help-links {
  list-style: none; padding: 0; margin: 0;
  display: flex; flex-wrap: wrap; gap: 12px;
  font-size: 13px;
}
.kips-mainmenu__help-links a { color: var(--kt-accent, #6E5BFF); text-decoration: none; font-weight: 600; }
.kips-mainmenu__help-foot {
  display: flex; align-items: center; justify-content: space-between;
  gap: 10px; margin-top: 16px;
  padding-top: 12px;
  border-top: 1px solid var(--kt-border, rgba(0, 0, 0, 0.06));
  font: 11px ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  color: var(--kt-text-3, rgba(0, 0, 0, 0.4));
}
.kips-mainmenu__help-ok {
  appearance: none; border: 0; cursor: pointer;
  font: inherit; font-family: inherit; font-size: 13px; font-weight: 600;
  padding: 8px 14px; border-radius: 8px;
  background: var(--kt-accent, #6E5BFF); color: white;
}
.kips-mainmenu__help-ok:hover { filter: brightness(1.06); }

[data-theme="obsidian"] .kips-mainmenu__help-card {
  background: #14161F;
  border-color: rgba(255, 255, 255, 0.06);
}
[data-theme="obsidian"] .kips-mainmenu__help-kbd kbd {
  background: rgba(255, 255, 255, 0.06);
  border-color: rgba(255, 255, 255, 0.08);
}
