/* ==========================================================================
   KSKO User Dashboard – Base styles (aislados, sin chocar con Woodmart)
   Namespace: .ksko-ud-*
   ========================================================================== */

:root {
  --ud-bg: #f6f8fb;
  --ud-card-bg: #ffffff;
  --ud-line: #e7ebf0;
  --ud-text: #111827;
  --ud-muted: #6b7280;
  --ud-brand: var(--wd-primary-color);
  --ud-brand-contrast: #ffffff;
  --ud-radius: 14px;
  --ud-shadow: 0 8px 24px rgba(16, 24, 40, .06);
}

/* -------- Shell general -------- */
.ksko-ud-shell {
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: 24px;
  background: var(--ud-bg);
  padding: 24px;
  padding-top: 0px !important;
  padding-bottom: 45px !important;
  border-radius: 12px;
}

/* Reset mínimo para tipografía interna */
.ksko-ud-shell, .ksko-ud-shell * {
  box-sizing: border-box;
}

/* -------- Sidebar propio -------- */
.ksko-ud-sidebar {
  background: var(--ud-card-bg);
  border: 1px solid var(--ud-line);
  border-radius: var(--ud-radius);
  box-shadow: var(--ud-shadow);
  position: relative;
  z-index: 90; /* debajo del header de woodmart (normalmente más alto) */
}

.ksko-ud-sidebar__inner { padding: 18px; }

.ksko-ud-usercard {
  display: grid;
  grid-template-columns: 64px 1fr;
  gap: 12px;
  align-items: center;
  margin-bottom: 16px;
}

.ksko-ud-avatar {
  width: 64px; height: 64px; border-radius: 50%; object-fit: cover;
  display: block;
}
.ksko-ud-nav li.is-active > a, .ksko-ud-nav a:hover {
    font-size: 14px !important;
}
.ksko-ud-nav i {
    margin-right: 5px;
}

.ksko-ud-usercard__name { font-weight: 600; color: var(--ud-text); line-height: 1.2; }
.ksko-ud-usercard__email { color: var(--ud-muted); font-size: 0.92rem; }

.ksko-ud-nav ul { list-style: none; margin: 0; padding: 8px 0 0; }
.ksko-ud-nav li { margin: 0; }
.ksko-ud-nav a {
  display: block;
  padding: 10px 12px;
  border-radius: 10px;
  text-decoration: none;
  color: var(--ud-text);
  font-size: 14px !important;
}
.ksko-ud-nav li.is-active > a,
.ksko-ud-nav a:hover {
  background: rgba(37, 99, 235, 0.08);
  color: var(--ud-brand);
}

/* -------- Botón hamburguesa (sólo móvil) -------- */
.ksko-ud-hamburger {
  display: none;
  align-items: center;
  gap: 8px;
  background: var(--ud-card-bg);
  border: 1px solid var(--ud-line);
  border-radius: 12px;
  padding: 10px 12px;
  box-shadow: var(--ud-shadow);
  margin-bottom: 12px;
}
.ksko-ud-hamburger span {
  display: block; width: 18px; height: 2px; background: var(--ud-text);
}
.ksko-ud-hamburger-title { font-size: .95rem; color: var(--ud-text); }

/* -------- Contenido -------- */
.ksko-ud-content { min-width: 0; }

.ksko-ud-section-title {
  margin: 0 0 12px 0;
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--ud-text);
}

/* Grid de tarjetas */
.ksko-ud-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 18px;
}

@media (min-width: 900px) {
  .ksko-ud-grid {
    grid-template-columns: 1fr 1fr;
  }
}

/* Tarjetas */
.ksko-ud-card {
  background: var(--ud-card-bg);
  border: 1px solid var(--ud-line);
  border-radius: var(--ud-radius);
  box-shadow: var(--ud-shadow);
  overflow: hidden;
}

.ksko-ud-card__header {
  padding: 14px 16px;
  border-bottom: 1px solid var(--ud-line);
}
.ksko-ud-card__header h3 {
  margin: 0; font-size: 1.05rem; font-weight: 700; color: var(--ud-text);
}
.ksko-ud-card__body { padding: 16px; }

/* Formularios */
.ksko-ud-form .form-row { margin-bottom: 14px; }
.ksko-ud-form label { display:block; margin-bottom:6px; color: var(--ud-muted); }
.ksko-ud-form .input-text, .ksko-ud-form input[type="file"] {
  width: 100%;
  border: 1px solid var(--ud-line);
  border-radius: 10px;
  padding: 10px 12px;
  background: #fff;
}
.ksko-ud-form .button {
  background: var(--ud-brand);
  color: var(--ud-brand-contrast) !important;
  border: 0;
  padding: 10px 14px;
  border-radius: 10px;
  cursor: pointer;
}
.ksko-ud-form .button.alt { background: var(--ud-brand); }
.ksko-ud-form .button:hover { filter: brightness(0.95); }

/* Fieldgroups */
.ksko-ud-fieldgroup--two {
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
}
@media (min-width: 720px) {
  .ksko-ud-fieldgroup--two {
    grid-template-columns: 1fr 1fr;
  }
}
.ksko-ud-fieldgroup--avatar {
  display: grid;
  grid-template-columns: 64px 1fr;
  gap: 12px;
  align-items: center;
}

