/* ═══════════════════════════════════════════════════════════════
   Avori E-Commerce — Customer Auth & Profile Stylesheet
   Developer: Nathstack Technologies | nathstack.online
═══════════════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:wght@500;700&family=DM+Sans:wght@300;400;500;600&display=swap');

:root {
  --red:        #C0392B;
  --red-dark:   #96281B;
  --red-light:  #E74C3C;
  --red-glow:   rgba(192,57,43,0.16);
  --copper:     #B87333;
  --terracotta: #C4622D;
  --cream:      #FDF6EC;
  --spice:      #8B4513;

  --bg:         #FDF6EC;
  --surface:    #FFFFFF;
  --surface2:   #FFF8F0;
  --border:     #E8D5B7;
  --text:       #2C1810;
  --text-muted: #7A5C4A;
  --text-light: #A8887A;
  --input-bg:   #FFFAF5;
  --shadow:     rgba(139,69,19,0.11);
  --shadow-lg:  rgba(139,69,19,0.20);
  --overlay:    rgba(44,24,16,0.45);
  --radius:     16px;
  --radius-sm:  9px;
  --tr:         0.24s cubic-bezier(.4,0,.2,1);
}

[data-theme="dark"] {
  --bg:         #1A0F0A;
  --surface:    #251810;
  --surface2:   #2E1E14;
  --border:     #3D2618;
  --text:       #F5EBE0;
  --text-muted: #C4A882;
  --text-light: #8A6A52;
  --input-bg:   #1E1208;
  --shadow:     rgba(0,0,0,0.40);
  --shadow-lg:  rgba(0,0,0,0.60);
  --overlay:    rgba(0,0,0,0.60);
}

/* ── Reset ───────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}

/* ── Auth body (center cards) ────────────────────────────────── */
body.auth-body {
  font-family:'DM Sans',sans-serif;
  background:var(--bg);
  color:var(--text);
  min-height:100vh;
  display:flex;
  align-items:center;
  justify-content:center;
  transition:background var(--tr),color var(--tr);
  position:relative;
  overflow-x:hidden;
}
body.auth-body::before{
  content:'';position:fixed;inset:0;
  background:
    radial-gradient(ellipse 60% 50% at 15% 20%,rgba(192,57,43,0.08) 0%,transparent 60%),
    radial-gradient(ellipse 50% 60% at 85% 80%,rgba(184,115,51,0.09) 0%,transparent 60%);
  pointer-events:none;z-index:0;
}
[data-theme="dark"] body.auth-body::before{
  background:
    radial-gradient(ellipse 60% 50% at 15% 20%,rgba(192,57,43,0.13) 0%,transparent 60%),
    radial-gradient(ellipse 50% 60% at 85% 80%,rgba(184,115,51,0.07) 0%,transparent 60%);
}

/* ── Profile/shop body ───────────────────────────────────────── */
body.shop-body {
  font-family:'DM Sans',sans-serif;
  background:var(--bg);
  color:var(--text);
  min-height:100vh;
  transition:background var(--tr),color var(--tr);
}

/* ── Auth wrapper ────────────────────────────────────────────── */
.auth-wrap{
  position:relative;z-index:1;width:100%;min-height:100vh;
  display:flex;align-items:center;justify-content:center;
  padding:2rem 1rem;
}

/* ── Card ────────────────────────────────────────────────────── */
.c-card{
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius);padding:2.6rem 2.4rem;
  width:100%;max-width:460px;
  box-shadow:0 6px 32px var(--shadow);
  animation:cardIn .5s cubic-bezier(.22,1,.36,1) both;
}
.c-card.wide{max-width:520px;}
@keyframes cardIn{from{opacity:0;transform:translateY(24px) scale(.97)}to{opacity:1;transform:none}}

