:root {
  --midnight: #070A10;
  --navy: #0B1220;
  --card: #101A2E;
  --text: #F8FAFF;
  --muted: rgba(248, 250, 255, .78);
  --border: rgba(255, 255, 255, .12);
  --gold: #C9A227;
  --goldLight: #F1D58A;
  --violet: #6D5CFF;
  --emerald: #2ED3B7;
  --danger: #EF4444;
  --warning: #F59E0B;
  --info: #60A5FA;
  --shadow: 0 22px 55px rgba(0, 0, 0, .55);
  --radius: 18px;
  
  --space-1: 8px;
  --space-2: 12px;
  --space-3: 16px;
  --space-4: 24px;
  --space-5: 32px;

  --m3-duration-short: 100ms;
  --m3-duration-medium: 250ms;
  --m3-duration-long: 300ms;
  --m3-duration-longer: 400ms;
  --m3-easing-standard: cubic-bezier(0.2, 0, 0, 1);
  --m3-easing-emphasized: cubic-bezier(0.2, 0, 0, 1);
  --m3-easing-decelerated: cubic-bezier(0, 0, 0.2, 1);
  --m3-easing-accelerated: cubic-bezier(0.4, 0, 1, 1);
  --ease-bounce: cubic-bezier(0.68, -0.55, 0.265, 1.55);
  --ease-elastic: cubic-bezier(0.68, -0.6, 0.32, 1.6);
  --ease-smooth: cubic-bezier(0.33, 1, 0.68, 1);
  --ease-spring: cubic-bezier(0.34, 1.56, 0.64, 1);
  --physics-transition: transform 220ms var(--ease-spring);

  --glow-gold: 0 0 20px rgba(201, 162, 39, .25), 0 0 40px rgba(201, 162, 39, .12);
  --glow-violet: 0 0 20px rgba(109, 92, 255, .2), 0 0 40px rgba(109, 92, 255, .08);

  --tile-signature: url("https://web.rabbani.watch/assets/images/pattern-signature.png");
  --tile-luxury: url("https://web.rabbani.watch/assets/images/pattern-luxury.png");
  --tile: var(--tile-luxury);
  --tile-size-signature: 96px;
  --tile-size-luxury: 360px;
  --tile-size: var(--tile-size-luxury);
  --tile-grout-x: none;
  --tile-grout-y: none;
  --tile-opacity: .10;
  --mesh: url("https://web.rabbani.watch/assets/images/bg-mesh.svg");
  --grain: url("https://web.rabbani.watch/assets/images/bg-grain.svg");
  --lines: url("https://web.rabbani.watch/assets/images/bg-lines.svg");
  --ring: url("https://web.rabbani.watch/assets/images/bg-glow-ring.svg");

  --m3-primary: #C9A227;
  --m3-on-primary: #1B1400;
  --m3-primary-container: #3D3000;
  --m3-on-primary-container: #FFE08A;
  --m3-secondary: #6D5CFF;
  --m3-on-secondary: #0B0630;
  --m3-secondary-container: #241F5A;
  --m3-on-secondary-container: #E8E5FF;
  --m3-tertiary: #2ED3B7;
  --m3-on-tertiary: #00201B;
  --m3-tertiary-container: #003D35;
  --m3-on-tertiary-container: #9CF1E1;
  --m3-error: #F44336;
  --m3-on-error: #1F0000;
  --m3-surface: #0B1220;
  --m3-surface-dim: #0A0F19;
  --m3-surface-container-lowest: #070A10;
  --m3-surface-container-low: #101827;
  --m3-surface-container: #121B2B;
  --m3-surface-container-high: #162033;
  --m3-surface-container-highest: #1A263B;
  --m3-on-surface: #E6E9F2;
  --m3-on-surface-variant: #C3C8D4;
  --m3-outline: #3B4556;
  --m3-outline-variant: #2A3343;
  --m3-corner-small: 8px;
  --m3-corner-medium: 12px;
  --m3-corner-large: 18px;
  --m3-elev-1: 0 1px 2px rgba(0,0,0,.3), 0 1px 3px rgba(0,0,0,.15);
  --m3-elev-2: 0 2px 6px rgba(0,0,0,.35), 0 1px 3px rgba(0,0,0,.2);
  --m3-elev-3: 0 6px 12px rgba(0,0,0,.4), 0 2px 6px rgba(0,0,0,.25);
}

