/* ═══════════════════════════════════════
   VALENHEIM — Components Stylesheet
════════════════════════════════════════ */

/* ─── Product Page ──────────────────── */
.product-hero {
  padding-top: 108px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  min-height: 100vh;
}
.product-gallery {
  position: relative;
  background: var(--surface-1);
}
.gallery-main {
  width: 100%; height: 500px;
  background-size: cover; background-position: center;
  transition: background-image 0.4s ease;
}
.gallery-thumbs {
  display: flex; gap: 8px; padding: 12px;
  background: var(--surface-2);
  overflow-x: auto;
}
.gallery-thumb {
  width: 80px; height: 60px;
  background-size: cover; background-position: center;
  border: 2px solid transparent;
  border-radius: var(--radius-sm);
  cursor: pointer;
  flex-shrink: 0;
  transition: border-color var(--transition);
}
.gallery-thumb.active { border-color: var(--gold); }
.product-detail {
  padding: 60px;
  background: var(--surface-2);
  display: flex; flex-direction: column;
}
.product-category { font-size: 10px; letter-spacing: 0.25em; text-transform: uppercase; color: var(--gold); margin-bottom: 8px; }
.product-title {
  font-family: var(--font-display);
  font-size: clamp(1.8rem, 3vw, 3rem);
  font-weight: 300; line-height: 1.1;
  margin-bottom: 16px;
}
.product-region { font-size: 11px; color: var(--text-muted); margin-bottom: 24px; }
.product-price-block {
  background: var(--surface-3);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: 24px;
  margin-bottom: 32px;
}
.price-crypto {
  font-family: var(--font-display);
  font-size: 2.2rem; color: var(--gold);
  margin-bottom: 4px;
}
.price-fiat { font-size: 13px; color: var(--text-muted); }
.price-label { font-size: 9px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--text-muted); margin-bottom: 8px; }
.stock-badge {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 10px; letter-spacing: 0.1em;
  color: var(--accent-green); margin-top: 12px;
}
.stock-badge::before { content:''; width:6px; height:6px; border-radius:50%; background: var(--accent-green); }
.product-specs { margin-bottom: 32px; }
.product-specs h3 { font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--text-secondary); margin-bottom: 16px; }
.specs-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.spec-item { background: var(--surface-3); padding: 12px; border-radius: var(--radius-sm); }
.spec-label { font-size: 9px; letter-spacing: 0.15em; text-transform: uppercase; color: var(--text-muted); margin-bottom: 4px; }
.spec-val { font-size: 13px; color: var(--text-primary); }
.product-actions { display: flex; flex-direction: column; gap: 12px; margin-top: auto; }
.product-actions .btn-gold { text-align: center; justify-content: center; }

/* ─── Rental Calendar ───────────────── */
.rental-calendar {
  background: var(--surface-3);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: 24px; margin-bottom: 24px;
}
.calendar-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 16px; }
.calendar-header h4 { font-size: 13px; letter-spacing: 0.1em; }
.cal-nav { background: none; color: var(--text-secondary); font-size: 1.2rem; padding: 4px 10px; border: 1px solid var(--border-dim); border-radius: var(--radius-sm); transition: all var(--transition); }
.cal-nav:hover { border-color: var(--gold); color: var(--gold); }
.calendar-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 4px; text-align: center; }
.cal-day-label { font-size: 9px; letter-spacing: 0.1em; color: var(--text-muted); padding: 4px; }
.cal-day {
  padding: 6px 4px; font-size: 12px; border-radius: var(--radius-sm);
  cursor: pointer; transition: all var(--transition);
}
.cal-day:hover { background: rgba(201,168,76,0.1); color: var(--gold); }
.cal-day.today { color: var(--gold); font-weight: 600; }
.cal-day.selected { background: var(--gold); color: var(--black); font-weight: 600; }
.cal-day.range { background: rgba(201,168,76,0.15); }
.cal-day.booked { color: var(--text-muted); text-decoration: line-through; cursor: not-allowed; }
.cal-day.empty { cursor: default; }