/* ── Brand ───────────────────────────────────────────────────── */
.c-brand{text-align:center;margin-bottom:1.8rem;}
.c-brand-logo{
  width:62px;height:62px;
  background:linear-gradient(135deg,var(--red),var(--terracotta));
  border-radius:18px;
  display:inline-flex;align-items:center;justify-content:center;
  margin-bottom:.8rem;
  box-shadow:0 8px 22px var(--red-glow);
  animation:pop .55s .1s cubic-bezier(.34,1.56,.64,1) both;
}
@keyframes pop{from{opacity:0;transform:scale(.4) rotate(-12deg)}to{opacity:1;transform:none}}
.c-brand-logo svg{width:32px;height:32px;fill:white;}
.c-brand-name{font-family:'Playfair Display',serif;font-size:1.9rem;font-weight:700;color:var(--red);line-height:1;}
.c-brand-sub{font-size:.75rem;color:var(--text-muted);letter-spacing:.5px;text-transform:uppercase;margin-top:3px;}

.c-heading{font-family:'Playfair Display',serif;font-size:1.5rem;font-weight:700;color:var(--text);text-align:center;margin-bottom:.3rem;}
.c-sub{font-size:.87rem;color:var(--text-muted);text-align:center;margin-bottom:1.7rem;line-height:1.5;}