html, body {
  min-height: 100%;
}

.wrap{
  max-width: 980px;
  margin: 0 auto;
  padding: 48px 20px 80px;
  position: relative;
  z-index: 1;
}

.page{
  background:
    radial-gradient(900px 360px at 20% 0%, rgba(201,162,39,.10), transparent 60%),
    radial-gradient(700px 320px at 90% 10%, rgba(109,92,255,.12), transparent 62%),
    linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,.02)),
    rgba(21,29,43,.92);
  border:1px solid rgba(255,255,255,.12);
  border-radius:22px;
  box-shadow:0 22px 55px rgba(0,0,0,.55), inset 0 1px 0 rgba(255,255,255,.10);
  padding:34px 36px;
  margin:0 auto 22px;
  position:relative;
  transition: box-shadow var(--m3-duration-medium) var(--m3-easing-emphasized), transform var(--m3-duration-medium) var(--m3-easing-emphasized), border-color var(--m3-duration-short) var(--m3-easing-standard);
}
.page:hover{
  box-shadow:0 24px 60px rgba(0,0,0,.5), inset 0 1px 0 rgba(255,255,255,.12);
  transform: translateY(-2px);
}
.page > *{position:relative}

body {
  margin: 0;
  font-family: 'Roboto', system-ui, -apple-system, "Segoe UI", Arial, sans-serif;
  color: var(--text);
  background-color: var(--midnight);
  background:
    var(--grain) 0 0 / 260px 260px repeat,
    var(--mesh) 0 0 / 420px 420px repeat,
    radial-gradient(1200px 600px at 10% 10%, rgba(109, 92, 255, .18), transparent 60%),
    radial-gradient(900px 500px at 90% 0%, rgba(201, 162, 39, .16), transparent 55%),
    linear-gradient(180deg, rgba(11, 18, 32, .78), rgba(7, 10, 16, .98)),
    var(--midnight);
  background-attachment: fixed, fixed, fixed, fixed, fixed, fixed;
  min-height: 100vh;
  overflow-x: hidden;
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  background:
    var(--tile-grout-x),
    var(--tile-grout-y),
    var(--tile) 0 0 / var(--tile-size) var(--tile-size) repeat;
  opacity: var(--tile-opacity);
  filter: blur(.35px);
  mix-blend-mode: normal;
}

body::after {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: -1;
  background:
    radial-gradient(900px 520px at 10% 10%, rgba(109, 92, 255, .22), transparent 60%),
    radial-gradient(900px 520px at 90% 0%, rgba(201, 162, 39, .20), transparent 58%),
    radial-gradient(1100px 700px at 50% -10%, rgba(201, 162, 39, .10), transparent 55%),
    radial-gradient(1100px 700px at 50% 120%, rgba(109, 92, 255, .10), transparent 55%);
  opacity: .78;
  animation: aurora 18s cubic-bezier(0.16, 1, 0.3, 1) infinite;
}

@keyframes aurora {
  0% { background-position: 10% 10%, 90% 0%, 50% -10%, 50% 120%; }
  50% { background-position: 18% 18%, 82% 10%, 54% -6%, 46% 112%; }
  100% { background-position: 10% 10%, 90% 0%, 50% -10%, 50% 120%; }
}

h1, h2, h3, h4, h5, h6, .page-title, .card-title {
  font-family: "Cormorant Garamond", Georgia, serif !important;
  letter-spacing: -0.02em;
  color: var(--gold) !important;
  font-weight: 600;
}

h1 { font-size: 2.5rem; line-height: 1.1; }
h2 { font-size: 2rem; }
h3 { font-size: 1.5rem; }

.text-muted { color: var(--muted) !important; }
.text-body { color: var(--text) !important; }
.text-danger { color: var(--m3-error) !important; }

* { box-sizing: border-box; }
html, body, #app { height: 100%; }
h1, h2, h3, h4, h5, h6, p { margin: 0; }