/* ─── Auth Pages ────────────────────── */
.auth-page {
  min-height: 100vh;
  display: grid; grid-template-columns: 1fr 1fr;
}
.auth-visual {
  background: linear-gradient(135deg, var(--surface-1), var(--black));
  position: relative; overflow: hidden;
  display: flex; align-items: flex-end; padding: 60px;
}
.auth-visual-bg {
  position: absolute; inset: 0;
  background-size: cover; background-position: center;
  opacity: 0.3;
}
.auth-visual-content { position: relative; z-index: 1; }
.auth-visual-content h2 {
  font-family: var(--font-display);
  font-size: 3rem; font-weight: 300; color: var(--text-primary);
  margin-bottom: 12px;
}
.auth-visual-content p { color: var(--text-secondary); font-size: 14px; }
.auth-form-panel {
  background: var(--surface-2);
  display: flex; align-items: center; justify-content: center;
  padding: 60px;
}
.auth-form-inner { width: 100%; max-width: 400px; }
.auth-logo {
  font-family: var(--font-display);
  font-size: 1.6rem; letter-spacing: 0.35em;
  color: var(--gold); margin-bottom: 40px; display: block;
}
.auth-form-inner h2 {
  font-family: var(--font-display);
  font-size: 2rem; font-weight: 300;
  margin-bottom: 8px;
}
.auth-form-inner p { font-size: 13px; color: var(--text-muted); margin-bottom: 36px; }

/* ─── Form Elements ─────────────────── */
.form-group { margin-bottom: 20px; }
.form-label {
  display: block; font-size: 10px;
  letter-spacing: 0.15em; text-transform: uppercase;
  color: var(--text-secondary); margin-bottom: 8px;
}
.form-input {
  width: 100%;
  background: var(--surface-3);
  border: 1px solid var(--border-dim);
  border-radius: var(--radius-sm);
  padding: 12px 16px;
  color: var(--text-primary);
  font-family: var(--font-body);
  font-size: 14px;
  transition: border-color var(--transition);
  outline: none;
}
.form-input:focus { border-color: var(--gold); }
.form-input::placeholder { color: var(--text-muted); }
.form-select { appearance: none; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath d='M2 4l4 4 4-4' stroke='%239A9282' stroke-width='1.5' fill='none'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 16px center; cursor: pointer; }
.form-textarea { resize: vertical; min-height: 100px; }
.form-error { font-size: 11px; color: var(--accent-red); margin-top: 4px; }
.form-hint { font-size: 11px; color: var(--text-muted); margin-top: 4px; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.form-check { display: flex; align-items: center; gap: 10px; cursor: pointer; }
.form-check input[type="checkbox"] { width: 16px; height: 16px; accent-color: var(--gold); cursor: pointer; }
.form-check span { font-size: 12px; color: var(--text-secondary); }
.form-divider { display: flex; align-items: center; gap: 12px; margin: 24px 0; }
.form-divider::before, .form-divider::after { content:''; flex:1; height:1px; background: var(--border-dim); }
.form-divider span { font-size: 11px; color: var(--text-muted); }

/* ─── Dashboard ─────────────────────── */
.dashboard-layout {
  display: grid;
  grid-template-columns: 260px 1fr;
  min-height: 100vh;
  padding-top: 108px;
}
.dashboard-sidebar {
  background: var(--surface-1);
  border-right: 1px solid var(--border);
  padding: 32px 0;
  position: sticky; top: 108px;
  height: calc(100vh - 108px);
  overflow-y: auto;
}
.sidebar-section { margin-bottom: 32px; }
.sidebar-label { font-size: 9px; letter-spacing: 0.25em; text-transform: uppercase; color: var(--text-muted); padding: 0 24px; margin-bottom: 8px; }
.sidebar-link {
  display: flex; align-items: center; gap: 12px;
  padding: 10px 24px;
  font-size: 13px; color: var(--text-secondary);
  transition: all var(--transition);
  border-left: 2px solid transparent;
}
.sidebar-link:hover { color: var(--text-primary); background: rgba(255,255,255,0.02); }
.sidebar-link.active { color: var(--gold); border-left-color: var(--gold); background: rgba(201,168,76,0.04); }
.sidebar-link svg { flex-shrink: 0; }
.dashboard-main { padding: 40px 48px; }
.dashboard-header { margin-bottom: 40px; }
.dashboard-header h1 { font-family: var(--font-display); font-size: 2rem; font-weight: 300; margin-bottom: 4px; }
.dashboard-header p { color: var(--text-muted); font-size: 13px; }
.stats-cards { display: grid; grid-template-columns: repeat(4,1fr); gap: 16px; margin-bottom: 40px; }
.stat-card {
  background: var(--surface-2); border: 1px solid var(--border-dim);
  border-radius: var(--radius-md); padding: 24px;
  transition: border-color var(--transition);
}
.stat-card:hover { border-color: var(--border); }
.stat-card-label { font-size: 10px; letter-spacing: 0.15em; text-transform: uppercase; color: var(--text-muted); margin-bottom: 12px; }
.stat-card-val { font-family: var(--font-display); font-size: 1.8rem; color: var(--gold); margin-bottom: 4px; }
.stat-card-sub { font-size: 11px; color: var(--text-secondary); }

/* ─── Table ─────────────────────────── */
.table-section { background: var(--surface-2); border: 1px solid var(--border-dim); border-radius: var(--radius-md); overflow: hidden; margin-bottom: 32px; }
.table-header { display: flex; align-items: center; justify-content: space-between; padding: 20px 24px; border-bottom: 1px solid var(--border-dim); }
.table-header h3 { font-size: 13px; font-weight: 500; letter-spacing: 0.05em; }
.data-table { width: 100%; border-collapse: collapse; }
.data-table th { font-size: 9px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--text-muted); padding: 12px 16px; text-align: left; background: var(--surface-3); }
.data-table td { padding: 14px 16px; font-size: 13px; color: var(--text-secondary); border-bottom: 1px solid var(--border-dim); }
.data-table tr:last-child td { border-bottom: none; }
.data-table tr:hover td { background: rgba(255,255,255,0.01); color: var(--text-primary); }
.status-pill {
  display: inline-flex; align-items: center; gap: 5px;
  font-size: 10px; letter-spacing: 0.1em;
  padding: 3px 10px; border-radius: 100px;
}
.status-pill.confirmed { background: rgba(39,174,96,0.15); color: var(--accent-green); }
.status-pill.pending { background: rgba(201,168,76,0.15); color: var(--gold); }
.status-pill.failed { background: rgba(192,57,43,0.15); color: var(--accent-red); }
.status-pill::before { content:''; width:5px; height:5px; border-radius:50%; background: currentColor; }