/* ── Step indicator ──────────────────────────────────────────── */
.c-steps{display:flex;align-items:center;justify-content:center;gap:.35rem;margin-bottom:1.6rem;}
.c-step-dot{width:28px;height:28px;border-radius:50%;border:2px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:.73rem;font-weight:700;color:var(--text-light);background:var(--surface2);transition:all var(--tr);}
.c-step-dot.active{border-color:var(--red);background:var(--red);color:white;}
.c-step-dot.done{border-color:#27ae60;background:#27ae60;color:white;}
.c-step-line{width:34px;height:2px;background:var(--border);border-radius:2px;}
.c-step-line.done{background:#27ae60;}

/* ── Form elements ───────────────────────────────────────────── */
.c-form-group{margin-bottom:1.1rem;animation:fadeUp .35s both;}
.c-form-group:nth-child(1){animation-delay:.04s;}
.c-form-group:nth-child(2){animation-delay:.08s;}
.c-form-group:nth-child(3){animation-delay:.12s;}
.c-form-group:nth-child(4){animation-delay:.16s;}
.c-form-group:nth-child(5){animation-delay:.20s;}
@keyframes fadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}

.c-label{display:block;font-size:.81rem;font-weight:600;color:var(--text-muted);margin-bottom:.4rem;letter-spacing:.3px;}
.c-hint{font-size:.74rem;color:var(--text-light);margin-top:.32rem;}

.c-input-wrap{position:relative;display:flex;align-items:center;}
.c-input-ico{position:absolute;left:13px;color:var(--text-light);width:17px;height:17px;pointer-events:none;transition:color var(--tr);}
.c-input-wrap:focus-within .c-input-ico{color:var(--red);}

.c-input{
  width:100%;background:var(--input-bg);border:1.5px solid var(--border);
  border-radius:var(--radius-sm);padding:.72rem .9rem .72rem 2.6rem;
  font-family:'DM Sans',sans-serif;font-size:.9rem;color:var(--text);
  outline:none;transition:border-color var(--tr),box-shadow var(--tr),background var(--tr);
}
.c-input:focus{border-color:var(--red);box-shadow:0 0 0 3px var(--red-glow);background:var(--surface);}
.c-input.error{border-color:#e74c3c;box-shadow:0 0 0 3px rgba(231,76,60,.15);}

.c-select-wrap{position:relative;}
.c-select{
  width:100%;background:var(--input-bg);border:1.5px solid var(--border);
  border-radius:var(--radius-sm);padding:.72rem 2.4rem .72rem .9rem;
  font-family:'DM Sans',sans-serif;font-size:.9rem;color:var(--text);
  outline:none;appearance:none;cursor:pointer;
  transition:border-color var(--tr),box-shadow var(--tr);
}
.c-select:focus{border-color:var(--red);box-shadow:0 0 0 3px var(--red-glow);}
.c-select-arrow{position:absolute;right:11px;top:50%;transform:translateY(-50%);width:15px;height:15px;color:var(--text-light);pointer-events:none;}

.toggle-pw{position:absolute;right:12px;background:none;border:none;cursor:pointer;color:var(--text-light);display:flex;align-items:center;padding:4px;border-radius:4px;transition:color var(--tr);}
.toggle-pw:hover{color:var(--red);}

/* ── Password strength ───────────────────────────────────────── */
.pw-strength{margin-top:.45rem;display:none;}
.pw-strength.visible{display:block;}
.pw-bars{display:flex;gap:4px;margin-bottom:.28rem;}
.pw-bar{flex:1;height:3px;border-radius:99px;background:var(--border);transition:background .3s;}
.pw-bar.weak{background:#e74c3c;}.pw-bar.fair{background:#f39c12;}.pw-bar.good{background:#27ae60;}.pw-bar.strong{background:#2ecc71;}
.pw-bar-label{font-size:.72rem;color:var(--text-light);}

/* ── OTP boxes ───────────────────────────────────────────────── */
.otp-row{display:flex;gap:.55rem;justify-content:center;margin:1.1rem 0;}
.otp-box{
  width:50px;height:56px;text-align:center;font-size:1.45rem;font-weight:700;
  font-family:'Playfair Display',serif;
  background:var(--input-bg);border:2px solid var(--border);
  border-radius:var(--radius-sm);color:var(--text);outline:none;
  transition:border-color var(--tr),box-shadow var(--tr);padding:0;
}
.otp-box:focus{border-color:var(--red);box-shadow:0 0 0 3px var(--red-glow);}
.otp-box.filled{border-color:var(--copper);}

/* ── Resend ──────────────────────────────────────────────────── */
.resend-row{text-align:center;font-size:.82rem;color:var(--text-muted);margin-bottom:.9rem;}
.resend-btn{background:none;border:none;color:var(--red);font-weight:600;cursor:pointer;font-size:.82rem;padding:0;text-decoration:underline;font-family:'DM Sans',sans-serif;}
.resend-btn:disabled{color:var(--text-light);cursor:default;text-decoration:none;}

/* ── Alerts ──────────────────────────────────────────────────── */
.c-alert{border-radius:var(--radius-sm);padding:.72rem .95rem;font-size:.84rem;margin-bottom:1.1rem;display:flex;align-items:flex-start;gap:.45rem;line-height:1.5;animation:fadeUp .28s both;}
.c-alert svg{flex-shrink:0;margin-top:1px;width:15px;height:15px;}
.c-alert.success{background:rgba(39,174,96,.1);color:#1a7a42;border:1px solid rgba(39,174,96,.25);}
.c-alert.error  {background:rgba(192,57,43,.09);color:var(--red-dark);border:1px solid rgba(192,57,43,.22);}
.c-alert.info   {background:rgba(184,115,51,.1);color:var(--copper);border:1px solid rgba(184,115,51,.24);}

/* ── Primary button ──────────────────────────────────────────── */
.c-btn{
  width:100%;background:linear-gradient(135deg,var(--red),var(--terracotta));
  color:white;border:none;border-radius:var(--radius-sm);
  padding:.84rem 1.4rem;font-family:'DM Sans',sans-serif;
  font-size:.93rem;font-weight:600;cursor:pointer;
  display:flex;align-items:center;justify-content:center;gap:.45rem;
  transition:transform .17s,box-shadow .17s,opacity .17s;
  box-shadow:0 4px 16px var(--red-glow);position:relative;overflow:hidden;
}
.c-btn::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.1),transparent);pointer-events:none;}
.c-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 26px rgba(192,57,43,.33);}
.c-btn:active:not(:disabled){transform:none;}
.c-btn:disabled{opacity:.6;cursor:not-allowed;}
.c-btn .spinner{display:none;width:17px;height:17px;border:2.5px solid rgba(255,255,255,.35);border-top-color:white;border-radius:50%;animation:spin .7s linear infinite;}
.c-btn.loading .btn-text{display:none;}
.c-btn.loading .spinner{display:block;}
@keyframes spin{to{transform:rotate(360deg)}}