.display-large { font: 400 57px/64px "Cormorant Garamond", Georgia, serif; letter-spacing: -0.25px; }
.display-medium { font: 400 45px/52px "Cormorant Garamond", Georgia, serif; }
.display-small { font: 400 36px/44px "Cormorant Garamond", Georgia, serif; }
.headline-large { font: 500 32px/40px "Cormorant Garamond", Georgia, serif; }
.headline-medium { font: 500 28px/36px "Cormorant Garamond", Georgia, serif; }
.headline-small { font: 500 24px/32px "Cormorant Garamond", Georgia, serif; }
.title-large { font: 600 22px/28px Roboto, system-ui, -apple-system, "Segoe UI", Arial, sans-serif; }
.title-medium { font: 600 16px/24px Roboto, system-ui, -apple-system, "Segoe UI", Arial, sans-serif; letter-spacing: 0.15px; }
.title-small { font: 600 14px/20px Roboto, system-ui, -apple-system, "Segoe UI", Arial, sans-serif; letter-spacing: 0.1px; }
.label-large { font: 600 14px/20px Roboto, system-ui, -apple-system, "Segoe UI", Arial, sans-serif; letter-spacing: 0.1px; }
.label-medium { font: 600 12px/16px Roboto, system-ui, -apple-system, "Segoe UI", Arial, sans-serif; letter-spacing: 0.5px; }
.label-small { font: 600 11px/16px Roboto, system-ui, -apple-system, "Segoe UI", Arial, sans-serif; letter-spacing: 0.5px; }
.body-large { font: 400 16px/24px Roboto, system-ui, -apple-system, "Segoe UI", Arial, sans-serif; letter-spacing: 0.5px; }
.body-medium { font: 400 14px/20px Roboto, system-ui, -apple-system, "Segoe UI", Arial, sans-serif; letter-spacing: 0.25px; }
.body-small { font: 400 12px/16px Roboto, system-ui, -apple-system, "Segoe UI", Arial, sans-serif; letter-spacing: 0.4px; }

.card {
  border: 1px solid var(--m3-outline-variant);
  border-radius: var(--m3-corner-large);
  background: linear-gradient(180deg, rgba(255, 255, 255, .06), rgba(255, 255, 255, .03)), var(--m3-surface-container) !important;
  box-shadow: var(--m3-elev-2);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  color: #fff !important;
  overflow: hidden;
  transition: box-shadow var(--m3-duration-medium), border-color var(--m3-duration-short), transform var(--physics-transition);
}

.card:hover {
  box-shadow: var(--m3-elev-3), var(--glow-violet);
  border-color: rgba(255, 255, 255, .16);
  transform: translateY(-4px) scale(1.01);
}

.fixed-header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1030;
  background: rgba(7, 10, 16, 0.85);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border-bottom: 1px solid rgba(212, 175, 55, 0.2);
  padding: 0.75rem 1.5rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 64px;
  box-shadow: 0 4px 30px rgba(0, 0, 0, 0.2);
}

#app {
  padding-top: 84px;
  min-height: 100vh;
  position: relative;
  z-index: 1;
}
@media (max-width: 768px) {
  #app { padding-bottom: 72px; }
}

.metrics-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 320px));
  gap: var(--space-3);
  align-items: stretch;
  grid-auto-flow: row dense;
  justify-content: center;
  justify-items: stretch;
}

.badge.bg-violet-lt {
  color: var(--violet);
  background-color: rgba(109, 92, 255, 0.15);
  border: 1px solid rgba(109, 92, 255, 0.25);
  box-shadow: 0 0 10px rgba(109, 92, 255, 0.05);
}
.badge.bg-success-lt {
  color: #34d399;
  background-color: rgba(52, 211, 153, 0.15);
  border: 1px solid rgba(52, 211, 153, 0.25);
}
.nav-tabs {
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
  gap: 8px;
  padding-bottom: 12px;
}