/* Avisos */
.ksko-ud-notice {
  padding:12px 16px; margin-bottom:16px;
  border-left:4px solid #46b450; background:#f1fff1; border-radius: 8px;
}
.ksko-ud-notice.error { border-color:#dc3232; background:#fff5f5; }

/* ---------- Responsivo / Off-canvas propio ---------- */
@media (max-width: 1024px) {
  .ksko-ud-shell {
    grid-template-columns: 1fr;
    gap: 12px;
    padding: 16px;
  }

  .ksko-ud-hamburger { display: inline-flex; }

  /* Sidebar oculto por defecto en móvil */
  .ksko-ud-sidebar {
    position: fixed;
    top: 120px; /* bajo el header de woodmart; ajusta si tu header cambia de alto */
    left: 0;
    width: 300px;
    height: calc(100vh - 92px);
    transform: translateX(-105%);
    transition: transform .25s ease;
    border-radius: 0 16px 16px 0;
  }

  /* Cuando el shell tiene la clase .sidebar-open, mostramos */
  .ksko-ud-shell.sidebar-open .ksko-ud-sidebar {
    transform: translateX(0);
  }
}

/* Aseguramos que no afecte otros menús de Woodmart */
.wd-mobile-nav, .wd-header-nav { z-index: 999; }

/* === Uploader minimal (inline filename, sin meta inferior) ================ */

.ksko-ud-label { display:block; margin-bottom:6px; color: var(--ud-muted); }

.ksko-ud-upload { width:100%; position:relative; }

.ksko-ud-file-input {
  position:absolute !important;
  width:1px; height:1px; padding:0; margin:-1px;
  overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0;
}

.ksko-ud-dropzone {
  border:2px dashed var(--ud-line);
  background:#fafbff;
  border-radius:12px;
  padding:14px;
  text-align:center;
  transition:border-color .2s ease, background .2s ease;
  cursor:pointer;
  user-select:none;
}
.ksko-ud-dropzone:hover { border-color: rgba(37,99,235,.5); }
.ksko-ud-dropzone.is-dragover {
  border-color: var(--ud-brand);
  background: rgba(37,99,235,.06);
}

.ksko-ud-drop-icon { font-size:22px; line-height:1; margin-bottom:6px; }

.ksko-ud-drop-text {
  display:flex; align-items:center; justify-content:center; gap:8px; flex-wrap:wrap;
}
.ksko-ud-drop-text .ksko-ud-sep, .ksko-ud-drop-text button, .ksko-ud-file-hint{
    display: none;
}
.ksko-ud-drop-text [data-ud-prompt] { color: var(--ud-text); }
.ksko-ud-drop-text [data-ud-filename] {
  color: var(--ud-text);
  max-width:320px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap;
}
.ksko-ud-sep { color: var(--ud-muted); }

.ksko-ud-browse { padding:6px 10px; border-radius:8px; }


/* Pequeño sombreado en la preview */
.ksko-ud-avatar-preview { box-shadow: var(--ud-shadow); }

/* ===== HAMBURGUER FIX ===== */
.ksko-ud-hamburger{
  /* layout */
  display:grid;
  grid-template-columns:auto 0fr;          /* [icono] [texto] */
  grid-template-rows:repeat(3, 0px);       /* 3 filas para las barras */
  align-items:center;
  column-gap:10px;

  /* look & feel (ajústalo a tu theme) */
  padding:10px 14px;
  border:1px solid rgba(0,0,0,.08);
  border-radius:12px;
  background:#fff;
  line-height:1;
  cursor:pointer;
  user-select:none;
}

/* las 3 barras */
.ksko-ud-hamburger > span{
  grid-column:1;                 /* primera columna (icono) */
  width:22px;
  height:2px;
  background:currentColor;
  border-radius:2px;
  align-self:center;
}
.ksko-ud-hamburger > span:nth-child(1){ grid-row:1; }
.ksko-ud-hamburger > span:nth-child(2){ grid-row:2; }
.ksko-ud-hamburger > span:nth-child(3){ grid-row:3; }

/* el texto “Menu” centrado verticalmente */
.ksko-ud-hamburger .ksko-ud-hamburger-title{
  grid-column:2;
  grid-row:1 / span 3;           /* ocupa las 3 filas */
  align-self:center;
  font-weight:600;
  text-transform:uppercase;       /* opcional */
  letter-spacing:.02em;           /* opcional */
}

/* estados */
.ksko-ud-hamburger:hover{ box-shadow:0 1px 6px rgba(0,0,0,.06); }
.ksko-ud-hamburger:focus{ outline:2px solid rgba(0,0,0,.15); outline-offset:2px; }

/* animación simple al abrir (opcional) */
.ksko-ud-hamburger[aria-expanded="true"] > span:nth-child(1){
  transform:translateY(4px) rotate(45deg);
}
.ksko-ud-hamburger[aria-expanded="true"] > span:nth-child(2){
  opacity:0;
}
.ksko-ud-hamburger[aria-expanded="true"] > span:nth-child(3){
  transform:translateY(-12px) rotate(-45deg);
}

/* si quieres ocultarlo en desktop y mostrarlo solo en móvil */
@media (min-width: 992px){
  .ksko-ud-hamburger{ display:none; }
}

@media (max-width: 767px){
      .ksko-ud-fieldgroup--two {
      display: block;
  }
  .ksko-ud-card__body button{
      width: 100% !important;
      margin-top: 10px !important;
  }
}

@media (max-width: 512px){
    .ksko-ud-hamburger {
        padding-top: 14px;
        padding-bottom: 14px;
    }
}
