/* ============================================================
   ELENA SUÁREZ & CO. — CSS del área de cuenta
   Archivo: mi-cuenta/assets/cuenta.css
   ============================================================
   Reutiliza exactamente las variables y clases del sitio principal
   (sidebar, topbar, footer, .btn, .announce) y añade los estilos
   específicos del área de cuenta.
   ============================================================ */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Jost',Helvetica,sans-serif;font-weight:400;font-size:15px;line-height:1.7;color:#1c1a18;background:#faf8f5;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{display:block;max-width:100%;object-fit:cover}
a{text-decoration:none;color:inherit}
button{font-family:'Jost',sans-serif;cursor:pointer;background:none;border:none}
input,select,textarea{font-family:'Jost',sans-serif;font-size:15px;color:#1c1a18}

:root{
  --bg:#faf8f5;--bg2:#f2ede6;--bg3:#e8e1d8;
  --line:#ddd8d0;--line2:#e8e3dc;
  --ink:#1c1a18;--ink2:#4a4642;--ink3:#8a8580;
  --gold:#8a6d4a;--gold2:#b8864e;--gold3:#c4a47a;
  --ok:#2a7a4b;--err:#c0392b;--warn:#d4a030;
  --serif:'Cormorant Garamond',Georgia,serif;
  --nav:272px;
  --ease:.3s cubic-bezier(.4,0,.2,1);
}

/* ═══════════════════════════════════════════════════════════
   LAYOUT BASE (copiado exactamente del sitio)
   ═══════════════════════════════════════════════════════════ */
.site{display:flex;min-height:100vh}

/* SIDEBAR */
.sidebar{width:var(--nav);position:fixed;top:0;left:0;bottom:0;background:var(--bg);border-right:1px solid var(--line);z-index:200;overflow-y:auto;scrollbar-width:none;transition:transform var(--ease)}
.sidebar::-webkit-scrollbar{display:none}
.sidebar-inner{display:flex;flex-direction:column;min-height:100%;padding:48px 32px 36px}
.logo-wrap{margin-bottom:44px;display:block}
.logo-img{width:160px;height:auto;display:block}
.logo-tag{display:block;margin-top:8px;font-size:9px;letter-spacing:.26em;text-transform:uppercase;color:var(--ink3)}
.nav-label{font-size:9px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink3);display:block;margin:26px 0 10px}
.nav-link{display:block;font-size:13.5px;color:var(--ink2);padding:5.5px 0;position:relative;transition:color var(--ease)}
.nav-link::after{content:'';position:absolute;bottom:0;left:0;width:0;height:.5px;background:var(--gold);transition:width var(--ease)}
.nav-link:hover{color:var(--ink)}.nav-link:hover::after{width:16px}
.nav-link.on{color:var(--ink);font-weight:500}.nav-link.on::after{width:16px}
.sidebar-foot{margin-top:auto;padding-top:26px;border-top:1px solid var(--line)}
.sidebar-foot a{display:block;font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink3);padding:4px 0;transition:color var(--ease)}
.sidebar-foot a:hover{color:var(--ink)}
.sidebar-foot a.on{color:var(--gold);font-weight:500}
.sidebar-social{display:flex;gap:16px;margin-top:12px}
.sidebar-social a{font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink3);transition:color var(--ease)}
.sidebar-social a:hover{color:var(--ink)}

/* MOBILE BAR */
.mbar{display:none;position:fixed;top:0;left:0;right:0;z-index:300;height:56px;background:var(--bg);border-bottom:1px solid var(--line);align-items:center;justify-content:space-between;padding:0 20px}
.mbar-logo{height:28px;width:auto;display:block}
.burger{display:flex;flex-direction:column;gap:5px;padding:6px}
.burger span{display:block;width:22px;height:1px;background:var(--ink);transition:all .28s ease;transform-origin:center}
.scrim{display:none;position:fixed;inset:0;background:rgba(28,26,24,.5);z-index:199}
.scrim.on{display:block}