.nav-link {
  border: 1px solid transparent !important;
  color: var(--m3-on-surface-variant) !important;
  background: transparent !important;
  border-radius: 999px !important;
  padding: 0.6rem 1.5rem;
  font-family: 'Roboto', sans-serif;
  font-weight: 500;
  letter-spacing: 0.3px;
  position: relative;
  overflow: hidden;
  transition: all var(--m3-duration-medium) var(--m3-easing-emphasized);
}

.nav-link:hover {
  background-color: rgba(255, 255, 255, 0.08) !important;
  color: var(--text) !important;
  transform: scale(1.02);
}

.nav-link.active {
  background-color: rgba(212, 175, 55, 0.18) !important;
  border-color: rgba(212, 175, 55, 0.28) !important;
  color: var(--gold) !important;
  font-weight: 600;
  box-shadow: 0 4px 12px rgba(212, 175, 55, 0.1);
}

.nav-link.active::before {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  width: 0;
  height: 0;
  background: rgba(212, 175, 55, 0.2);
  border-radius: 50%;
  transform: translate(-50%, -50%);
  animation: ripple-out 0.6s var(--m3-easing-decelerated) forwards;
}

@keyframes ripple-out {
  0% { width: 0; height: 0; opacity: 0.5; }
  100% { width: 300px; height: 300px; opacity: 0; }
}

.btn {
  -webkit-tap-highlight-color: transparent;
  user-select: none;
  height: 40px;
  padding: 0 16px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  border-radius: var(--m3-corner-medium);
  border: 1px solid transparent;
  font: 600 14px/20px Roboto, system-ui, -apple-system, "Segoe UI", Arial, sans-serif;
  letter-spacing: 0.1px;
  transition: background-color var(--m3-duration-medium), color var(--m3-duration-medium), border-color var(--m3-duration-medium), box-shadow var(--m3-duration-medium);
}
.btn:disabled { opacity: .6; pointer-events: none; }
.btn-primary {
  background: var(--m3-primary);
  color: var(--m3-on-primary);
  box-shadow: var(--m3-elev-1);
}
.btn-sm { height: 32px; padding: 0 12px; font-size: 13px; }
.btn-primary:hover { box-shadow: var(--m3-elev-2); filter: brightness(1.02); }
.btn-tonal {
  background: var(--m3-primary-container);
  color: var(--m3-on-primary-container);
  border-color: var(--m3-outline-variant);
}
.btn-outline-primary {
  background: transparent;
  color: var(--m3-primary);
  border-color: color-mix(in srgb, var(--m3-primary) 55%, transparent);
}
.btn-outline-primary:hover {
  background: rgba(201,162,39,.12);
}
.btn-ghost {
  color: var(--m3-primary);
  background: transparent;
  border: 1px solid transparent;
  border-radius: var(--m3-corner-medium);
  transition: all 0.2s ease;
}
.btn-ghost:hover {
  color: var(--gold);
  border-color: rgba(212, 175, 55, 0.3);
  background: rgba(212, 175, 55, 0.1);
}

.btn-outline-secondary {
  color: var(--m3-on-surface-variant);
  border-color: var(--m3-outline);
  border-radius: var(--m3-corner-medium);
}
.btn-outline-secondary:hover {
  color: #fff;
  background-color: rgba(255,255,255,0.08);
  border-color: rgba(255,255,255,0.35);
}

.badge {
  border-radius: 999px;
  font-weight: 500;
  padding: 0.35em 0.8em;
}

.badge.bg-gold-lt {
  color: var(--gold);
  background-color: rgba(212, 175, 55, 0.15);
  border: 1px solid rgba(212, 175, 55, 0.25);
  box-shadow: 0 0 10px rgba(212, 175, 55, 0.05);
}

[dir="rtl"] .me-2 { margin-left: 0.5rem !important; margin-right: 0 !important; }
[dir="rtl"] .ms-2 { margin-right: 0.5rem !important; margin-left: 0 !important; }
.ms-auto { margin-left: auto !important; }
[dir="rtl"] .ms-auto { margin-right: auto !important; margin-left: 0 !important; }
.mx-auto { margin-left: auto !important; margin-right: auto !important; }