/* ── Links ───────────────────────────────────────────────────── */
.c-links{text-align:center;margin-top:1.2rem;font-size:.84rem;color:var(--text-muted);}
.c-links a{color:var(--red);font-weight:600;text-decoration:none;transition:color var(--tr);}
.c-links a:hover{color:var(--red-dark);text-decoration:underline;}

/* ── Theme toggle ────────────────────────────────────────────── */
.c-theme-btn{
  position:fixed;top:1.1rem;right:1.1rem;z-index:100;
  background:var(--surface);border:1.5px solid var(--border);
  border-radius:99px;padding:.4rem .85rem;
  display:flex;align-items:center;gap:.45rem;cursor:pointer;
  box-shadow:0 2px 10px var(--shadow);color:var(--text);
  font-family:'DM Sans',sans-serif;font-size:.78rem;font-weight:500;
  transition:all var(--tr);
}
.c-theme-btn:hover{border-color:var(--red);color:var(--red);}
.c-theme-btn svg{width:15px;height:15px;}

/* ── Dev credit ──────────────────────────────────────────────── */
.c-credit{position:fixed;bottom:.9rem;left:50%;transform:translateX(-50%);font-size:.7rem;color:var(--text-light);white-space:nowrap;z-index:1;}
.c-credit a{color:var(--copper);text-decoration:none;font-weight:500;}
.c-credit a:hover{color:var(--red);}

/* ═══════════════════════════════════════════════════════════════
   PROFILE / ACCOUNT PAGE STYLES
═══════════════════════════════════════════════════════════════ */

/* ── Customer top nav ────────────────────────────────────────── */
.cust-nav{
  background:var(--surface);border-bottom:1px solid var(--border);
  padding:.75rem 2rem;
  display:flex;align-items:center;justify-content:space-between;
  position:sticky;top:0;z-index:100;
  box-shadow:0 1px 8px var(--shadow);
}
.cust-nav-brand{font-family:'Playfair Display',serif;font-size:1.45rem;font-weight:700;color:var(--red);text-decoration:none;}
.cust-nav-right{display:flex;align-items:center;gap:.9rem;}
.cust-nav-link{font-size:.84rem;font-weight:500;color:var(--text-muted);text-decoration:none;transition:color var(--tr);}
.cust-nav-link:hover{color:var(--red);}
.cust-nav-theme{background:none;border:1.5px solid var(--border);border-radius:8px;width:34px;height:34px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-muted);transition:all var(--tr);}
.cust-nav-theme:hover{border-color:var(--red);color:var(--red);}
.cust-nav-theme svg{width:15px;height:15px;}

/* ── Profile layout ──────────────────────────────────────────── */
.profile-wrap{max-width:1100px;margin:0 auto;padding:2rem 1.5rem;}

.profile-grid{
  display:grid;
  grid-template-columns:260px 1fr;
  gap:1.5rem;
  align-items:start;
}
@media(max-width:860px){.profile-grid{grid-template-columns:1fr;}}

/* ── Sidebar card ────────────────────────────────────────────── */
.p-sidebar{
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius);overflow:hidden;
  box-shadow:0 2px 12px var(--shadow);
  animation:fadeUp .38s both;
}
.p-avatar-section{
  background:linear-gradient(135deg,var(--red),var(--terracotta));
  padding:1.8rem 1.4rem 1.4rem;
  text-align:center;
}
.p-avatar-wrap{position:relative;display:inline-block;margin-bottom:.9rem;}
.p-avatar{
  width:90px;height:90px;border-radius:50%;
  border:3px solid rgba(255,255,255,.35);
  object-fit:cover;display:block;background:rgba(255,255,255,.15);
}
.p-avatar-initial{
  width:90px;height:90px;border-radius:50%;
  border:3px solid rgba(255,255,255,.35);
  background:rgba(255,255,255,.2);
  display:flex;align-items:center;justify-content:center;
  font-family:'Playfair Display',serif;font-size:2.2rem;font-weight:700;color:white;
}
.p-avatar-edit{
  position:absolute;bottom:2px;right:2px;
  width:26px;height:26px;background:white;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;box-shadow:0 2px 8px rgba(0,0,0,.25);
  transition:transform .17s;
}
.p-avatar-edit:hover{transform:scale(1.12);}
.p-avatar-edit svg{width:13px;height:13px;color:var(--red);}
.p-name{font-family:'Playfair Display',serif;font-size:1.1rem;font-weight:700;color:white;margin-bottom:.2rem;}
.p-phone{font-size:.79rem;color:rgba(255,255,255,.75);}