/* MAIN */
.main{margin-left:var(--nav);flex:1;min-width:0}
.announce{background:var(--ink);padding:10px 52px;text-align:center;font-size:11.5px;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.72)}
.announce a{color:#c4a47a}
.topbar{display:flex;align-items:center;justify-content:flex-end;gap:24px;padding:13px 52px;border-bottom:1px solid var(--line);background:var(--bg)}
.topbar a{font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink2);transition:color var(--ease)}
.topbar a:hover{color:var(--ink)}
.topbar .tsub{color:var(--gold)!important}
.topbar .tcuenta.on{color:var(--gold)!important}
.topbar .tcart{background:transparent;color:var(--ink)!important;padding:7px 0;border-bottom:1.5px solid var(--ink);font-weight:500;letter-spacing:.14em}
.topbar .tcart:hover{background:var(--gold)!important;color:#fff!important}

/* BOTONES (idénticos al sitio) */
.btn{display:inline-block;font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;font-weight:400;padding:13px 32px;border:1px solid transparent;transition:all var(--ease);border-radius:100px;cursor:pointer;text-align:center}
.btn-d{background:var(--ink);color:var(--bg);border-color:var(--ink)}.btn-d:hover{background:var(--gold);border-color:var(--gold)}
.btn-o{background:transparent;color:var(--ink);border-color:var(--line)}.btn-o:hover{border-color:var(--ink)}
.btn-gold{background:var(--gold);color:white;border-color:var(--gold)}.btn-gold:hover{background:#7a5e3a;border-color:#7a5e3a}
.btn-danger{background:transparent;color:var(--err);border-color:#e8c8c0}.btn-danger:hover{background:var(--err);color:#fff;border-color:var(--err)}
.btn-sm{padding:9px 22px;font-size:9.5px;letter-spacing:.14em}
.btn-full{width:100%}
.btn[disabled]{opacity:.55;cursor:not-allowed}

/* FOOTER (idéntico al sitio) */
footer{background:var(--bg);border-top:1px solid var(--line);padding:60px 52px 32px}
.foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;margin-bottom:48px}
.foot-brand{font-family:var(--serif);font-size:20px;font-weight:400;color:var(--ink);margin-bottom:12px}
.foot-brand em{font-style:italic}
.foot-about{font-size:12.5px;color:var(--ink3);line-height:1.85;max-width:230px;margin-bottom:14px}
.foot-ci{font-size:12.5px;color:var(--ink2);margin-bottom:5px}
.foot-ci a{color:var(--ink2);transition:color var(--ease)}.foot-ci a:hover{color:var(--ink)}
.foot-col-title{font-size:9px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink3);margin-bottom:15px}
.foot-col a{display:block;font-size:12.5px;color:var(--ink2);padding:3.5px 0;transition:color var(--ease)}.foot-col a:hover{color:var(--ink)}
.foot-bot{display:flex;align-items:center;justify-content:space-between;border-top:1px solid var(--line);padding-top:20px;flex-wrap:wrap;gap:10px}
.foot-copy{font-size:11px;color:var(--ink3)}
.foot-links{display:flex;gap:18px}
.foot-links a{font-size:11px;color:var(--ink3);transition:color var(--ease)}.foot-links a:hover{color:var(--ink)}


/* ═══════════════════════════════════════════════════════════
   ESPECÍFICO DE /mi-cuenta/
   ═══════════════════════════════════════════════════════════ */

/* CONTENEDOR PRINCIPAL */
.cuenta-page{padding:52px 52px 80px;max-width:1100px;margin:0 auto}
.cuenta-hero{margin-bottom:36px;padding-bottom:26px;border-bottom:1px solid var(--line)}
.cuenta-kicker{font-size:10px;letter-spacing:.26em;text-transform:uppercase;color:var(--ink3);margin-bottom:14px}
.cuenta-h1{font-family:var(--serif);font-size:44px;font-weight:400;line-height:1.1;color:var(--ink);margin-bottom:10px}
.cuenta-h1 em{font-style:italic;color:var(--gold)}
.cuenta-sub{font-size:14px;color:var(--ink2);line-height:1.85;max-width:600px}

/* NAV DE PESTAÑAS DENTRO DE LA CUENTA */
.cuenta-nav{border-bottom:1px solid var(--line);background:var(--bg);margin-bottom:40px;overflow-x:auto;scrollbar-width:none}
.cuenta-nav::-webkit-scrollbar{display:none}
.cuenta-nav-inner{display:flex;align-items:center;gap:8px;padding:0 52px;max-width:1200px;margin:0 auto;min-width:max-content}
.cn-link{font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink3);padding:18px 18px;border-bottom:2px solid transparent;transition:all var(--ease);white-space:nowrap}
.cn-link:hover{color:var(--ink)}
.cn-link.on{color:var(--ink);border-bottom-color:var(--gold);font-weight:500}
.cn-logout-form{margin-left:auto}
.cn-logout{font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink3);padding:8px 16px;border:1px solid var(--line);border-radius:100px;background:transparent;transition:all var(--ease)}
.cn-logout:hover{color:var(--err);border-color:#e8c8c0}

/* TARJETAS */
.card{background:#fff;border:1px solid var(--line);border-radius:4px;padding:28px;margin-bottom:18px;transition:border-color var(--ease)}
.card:hover{border-color:#c8c2b8}
.card-title{font-family:var(--serif);font-size:22px;font-weight:400;color:var(--ink);margin-bottom:6px}
.card-title em{font-style:italic;color:var(--gold)}
.card-sub{font-size:12.5px;color:var(--ink3);margin-bottom:18px}
.card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:20px;margin-bottom:16px;flex-wrap:wrap}
.card-head-t{flex:1;min-width:0}

/* GRID DE TARJETAS */
.cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:18px}

/* CHIPS / BADGES */
.chip{display:inline-flex;align-items:center;gap:6px;font-size:9.5px;letter-spacing:.18em;text-transform:uppercase;padding:5px 11px;border-radius:100px;background:var(--bg2);color:var(--ink2);font-weight:500}
.chip-gold{background:rgba(138,109,74,.12);color:var(--gold)}
.chip-ok{background:rgba(42,122,75,.12);color:var(--ok)}
.chip-warn{background:rgba(212,160,48,.14);color:var(--warn)}
.chip-err{background:rgba(192,57,43,.12);color:var(--err)}
.chip-ink{background:var(--ink);color:#fff}
.chip-outline{background:transparent;border:1px solid var(--line);color:var(--ink3)}

/* LABEL + VALOR (tipo .fila del email) */
.kv{display:flex;padding:10px 0;border-bottom:1px solid var(--line2);gap:20px}
.kv:last-child{border-bottom:0}
.kv-k{font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink3);width:110px;flex-shrink:0;padding-top:3px}
.kv-v{font-size:14px;color:var(--ink);line-height:1.65;flex:1;word-break:break-word}
.kv-v strong{font-weight:500}
.kv-v a{color:var(--gold)}
.kv-v a:hover{text-decoration:underline}

/* FORMULARIOS */
.form-group{margin-bottom:18px}
.form-group label{display:block;font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink3);margin-bottom:8px;font-weight:500}
.form-group input[type=text],
.form-group input[type=email],
.form-group input[type=tel],
.form-group input[type=password],
.form-group input[type=date],
.form-group select,
.form-group textarea{
  display:block;width:100%;
  font-family:'Jost',sans-serif;font-size:15px;color:var(--ink);
  padding:13px 16px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:10px;
  transition:border-color var(--ease), box-shadow var(--ease);
}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus{outline:0;border-color:var(--gold);box-shadow:0 0 0 3px rgba(138,109,74,.1)}
.form-group textarea{resize:vertical;min-height:90px;line-height:1.6}
.form-group .hint{font-size:11.5px;color:var(--ink3);margin-top:6px;line-height:1.6}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-row-3{display:grid;grid-template-columns:2fr 1fr 1fr;gap:14px}
.form-actions{display:flex;gap:12px;justify-content:flex-end;align-items:center;margin-top:26px;flex-wrap:wrap}
.form-actions .left{margin-right:auto}
.form-group input[aria-invalid=true],
.form-group select[aria-invalid=true]{border-color:var(--err)}