.progress {
  position: relative;
  height: 8px;
  background: var(--m3-surface-container-high);
  border-radius: 999px;
  overflow: hidden;
}
.progress-bar {
  height: 100%;
  background: linear-gradient(90deg, color-mix(in srgb, var(--m3-primary) 90%, transparent), var(--goldLight));
  border-radius: 999px;
  transition: width var(--m3-duration-long) var(--m3-easing-standard);
}

.table {
  width: 100%;
  border-collapse: collapse;
  color: var(--text);
}
.table th, .table td {
  padding: 12px 16px;
  border-bottom: 1px solid var(--m3-outline-variant);
}
.table thead th {
  color: var(--m3-on-surface-variant);
  text-transform: none;
  font-weight: 600;
}
.table tr:hover td {
  background: rgba(255,255,255,0.04);
}

.list-group { display: block; border-radius: var(--m3-corner-large); overflow: hidden; border: 1px solid var(--m3-outline-variant); }
.list-group-item { padding: 14px 16px; background: var(--m3-surface-container); border-bottom: 1px solid var(--m3-outline-variant); }
.list-group-item:last-child { border-bottom: none; }

.avatar {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background-size: cover;
  background-position: center;
  background-color: rgba(255,255,255,0.08);
  border: 1px solid var(--m3-outline-variant);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--text);
  font-weight: 600;
}
.avatar.avatar-sm { width: 32px; height: 32px; }
.avatar.avatar-lg { width: 64px; height: 64px; }

.container-xl { width: min(1160px, 100% - 32px); margin: 0 auto; padding: 0 16px; }
.container-centered { width: min(980px, 100% - 32px); margin: 0 auto; padding: 0 16px; }
.container-tight { width: min(520px, 100% - 32px); margin: 0 auto; padding: 0 16px; }
.page-title { margin: 0; text-align: center; }
.card-body { padding: 16px; }
.card-title { margin: 0 0 8px 0; }
.subheader { color: var(--m3-on-surface-variant); font: 600 12px/16px Roboto, system-ui, -apple-system, "Segoe UI", Arial, sans-serif; letter-spacing: 0.5px; text-transform: none; }
.text-center { text-align: center; }
.d-flex { display: flex; }
.d-none { display: none; }
.d-sm-block { display: none; }
.d-sm-none { display: block; }
@media (min-width: 576px) {
  .d-sm-block { display: block !important; }
  .d-sm-none { display: none !important; }
}
.align-items-center { align-items: center; }
.justify-content-between { justify-content: space-between; }
.justify-content-center { justify-content: center; }
.gap-2 { gap: 8px; }
.gap-3 { gap: 12px; }
.gap-4 { gap: 16px; }
.mb-2 { margin-bottom: 8px; }
.mb-3 { margin-bottom: 12px; }
.mb-4 { margin-bottom: 16px; }
.mt-1 { margin-top: 4px; }
.mt-2 { margin-top: 8px; }
.mt-3 { margin-top: 12px; }
.mt-4 { margin-top: 16px; }
.mt-n1 { margin-top: -4px; }
.py-6 { padding-top: 24px; padding-bottom: 24px; }
.me-2 { margin-right: 8px; }
.ms-2 { margin-left: 8px; }
.w-100 { width: 100%; }
.h1 { font-size: 28px; font-weight: 600; line-height: 1.2; }
.nav-scroller { overflow-x: auto; -webkit-overflow-scrolling: touch; display: flex; justify-content: center; }

.row { display: grid; grid-template-columns: repeat(12, minmax(0, 1fr)); gap: 16px; }
.row.row-cards { grid-template-columns: repeat(auto-fit, minmax(280px, 320px)); justify-content: center; }
.row.align-items-center, .row.justify-content-between { display: flex; gap: 16px; }
.row.align-items-center { align-items: center; }
.row.justify-content-between { justify-content: space-between; }
.row.align-items-center .col { flex: 1 1 0%; min-width: 0; }
.row.align-items-center .col-auto { flex: 0 0 auto; }
@media (min-width: 768px) { .col-md-6 { grid-column: span 6; } }
@media (min-width: 992px) { .col-lg-4 { grid-column: span 4; } }
.col { grid-column: 1 / -1; }