/* Sidebar nav */
.p-nav{padding:.6rem 0;}
.p-nav-item{
  display:flex;align-items:center;gap:.65rem;
  padding:.65rem 1.3rem;font-size:.87rem;font-weight:500;
  color:var(--text-muted);text-decoration:none;cursor:pointer;
  transition:background var(--tr),color var(--tr);border:none;background:none;width:100%;text-align:left;
}
.p-nav-item:hover{background:var(--surface2);color:var(--text);}
.p-nav-item.active{background:var(--red-glow);color:var(--red);font-weight:600;border-left:3px solid var(--red);}
.p-nav-item svg{width:17px;height:17px;flex-shrink:0;}
.p-nav-divider{height:1px;background:var(--border);margin:.4rem 0;}

/* ── Main content cards ──────────────────────────────────────── */
.p-main{display:flex;flex-direction:column;gap:1.4rem;}

.p-card{
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius);padding:1.7rem;
  box-shadow:0 2px 12px var(--shadow);
  animation:fadeUp .38s both;
}
.p-card-head{
  display:flex;align-items:center;gap:.55rem;
  margin-bottom:1.4rem;padding-bottom:1rem;border-bottom:1px solid var(--border);
}
.p-card-head svg{width:17px;height:17px;color:var(--red);flex-shrink:0;}
.p-card-title{font-family:'Playfair Display',serif;font-size:1.05rem;font-weight:700;color:var(--text);}

/* ── Two column form grid ────────────────────────────────────── */
.p-two-col{display:grid;grid-template-columns:1fr 1fr;gap:1rem;}
@media(max-width:560px){.p-two-col{grid-template-columns:1fr;}}

/* ── Address card ────────────────────────────────────────────── */
.addr-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1rem;}
.addr-item{
  background:var(--surface2);border:1.5px solid var(--border);
  border-radius:var(--radius-sm);padding:1.1rem;
  position:relative;transition:border-color var(--tr);
}
.addr-item.default{border-color:var(--red);background:var(--red-glow);}
.addr-label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-light);margin-bottom:.4rem;}
.addr-name{font-size:.9rem;font-weight:600;color:var(--text);margin-bottom:.2rem;}
.addr-detail{font-size:.82rem;color:var(--text-muted);line-height:1.5;}
.addr-default-badge{display:inline-block;font-size:.67rem;font-weight:700;background:var(--red);color:white;padding:2px 7px;border-radius:4px;margin-top:.4rem;}
.addr-actions{display:flex;gap:.4rem;margin-top:.7rem;}
.addr-btn{display:inline-flex;align-items:center;gap:.28rem;padding:.3rem .7rem;border-radius:6px;font-family:'DM Sans',sans-serif;font-size:.74rem;font-weight:600;cursor:pointer;border:none;transition:all var(--tr);}
.addr-btn.edit{background:var(--surface);border:1.5px solid var(--border);color:var(--text-muted);}
.addr-btn.edit:hover{border-color:var(--red);color:var(--red);}
.addr-btn.del{background:rgba(192,57,43,.08);color:var(--red);border:1.5px solid rgba(192,57,43,.2);}
.addr-btn.del:hover{background:rgba(192,57,43,.15);}
.addr-btn svg{width:12px;height:12px;}