/* CHECKBOX */
.form-check{display:flex;align-items:flex-start;gap:10px;padding:8px 0;cursor:pointer;user-select:none}
.form-check input[type=checkbox]{width:18px;height:18px;margin-top:1px;accent-color:var(--gold);cursor:pointer;flex-shrink:0}
.form-check span{font-size:14px;color:var(--ink);line-height:1.6}

/* AUTH: caja centrada (login, registro, reset) */
.auth-wrap{display:flex;align-items:center;justify-content:center;padding:60px 24px 100px;min-height:calc(100vh - 200px)}
.auth-card{background:#fff;border:1px solid var(--line);border-radius:4px;padding:44px 40px;width:100%;max-width:440px}
.auth-head{text-align:center;margin-bottom:30px}
.auth-eye{font-size:10px;letter-spacing:.26em;text-transform:uppercase;color:var(--gold);margin-bottom:14px}
.auth-h1{font-family:var(--serif);font-size:32px;font-weight:400;color:var(--ink);line-height:1.15;margin-bottom:10px}
.auth-h1 em{font-style:italic;color:var(--gold)}
.auth-sub{font-size:13.5px;color:var(--ink3);line-height:1.75}
.auth-foot{text-align:center;margin-top:22px;padding-top:22px;border-top:1px solid var(--line2);font-size:13px;color:var(--ink2)}
.auth-foot a{color:var(--gold);font-weight:500}
.auth-foot a:hover{text-decoration:underline}
.auth-link-small{display:block;text-align:right;font-size:11.5px;color:var(--ink3);margin-top:-6px;margin-bottom:18px}
.auth-link-small:hover{color:var(--gold)}

/* MENSAJES (alert banners) */
.msg{padding:14px 18px;border-radius:6px;font-size:13.5px;line-height:1.7;margin-bottom:18px;display:flex;align-items:flex-start;gap:10px}
.msg::before{content:'';width:18px;height:18px;border-radius:50%;flex-shrink:0;margin-top:2px}
.msg-ok{background:rgba(42,122,75,.08);color:var(--ok);border:1px solid rgba(42,122,75,.18)}
.msg-ok::before{background:var(--ok)}
.msg-err{background:rgba(192,57,43,.08);color:var(--err);border:1px solid rgba(192,57,43,.18)}
.msg-err::before{background:var(--err)}
.msg-info{background:rgba(138,109,74,.08);color:var(--gold);border:1px solid rgba(138,109,74,.18)}
.msg-info::before{background:var(--gold)}
.msg-warn{background:rgba(212,160,48,.10);color:var(--warn);border:1px solid rgba(212,160,48,.24)}
.msg-warn::before{background:var(--warn)}
.msg[hidden]{display:none}

/* ESTADO VACÍO */
.empty{text-align:center;padding:60px 20px;background:var(--bg);border:1px dashed var(--line);border-radius:4px}
.empty-icon{font-size:32px;margin-bottom:14px;opacity:.5}
.empty-title{font-family:var(--serif);font-size:22px;font-weight:400;color:var(--ink);margin-bottom:10px}
.empty-sub{font-size:13.5px;color:var(--ink3);max-width:400px;margin:0 auto 22px;line-height:1.8}

/* DASHBOARD HOME */
.stat-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;margin-bottom:30px}
.stat{background:#fff;border:1px solid var(--line);border-radius:4px;padding:22px 20px}
.stat-k{font-size:9px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink3);margin-bottom:10px}
.stat-v{font-family:var(--serif);font-size:32px;font-weight:400;color:var(--ink);line-height:1}
.stat-v em{font-style:italic;color:var(--gold)}
.stat-foot{font-size:12px;color:var(--ink3);margin-top:10px}