.card.clickable { cursor: pointer; }
.card.clickable:active { transform: translateY(0.5px); }

/* Force two columns for cards/metrics on mobile */
@media (max-width: 768px) {
  .metrics-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .row.row-cards {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

/* Catalog domain label (smaller, below title) */
.domain-label {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 999px;
  font: 600 12px/16px Roboto, system-ui, -apple-system, "Segoe UI", Arial, sans-serif;
  color: var(--gold);
  background: rgba(212,175,55,0.10);
  border: 1px solid rgba(212,175,55,0.35);
}

.form-label { display: block; margin-bottom: 6px; color: var(--m3-on-surface-variant); }
.form-select { height: 40px; border-radius: var(--m3-corner-medium); border: 1px solid var(--m3-outline-variant); background: var(--m3-surface-container-high); color: var(--text); padding: 8px 12px; }
.form-select-sm { height: 32px; padding: 4px 10px; }
.form-control-plaintext { color: var(--text); }

.dropdown { position: relative; }
.dropdown-toggle { height: 32px; }
.dropdown-menu { display: none; position: absolute; top: 100%; left: 0; min-width: 200px; background: var(--m3-surface-container-high); border: 1px solid var(--m3-outline-variant); border-radius: var(--m3-corner-large); box-shadow: var(--m3-elev-2); padding: 6px; margin-top: 8px; z-index: 1000; }
.dropdown-menu-end { right: 0; left: auto; }
.dropdown.open .dropdown-menu { display: block; }
.dropdown-item { display: block; padding: 8px 10px; border-radius: var(--m3-corner-medium); color: var(--text); text-decoration: none; cursor: pointer; }
.dropdown-item:hover { background: rgba(255,255,255,0.06); }

.empty { text-align: center; padding: 32px 12px; color: var(--m3-on-surface-variant); }
.empty-title { margin: 0 0 4px 0; color: var(--text); font-weight: 600; }

.segmented { display: inline-flex; padding: 4px; gap: 4px; background: var(--m3-surface-container-high); border: 1px solid var(--m3-outline-variant); border-radius: 999px; }
.segmented .seg-item { border-radius: 999px; padding: 8px 14px; color: var(--m3-on-surface-variant); cursor: pointer; transition: background-color var(--m3-duration-medium); }
.segmented .seg-item.active { background: rgba(212,175,55,0.18); color: var(--gold); }

.chip { display: inline-flex; align-items: center; gap: 6px; padding: 6px 10px; border-radius: 999px; font: 600 12px/16px Roboto, system-ui, -apple-system, "Segoe UI", Arial, sans-serif; letter-spacing: 0.4px; border: 1px solid var(--m3-outline-variant); color: var(--m3-on-surface-variant); background: var(--m3-surface-container-high); cursor: pointer; }
.chip.selected { background: rgba(212,175,55,0.18); color: var(--gold); border-color: rgba(212,175,55,0.35); }
.chip + .chip { margin-left: 8px; }

.bottom-nav { position: fixed; left: 0; right: 0; bottom: 0; height: 64px; background: var(--m3-surface-container-high); display: none; border-top: 1px solid var(--m3-outline-variant); z-index: 1029; }
.bottom-nav .bottom-nav-inner { display: grid; grid-template-columns: repeat(4, 1fr); height: 100%; }
.bottom-nav a { display: flex; align-items: center; justify-content: center; color: var(--m3-on-surface-variant); text-decoration: none; font: 600 12px/16px Roboto, system-ui, -apple-system, "Segoe UI", Arial, sans-serif; }
.bottom-nav .bottom-nav-inner { display: grid; grid-template-columns: repeat(4, 1fr); height: 100%; }
.bottom-nav a { display: flex; align-items: center; justify-content: center; color: var(--m3-on-surface-variant); text-decoration: none; font: 600 12px/16px Roboto, system-ui, -apple-system, "Segoe UI", Arial, sans-serif; }
.bottom-nav a.active { color: var(--gold); background: rgba(212,175,55,0.10); }
@media (max-width: 768px) {
  .bottom-nav { display: block; }
  .main-nav { display: none !important; }
}

.snackbar-container { position: fixed; left: 50%; bottom: 80px; transform: translateX(-50%); display: grid; gap: 8px; z-index: 1031; }
.snackbar { min-width: 280px; max-width: 520px; padding: 12px 16px; border-radius: 12px; background: var(--m3-surface-container-high); color: var(--text); border: 1px solid var(--m3-outline-variant); box-shadow: var(--m3-elev-2); animation: snack-in var(--m3-duration-medium) var(--m3-easing-emphasized); }
@keyframes snack-in { from { opacity: 0; transform: translate(-50%, 10px); } to { opacity: 1; transform: translate(-50%, 0); } }

[role="alert"], .alert { border-radius: 12px; padding: 12px 16px; border: 1px solid var(--m3-outline-variant); background: var(--m3-surface-container-high); color: var(--text); }
.alert-danger { border-color: color-mix(in srgb, var(--m3-error) 45%, var(--m3-outline-variant)); background: rgba(244, 67, 54, 0.1); }
.table-responsive { overflow-x: auto; }
.table.table-vcenter td, .table.table-vcenter th { vertical-align: middle; }

[class^="section"], .section, .page { 
  background: linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02)), var(--m3-surface-container); 
  border: 1px solid var(--m3-outline-variant); 
  border-radius: var(--m3-corner-large); 
  box-shadow: var(--m3-elev-2); 
  padding: 24px 16px; 
  margin-bottom: 16px; 
}
.section-hero { 
  background: linear-gradient(180deg, rgba(201,162,39,.10), rgba(255,255,255,.02)), var(--m3-surface-container); 
  border-color: rgba(212,175,55,0.25); 
}