/* ─── Checkout ──────────────────────── */
.checkout-layout {
  display: grid;
  grid-template-columns: 1fr 400px;
  gap: 40px;
  padding: 120px 80px 80px;
}
.checkout-main h2 { font-family: var(--font-display); font-size: 2rem; font-weight: 300; margin-bottom: 32px; }
.checkout-step {
  background: var(--surface-2); border: 1px solid var(--border-dim);
  border-radius: var(--radius-md); padding: 32px; margin-bottom: 16px;
}
.checkout-step-header { display: flex; align-items: center; gap: 16px; margin-bottom: 24px; }
.step-num {
  width: 32px; height: 32px; border-radius: 50%;
  background: var(--gold); color: var(--black);
  display: flex; align-items: center; justify-content: center;
  font-size: 13px; font-weight: 600; flex-shrink: 0;
}
.step-num.inactive { background: var(--surface-3); color: var(--text-muted); }
.step-title { font-size: 14px; font-weight: 500; letter-spacing: 0.05em; }
.crypto-options { display: grid; grid-template-columns: repeat(4,1fr); gap: 12px; margin-bottom: 24px; }
.crypto-option {
  display: flex; flex-direction: column; align-items: center; gap: 8px;
  padding: 16px 8px;
  border: 2px solid var(--border-dim);
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: all var(--transition);
}
.crypto-option:hover, .crypto-option.selected { border-color: var(--gold); background: rgba(201,168,76,0.05); }
.crypto-option img { width: 32px; height: 32px; object-fit: contain; }
.crypto-option span { font-size: 11px; color: var(--text-secondary); }
.wallet-display {
  background: var(--surface-3);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: 20px;
  margin-bottom: 20px;
}
.wallet-label { font-size: 9px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--text-muted); margin-bottom: 8px; }
.wallet-address { font-size: 12px; font-family: monospace; color: var(--text-primary); word-break: break-all; margin-bottom: 12px; }
.wallet-copy {
  font-size: 10px; letter-spacing: 0.15em;
  color: var(--gold); cursor: pointer;
  border: 1px solid var(--border);
  padding: 5px 12px; border-radius: var(--radius-sm);
  transition: all var(--transition);
}
.wallet-copy:hover { background: rgba(201,168,76,0.1); }
.qr-placeholder { width: 120px; height: 120px; background: #fff; border-radius: var(--radius-sm); margin: 16px 0; display: flex; align-items: center; justify-content: center; }
.payment-status {
  display: flex; align-items: center; gap: 12px;
  background: var(--surface-3); border: 1px solid var(--border-dim);
  border-radius: var(--radius-md); padding: 16px 20px;
  font-size: 13px;
}
.payment-status .spinner { width: 18px; height: 18px; border: 2px solid var(--border-dim); border-top-color: var(--gold); border-radius: 50%; animation: spin 0.8s linear infinite; }
@keyframes spin { to { transform: rotate(360deg); } }
.checkout-sidebar { }
.order-summary {
  background: var(--surface-2); border: 1px solid var(--border-dim);
  border-radius: var(--radius-md); padding: 28px;
  position: sticky; top: 120px;
}
.order-summary h3 { font-size: 13px; letter-spacing: 0.1em; margin-bottom: 24px; }
.summary-item { display: flex; justify-content: space-between; margin-bottom: 12px; font-size: 13px; }
.summary-item span:first-child { color: var(--text-muted); }
.summary-divider { border: none; border-top: 1px solid var(--border-dim); margin: 20px 0; }
.summary-total { display: flex; justify-content: space-between; font-size: 16px; }
.summary-total span:last-child { color: var(--gold); font-family: var(--font-display); font-size: 1.4rem; }

/* ─── Filters ───────────────────────── */
.filter-bar {
  background: var(--surface-1);
  border-bottom: 1px solid var(--border);
  padding: 16px 80px;
  display: flex; gap: 16px; align-items: center;
  position: sticky; top: 108px; z-index: 100;
  overflow-x: auto;
}
.filter-chip {
  display: flex; align-items: center; gap: 6px;
  padding: 7px 16px;
  background: var(--surface-2);
  border: 1px solid var(--border-dim);
  border-radius: 100px;
  font-size: 11px; letter-spacing: 0.08em;
  color: var(--text-secondary);
  cursor: pointer; white-space: nowrap;
  transition: all var(--transition);
}
.filter-chip:hover, .filter-chip.active { border-color: var(--gold); color: var(--gold); background: rgba(201,168,76,0.06); }
.filter-select {
  background: var(--surface-2);
  border: 1px solid var(--border-dim);
  border-radius: 100px;
  padding: 7px 32px 7px 16px;
  font-family: var(--font-body); font-size: 11px;
  color: var(--text-secondary);
  cursor: pointer; outline: none;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 12 12'%3E%3Cpath d='M2 4l4 4 4-4' stroke='%239A9282' stroke-width='1.5' fill='none'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 12px center;
  transition: all var(--transition);
}
.filter-select:focus { border-color: var(--gold); color: var(--gold); }

/* ─── KYC Upload ────────────────────── */
.kyc-upload {
  border: 2px dashed var(--border);
  border-radius: var(--radius-md);
  padding: 40px; text-align: center;
  cursor: pointer; transition: all var(--transition);
  background: var(--surface-3);
}
.kyc-upload:hover { border-color: var(--gold); background: rgba(201,168,76,0.03); }
.kyc-upload-icon { font-size: 2rem; margin-bottom: 12px; color: var(--gold); }
.kyc-upload p { font-size: 13px; color: var(--text-secondary); margin-bottom: 8px; }
.kyc-upload small { font-size: 11px; color: var(--text-muted); }

/* ─── Toast Notifications ───────────── */
#toast-container {
  position: fixed; bottom: 24px; right: 24px;
  display: flex; flex-direction: column; gap: 10px;
  z-index: 9999;
}
.toast {
  background: var(--surface-3); border: 1px solid var(--border);
  border-radius: var(--radius-md); padding: 14px 20px;
  font-size: 13px; min-width: 280px;
  display: flex; align-items: center; gap: 12px;
  animation: slide-in-right 0.3s ease;
}
@keyframes slide-in-right { from{transform:translateX(100%);opacity:0} to{transform:none;opacity:1} }
.toast.success { border-left: 3px solid var(--accent-green); }
.toast.error { border-left: 3px solid var(--accent-red); }
.toast.info { border-left: 3px solid var(--gold); }