/* PEDIDOS / SUSCRIPCIONES listas */
.pedido-row{display:grid;grid-template-columns:auto 1fr auto auto;gap:20px;align-items:center;padding:18px 22px;background:#fff;border:1px solid var(--line);border-radius:4px;margin-bottom:10px;transition:all var(--ease)}
.pedido-row:hover{border-color:var(--gold3);transform:translateY(-1px)}
.pedido-ref{font-family:var(--serif);font-size:16px;font-weight:400;color:var(--ink);letter-spacing:.02em}
.pedido-ref em{font-style:italic;color:var(--gold)}
.pedido-info{min-width:0}
.pedido-prod{font-size:14px;color:var(--ink);font-weight:500;margin-bottom:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pedido-meta{font-size:12px;color:var(--ink3)}
.pedido-total{font-family:var(--serif);font-size:20px;font-weight:400;color:var(--ink)}
.pedido-arrow{font-size:20px;color:var(--ink3);transition:color var(--ease)}
.pedido-row:hover .pedido-arrow{color:var(--gold)}

/* DIRECCIONES */
.dir-card{position:relative;background:#fff;border:1px solid var(--line);border-radius:4px;padding:24px 24px 20px;transition:all var(--ease)}
.dir-card.favorita{border-color:var(--gold);box-shadow:0 0 0 1px var(--gold)}
.dir-etiqueta{display:inline-block;font-size:9.5px;letter-spacing:.2em;text-transform:uppercase;padding:5px 11px;border-radius:100px;background:var(--bg2);color:var(--ink2);font-weight:500;margin-bottom:14px}
.dir-card.favorita .dir-etiqueta{background:var(--gold);color:#fff}
.dir-nombre{font-family:var(--serif);font-size:19px;font-weight:400;color:var(--ink);margin-bottom:4px;line-height:1.3}
.dir-direccion{font-size:13.5px;color:var(--ink2);line-height:1.7;margin-bottom:14px}
.dir-direccion strong{font-weight:500}
.dir-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:14px;padding-top:14px;border-top:1px solid var(--line2)}
.dir-star{position:absolute;top:22px;right:22px;font-size:18px;color:var(--ink3);cursor:pointer;transition:color var(--ease);background:none;border:none;padding:4px}
.dir-star:hover{color:var(--gold)}
.dir-star.on{color:var(--gold)}

/* SPINNER / LOADING */
.spin{display:inline-block;width:16px;height:16px;border:2px solid rgba(138,109,74,.25);border-top-color:var(--gold);border-radius:50%;animation:spin .7s linear infinite;vertical-align:middle;margin-right:8px}
@keyframes spin{to{transform:rotate(360deg)}}
.loading-wrap{text-align:center;padding:48px 20px;color:var(--ink3);font-size:13px;letter-spacing:.1em;text-transform:uppercase}

/* MODAL (para pausar, cancelar, editar) */
.modal-back{display:none;position:fixed;inset:0;background:rgba(28,26,24,.55);z-index:500;align-items:center;justify-content:center;padding:20px;animation:fadein .2s ease}
.modal-back.on{display:flex}
@keyframes fadein{from{opacity:0}to{opacity:1}}
.modal{background:#fff;border-radius:4px;width:100%;max-width:480px;max-height:92vh;overflow-y:auto;animation:slideup .25s ease}
@keyframes slideup{from{transform:translateY(10px);opacity:0}to{transform:translateY(0);opacity:1}}
.modal-head{padding:26px 28px 14px;border-bottom:1px solid var(--line2)}
.modal-h{font-family:var(--serif);font-size:24px;font-weight:400;color:var(--ink);line-height:1.2;margin-bottom:6px}
.modal-h em{font-style:italic;color:var(--gold)}
.modal-sub{font-size:13px;color:var(--ink3);line-height:1.7}
.modal-body{padding:22px 28px}
.modal-foot{padding:16px 28px 24px;display:flex;gap:10px;justify-content:flex-end;flex-wrap:wrap;border-top:1px solid var(--line2);background:var(--bg)}

/* DETALLE DE PEDIDO: barra de estado */
.status-bar{display:flex;align-items:flex-start;justify-content:space-between;gap:4px;padding:24px 0;margin-bottom:30px;border-top:1px solid var(--line2);border-bottom:1px solid var(--line2)}
.status-step{flex:1;text-align:center;position:relative}
.status-step:not(:last-child)::after{content:'';position:absolute;top:6px;right:-50%;width:100%;height:1px;background:var(--line);z-index:0}
.status-step.done:not(:last-child)::after{background:var(--gold)}
.status-dot{width:13px;height:13px;border-radius:50%;background:var(--line);margin:0 auto 10px;position:relative;z-index:1;transition:all var(--ease)}
.status-step.done .status-dot{background:var(--gold)}
.status-step.now .status-dot{background:var(--ink);box-shadow:0 0 0 4px rgba(138,109,74,.25)}
.status-lbl{font-size:9.5px;letter-spacing:.15em;text-transform:uppercase;color:var(--ink3);font-weight:400}
.status-step.done .status-lbl{color:var(--gold);font-weight:500}
.status-step.now .status-lbl{color:var(--ink);font-weight:500}


/* ═══════════════════════════════════════════════════════════
   RESPONSIVE (idéntico al sitio)
   ═══════════════════════════════════════════════════════════ */
@media(max-width:1024px){
  .sidebar .logo-wrap{display:none}
  .mbar{display:flex}
  .sidebar{transform:translateX(-100%)}
  .sidebar.open{transform:translateX(0)}
  .main{margin-left:0;padding-top:52px}
  .topbar,.announce{display:none}
  .cuenta-page{padding:30px 16px 60px}
  .cuenta-nav-inner{padding:0 16px;gap:2px}
  .cn-link{padding:14px 14px;font-size:10px}
  .cn-logout{padding:7px 12px;font-size:9.5px}
  footer{padding:40px 16px 80px}
  .foot-grid{grid-template-columns:1fr 1fr;gap:32px}
}

@media(max-width:640px){
  .cuenta-h1{font-size:34px}
  .cuenta-hero{margin-bottom:26px;padding-bottom:20px}
  .card{padding:22px 20px}
  .form-row,.form-row-3{grid-template-columns:1fr}
  .auth-card{padding:34px 26px}
  .auth-h1{font-size:26px}
  .pedido-row{grid-template-columns:1fr auto;gap:10px;padding:16px}
  .pedido-ref{grid-column:1/3;font-size:14px}
  .pedido-arrow{display:none}
  .status-bar{padding:18px 0}
  .status-lbl{font-size:8.5px;letter-spacing:.1em}
  .modal-head,.modal-body,.modal-foot{padding-left:20px;padding-right:20px}
  .foot-grid{grid-template-columns:1fr;gap:24px}
  .cards-grid{grid-template-columns:1fr}
  .stat-row{grid-template-columns:1fr 1fr}
  .form-actions{flex-direction:column-reverse;align-items:stretch}
  .form-actions .btn{width:100%}
  .form-actions .left{margin-right:0}
  .cn-logout-form{display:none}
}