[data-tile="signature"] {
  --tile: var(--tile-signature);
  --tile-size: var(--tile-size-signature);
  --tile-grout-x: repeating-linear-gradient(90deg, rgba(255,255,255,.040) 0 1px, transparent 1px var(--tile-size));
  --tile-grout-y: repeating-linear-gradient(0deg, rgba(255,255,255,.034) 0 1px, transparent 1px var(--tile-size));
  --tile-opacity: .22;
}

[data-theme="light"] {
  --text: #101828;
  --muted: rgba(16, 24, 40, .65);
  --midnight: #FAFAFA;
  --navy: #FFFFFF;
  --card: #FFFFFF;
  --m3-surface: #FFFFFF;
  --m3-surface-dim: #F7F7F8;
  --m3-surface-container-lowest: #FFFFFF;
  --m3-surface-container-low: #F5F6F9;
  --m3-surface-container: #FFFFFF;
  --m3-surface-container-high: #FFFFFF;
  --m3-surface-container-highest: #FFFFFF;
  --m3-on-surface: #101828;
  --m3-on-surface-variant: #475467;
  --m3-outline: #D0D5DD;
  --m3-outline-variant: #E5E7EB;
  --glow-violet: 0 0 0 rgba(0,0,0,0);
}

/* Google Sign-In (international standard) */
.google-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  height: 44px;
  width: 100%;
  background: #FFFFFF;
  color: #3c4043;
  border: 1px solid #dadce0;
  border-radius: 4px;
  text-decoration: none;
  font: 500 14px/20px Roboto, system-ui, -apple-system, "Segoe UI", Arial, sans-serif;
  letter-spacing: .25px;
  box-shadow: 0 1px 2px rgba(0,0,0,.12), 0 1px 3px rgba(0,0,0,.08);
  transition: box-shadow var(--m3-duration-medium) var(--m3-easing-standard), transform var(--m3-duration-short) var(--m3-easing-standard), background-color var(--m3-duration-short);
}
.google-btn:hover {
  box-shadow: 0 2px 6px rgba(0,0,0,.18), 0 1px 3px rgba(0,0,0,.12);
}
.google-btn:active {
  background: #f8f9fa;
  transform: translateY(0.5px);
}
.google-btn:focus-visible {
  outline: 2px solid #4285F4;
  outline-offset: 2px;
}
.google-btn .google-icon {
  width: 18px;
  height: 18px;
  display: inline-flex;
}
.google-btn .google-label {
  white-space: nowrap;
}