/* ─── Admin Panel ───────────────────── */
.admin-layout {
  display: grid;
  grid-template-columns: 240px 1fr;
  min-height: 100vh;
}
.admin-sidebar {
  background: #0A0A0A;
  border-right: 1px solid var(--border);
}
.admin-sidebar-header {
  padding: 24px;
  border-bottom: 1px solid var(--border);
  font-family: var(--font-display);
  font-size: 1.2rem; color: var(--gold);
  letter-spacing: 0.2em;
}
.admin-sidebar-header small { display: block; font-family: var(--font-body); font-size: 9px; letter-spacing: 0.15em; color: var(--text-muted); margin-top: 2px; }
.admin-nav-item {
  display: flex; align-items: center; gap: 10px;
  padding: 12px 20px; font-size: 13px;
  color: var(--text-muted);
  transition: all var(--transition);
  border-left: 2px solid transparent;
  cursor: pointer;
}
.admin-nav-item:hover { color: var(--text-primary); background: rgba(255,255,255,0.02); }
.admin-nav-item.active { color: var(--gold); border-left-color: var(--gold); background: rgba(201,168,76,0.04); }
.admin-main { background: #0D0D0D; }
.admin-topbar {
  display: flex; align-items: center; justify-content: space-between;
  padding: 20px 32px;
  border-bottom: 1px solid var(--border);
  background: #0A0A0A;
}
.admin-content { padding: 32px; }
.admin-grid-4 { display: grid; grid-template-columns: repeat(4,1fr); gap: 16px; margin-bottom: 32px; }
.admin-card { background: var(--surface-2); border: 1px solid var(--border-dim); border-radius: var(--radius-md); padding: 20px; }
.admin-card-label { font-size: 9px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--text-muted); margin-bottom: 8px; }
.admin-card-val { font-family: var(--font-display); font-size: 1.6rem; color: var(--text-primary); }
.admin-card-val.gold { color: var(--gold); }
.admin-card-val.green { color: var(--accent-green); }
.admin-card-val.red { color: var(--accent-red); }

