/* ==========================================================================
   KESAGOX - MY ACCOUNT V2+ (Modern UI for Orders, Addresses, Profile)
   ========================================================================== */

:root{
  --kg-blue: #0b2a6a;
  --kg-blue-2:#102f78;
  --kg-soft: #f3f7ff;
  --kg-soft-2:#fbfdff;
  --kg-text: #0b2a6a;
  --kg-muted:#3b4f7a;
  --kg-gold:#D4AF37;
  --kg-border: rgba(11,42,106,.12);
  --kg-shadow: 0 16px 40px rgba(0,0,0,.06);
  --kg-shadow-2: 0 10px 28px rgba(0,0,0,.05);
}

.woocommerce-account .woocommerce{
  max-width: 1240px;
  margin: 0 auto;
  padding: 16px 14px;
}

.kg-ma2{
  display:grid;
  grid-template-columns: 320px 1fr;
  gap: 16px;
  align-items:start;
}

/* Sidebar */
.kg-ma2-sidebar{
  position: sticky;
  top: 14px;
  height: fit-content;
  background: linear-gradient(180deg,#fff 0%, var(--kg-soft-2) 100%);
  border: 1px solid var(--kg-border);
  border-radius: 18px;
  box-shadow: var(--kg-shadow);
  padding: 12px;
}

.kg-ma2-nav-toggle{
  display:none;
  width:100%;
  border-radius:14px;
  padding:12px 12px;
  font-weight: 1000;
  border: 1px solid rgba(11,42,106,.18);
  background: var(--kg-blue);
  color:#fff;
  cursor:pointer;
  margin-bottom: 10px;
}
.kg-ma2-nav-toggle:hover{ filter: brightness(1.08); }

.kg-ma2-nav-list{
  display:flex;
  flex-direction:column;
  gap: 8px;
}

.kg-ma2-nav-item{
  display:flex;
  gap: 10px;
  align-items:center;
  text-decoration:none !important;
  padding: 12px 12px;
  border-radius: 16px;
  font-weight: 1000;
  color: var(--kg-blue);
  background: var(--kg-soft);
  border: 1px solid rgba(11,42,106,.10);
  transition: transform .08s ease, filter .12s ease, background .12s ease;
  line-height: 1.1;
}
.kg-ma2-nav-item:hover{
  background: var(--kg-blue);
  color:#fff;
  transform: translateY(1px);
}
.kg-ma2-nav-ico{ font-size: 18px; width: 26px; display:inline-flex; justify-content:center; }

.kg-ma2-nav-item.is-active{
  background: linear-gradient(180deg, var(--kg-blue) 0%, var(--kg-blue-2) 100%);
  color:#fff;
  border-color: rgba(212,175,55,.55);
  box-shadow: 0 12px 26px rgba(11,42,106,.22);
}

/* Main */
.kg-ma2-main{
  border: 1px solid var(--kg-border);
  border-radius: 18px;
  box-shadow: var(--kg-shadow);
  background:#fff;
  overflow:hidden;
}

.kg-ma2-topbar{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap: 14px;
  padding: 16px 16px;
  border-bottom: 1px solid rgba(11,42,106,.10);
  background: linear-gradient(180deg, #ffffff 0%, var(--kg-soft-2) 100%);
}

.kg-ma2-brand{
  display:inline-flex;
  font-weight: 1000;
  letter-spacing: .10em;
  font-size: 12px;
  padding: 6px 10px;
  border-radius: 999px;
  color: var(--kg-blue);
  background: var(--kg-soft);
  border: 1px solid rgba(11,42,106,.14);
  height: fit-content;
}
.kg-ma2-topbar-left{ display:flex; align-items:flex-start; gap: 10px; }
.kg-ma2-title{ display:flex; flex-direction:column; line-height:1.05; }
.kg-ma2-title-strong{ font-weight: 1100; color: var(--kg-text); font-size: 20px; }
.kg-ma2-title-sub{ color: var(--kg-muted); font-weight: 800; font-size: 12px; margin-top: 6px; }

.kg-ma2-topbar-right{ display:flex; gap: 10px; align-items:center; flex-wrap:wrap; }

.kg-ma2-content{ padding: 16px; }

/* Buttons (global inside My Account) */
.kg-ma2 .button,
.kg-ma2 a.button,
.kg-ma2 button.button,
.kg-ma2 input.button,
.kg-ma2 .woocommerce-button{
  border-radius: 999px !important;
  font-weight: 1000 !important;
  padding: 10px 14px !important;
  border: 1px solid rgba(11,42,106,.18) !important;
  background: var(--kg-soft) !important;
  color: var(--kg-blue) !important;
  transition: transform .08s ease, filter .12s ease, background .12s ease;
  line-height: 1 !important;
  box-shadow: 0 10px 22px rgba(0,0,0,.05);
}
.kg-ma2 .button:hover,
.kg-ma2 a.button:hover,
.kg-ma2 button.button:hover,
.kg-ma2 input.button:hover,
.kg-ma2 .woocommerce-button:hover{
  background: var(--kg-blue) !important;
  color:#fff !important;
  transform: translateY(1px);
}
.kg-ma2 .button:active{ transform: translateY(1px); }

.kg-ma2-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding: 10px 14px;
  border-radius: 999px;
  text-decoration:none !important;
  font-weight: 1000;
  border: 1px solid rgba(11,42,106,.18);
  transition: transform .08s ease, filter .12s ease;
  line-height:1;
  box-shadow: 0 10px 22px rgba(0,0,0,.05);
}
.kg-ma2-btn:active{ transform: translateY(1px); }

.kg-ma2-btn-primary{ background: var(--kg-blue); color:#fff !important; border-color: rgba(11,42,106,.22); }
.kg-ma2-btn-primary:hover{ filter: brightness(1.08); }
.kg-ma2-btn-outline{ background:#fff; color: var(--kg-blue) !important; }
.kg-ma2-btn-outline:hover{ background: var(--kg-soft); }
.kg-ma2-btn-gold{ background: var(--kg-gold); color:#1b1b1b !important; border-color: rgba(212,175,55,.70); }
.kg-ma2-btn-gold:hover{ filter: brightness(1.05); }

/* Dashboard blocks */
.kg-ma2-hero{
  border-radius: 18px;
  padding: 16px;
  border: 1px solid rgba(212,175,55,.55);
  background: linear-gradient(180deg, #ffffff 0%, #f9fbff 100%);
  margin-bottom: 14px;
}
.kg-ma2-hero h2{ margin:0 0 6px 0; color: var(--kg-blue); font-weight: 1100; font-size: 20px; }
.kg-ma2-hero p{ margin:0; color: var(--kg-muted); font-weight: 800; line-height: 1.2; }

.kg-ma2-grid{
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap: 12px;
}
.kg-ma2-stack{ display:flex; flex-direction:column; gap: 12px; }

.kg-ma2-card{
  border-radius: 18px;
  border: 1px solid rgba(11,42,106,.12);
  background:#fff;
  box-shadow: var(--kg-shadow-2);
  padding: 14px;
}

.kg-ma2-card-title{
  margin: 0 0 12px 0;
  font-size: 14px;
  color: var(--kg-blue);
  font-weight: 1100;
}

.kg-ma2-tiles{
  display:grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 10px;
}

.kg-ma2-tile{
  display:block;
  border-radius: 16px;
  padding: 12px;
  background: var(--kg-soft);
  border: 1px solid rgba(11,42,106,.10);
  color: var(--kg-blue) !important;
  text-decoration:none !important;
  font-weight: 1100;
  box-shadow: 0 10px 22px rgba(0,0,0,.05);
  transition: transform .08s ease, filter .12s ease;
}
.kg-ma2-tile:hover{ background: var(--kg-blue); color:#fff !important; transform: translateY(1px); }
.kg-ma2-tile-ico{ font-size: 22px; display:block; margin-bottom: 8px; }
.kg-ma2-tile-title{ display:block; font-size: 14px; }
.kg-ma2-tile-desc{ display:block; font-size: 12px; font-weight: 900; opacity: .9; margin-top: 6px; line-height:1.2; }
.kg-ma2-tile-gold{ background: linear-gradient(180deg, #fff8e3 0%, #fff 100%); border-color: rgba(212,175,55,.70); }
.kg-ma2-tile-gold:hover{ background: var(--kg-gold); color:#1b1b1b !important; }

/* Address widget */
.kg-ma2-address-head{ display:flex; align-items:center; justify-content:space-between; gap: 10px; }
.kg-ma2-address-body{
  margin-top: 10px;
  padding: 12px;
  border-radius: 16px;
  background: var(--kg-soft-2);
  border: 1px solid rgba(11,42,106,.08);
  color: var(--kg-muted);
  font-weight: 900;
  line-height: 1.25;
}
.kg-ma2-actions{ display:flex; gap: 10px; margin-top: 12px; flex-wrap:wrap; }

/* Last order */
.kg-ma2-last-summary{ display:flex; flex-direction:column; gap: 10px; }
.kg-ma2-last-row{
  display:flex;
  justify-content:space-between;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 16px;
  background: var(--kg-soft-2);
  border: 1px solid rgba(11,42,106,.08);
}
.kg-ma2-last-k{ color: var(--kg-muted); font-weight: 1000; font-size: 12px; }
.kg-ma2-last-v{ color: var(--kg-blue); font-weight: 1100; font-size: 13px; text-align:right; }

.kg-ma2-pill{
  display:inline-flex;
  padding: 6px 10px;
  border-radius: 999px;
  background: var(--kg-soft);
  border: 1px solid rgba(11,42,106,.12);
  font-weight: 1100;
  font-size: 12px;
  color: var(--kg-blue);
}

.kg-ma2-last-items-title{ margin-top: 8px; font-weight: 1100; color: var(--kg-blue); font-size: 13px; }
.kg-ma2-last-items ul{ margin: 8px 0 0 0; padding-left: 18px; color: var(--kg-muted); font-weight: 900; }
.kg-ma2-last-items li{ margin: 6px 0; }
.kg-ma2-last-items li span{ opacity:.9; font-weight: 1100; }
.kg-ma2-last-more{ margin-top: 6px; color: var(--kg-muted); font-weight: 1000; font-size: 12px; }

.kg-ma2-last-actions{ display:flex; gap: 10px; margin-top: 10px; flex-wrap:wrap; }

.kg-ma2-muted{ color: var(--kg-muted); font-weight: 900; line-height:1.2; }

/* ---------- Modern UI for Woo sections ---------- */

/* Headings inside endpoints */
.kg-ma2 .woocommerce-MyAccount-content h2,
.kg-ma2 .woocommerce-MyAccount-content h3{
  font-weight: 1100;
  color: var(--kg-blue);
  letter-spacing: -0.01em;
}

/* Tables: Orders */
.kg-ma2 table.shop_table,
.kg-ma2 table.woocommerce-orders-table{
  border: 1px solid rgba(11,42,106,.12) !important;
  border-radius: 18px;
  overflow: hidden;
  box-shadow: var(--kg-shadow-2);
  background: #fff;
}
.kg-ma2 table.shop_table thead th,
.kg-ma2 table.woocommerce-orders-table thead th{
  background: var(--kg-soft);
  color: var(--kg-blue);
  font-weight: 1100;
  border-bottom: 1px solid rgba(11,42,106,.10) !important;
}
.kg-ma2 table.shop_table td,
.kg-ma2 table.woocommerce-orders-table td{
  border-top: 1px solid rgba(11,42,106,.06) !important;
  color: var(--kg-muted);
  font-weight: 900;
}
.kg-ma2 .woocommerce-orders-table__cell-order-actions a{
  margin-right: 8px;
}

/* Addresses page */
.kg-ma2 .woocommerce-Addresses{
  display:grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 12px;
}
.kg-ma2 .woocommerce-Address{
  border: 1px solid rgba(11,42,106,.12);
  border-radius: 18px;
  padding: 14px;
  background: #fff;
  box-shadow: var(--kg-shadow-2);
}
.kg-ma2 .woocommerce-Address-title{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 10px;
}
.kg-ma2 .woocommerce-Address-title h3{
  margin: 0;
  font-weight: 1100;
}

/* Profile form */
.kg-ma2 .woocommerce-EditAccountForm,
.kg-ma2 .woocommerce-address-fields{
  border: 1px solid rgba(11,42,106,.12);
  border-radius: 18px;
  padding: 14px;
  background: #fff;
  box-shadow: var(--kg-shadow-2);
}
.kg-ma2 .form-row label{
  font-weight: 1000;
  color: var(--kg-blue);
}
.kg-ma2 input[type="text"],
.kg-ma2 input[type="email"],
.kg-ma2 input[type="password"],
.kg-ma2 input[type="tel"],
.kg-ma2 select,
.kg-ma2 textarea{
  border-radius: 14px !important;
  border: 1px solid rgba(11,42,106,.16) !important;
  background: var(--kg-soft-2) !important;
  padding: 12px 12px !important;
  font-weight: 900 !important;
  color: var(--kg-blue) !important;
}
.kg-ma2 input:focus,
.kg-ma2 select:focus,
.kg-ma2 textarea:focus{
  outline: none !important;
  box-shadow: 0 0 0 3px rgba(11,42,106,.12) !important;
}

/* Notices */
.kg-ma2 .woocommerce-message,
.kg-ma2 .woocommerce-info,
.kg-ma2 .woocommerce-error{
  border-radius: 18px;
  border: 1px solid rgba(11,42,106,.12);
  box-shadow: var(--kg-shadow-2);
}

/* Responsive */
@media (max-width: 980px){
  .kg-ma2{ grid-template-columns: 1fr; }
  .kg-ma2-sidebar{ position: relative; top:auto; }
  .kg-ma2-grid{ grid-template-columns: 1fr; }
  .kg-ma2 .woocommerce-Addresses{ grid-template-columns: 1fr; }
}

@media (max-width: 640px){
  .kg-ma2-nav-toggle{ display:block; }
  .kg-ma2-nav-list{ display:none; }
  html.kg-ma2-nav-open .kg-ma2-nav-list{ display:flex; }
  .kg-ma2-tiles{ grid-template-columns: 1fr; }
  .kg-ma2-topbar{ flex-direction:column; align-items:flex-start; }
}

/* ==========================================================================
   KESAGOX - APP-LIKE UPGRADE (Mobile cards + status pills + forms)
   ========================================================================== */

/* ----- Status pills (Woo suele usar mark.order-status.status-xxx) ----- */
.kg-ma2 mark.order-status,
.kg-ma2 .order-status{
  display:inline-flex !important;
  align-items:center;
  padding: 6px 10px;
  border-radius: 999px;
  font-weight: 1100;
  font-size: 12px;
  border: 1px solid rgba(11,42,106,.12);
  background: var(--kg-soft);
  color: var(--kg-blue);
}

.kg-ma2 mark.status-completed{ background:#eefcf3; border-color: rgba(0,140,70,.18); color:#0a6a38; }
.kg-ma2 mark.status-processing{ background:#eef6ff; border-color: rgba(20,90,200,.18); color:#0b2a6a; }
.kg-ma2 mark.status-on-hold{ background:#fff8e3; border-color: rgba(212,175,55,.30); color:#6a520a; }
.kg-ma2 mark.status-cancelled,
.kg-ma2 mark.status-failed{ background:#fff0f0; border-color: rgba(220,20,60,.20); color:#8a0f23; }
.kg-ma2 mark.status-refunded{ background:#f5f5f7; border-color: rgba(0,0,0,.10); color:#222; }

/* ----- Botones de acciones en pedidos (Ver / Pagar / Reordenar) ----- */
.kg-ma2 .woocommerce-orders-table__cell-order-actions a,
.kg-ma2 .woocommerce-button,
.kg-ma2 a.woocommerce-button{
  border-radius: 999px !important;
  font-weight: 1100 !important;
  padding: 10px 12px !important;
  border: 1px solid rgba(11,42,106,.16) !important;
  background: var(--kg-soft) !important;
  color: var(--kg-blue) !important;
  text-decoration: none !important;
}
.kg-ma2 .woocommerce-orders-table__cell-order-actions a:hover{
  background: var(--kg-blue) !important;
  color:#fff !important;
  transform: translateY(1px);
}

/* ----- Forms más “app”: fieldset como cards ----- */
.kg-ma2 .woocommerce-EditAccountForm fieldset,
.kg-ma2 .woocommerce-address-fields fieldset{
  border: 1px solid rgba(11,42,106,.12) !important;
  border-radius: 18px !important;
  padding: 14px !important;
  background: #fff !important;
  box-shadow: var(--kg-shadow-2);
}
.kg-ma2 .woocommerce-EditAccountForm legend,
.kg-ma2 .woocommerce-address-fields legend{
  font-weight: 1100;
  color: var(--kg-blue);
  padding: 0 10px;
}

/* ----- Mobile: Orders table -> cards ----- */
@media (max-width: 760px){

  /* Oculta el header y convierte la tabla en bloques */
  .kg-ma2 table.woocommerce-orders-table,
  .kg-ma2 table.woocommerce-orders-table thead,
  .kg-ma2 table.woocommerce-orders-table tbody,
  .kg-ma2 table.woocommerce-orders-table th,
  .kg-ma2 table.woocommerce-orders-table td,
  .kg-ma2 table.woocommerce-orders-table tr{
    display:block !important;
    width: 100% !important;
  }

  .kg-ma2 table.woocommerce-orders-table thead{
    display:none !important;
  }

  /* Cada fila como card */
  .kg-ma2 table.woocommerce-orders-table tr{
    border: 1px solid rgba(11,42,106,.12) !important;
    border-radius: 18px !important;
    background:#fff !important;
    box-shadow: var(--kg-shadow-2);
    padding: 12px !important;
    margin-bottom: 12px !important;
  }

  /* Cada celda como fila label/value (Woo trae data-title en td) */
  .kg-ma2 table.woocommerce-orders-table td{
    border: none !important;
    border-top: 1px solid rgba(11,42,106,.06) !important;
    padding: 10px 0 !important;
    display:flex !important;
    justify-content: space-between !important;
    gap: 12px !important;
    align-items: center !important;
    color: var(--kg-muted) !important;
    font-weight: 900 !important;
  }
  .kg-ma2 table.woocommerce-orders-table td:first-child{
    border-top:none !important;
    padding-top: 0 !important;
  }

  /* Label automático */
  .kg-ma2 table.woocommerce-orders-table td::before{
    content: attr(data-title);
    font-weight: 1100;
    color: var(--kg-blue);
    opacity: .95;
    padding-right: 10px;
  }

  /* Acciones: que se vean como fila final con botones */
  .kg-ma2 td.woocommerce-orders-table__cell-order-actions{
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 8px !important;
  }
  .kg-ma2 td.woocommerce-orders-table__cell-order-actions::before{
    content: "Acciones";
  }
  .kg-ma2 td.woocommerce-orders-table__cell-order-actions a{
    width:100%;
    justify-content:center;
  }

  /* El número del pedido bien destacado */
  .kg-ma2 td.woocommerce-orders-table__cell-order-number a{
    font-weight: 1100;
    color: var(--kg-blue) !important;
    text-decoration:none !important;
  }
}

/* ----- Mobile: Address cards full width & tighter spacing ----- */
@media (max-width: 760px){
  .kg-ma2 .woocommerce-Addresses{ grid-template-columns: 1fr !important; }
  .kg-ma2 .woocommerce-Address{ padding: 12px !important; }
}

/* ----- Bottom Nav (app-like) ----- */
.kg-ma2-bottomnav{
  display:none;
}

@media (max-width: 760px){
  .kg-ma2-bottomnav{
    display:flex;
    position: fixed;
    left: 10px;
    right: 10px;
    bottom: 10px;
    z-index: 99999;
    background: rgba(255,255,255,.92);
    backdrop-filter: blur(8px);
    border: 1px solid rgba(11,42,106,.14);
    border-radius: 18px;
    box-shadow: 0 18px 55px rgba(0,0,0,.18);
    padding: 10px 10px;
    gap: 8px;
    justify-content: space-between;
  }

  .kg-ma2-bottomnav-item{
    flex: 1;
    display:flex;
    flex-direction: column;
    align-items:center;
    justify-content:center;
    text-decoration:none !important;
    border-radius: 14px;
    padding: 10px 6px;
    font-weight: 1100;
    color: var(--kg-blue);
    background: var(--kg-soft);
    border: 1px solid rgba(11,42,106,.10);
  }

  .kg-ma2-bottomnav-item.is-active{
    background: linear-gradient(180deg, var(--kg-blue) 0%, var(--kg-blue-2) 100%);
    color:#fff !important;
    border-color: rgba(212,175,55,.55);
  }

  .kg-ma2-bottomnav-ico{ font-size: 18px; line-height: 1; }
  .kg-ma2-bottomnav-txt{ font-size: 11px; margin-top: 6px; line-height: 1; }

  /* deja espacio al contenido para que no quede tapado */
  html.kg-ma2-has-bottomnav .kg-ma2-content{
    padding-bottom: 90px;
  }
}

/* ==========================================================================
   KESAGOX - LOGIN / AUTH (Modern)
   ========================================================================== */

/* (Opcional) Ocultar el título “Mi Cuenta” del theme para que no duplique */
body.woocommerce-account:not(.logged-in) .entry-header,
body.woocommerce-account:not(.logged-in) .page-header{
  display:none !important;
}

.kg-auth{
  padding: 26px 14px;
}
.kg-auth-shell{
  max-width: 1100px;
  margin: 0 auto;
  display:grid;
  grid-template-columns: 1.05fr .95fr;
  border-radius: 26px;
  overflow:hidden;
  border: 1px solid rgba(11,42,106,.12);
  box-shadow: 0 22px 70px rgba(0,0,0,.10);
  background: #fff;
}

/* Panel izquierdo */
.kg-auth-side{
  padding: 28px;
  background: linear-gradient(180deg, #0b2a6a 0%, #102f78 100%);
  color:#fff;
  position: relative;
}
.kg-auth-side::after{
  content:"";
  position:absolute;
  inset:-40% -30% auto auto;
  width: 420px;
  height: 420px;
  background: radial-gradient(circle at 30% 30%, rgba(212,175,55,.35), rgba(255,255,255,0) 60%);
  transform: rotate(12deg);
  pointer-events:none;
}

.kg-auth-logo img{
  max-height: 34px;
  height: auto;
}
.kg-auth-brand-txt{
  font-weight: 1100;
  letter-spacing: .12em;
  font-size: 14px;
  background: rgba(255,255,255,.12);
  border: 1px solid rgba(255,255,255,.18);
  padding: 8px 12px;
  border-radius: 999px;
  display:inline-flex;
}
.kg-auth-title{
  margin: 16px 0 10px 0;
  font-weight: 1200;
  font-size: 30px;
  line-height: 1.05;
}
.kg-auth-sub{
  margin: 0 0 14px 0;
  opacity:.92;
  font-weight: 800;
  line-height: 1.25;
}

.kg-auth-bullets{
  list-style:none;
  padding:0;
  margin: 16px 0 20px 0;
  display:flex;
  flex-direction:column;
  gap: 10px;
}
.kg-auth-bullets li{
  display:flex;
  gap: 10px;
  align-items:flex-start;
  font-weight: 900;
  opacity:.95;
}
.kg-auth-bullets li span{ font-size: 18px; line-height: 1; }

.kg-auth-cta{
  display:inline-flex;
  text-decoration:none !important;
  background: #D4AF37;
  color:#1b1b1b !important;
  font-weight: 1100;
  padding: 12px 16px;
  border-radius: 999px;
  border: 1px solid rgba(212,175,55,.75);
  box-shadow: 0 18px 50px rgba(0,0,0,.20);
}
.kg-auth-cta:hover{ filter: brightness(1.05); transform: translateY(1px); }
.kg-auth-note{ margin-top: 14px; opacity:.92; font-weight: 800; }

/* Panel derecho */
.kg-auth-main{
  padding: 22px;
  background: linear-gradient(180deg, #ffffff 0%, #fbfdff 100%);
}
.kg-auth-card{
  border-radius: 20px;
  border: 1px solid rgba(11,42,106,.12);
  box-shadow: 0 16px 40px rgba(0,0,0,.06);
  padding: 18px;
  background:#fff;
}
.kg-auth-card + .kg-auth-card{ margin-top: 14px; }

.kg-auth-card-title{
  margin: 0 0 6px 0;
  font-weight: 1200;
  color:#0b2a6a;
  font-size: 18px;
}
.kg-auth-card-sub{
  margin: 0 0 14px 0;
  color:#3b4f7a;
  font-weight: 800;
  line-height: 1.2;
}

/* Inputs */
.kg-auth .woocommerce-form-row label{
  font-weight: 1100;
  color:#0b2a6a;
}
.kg-auth input[type="text"],
.kg-auth input[type="email"],
.kg-auth input[type="password"]{
  width:100%;
  border-radius: 16px !important;
  border: 1px solid rgba(11,42,106,.16) !important;
  background:#fbfdff !important;
  padding: 12px 12px !important;
  font-weight: 900 !important;
  color:#0b2a6a !important;
}
.kg-auth input:focus{
  outline:none !important;
  box-shadow: 0 0 0 3px rgba(11,42,106,.12) !important;
}

/* Password eye */
.kg-auth-pass{
  display:flex;
  gap: 8px;
  align-items: center;
}
.kg-auth-passbtn{
  border-radius: 14px;
  border: 1px solid rgba(11,42,106,.16);
  background:#f3f7ff;
  padding: 10px 12px;
  cursor:pointer;
  font-weight: 1100;
}
.kg-auth-passbtn:hover{
  background:#0b2a6a;
  color:#fff;
}

/* Row remember + lost */
.kg-auth-row{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap: 12px;
  flex-wrap:wrap;
  margin-top: 10px;
}
.kg-auth-lost{
  color:#0b2a6a;
  font-weight: 1000;
  text-decoration:none !important;
}
.kg-auth-lost:hover{ text-decoration: underline !important; }

/* Submit */
.kg-auth-submit{
  width:100% !important;
  border-radius: 999px !important;
  padding: 12px 16px !important;
  background:#0b2a6a !important;
  color:#fff !important;
  border: 1px solid rgba(11,42,106,.25) !important;
  font-weight: 1200 !important;
  box-shadow: 0 18px 50px rgba(11,42,106,.18);
}
.kg-auth-submit:hover{ filter: brightness(1.08); transform: translateY(1px); }

/* Social login (compat: Nextend Social Login y otros) */
.kg-auth .nsl-container,
.kg-auth .nsl-container-block{
  margin-bottom: 12px !important;
}
.kg-auth .nsl-container a,
.kg-auth .nsl-button{
  width:100% !important;
  border-radius: 999px !important;
  overflow:hidden;
  font-weight: 1100 !important;
}

/* Responsive */
@media (max-width: 980px){
  .kg-auth-shell{ grid-template-columns: 1fr; }
  .kg-auth-side{ padding: 22px; }
  .kg-auth-title{ font-size: 26px; }
}

/* ==========================================================================
   FIX: Direcciones (Woo floats vs nuestro layout)
   ========================================================================== */

/* Contenedor real en Woo suele ser .woocommerce-Addresses + .addresses + .u-columns */
.kg-ma2 .woocommerce-Addresses,
.kg-ma2 .woocommerce .woocommerce-Addresses,
.kg-ma2 .woocommerce .addresses,
.kg-ma2 .woocommerce .u-columns.woocommerce-Addresses{
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 12px !important;
  align-items: stretch !important;
  margin: 0 !important;
  width: 100% !important;
}

/* Hijos: Woo usa u-column1/u-column2 y/o col-1/col-2 con float/width */
.kg-ma2 .woocommerce-Addresses .u-column1,
.kg-ma2 .woocommerce-Addresses .u-column2,
.kg-ma2 .addresses .u-column1,
.kg-ma2 .addresses .u-column2,
.kg-ma2 .woocommerce-Addresses .col-1,
.kg-ma2 .woocommerce-Addresses .col-2,
.kg-ma2 .addresses .col-1,
.kg-ma2 .addresses .col-2,
.kg-ma2 .woocommerce-Address{
  float: none !important;
  width: auto !important;
  margin: 0 !important;
  min-width: 0 !important;
  box-sizing: border-box !important;
}

/* Card de dirección: asegura encuadre perfecto */
.kg-ma2 .woocommerce-Address{
  border: 1px solid rgba(11,42,106,.12);
  border-radius: 18px;
  padding: 14px;
  background: #fff;
  box-shadow: 0 10px 28px rgba(0,0,0,.05);
  overflow: hidden;
}

/* Título + botón editar alineados */
.kg-ma2 .woocommerce-Address-title{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 10px;
  margin-bottom: 10px;
}
.kg-ma2 .woocommerce-Address-title h3{
  margin:0 !important;
  font-weight: 1100;
  color: var(--kg-blue);
}

/* Dirección con buena tipografía */
.kg-ma2 .woocommerce-Address address{
  margin: 0 !important;
  line-height: 1.25;
  font-weight: 900;
  color: var(--kg-muted);
}

/* Mobile: una sola columna */
@media (max-width: 760px){
  .kg-ma2 .woocommerce-Addresses,
  .kg-ma2 .woocommerce .addresses,
  .kg-ma2 .woocommerce .u-columns.woocommerce-Addresses{
    grid-template-columns: 1fr !important;
  }
}

.kg-ma2 .woocommerce-Address-title a{
  border-radius: 999px !important;
  padding: 10px 12px !important;
  font-weight: 1100 !important;
  background: var(--kg-soft) !important;
  border: 1px solid rgba(11,42,106,.16) !important;
  color: var(--kg-blue) !important;
  text-decoration: none !important;
}
.kg-ma2 .woocommerce-Address-title a:hover{
  background: var(--kg-blue) !important;
  color: #fff !important;
}

/* ==========================================================================
   KESAGOX - LOGIN BUTTONS (Más visibles, modernos, legibles)
   ========================================================================== */

/* Botón principal "Acceder" (alta prioridad visual) */
.kg-auth .kg-auth-submit,
.kg-auth .woocommerce-form-login__submit{
  width: 100% !important;
  min-height: 48px !important;
  border-radius: 16px !important; /* más moderno que 999px */
  padding: 14px 16px !important;
  font-weight: 1200 !important;
  font-size: 15px !important;
  letter-spacing: .01em !important;

  background: linear-gradient(180deg, #0b2a6a 0%, #0a255c 100%) !important;
  color: #ffffff !important;
  border: 1px solid rgba(11,42,106,.28) !important;
  box-shadow: 0 18px 46px rgba(11,42,106,.22) !important;

  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 10px !important;
}

.kg-auth .kg-auth-submit:hover,
.kg-auth .woocommerce-form-login__submit:hover{
  filter: brightness(1.07);
  transform: translateY(1px);
}

/* Añade un "icono" visual al botón sin tocar el HTML */
.kg-auth .kg-auth-submit::before,
.kg-auth .woocommerce-form-login__submit::before{
  content: "🔐";
  font-size: 16px;
  line-height: 1;
}

/* Botón de Google / Social login: que se vea como CTA secundario potente */
.kg-auth .nsl-container a,
.kg-auth .nsl-button,
.kg-auth .wp-social-login-provider,
.kg-auth .login-with-google-btn{
  width: 100% !important;
  min-height: 48px !important;
  border-radius: 16px !important;
  padding: 14px 16px !important;
  font-weight: 1100 !important;
  font-size: 14px !important;

  background: #ffffff !important;
  color: #0b2a6a !important;
  border: 1px solid rgba(11,42,106,.18) !important;
  box-shadow: 0 14px 40px rgba(0,0,0,.06) !important;

  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  gap: 10px !important;
}

.kg-auth .nsl-container a:hover,
.kg-auth .nsl-button:hover{
  background: #f3f7ff !important;
  transform: translateY(1px);
}

/* “Recuérdame” + link de contraseña: más legible */
.kg-auth .woocommerce-form-login__rememberme{
  font-weight: 1000;
  color: #0b2a6a;
}
.kg-auth .kg-auth-lost{
  font-weight: 1100;
  color: #0b2a6a;
  text-decoration: none !important;
}
.kg-auth .kg-auth-lost:hover{
  text-decoration: underline !important;
}

/* Botón ojo (mostrar contraseña): más “premium” y legible */
.kg-auth .kg-auth-passbtn{
  min-height: 48px;
  border-radius: 16px;
  border: 1px solid rgba(11,42,106,.16);
  background: #f3f7ff;
  font-weight: 1100;
  padding: 12px 14px;
}
.kg-auth .kg-auth-passbtn:hover{
  background: #0b2a6a;
  color:#fff;
}

/* Ajuste: al quitar el logo, compactamos un poco el panel izquierdo */
.kg-auth-side{
  padding-top: 24px;
}
.kg-auth-title{
  margin-top: 0;
}

/* Login: título principal del panel izquierdo */
.kg-auth .kg-auth-title{
  color: #fff !important;
  font-weight: 1200 !important; /* súper negrita */
}

/* ==========================================================================
   KESAGOX FIX - MY ACCOUNT > DIRECCIONES (hard reset)
   Corrige:
   - Columnas con float que rompen el grid
   - Títulos enormes (h3) heredados del theme
   - Botón "Editar" circular/posicionado raro
   - Bordes/paddings internos que desencuadran
   ========================================================================== */

/* 1) Reset del contenedor de direcciones (Woo usa floats) */
.kg-ma2 .woocommerce-MyAccount-content .woocommerce-Addresses,
.kg-ma2 .woocommerce-MyAccount-content .u-columns.woocommerce-Addresses,
.kg-ma2 .woocommerce-MyAccount-content .addresses.u-columns,
.kg-ma2 .woocommerce-MyAccount-content .woocommerce-addresses{
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 14px !important;
  align-items: flex-start !important;
  width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  clear: both !important;
}

/* 2) Reset de columnas/hijos (evita que float mande) */
.kg-ma2 .woocommerce-MyAccount-content .woocommerce-Addresses > *,
.kg-ma2 .woocommerce-MyAccount-content .woocommerce-Addresses .u-column1,
.kg-ma2 .woocommerce-MyAccount-content .woocommerce-Addresses .u-column2,
.kg-ma2 .woocommerce-MyAccount-content .woocommerce-Addresses .col-1,
.kg-ma2 .woocommerce-MyAccount-content .woocommerce-Addresses .col-2,
.kg-ma2 .woocommerce-MyAccount-content .woocommerce-Address{
  float: none !important;
  clear: none !important;
  width: auto !important;
  margin: 0 !important;
  min-width: 0 !important;
  box-sizing: border-box !important;
  flex: 1 1 360px !important; /* 2 columnas “app-like”, baja a 1 si no cabe */
  align-self: flex-start !important;
}

/* 3) Tarjeta (encuadre limpio) */
.kg-ma2 .woocommerce-MyAccount-content .woocommerce-Address{
  border: 1px solid rgba(11,42,106,.12) !important;
  border-radius: 18px !important;
  padding: 14px !important;
  background: #fff !important;
  box-shadow: 0 10px 28px rgba(0,0,0,.05) !important;
  overflow: hidden !important;
}

/* 4) Header de la tarjeta: título + botón editar bien alineados */
.kg-ma2 .woocommerce-MyAccount-content .woocommerce-Address-title{
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 12px !important;
  margin: 0 0 10px 0 !important;
  padding: 0 0 10px 0 !important;
  border-bottom: 1px solid rgba(11,42,106,.08) !important;
}

/* 5) Título: evita el tamaño gigante heredado */
.kg-ma2 .woocommerce-MyAccount-content .woocommerce-Address-title h3{
  margin: 0 !important;
  font-size: 18px !important;
  line-height: 1.1 !important;
  font-weight: 1100 !important;
  color: var(--kg-blue) !important;
  letter-spacing: -0.01em !important;
}

/* 6) Botón "Editar": quita círculo/posición rara y lo deja moderno */
.kg-ma2 .woocommerce-MyAccount-content .woocommerce-Address-title a{
  position: static !important;
  width: auto !important;
  height: auto !important;
  border-radius: 999px !important;
  padding: 10px 12px !important;
  font-weight: 1100 !important;
  font-size: 13px !important;
  line-height: 1 !important;
  white-space: nowrap !important;

  background: var(--kg-soft) !important;
  border: 1px solid rgba(11,42,106,.16) !important;
  color: var(--kg-blue) !important;
  text-decoration: none !important;

  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  box-shadow: 0 10px 22px rgba(0,0,0,.05) !important;
}
.kg-ma2 .woocommerce-MyAccount-content .woocommerce-Address-title a:hover{
  background: var(--kg-blue) !important;
  color: #fff !important;
  transform: translateY(1px);
}

/* 7) Dirección (texto) sin “cajas” internas raras */
.kg-ma2 .woocommerce-MyAccount-content .woocommerce-Address address{
  margin: 0 !important;
  padding: 10px 12px !important;
  border: 1px solid rgba(11,42,106,.08) !important;
  border-radius: 16px !important;
  background: #fbfdff !important;
  color: var(--kg-muted) !important;
  font-weight: 900 !important;
  font-size: 13px !important;
  line-height: 1.25 !important;
}

/* 8) Responsive: una columna */
@media (max-width: 760px){
  .kg-ma2 .woocommerce-MyAccount-content .woocommerce-Addresses,
  .kg-ma2 .woocommerce-MyAccount-content .u-columns.woocommerce-Addresses{
    gap: 12px !important;
  }
  .kg-ma2 .woocommerce-MyAccount-content .woocommerce-Addresses > *,
  .kg-ma2 .woocommerce-MyAccount-content .woocommerce-Address{
    flex: 1 1 100% !important;
  }
}
