/* ============================================================================
   VALYON — My Account (v2)  ·  scoped to .valyon-account
   Style-only over the native WooCommerce myaccount/ templates. Tokens are scoped
   here so the file is self-contained (exact handoff values), regardless of which
   other v2 stylesheet is loaded. Buttons reuse the global .btn-primary/.btn-ghost.
   ========================================================================== */
.valyon-account {
  --cream: #F7EFE3;
  --cream-soft: #FBF7F0;
  --dark: #1C1A16;
  --gold: #B8923E;
  --muted: #6E665B;
  --line: #E7DDCC;
  --gold-soft: rgba(184,146,62,.28);
  --success: #2F7350;
  --success-soft: rgba(47,115,80,.12);
  --shadow-sm: 0 2px 10px rgba(28,26,22,.05);
  --shadow-md: 0 14px 34px -12px rgba(28,26,22,.18);
  --shadow-lg: 0 30px 64px -20px rgba(28,26,22,.32);
  font-variant-numeric: lining-nums tabular-nums; /* lining + tabular figures (sums/dates) */
}

.valyon-account .acc-wrap { max-width: 1316px; margin: 0 auto; padding: 0 24px; }

/* account head */
.valyon-account .acc-head { padding: 40px 0 26px; }
.valyon-account .acc-head .eyebrow { color: var(--gold); font-weight: 700; font-size: 13px; letter-spacing: .16em; text-transform: uppercase; margin-bottom: 12px; }
.valyon-account .acc-head h1 { font-family: 'Playfair Display', serif; font-weight: 700; font-size: 40px; letter-spacing: -.015em; color: var(--dark); }
.valyon-account .acc-head p { color: var(--muted); font-size: 16px; margin-top: 10px; max-width: 560px; line-height: 1.55; }

/* layout: nav + content */
.valyon-account .acc-layout { display: grid; grid-template-columns: 268px 1fr; gap: 34px; padding-bottom: 80px; align-items: start; }