/* ─── Payment Confirmation ──────────── */
.confirmation-page {
  min-height: 100vh; display: flex;
  align-items: center; justify-content: center;
  padding: 80px 24px;
}
.confirmation-box {
  background: var(--surface-2); border: 1px solid var(--border);
  border-radius: var(--radius-lg); padding: 60px;
  max-width: 540px; width: 100%; text-align: center;
}
.confirmation-icon { font-size: 4rem; margin-bottom: 24px; }
.confirmation-box h2 { font-family: var(--font-display); font-size: 2rem; font-weight: 300; margin-bottom: 12px; }
.confirmation-box p { color: var(--text-secondary); font-size: 14px; line-height: 1.8; margin-bottom: 32px; }
.tx-hash { background: var(--surface-3); border-radius: var(--radius-sm); padding: 12px 16px; font-family: monospace; font-size: 11px; color: var(--text-muted); word-break: break-all; margin-bottom: 24px; }
.confirmation-steps { display: grid; grid-template-columns: repeat(3,1fr); gap: 12px; margin-bottom: 32px; }
.conf-step { padding: 16px 8px; border: 1px solid var(--border-dim); border-radius: var(--radius-sm); font-size: 11px; text-align: center; }
.conf-step.done { border-color: var(--accent-green); color: var(--accent-green); }
.conf-step.active { border-color: var(--gold); color: var(--gold); }
.conf-step.waiting { color: var(--text-muted); }

/* ═══════════════════════════════════════
   MOBILE COMPONENT FIXES (added)
════════════════════════════════════════ */

