/* Layla Uniform — shell (auth/payment/account) */
:root{
  --bg:#ffffff;
  --text:#0f0f10;
  --muted:#6b7280;
  --line:#ececec;
  --soft:#f7f7f8;
  --red:#d61f2a;
  --accent:var(--red);
  --accent-soft:rgba(214,31,42,.10);
  --radius:18px;
  --shadow:0 12px 28px rgba(0,0,0,.08);
  --shadow2:0 10px 24px rgba(0,0,0,.10);
  --max:1200px;
  --nav-h:74px;
  --focus:0 0 0 3px rgba(15,15,15,.16);
  --font: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, "Apple Color Emoji","Segoe UI Emoji";
}

*{ box-sizing:border-box }
html,body{ height:100% }
body{
  margin:0;
  font-family:var(--font);
  color:var(--text);
  background:linear-gradient(180deg,#fbfbfc,#ffffff);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
body.no-scroll{ overflow:hidden; }

a{ color:inherit; text-decoration:none }
img{ display:block; max-width:100% }

.container{ width:min(var(--max), calc(100vw - 40px)); margin:0 auto; }
.pill{
  display:inline-flex; align-items:center; gap:10px;
  padding:8px 10px;
  border:1px solid var(--line);
  border-radius:999px;
  background:#fff;
  box-shadow:0 10px 26px rgba(0,0,0,.06);
  font-weight:900;
  font-size:13px;
}
.btn{
  appearance:none; border:0;
  border-radius:14px;
  padding:10px 14px;
  font-weight:950;
  cursor:pointer;
  display:inline-flex; align-items:center; justify-content:center;
  gap:10px;
  transition:.15s ease;
}
.btn.primary{ background:var(--text); color:#fff; }
.btn.primary.red{ background:var(--accent); }
.btn.ghost{ background:#fff; border:1px solid var(--line); color:var(--text); }
.btn:hover{ transform:translateY(-1px) }
.btn:active{ transform:translateY(0) }
.btn:focus{ outline:none; box-shadow:var(--focus) }

.field{ display:grid; gap:6px; }
.label{ font-size:12px; color:#2a2a2a; font-weight:900; letter-spacing:.2px; }
.input{
  width:100%;
  padding:12px 12px;
  border-radius:14px;
  border:1px solid rgba(0,0,0,.10);
  background:#fff;
  font-size:14px;
  outline:none;
}
.input:focus{
  border-color: rgba(214,31,42,.55);
  box-shadow: 0 0 0 4px rgba(214,31,42,.12);
}
.helper{ font-size:12px; color:var(--muted) }

.alert{
  border:1px solid rgba(214,31,42,.35);
  background:rgba(214,31,42,.06);
  color:#7a0b12;
  padding:10px 12px;
  border-radius:14px;
  font-size:13px;
  line-height:1.5;
}

.notice{
  border:1px solid rgba(16,185,129,.35);
  background:rgba(16,185,129,.08);
  padding:10px 12px;
  border-radius:14px;
  font-size:13px;
  color:#065f46;
}

/* ===== Header / Nav (Layla style) ===== */
header{
  position:sticky; top:0; z-index:50;
  background:rgba(255,255,255,.86);
  backdrop-filter:saturate(180%) blur(12px);
  border-bottom:1px solid rgba(0,0,0,.06);
}
.nav{
  height:var(--nav-h);
  display:flex; align-items:center; gap:14px;
}
.logo{
  font-weight:950;
  font-size:18px;
  letter-spacing:.2px;
}
.logo b{ color:var(--accent); }
nav.primary{
  display:flex; align-items:center; gap:18px;
  margin-left:10px;
}
nav.primary a{
  font-weight:800;
  font-size:13px;
  color:#222;
  opacity:.92;
  padding:10px 8px;
  border-radius:12px;
}
nav.primary a:hover{ background:rgba(0,0,0,.04) }

.nav-right{ margin-left:auto; display:flex; align-items:center; gap:10px; }

/* Language dropdown */
.lang-wrap{ position:relative; }
.lang-pill{
  display:flex; align-items:center; gap:10px;
  border:1px solid var(--line);
  border-radius:999px;
  background:#fff;
  padding:8px 10px;
  font-weight:900;
  cursor:pointer;
  box-shadow:0 10px 26px rgba(0,0,0,.06);
}
.lang-pill .lang-name{ display:none; font-weight:800; color:#222; }
.lang-pill .lang-code{ font-size:12px; color:#111; opacity:.9; }
.lang-pill .lang-chev{ opacity:.6; }
.lang-menu{
  position:absolute;
  right:0; top:calc(100% + 8px);
  width:220px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:14px;
  box-shadow:var(--shadow);
  padding:8px;
  opacity:0;
  pointer-events:none;
  transform:translateY(-6px);
  transition:.15s ease;
  z-index:200;
}
.lang-wrap.open .lang-menu{ opacity:1; pointer-events:auto; transform:translateY(0); }
.lang-item{
  display:flex; justify-content:space-between; align-items:center;
  padding:10px 12px; border-radius:10px;
  cursor:pointer; font-size:14px; color:#222;
}
.lang-item:hover{ background:rgba(0,0,0,.04) }
.lang-item small{ color:var(--muted); font-size:12px }
.lang-item.active{ background:rgba(15,15,15,.08); border:1px solid rgba(15,15,15,.18); }

/* Cart badge */
.cart-badge{
  min-width:20px; height:20px;
  padding:0 6px;
  border-radius:999px;
  display:inline-flex;
  align-items:center; justify-content:center;
  font-size:12px;
  font-weight:950;
  background:var(--accent);
  color:#fff;
}

/* Hamburger + Drawer */
.hamburger{
  display:none;
  width:42px; height:42px;
  border-radius:12px;
  border:1px solid var(--line);
  background:#fff;
  cursor:pointer;
  align-items:center;
  justify-content:center;
  gap:4px;
  flex-direction:column;
}
.hamburger span{
  width:18px; height:2px;
  background:#111; border-radius:999px;
  display:block;
  transition: transform .2s ease, opacity .2s ease;
}
.hamburger.active span:nth-child(1){ transform:translateY(6px) rotate(45deg) }
.hamburger.active span:nth-child(2){ opacity:0 }
.hamburger.active span:nth-child(3){ transform:translateY(-6px) rotate(-45deg) }

.drawer{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,.38);
  opacity:0;
  pointer-events:none;
  transition:.18s ease;
  z-index:80;
}
.drawer.open{ opacity:1; pointer-events:auto; }
.drawer-inner{
  position:absolute; top:0; right:0;
  width:min(420px, 92vw);
  height:100%;
  background:#fff;
  border-left:1px solid var(--line);
  padding:14px 18px 18px;
  transform:translateX(10px);
  transition:.18s ease;
  box-shadow:var(--shadow2);
  display:grid;
  gap:10px;
}
.drawer.open .drawer-inner{ transform:translateX(0); }
.drawer a{
  padding:12px 12px;
  border:1px solid var(--line);
  border-radius:14px;
  font-weight:800;
  font-size:14px;
  background:#fff;
  color:#222;
}
.drawer a:hover{ background:rgba(0,0,0,.03) }
.drawer .drawer-top{
  display:flex; align-items:center; justify-content:space-between;
}
.drawer .drawer-close{
  width:42px; height:42px;
  border-radius:12px;
  border:1px solid var(--line);
  background:#fff;
  cursor:pointer;
  font-weight:950;
}

/* ===== Page layouts ===== */
.page{
  min-height:calc(100vh - var(--nav-h));
  display:grid;
  align-items:center;
  padding:26px 0;
}

/* Cart / Checkout pages should start at top (not vertically centered) */
body[data-page="cart"] .page,
body[data-page="checkout"] .page{
  align-items:start;
  padding-top:18px;
}

.panel{
  width:min(520px, 100%);
  margin:0 auto;
  background:#fff;
  border:1px solid rgba(0,0,0,.08);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  overflow:hidden;
}
.panel .pad{ padding:18px; }
.panel .head{
  padding:18px;
  border-bottom:1px solid rgba(0,0,0,.06);
  background:linear-gradient(180deg, rgba(214,31,42,.06), rgba(0,0,0,0));
}
.h1{ margin:0; font-size:20px; letter-spacing:.2px; }
.sub{ margin:6px 0 0; color:var(--muted); font-size:13px; line-height:1.5; }
.form{ display:grid; gap:12px; }
.row{ display:flex; gap:10px; flex-wrap:wrap; align-items:center; }
.row.between{ justify-content:space-between; }
.mini-link{ font-size:13px; font-weight:850; color:#111; opacity:.86; }
.mini-link:hover{ text-decoration:underline; }

/* Payment stepper */
.steps{
  display:flex; gap:10px; flex-wrap:wrap;
  margin-top:12px;
}
.step{
  flex:1;
  min-width:120px;
  border:1px solid rgba(0,0,0,.08);
  border-radius:14px;
  padding:10px 12px;
  background:#fff;
  display:flex; align-items:center; justify-content:space-between;
  gap:10px;
  font-size:13px;
  font-weight:900;
  color:#222;
}
.step .dot{
  width:10px; height:10px; border-radius:999px;
  background:rgba(0,0,0,.14);
}
.step.active{ border-color: rgba(214,31,42,.35); background: rgba(214,31,42,.06); }
.step.active .dot{ background: var(--accent); }
.step.done{ border-color: rgba(16,185,129,.35); background: rgba(16,185,129,.08); }
.step.done .dot{ background: rgb(16,185,129); }

.kv{
  display:flex; gap:10px; flex-wrap:wrap;
  color:#111;
  font-size:13px;
}
.kv code{
  background:#f4f5fa;
  border:1px solid rgba(0,0,0,.08);
  padding:2px 8px;
  border-radius:999px;
}

/* Success overlay */
.overlay{
  position:fixed; inset:0; z-index:9999;
  background:rgba(15,15,15,.40);
  display:none;
  align-items:center; justify-content:center;
  padding:18px;
}
.overlay.show{ display:flex; }
.toast{
  width:min(520px, 100%);
  background:#fff;
  border:1px solid rgba(0,0,0,.10);
  border-radius:22px;
  box-shadow:0 30px 80px rgba(0,0,0,.20);
  padding:18px;
  display:flex;
  gap:12px;
  align-items:flex-start;
}
.toast .icon{
  width:42px; height:42px;
  border-radius:14px;
  background:rgba(16,185,129,.10);
  border:1px solid rgba(16,185,129,.25);
  display:flex; align-items:center; justify-content:center;
  font-size:22px;
}
.toast .t-title{ margin:0; font-weight:950; font-size:16px; }
.toast .t-sub{ margin:4px 0 0; color:var(--muted); font-size:13px; line-height:1.5; }


@keyframes floatIn{
  from{ opacity:0; transform:translateY(10px); }
  to{ opacity:1; transform:translateY(0); }
}
@keyframes pop{
  from{ opacity:0; transform:translateY(8px) scale(.98); }
  to{ opacity:1; transform:translateY(0) scale(1); }
}
.panel{ animation: floatIn .35s ease both; }
.overlay.show .toast{ animation: pop .22s ease both; }

/* Responsive */
@media (max-width: 980px){
  nav.primary{ display:none; }
  .hamburger{ display:inline-flex; }
  .lang-pill .lang-name{ display:none; }
  /* Mobile navbar: keep it compact */
  .nav-right .btn.primary{ display:none; }
  .pill span[data-i18n]{ display:none; }
  .pill{ padding:7px 10px; gap:6px; }
  .lang-pill{ padding:7px 10px; }
  .cart-text{ display:none; }
  .search{ display:none; }

}

@media (max-width: 720px){
  .brand{ font-size:14px; }
  .nav-right{ gap:8px; }
  .pill{ padding:6px 9px; }
  .logo{ font-size:16px; }

}

@media (min-width: 981px){
  .lang-pill .lang-name{ display:inline; }
}
@media (max-width: 520px){
  .container{ width:calc(100vw - 28px); }
  .panel .head{ padding:16px; }
  .panel .pad{ padding:16px; }
  .btn{ width:100%; }
  .row .btn{ flex:1; }
}


/* Card brand pills */
.brand-row{display:flex;align-items:center;justify-content:space-between;gap:10px}
.brand-pill{position:relative;display:inline-flex;align-items:center;gap:8px;border:1px solid rgba(0,0,0,.08);border-radius:999px;padding:6px 10px 6px 34px;font-size:12px;color:#111;background:#fff;min-height:26px}
.brand-pill::before{content:"";position:absolute;left:10px;top:50%;transform:translateY(-50%);width:18px;height:14px;background-repeat:no-repeat;background-position:center;background-size:contain;opacity:.9}
.brand-pill[data-brand="visa"]::before{background-image:url('brands/visa.svg')}
.brand-pill[data-brand="mastercard"]::before{background-image:url('brands/mastercard.svg')}
.brand-pill[data-brand="troy"]::before{background-image:url('brands/troy.svg')}
.brand-pill[data-brand="amex"]::before{background-image:url('brands/amex.svg')}
.brand-pill[data-brand="unknown"]::before{background-image:url('brands/card.svg');opacity:.55}
.brand-accept{display:flex;gap:10px;align-items:center;margin-top:8px;opacity:.92}
.brandmark{display:inline-block;width:44px;height:18px;border-radius:8px;border:1px solid rgba(0,0,0,.08);background:#fff;background-repeat:no-repeat;background-position:center;background-size:contain}
.brandmark.visa{background-image:url('brands/visa.svg')}
.brandmark.mastercard{background-image:url('brands/mastercard.svg')}
.brandmark.troy{background-image:url('brands/troy.svg')}
.brandmark.amex{background-image:url('brands/amex.svg')}

.token-cell{white-space:nowrap}
.token-code{padding:2px 6px;border-radius:8px;background:rgba(0,0,0,.04);border:1px solid rgba(0,0,0,.06)}
.mini-btn{margin-left:8px;display:inline-flex;align-items:center;justify-content:center;padding:6px 10px;border-radius:999px;border:1px solid rgba(0,0,0,.10);background:#fff;color:#111;font-size:12px;cursor:pointer;transition:transform .15s ease, box-shadow .15s ease}
.mini-btn:hover{transform:translateY(-1px);box-shadow:0 10px 20px rgba(0,0,0,.08)}
.mini-btn.copied{border-color:rgba(16,185,129,.35);background:rgba(16,185,129,.10)}