.btn-add-addr{
  display:inline-flex;align-items:center;gap:.4rem;
  background:var(--surface2);border:1.5px dashed var(--border);
  border-radius:var(--radius-sm);padding:.6rem 1rem;
  font-family:'DM Sans',sans-serif;font-size:.84rem;font-weight:600;
  color:var(--text-muted);cursor:pointer;transition:all var(--tr);
  text-decoration:none;
}
.btn-add-addr:hover{border-color:var(--red);color:var(--red);}

/* ── Order history table ─────────────────────────────────────── */
.order-tbl{width:100%;border-collapse:collapse;font-size:.875rem;}
.order-tbl thead th{padding:.75rem 1rem;text-align:left;font-size:.71rem;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--text-muted);border-bottom:1px solid var(--border);background:var(--surface2);}
.order-tbl tbody tr{border-bottom:1px solid var(--border);transition:background var(--tr);}
.order-tbl tbody tr:last-child{border-bottom:none;}
.order-tbl tbody tr:hover{background:var(--surface2);}
.order-tbl tbody td{padding:.9rem 1rem;color:var(--text);vertical-align:middle;}
.order-status{display:inline-block;font-size:.72rem;font-weight:700;border-radius:6px;padding:2px 9px;}
.order-status.pending  {background:rgba(243,156,18,.1);color:#b7770d;}
.order-status.delivered{background:rgba(39,174,96,.1); color:#1a7a42;}
.order-status.cancelled{background:rgba(192,57,43,.1); color:var(--red);}

/* ── Stats row ───────────────────────────────────────────────── */
.stats-row{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1.4rem;}
@media(max-width:500px){.stats-row{grid-template-columns:1fr;}}
.stat-box{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:1.1rem;text-align:center;}
.stat-val{font-family:'Playfair Display',serif;font-size:1.8rem;font-weight:700;color:var(--red);line-height:1;}
.stat-lbl{font-size:.75rem;color:var(--text-muted);margin-top:.3rem;font-weight:500;}

/* ── Save button ─────────────────────────────────────────────── */
.p-save-btn{
  display:inline-flex;align-items:center;gap:.45rem;
  background:linear-gradient(135deg,var(--red),var(--terracotta));
  color:white;border:none;border-radius:var(--radius-sm);
  padding:.78rem 1.6rem;font-family:'DM Sans',sans-serif;
  font-size:.9rem;font-weight:600;cursor:pointer;
  transition:transform .17s,box-shadow .17s;
  box-shadow:0 4px 14px var(--red-glow);
}
.p-save-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 22px rgba(192,57,43,.32);}
.p-save-btn .spinner{display:none;width:16px;height:16px;border:2.5px solid rgba(255,255,255,.35);border-top-color:white;border-radius:50%;animation:spin .7s linear infinite;}
.p-save-btn.loading .btn-text{display:none;}
.p-save-btn.loading .spinner{display:block;}

/* ── Modal ───────────────────────────────────────────────────── */
.c-modal-bg{display:none;position:fixed;inset:0;background:var(--overlay);backdrop-filter:blur(4px);z-index:600;align-items:center;justify-content:center;padding:1rem;}
.c-modal-bg.open{display:flex;}
.c-modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.9rem;width:100%;max-width:440px;box-shadow:0 20px 56px var(--shadow-lg);animation:cardIn .28s cubic-bezier(.22,1,.36,1) both;}
.c-modal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.3rem;}
.c-modal-title{font-family:'Playfair Display',serif;font-size:1.1rem;font-weight:700;color:var(--text);}
.c-modal-close{background:none;border:none;cursor:pointer;color:var(--text-muted);padding:4px;border-radius:6px;display:flex;transition:color var(--tr);}
.c-modal-close:hover{color:var(--red);}
.c-modal-close svg{width:19px;height:19px;}

/* ── Responsive ──────────────────────────────────────────────── */
@media(max-width:500px){
  .c-card{padding:1.9rem 1.3rem;border-radius:14px;}
  .otp-box{width:42px;height:50px;font-size:1.3rem;}
  .cust-nav{padding:.65rem 1rem;}
}