/* ---- NAV (desktop aside) ---- */
.valyon-account .acc-nav { position: sticky; top: 104px; background: var(--cream-soft); border: 1px solid var(--gold-soft); border-radius: 16px; box-shadow: var(--shadow-sm); overflow: hidden; }
.valyon-account .acc-nav .me { display: flex; align-items: center; gap: 13px; padding: 22px; border-bottom: 1px solid var(--line); }
.valyon-account .acc-nav .me .av { flex: 0 0 auto; width: 46px; height: 46px; border-radius: 50%; background: linear-gradient(160deg,#FBEFDC,#F3E2C4); border: 1px solid var(--gold-soft); display: flex; align-items: center; justify-content: center; font-family: 'Playfair Display', serif; font-weight: 700; font-size: 19px; color: var(--gold); }
.valyon-account .acc-nav .me .who .n { font-weight: 700; font-size: 15px; line-height: 1.2; color: var(--dark); }
.valyon-account .acc-nav .me .who .e { font-size: 12.5px; color: var(--muted); margin-top: 2px; }
.valyon-account .acc-nav ul { list-style: none; padding: 10px; margin: 0; display: flex; flex-direction: column; gap: 2px; }
.valyon-account .acc-nav li a { display: flex; align-items: center; gap: 12px; padding: 13px 14px; border-radius: 10px; font-weight: 600; font-size: 15px; color: var(--dark); transition: background .18s, color .18s; position: relative; }
.valyon-account .acc-nav li a svg { flex: 0 0 auto; color: var(--muted); transition: color .18s; }
.valyon-account .acc-nav li a:hover { background: rgba(184,146,62,.08); }
.valyon-account .acc-nav li.is-active a { background: var(--dark); color: #fff; }
.valyon-account .acc-nav li.is-active a svg { color: var(--gold); }
.valyon-account .acc-nav li.logout a { color: #9a3b3b; }
.valyon-account .acc-nav li.logout a svg { color: #b35; }

/* ---- mobile pill tabs (hidden on desktop) ---- */
.valyon-account .acc-tabs { display: none; }

/* ---- CONTENT ---- */
.valyon-account .acc-content { min-width: 0; }
.valyon-account .card { background: var(--cream-soft); border: 1px solid var(--line); border-radius: 16px; box-shadow: var(--shadow-sm); }
.valyon-account .card-pad { padding: 26px 28px; }
.valyon-account .panel-title { font-family: 'Playfair Display', serif; font-weight: 700; font-size: 24px; margin-bottom: 6px; color: var(--dark); }
.valyon-account .panel-sub { color: var(--muted); font-size: 15px; margin-bottom: 22px; line-height: 1.5; }

/* dashboard tiles */
.valyon-account .dash-tiles { display: grid; grid-template-columns: repeat(3,1fr); gap: 16px; margin-bottom: 26px; }
.valyon-account .dtile { background: var(--cream-soft); border: 1px solid var(--gold-soft); border-radius: 14px; padding: 20px 22px; box-shadow: var(--shadow-sm); }
.valyon-account .dtile .ic { width: 42px; height: 42px; border-radius: 11px; background: linear-gradient(160deg,#FBEFDC,#F3E2C4); border: 1px solid var(--gold-soft); display: flex; align-items: center; justify-content: center; color: var(--gold); margin-bottom: 14px; }
.valyon-account .dtile .num { font-family: 'Playfair Display', serif; font-weight: 700; font-size: 28px; line-height: 1; color: var(--dark); }
.valyon-account .dtile .lbl { font-size: 13.5px; color: var(--muted); margin-top: 6px; }
.valyon-account .dash-intro { margin-bottom: 26px; font-size: 15.5px; line-height: 1.65; color: #4d4639; }
.valyon-account .dash-intro b { color: var(--dark); }
.valyon-account .dash-quick { display: flex; gap: 16px; flex-wrap: wrap; align-items: center; }

/* orders table */
.valyon-account .orders-tbl { width: 100%; border-collapse: collapse; }
.valyon-account .orders-tbl thead th { text-align: left; font-size: 11.5px; font-weight: 800; letter-spacing: .07em; text-transform: uppercase; color: var(--muted); padding: 0 14px 14px; border-bottom: 1px solid var(--line); }
.valyon-account .orders-tbl thead th.right { text-align: right; }
.valyon-account .orders-tbl tbody td { padding: 18px 14px; border-bottom: 1px solid var(--line); font-size: 15px; vertical-align: middle; color: var(--dark); }
.valyon-account .orders-tbl tbody tr:last-child td { border-bottom: none; }
.valyon-account .orders-tbl .onum { font-weight: 700; color: var(--dark); }
.valyon-account .orders-tbl .odate { color: var(--muted); font-size: 14px; }
.valyon-account .orders-tbl .ot { font-family: 'Playfair Display', serif; font-weight: 700; font-size: 16px; text-align: right; white-space: nowrap; }
.valyon-account .orders-tbl .ot .amount { font-family: 'Playfair Display', serif; }
.valyon-account .orders-tbl .oview { text-align: right; }
.valyon-account .ostatus { display: inline-flex; align-items: center; gap: 7px; font-size: 12.5px; font-weight: 700; padding: 5px 11px; border-radius: 20px; white-space: nowrap; }
.valyon-account .ostatus .dot { width: 7px; height: 7px; border-radius: 50%; }
.valyon-account .ostatus.done { color: var(--success); background: var(--success-soft); }
.valyon-account .ostatus.done .dot { background: var(--success); }
.valyon-account .ostatus.proc { color: #9a6a1e; background: rgba(184,146,62,.14); }
.valyon-account .ostatus.proc .dot { background: var(--gold); }
.valyon-account .ostatus.cancel { color: #9a3b3b; background: rgba(179,51,85,.1); }
.valyon-account .ostatus.cancel .dot { background: #b35; }
.valyon-account .link-gold { display: inline-flex; align-items: center; gap: 6px; font-weight: 700; font-size: 14px; color: var(--dark); border-bottom: 1.5px solid var(--gold-soft); transition: color .2s; }
.valyon-account .link-gold:hover { color: var(--gold); }
.valyon-account .orders-pagination { display: flex; justify-content: space-between; gap: 16px; margin-top: 24px; }
.valyon-account .orders-empty { padding: 6px 0; }

/* addresses */
.valyon-account .addr-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.valyon-account .addr-card { border: 1px solid var(--line); border-radius: 14px; padding: 24px 26px; background: var(--cream-soft); }
.valyon-account .addr-card .ah { display: flex; align-items: center; justify-content: space-between; margin-bottom: 16px; gap: 12px; }
.valyon-account .addr-card .ah .t { display: flex; align-items: center; gap: 9px; font-weight: 800; font-size: 13px; letter-spacing: .04em; text-transform: uppercase; color: var(--dark); }
.valyon-account .addr-card .ah .t svg { color: var(--gold); flex: 0 0 auto; }
.valyon-account .addr-card .ah .edit { font-size: 13px; font-weight: 700; color: var(--gold); display: inline-flex; align-items: center; gap: 5px; white-space: nowrap; }
.valyon-account .addr-card p { font-size: 15px; line-height: 1.65; color: #3a342a; margin: 0; }
.valyon-account .addr-card p b { color: var(--dark); }
.valyon-account .addr-card.empty { color: var(--muted); }

/* account details / forms (checkout field styling) */
.valyon-account .acc-form { max-width: 620px; }
.valyon-account .field-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.valyon-account .field { margin: 0 0 16px; }
.valyon-account .field.full { grid-column: 1 / -1; }
.valyon-account .field label { display: block; font-size: 13px; font-weight: 700; color: var(--dark); margin-bottom: 7px; }
.valyon-account .field label .req { color: var(--gold); }
.valyon-account .field input { width: 100%; height: 52px; border: 1.5px solid var(--line); border-radius: 10px; padding: 0 15px; font-family: inherit; font-size: 15px; color: var(--dark); background: #fff; transition: border-color .2s, box-shadow .2s; }
.valyon-account .field input:focus { outline: none; border-color: var(--gold); box-shadow: 0 0 0 3px rgba(184,146,62,.14); }
.valyon-account .field input:disabled { opacity: .6; cursor: not-allowed; background: var(--cream-soft); }
.valyon-account .field .hint { font-size: 12.5px; color: var(--muted); margin-top: 6px; }
.valyon-account .fieldset-label { font-weight: 800; font-size: 12px; letter-spacing: .08em; text-transform: uppercase; color: var(--muted); margin: 26px 0 16px; padding-top: 22px; border-top: 1px solid var(--line); }
.valyon-account .form-actions { margin-top: 24px; }
.valyon-account .clear { clear: both; }

/* downloads (functional, not emphasized) */
.valyon-account .downloads-empty { display: flex; align-items: center; gap: 12px; color: var(--muted); font-size: 15px; padding: 8px 0; }
.valyon-account .downloads-empty svg { color: var(--gold-soft); flex: 0 0 auto; }

/* ===== LOGGED-OUT: login / register ===== */
.valyon-account--auth .auth-wrap { max-width: 1000px; margin: 0 auto; padding: 0 24px 80px; }
.valyon-account--auth .auth-head { text-align: center; padding: 48px 0 30px; }
.valyon-account--auth .auth-head .eyebrow { color: var(--gold); font-weight: 700; font-size: 13px; letter-spacing: .16em; text-transform: uppercase; margin-bottom: 12px; }
.valyon-account--auth .auth-head h1 { font-family: 'Playfair Display', serif; font-weight: 700; font-size: 42px; letter-spacing: -.015em; color: var(--dark); }
.valyon-account--auth .auth-head p { color: var(--muted); font-size: 16px; margin-top: 10px; }
.valyon-account--auth .auth-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 26px; align-items: start; }
.valyon-account--auth .auth-grid.single { grid-template-columns: 1fr; max-width: 520px; margin: 0 auto; }
.valyon-account--auth .auth-card { background: var(--cream-soft); border: 1px solid var(--gold-soft); border-radius: 18px; box-shadow: var(--shadow-md); padding: 34px 34px 36px; }
.valyon-account--auth .auth-card h2 { font-family: 'Playfair Display', serif; font-weight: 700; font-size: 24px; margin-bottom: 6px; color: var(--dark); }
.valyon-account--auth .auth-card .ac-sub { color: var(--muted); font-size: 14.5px; margin-bottom: 24px; line-height: 1.5; }
.valyon-account--auth .auth-card.register { background: #fff; }
.valyon-account--auth .check-row { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin: 4px 0 22px; flex-wrap: wrap; }
.valyon-account--auth .remember { display: flex; align-items: center; gap: 9px; font-size: 14px; color: #4d4639; cursor: pointer; margin: 0; }
.valyon-account--auth .remember input { width: 18px; height: 18px; accent-color: var(--gold); }
.valyon-account--auth .forgot { font-size: 14px; font-weight: 600; color: var(--gold); }

/* reused global buttons inside account: ensure full-width + arrow hover behave */
.valyon-account .btn-full, .valyon-account--auth .btn-full { width: 100%; justify-content: center; }
.valyon-account .dash-quick .btn-primary .arr { transition: transform .2s; }
.valyon-account .dash-quick .btn-primary:hover .arr { transform: translateX(4px); }

/* ============================================================================
   Responsive
   ========================================================================== */
@media (max-width: 980px) {
  .valyon-account .acc-layout { grid-template-columns: 1fr; gap: 20px; }
  .valyon-account .acc-nav { display: none; }
  /* mobile: horizontal scrolling pill tabs, full-width row above the content */
  .valyon-account .acc-tabs { grid-column: 1 / -1; display: flex; gap: 8px; overflow-x: auto; -webkit-overflow-scrolling: touch; scroll-snap-type: x mandatory; margin: 0 -18px 8px; padding: 2px 18px 6px; }
  .valyon-account .acc-tabs a { flex: 0 0 auto; scroll-snap-align: start; font-family: inherit; font-weight: 700; font-size: 14px; color: var(--muted); background: var(--cream-soft); border: 1px solid var(--line); border-radius: 30px; padding: 11px 18px; white-space: nowrap; transition: all .2s; }
  .valyon-account .acc-tabs a.is-active { background: var(--dark); border-color: var(--dark); color: #fff; }
}
@media (max-width: 760px) {
  .valyon-account .acc-head { padding: 28px 0 18px; }
  .valyon-account .acc-head h1 { font-size: 30px; }
  .valyon-account--auth .auth-head h1 { font-size: 30px; }
  .valyon-account .card-pad { padding: 22px 20px; }
  .valyon-account .dash-tiles { grid-template-columns: 1fr; }
  .valyon-account .addr-grid { grid-template-columns: 1fr; }
  .valyon-account .field-grid { grid-template-columns: 1fr; }
  .valyon-account--auth .auth-grid { grid-template-columns: 1fr; }
  .valyon-account--auth .auth-head { padding: 32px 0 22px; }
  /* orders table → per-order cards (data-l labels become the row keys) */
  .valyon-account .orders-tbl, .valyon-account .orders-tbl thead, .valyon-account .orders-tbl tbody, .valyon-account .orders-tbl tr, .valyon-account .orders-tbl td { display: block; }
  .valyon-account .orders-tbl thead { display: none; }
  .valyon-account .orders-tbl tbody tr { border: 1px solid var(--line); border-radius: 13px; padding: 16px 18px; margin-bottom: 14px; background: var(--cream-soft); }
  .valyon-account .orders-tbl tbody td { border: none; padding: 5px 0; display: flex; justify-content: space-between; align-items: center; gap: 12px; }
  .valyon-account .orders-tbl tbody td::before { content: attr(data-l); font-size: 12px; font-weight: 700; letter-spacing: .04em; text-transform: uppercase; color: var(--muted); }
  .valyon-account .orders-tbl .ot, .valyon-account .orders-tbl .oview { text-align: right; }
}