@media (max-width: 768px) {
  /* Auth */
  .auth-page { grid-template-columns: 1fr !important; }
  .auth-visual { display: none !important; }
  .auth-form-panel { padding: 40px 24px !important; }
  .auth-form-inner { max-width: 100% !important; }

  /* Dashboard */
  .dashboard-layout { grid-template-columns: 1fr !important; }
  .dashboard-sidebar { display: none !important; }

  /* Product page */
  .product-layout { grid-template-columns: 1fr !important; }
  .product-gallery { height: 280px !important; }

  /* Checkout */
  .checkout-layout { grid-template-columns: 1fr !important; padding: 80px 16px 40px !important; }
  .checkout-sidebar { order: -1; }
  .crypto-options { gap: 8px !important; }
  .crypto-option { flex: 1 1 70px !important; min-width: 64px !important; padding: 10px 4px !important; }
  .crypto-option span { font-size: 9px !important; }
  .wallet-address { font-size: 9px !important; word-break: break-all; line-height: 1.5; }

  /* Confirmation */
  .confirmation-box { padding: 32px 20px !important; }
  .confirmation-steps { grid-template-columns: 1fr !important; }

  /* Tables / Rentals / Properties */
  .filters-bar { flex-wrap: wrap !important; gap: 8px !important; }
  .filter-btn  { font-size: 9px !important; padding: 6px 12px !important; }
  .listing-card .listing-info { padding: 12px !important; }
}

@media (max-width: 480px) {
  .auth-form-panel { padding: 32px 16px !important; }
  .confirmation-box { padding: 24px 16px !important; }
  .checkout-step { padding: 16px !important; }
  .wallet-display { padding: 14px !important; }
  .order-summary { padding: 16px !important; }
  .checkout-step-header .step-num { width: 28px !important; height: 28px !important; font-size: 11px !important; }
  .step-title { font-size: 12px !important; }
}

/* ═══════════════════════════════════════
   MOBILE COMPONENT OVERRIDES
════════════════════════════════════════ */
@media (max-width: 768px) {
  /* Auth pages: stack vertically on mobile */
  .auth-page { grid-template-columns: 1fr; }
  .auth-visual { display: none; }
  .auth-form-panel { padding: 40px 24px; min-height: 100vh; }
  .auth-form-inner { max-width: 100%; }
  .auth-form-inner h2 { font-size: 1.6rem; }

  /* Dashboard */
  .dashboard-layout { grid-template-columns: 1fr !important; }
  .dashboard-sidebar { display: none; }

  /* Product page */
  .product-layout { grid-template-columns: 1fr !important; }
  .product-gallery { margin-bottom: 24px; }

  /* Confirmation */
  .confirmation-box { padding: 32px 20px; }
  .confirmation-steps { grid-template-columns: 1fr; gap: 10px; }

  /* Modals */
  .modal-box { padding: 28px 20px; width: 95%; }

  /* Calendar */
  .calendar-grid { gap: 4px; }
  .cal-day { font-size: 11px; padding: 6px 4px; }

  /* Tables on mobile: horizontal scroll */
  .table-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; }
  .data-table  { min-width: 580px; }

  /* Checkout layout handled in checkout.html inline styles */
}

@media (max-width: 480px) {
  .auth-form-panel { padding: 24px 16px; }
  .modal-box { padding: 20px 14px; width: 98%; }
  .confirmation-box { padding: 24px 14px; }
  .product-specs-grid { grid-template-columns: 1fr !important; }
}

/* Crypto ticker — smaller on mobile */
@media (max-width: 600px) {
  #crypto-ticker { height: 30px; }
  .ticker-item    { font-size: 10px; gap: 4px; }
}

/* ═══════════════════════════════════════
   VALENHEIM — Mobile & Component Upgrades
════════════════════════════════════════ */

/* ── Filter bar mobile ── */
@media (max-width: 768px) {
  .filter-bar {
    padding: 12px 16px;
    gap: 10px;
    top: 56px;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
  }
  .filter-bar::-webkit-scrollbar { display: none; }
  .filter-chip {
    padding: 10px 18px;
    font-size: 12px;
    min-height: 40px;
  }
  .filter-select {
    padding: 10px 32px 10px 16px;
    font-size: 12px;
    min-height: 40px;
  }
}

/* ── Page header (supercars, jets, etc.) ── */
@media (max-width: 768px) {
  div[style*="padding: 130px 80px"],
  div[style*="padding: 140px 80px"],
  div[style*="padding: 160px 80px"],
  .page-header {
    padding: 100px 16px 40px !important;
  }
  .page-header h1 { font-size: clamp(2rem, 8vw, 3.5rem) !important; }
}

/* ── Listing cards - mobile ── */
@media (max-width: 768px) {
  .listing-card .listing-body { padding: 18px 16px; }
  .listing-title { font-size: 1.2rem !important; }
  .listing-price { font-size: 1.3rem !important; }
}

/* ── Crypto coin cards stacked on mobile ── */
@media (max-width: 768px) {
  .crypto-coins {
    grid-template-columns: 1fr !important;
  }
  .crypto-coin-card { padding: 20px 18px; }
}

/* ── Categories mosaic on mobile ── */
@media (max-width: 768px) {
  .categories-mosaic {
    grid-template-columns: 1fr !important;
    grid-template-rows: auto !important;
  }
  .cat-tile:first-child { grid-row: auto !important; }
  .cat-tile { height: 200px !important; }
  .cat-tile-name { font-size: 1.4rem !important; }
}

/* ── Trust items wrap nicely on mobile ── */
@media (max-width: 768px) {
  .trust-items {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 16px !important;
  }
  .trust-item {
    border: 1px solid var(--border-faint) !important;
    padding: 16px !important;
    gap: 10px !important;
  }
}
@media (max-width: 480px) {
  .trust-items { grid-template-columns: 1fr !important; }
}

/* ── Footer mobile ── */
@media (max-width: 768px) {
  .footer-grid, .footer-top {
    grid-template-columns: 1fr !important;
    gap: 32px !important;
  }
  .footer-bottom {
    flex-direction: column !important;
    gap: 12px !important;
    text-align: center !important;
  }
  .footer-crypto-logos { justify-content: center; }
}

/* ── Modal full-screen on mobile ── */
@media (max-width: 480px) {
  .modal-overlay { align-items: flex-end; }
  .modal-box {
    width: 100% !important;
    border-radius: 16px 16px 0 0 !important;
    padding: 28px 20px 40px !important;
    max-height: 85vh;
    overflow-y: auto;
  }
}

/* ── Nav center links — bigger across all pages ── */
.nav-center a {
  font-size: 11.5px;
  letter-spacing: 0.16em;
}

/* ── Nav icons — bigger, better tap targets ── */
.nav-icon {
  padding: 6px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 36px;
  min-width: 36px;
}
@media (max-width: 768px) {
  .nav-icon {
    min-height: 44px !important;
    min-width: 44px !important;
    padding: 10px !important;
  }
  .nav-right { gap: 2px !important; }
}

/* ── Services strip (index page) bigger on mobile ── */
@media (max-width: 768px) {
  .services-strip { gap: 0; }
  .service-item {
    min-width: 130px;
    padding: 18px 16px;
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
  }
  .service-name { font-size: 10.5px; }
  .service-count { font-size: 9px; }
  .service-icon { width: 32px; height: 32px; }
}

/* ── Hero CTA buttons full-width on mobile ── */
@media (max-width: 480px) {
  .hero-cta, .hero-actions {
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 10px !important;
  }
  .btn-gold, .btn-ghost, .btn-outline {
    width: 100% !important;
    justify-content: center !important;
    text-align: center !important;
  }
}

/* ── Smooth scroll inertia ── */
body { -webkit-overflow-scrolling: touch; }

/* ── Better input zoom prevention (iOS) ── */
@media (max-width: 768px) {
  input[type="text"],
  input[type="email"],
  input[type="password"],
  input[type="number"],
  input[type="tel"],
  textarea,
  select { font-size: 16px !important; }
}

/* ── Safe area padding for notched phones ── */
@media (max-width: 768px) {
  #navbar {
    padding-left: max(16px, env(safe-area-inset-left)) !important;
    padding-right: max(16px, env(safe-area-inset-right)) !important;
  }
  #footer {
    padding-bottom: max(40px, env(safe-area-inset-bottom)) !important;
  }
}

/* ── Region button on subpages — also bigger ── */
.region-btn {
  font-size: 11px;
  padding: 8px 14px;
  min-height: 36px;
}
@media (max-width: 768px) {
  .region-btn { display: none; } /* hide on mobile — replaced by location icon */
}
