/* =====================================================
   NAXOCRYPT DESIGN SYSTEM v2
   Theme: Professional White · Forest Green · Navy Blue
   Fonts: Cormorant Garamond (display) + Outfit (body)
   ===================================================== */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,600;0,700;1,400&family=Outfit:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap');

/* ── TOKENS ── */
:root {
  /* Greens */
  --g900: #053D2C;
  --g800: #0A5C42;
  --g700: #0B7A58;
  --g600: #0B8A65;   /* primary green */
  --g500: #12A87D;
  --g400: #2EBF94;
  --g200: #A7EDD8;
  --g100: #D4F5EB;
  --g50:  #F0FBF7;

  /* Blues */
  --b900: #0A1628;
  --b800: #0D1B2A;   /* near-black navy */
  --b700: #112236;
  --b600: #1A3A5C;
  --b500: #1E6FA8;
  --b400: #2E88C8;
  --b300: #60AADC;
  --b100: #D4EDFB;
  --b50:  #F0F7FD;

  /* Neutrals */
  --n900: #0D1117;
  --n800: #1C2333;
  --n700: #2C3E55;
  --n600: #4A5568;
  --n500: #718096;
  --n400: #A0AEC0;
  --n300: #CBD5E0;
  --n200: #E2E8F0;
  --n100: #F1F5F9;
  --n50:  #F8FAFC;
  --white: #ffffff;

  /* Semantic */
  --success: #0B8A65;
  --danger:  #DC2626;
  --warning: #D97706;
  --info:    #1E6FA8;

  /* Layout */
  --radius-xs: 4px;
  --radius-sm: 8px;
  --radius:    12px;
  --radius-lg: 18px;
  --radius-xl: 24px;

  --shadow-xs: 0 1px 3px rgba(0,0,0,0.06), 0 1px 2px rgba(0,0,0,0.04);
  --shadow-sm: 0 2px 8px rgba(0,0,0,0.07), 0 1px 3px rgba(0,0,0,0.04);
  --shadow:    0 4px 20px rgba(0,0,0,0.08), 0 2px 6px rgba(0,0,0,0.04);
  --shadow-md: 0 8px 32px rgba(0,0,0,0.10), 0 3px 10px rgba(0,0,0,0.05);
  --shadow-green: 0 4px 24px rgba(11,138,101,0.18);

  --transition: all 0.22s cubic-bezier(0.4,0,0.2,1);
}

/* ── RESET ── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 16px; }
body {
  font-family: 'Outfit', sans-serif;
  background: var(--white);
  color: var(--n800);
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}

/* ── TYPOGRAPHY ── */
h1,h2,h3,h4 { font-family: 'Cormorant Garamond', Georgia, serif; line-height: 1.15; }
h1 { font-size: clamp(2.4rem, 5vw, 4rem); font-weight: 700; }
h2 { font-size: clamp(1.8rem, 3.5vw, 2.8rem); font-weight: 600; }
h3 { font-size: 1.3rem; font-weight: 600; }
h4 { font-size: 1.05rem; font-weight: 600; }
p  { color: var(--n600); font-size: 1rem; }
.mono { font-family: 'JetBrains Mono', monospace; }

/* ── LAYOUT ── */
.container { max-width: 1180px; margin: 0 auto; padding: 0 28px; }
.section    { padding: 88px 0; }
.grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 32px; }
.grid-3 { display: grid; grid-template-columns: repeat(3,1fr); gap: 28px; }
.grid-4 { display: grid; grid-template-columns: repeat(4,1fr); gap: 20px; }
@media(max-width:900px){ .grid-2,.grid-3{ grid-template-columns:1fr; } }
@media(max-width:700px){ .grid-4{ grid-template-columns:repeat(2,1fr); } }

/* ── NAVBAR ── */
.navbar {
  position: fixed; top:0; left:0; right:0; z-index:1000;
  background: rgba(255,255,255,0.95);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--n200);
  height: 66px;
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 36px;
  box-shadow: var(--shadow-xs);
}
.nav-logo { display:flex; align-items:center; text-decoration:none; }
.nav-logo img { height: 36px; }
.nav-links { display:flex; align-items:center; gap:36px; }
.nav-links a {
  font-size: 0.9rem; font-weight: 500; color: var(--n700);
  text-decoration: none; letter-spacing: 0.2px; transition: var(--transition);
}
.nav-links a:hover { color: var(--g600); }
.nav-links a.active { color: var(--g600); }
.nav-actions { display:flex; gap:10px; align-items:center; }
.hamburger { display:none; flex-direction:column; gap:5px; cursor:pointer; padding:4px; }
.hamburger span { width:22px; height:2px; background:var(--n700); border-radius:2px; transition:var(--transition); }
@media(max-width:900px){ .nav-links{display:none;} .hamburger{display:flex;} .navbar{padding:0 20px;} }

/* ── BUTTONS ── */
.btn {
  display:inline-flex; align-items:center; gap:7px;
  padding:10px 22px; border-radius:var(--radius-sm);
  font-family:'Outfit',sans-serif; font-size:0.88rem; font-weight:600;
  text-decoration:none; cursor:pointer; border:none;
  letter-spacing:0.2px; transition:var(--transition); white-space:nowrap;
}
.btn-primary {
  background: var(--g600); color: white;
  box-shadow: var(--shadow-green);
}
.btn-primary:hover { background:var(--g700); transform:translateY(-1px); box-shadow:0 6px 28px rgba(11,138,101,0.28); }

.btn-outline {
  background:transparent; color:var(--g600);
  border:1.5px solid var(--g600);
}
.btn-outline:hover { background:var(--g50); }

.btn-navy {
  background: var(--b800); color:white;
}
.btn-navy:hover { background:var(--b700); transform:translateY(-1px); }

.btn-ghost { background:transparent; color:var(--g600); padding:8px 0; }
.btn-ghost:hover { color:var(--g700); }

.btn-danger { background:var(--danger); color:white; }
.btn-warning { background:var(--warning); color:white; }

.btn-sm  { padding:7px 16px; font-size:0.82rem; }
.btn-lg  { padding:13px 32px; font-size:1rem; }
.btn-xl  { padding:15px 40px; font-size:1.05rem; }
.btn-full{ width:100%; justify-content:center; }

/* ── CARDS ── */
.card {
  background: var(--white);
  border: 1px solid var(--n200);
  border-radius: var(--radius);
  padding: 28px;
  box-shadow: var(--shadow-xs);
  transition: var(--transition);
}
.card:hover { box-shadow: var(--shadow); }
.card-elevated { box-shadow: var(--shadow); }
.card-green {
  background: var(--g50);
  border-color: var(--g200);
}
.card-blue {
  background: var(--b50);
  border-color: var(--b100);
}

/* ── BADGES ── */
.badge {
  display:inline-flex; align-items:center; gap:4px;
  padding:3px 10px; border-radius:100px; font-size:0.73rem; font-weight:600;
}
.badge-green  { background:var(--g100); color:var(--g800); }
.badge-blue   { background:var(--b100); color:var(--b600); }
.badge-orange { background:#FEF3C7; color:#92400E; }
.badge-red    { background:#FEE2E2; color:#991B1B; }
.badge-gray   { background:var(--n100); color:var(--n600); }

/* ── TEXT UTILITIES ── */
.text-green    { color:var(--g600); }
.text-navy     { color:var(--b800); }
.text-muted    { color:var(--n500); }
.text-danger   { color:var(--danger); }
.text-success  { color:var(--success); }
.text-center   { text-align:center; }
.text-right    { text-align:right; }
.font-serif    { font-family:'Cormorant Garamond',Georgia,serif; }

/* ── SECTION LABELS ── */
.section-label {
  display:inline-block; font-size:0.72rem; font-weight:700;
  text-transform:uppercase; letter-spacing:3px; color:var(--g600);
  margin-bottom:10px;
}
.section-header { margin-bottom:52px; }
.section-header.center { text-align:center; }
.section-header p { color:var(--n500); margin-top:10px; font-size:1.05rem; max-width:560px; }
.section-header.center p { margin:10px auto 0; }

/* ── DIVIDERS ── */
.divider { border:none; border-top:1px solid var(--n200); margin:32px 0; }
.glow-line { height:1px; background:linear-gradient(90deg,transparent,var(--g400),transparent); opacity:0.35; }

/* ── TICKER ── */
.ticker-bar {
  background:var(--g900); padding:10px 0;
  overflow:hidden; position:sticky; top:66px; z-index:900;
}
.ticker-track { display:flex; gap:48px; animation:tickerMove 40s linear infinite; white-space:nowrap; }
.ticker-item { display:flex; align-items:center; gap:8px; font-size:0.78rem; font-family:'JetBrains Mono',monospace; }
.ticker-name  { color:rgba(255,255,255,0.5); }
.ticker-price { color:rgba(255,255,255,0.9); font-weight:500; }
.ticker-up    { color:#4ADE80; }
.ticker-down  { color:#F87171; }
@keyframes tickerMove{ 0%{transform:translateX(0)} 100%{transform:translateX(-50%)} }

/* ── HERO ── */
.hero {
  padding-top: 120px; padding-bottom: 90px;
  background: linear-gradient(160deg, var(--white) 55%, var(--g50) 100%);
  position:relative; overflow:hidden;
}
.hero::before {
  content:''; position:absolute; top:-120px; right:-120px;
  width:500px; height:500px; border-radius:50%;
  background:radial-gradient(circle, rgba(11,138,101,0.06), transparent 70%);
  pointer-events:none;
}
.hero-grid { display:grid; grid-template-columns:1.05fr 0.95fr; gap:64px; align-items:center; }
.hero-eyebrow { display:flex; align-items:center; gap:8px; margin-bottom:18px; }
.hero-eyebrow-dot { width:8px; height:8px; border-radius:50%; background:var(--g600); }
.hero-eyebrow-text { font-size:0.8rem; font-weight:600; color:var(--g700); letter-spacing:1.5px; text-transform:uppercase; }
.hero h1 { margin-bottom:16px; color:var(--b800); }
.hero h1 em { font-style:italic; color:var(--g600); }
.hero .lead { font-size:1.1rem; color:var(--n600); margin-bottom:36px; max-width:480px; line-height:1.7; }
.hero-cta { display:flex; gap:14px; flex-wrap:wrap; margin-bottom:44px; }
.hero-metrics { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; padding-top:32px; border-top:1px solid var(--n200); }
.metric-val { font-family:'Cormorant Garamond',serif; font-size:1.8rem; font-weight:700; color:var(--b800); line-height:1; }
.metric-label { font-size:0.78rem; color:var(--n500); margin-top:4px; }

/* Coin Visual */
.coin-wrap { position:relative; display:flex; align-items:center; justify-content:center; }
.coin-ring {
  width:280px; height:280px; border-radius:50%;
  border: 3px solid transparent;
  background: linear-gradient(white,white) padding-box,
              linear-gradient(135deg,var(--g600),var(--b500),var(--g400)) border-box;
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 20px 60px rgba(11,138,101,0.15);
  animation:rotateBorder 8s linear infinite;
}
@keyframes rotateBorder{ 0%{filter:hue-rotate(0deg)} 100%{filter:hue-rotate(360deg)} }
.coin-body {
  width:256px; height:256px; border-radius:50%;
  background:linear-gradient(145deg, var(--b800) 0%, var(--b700) 50%, var(--g900) 100%);
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:5px;
}
.coin-ticker { font-family:'JetBrains Mono',monospace; font-size:2.6rem; font-weight:500; color:var(--g400); }
.coin-name   { font-size:0.7rem; letter-spacing:3px; color:rgba(255,255,255,0.4); text-transform:uppercase; }
.coin-val    { font-size:1rem; color:rgba(255,255,255,0.85); margin-top:4px; font-family:'JetBrains Mono',monospace; }
.coin-tag    { font-size:0.65rem; color:var(--g400); letter-spacing:1px; }

.float-pill {
  position:absolute; background:white; border:1px solid var(--n200);
  border-radius:100px; padding:8px 14px; box-shadow:var(--shadow-sm);
  font-size:0.78rem; display:flex; align-items:center; gap:6px; white-space:nowrap;
}
.float-pill:nth-child(2){ top:30px; right:-30px; animation:floatY 3s ease-in-out infinite; }
.float-pill:nth-child(3){ bottom:50px; left:-20px; animation:floatY 3s ease-in-out infinite 1.5s; }
@keyframes floatY{ 0%,100%{transform:translateY(0)} 50%{transform:translateY(-8px)} }

@media(max-width:900px){ .hero-grid{grid-template-columns:1fr;} .coin-wrap{margin:0 auto;} }

/* ── TABLES ── */
.data-table { width:100%; border-collapse:collapse; }
.data-table th {
  text-align:left; padding:11px 16px;
  font-size:0.72rem; font-weight:600; letter-spacing:1px; text-transform:uppercase;
  color:var(--n500); border-bottom:1px solid var(--n200); background:var(--n50);
}
.data-table td { padding:13px 16px; border-bottom:1px solid var(--n100); font-size:0.9rem; }
.data-table tr:last-child td { border-bottom:none; }
.data-table tr:hover td { background:var(--n50); }
.data-table .coin-cell { display:flex; align-items:center; gap:10px; }
.coin-icon-circle {
  width:34px; height:34px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-size:1rem; font-weight:700; background:var(--n100); color:var(--n700);
  flex-shrink:0;
}

/* ── FORMS ── */
.form-group { margin-bottom:18px; }
.form-label { display:block; font-size:0.82rem; font-weight:600; color:var(--n700); margin-bottom:6px; }
.form-input,.form-select,.form-textarea {
  width:100%; padding:11px 14px; border-radius:var(--radius-sm);
  border:1.5px solid var(--n300); background:white; color:var(--n900);
  font-family:'Outfit',sans-serif; font-size:0.9rem;
  transition:var(--transition); outline:none;
}
.form-input:focus,.form-select:focus,.form-textarea:focus {
  border-color:var(--g600); box-shadow:0 0 0 3px rgba(11,138,101,0.12);
}
.form-input::placeholder { color:var(--n400); }
.form-hint { font-size:0.76rem; color:var(--n500); margin-top:5px; }
.form-error { font-size:0.76rem; color:var(--danger); margin-top:5px; display:none; }

/* ── MODAL ── */
.modal-overlay {
  position:fixed; inset:0; background:rgba(13,27,42,0.55);
  backdrop-filter:blur(5px); z-index:9000;
  display:none; align-items:center; justify-content:center; padding:20px;
}
.modal-overlay.open { display:flex; }
.modal {
  background:white; border-radius:var(--radius-lg); padding:36px;
  max-width:500px; width:100%; box-shadow:var(--shadow-md);
  animation:slideUp 0.25s ease;
}
@keyframes slideUp{ from{transform:translateY(20px);opacity:0} to{transform:translateY(0);opacity:1} }
.modal-title { font-family:'Cormorant Garamond',serif; font-size:1.6rem; margin-bottom:6px; }
.modal-close {
  position:absolute; top:16px; right:20px; background:none; border:none;
  font-size:1.4rem; cursor:pointer; color:var(--n500); line-height:1;
}

/* ── TOAST ── */
.toast-container { position:fixed; bottom:24px; right:24px; z-index:9999; display:flex; flex-direction:column; gap:10px; }
.toast {
  background:var(--b800); color:white; padding:12px 18px;
  border-radius:var(--radius-sm); font-size:0.85rem; box-shadow:var(--shadow-md);
  display:flex; align-items:center; gap:10px; max-width:340px;
  animation:toastIn 0.3s ease; border-left:3px solid var(--g500);
}
.toast.error { border-left-color:var(--danger); }
@keyframes toastIn{ from{transform:translateX(20px);opacity:0} to{transform:translateX(0);opacity:1} }

/* ── PACKAGES ── */
.pkg-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:18px; }
.pkg-card {
  background:white; border:1.5px solid var(--n200); border-radius:var(--radius);
  padding:24px 20px; text-align:center; transition:var(--transition); cursor:pointer; position:relative;
}
.pkg-card:hover { border-color:var(--g500); box-shadow:var(--shadow-green); transform:translateY(-3px); }
.pkg-card.selected { border-color:var(--g600); background:var(--g50); box-shadow:var(--shadow-green); }
.pkg-card.featured { border-color:var(--g600); }
.pkg-card.featured::before {
  content:'POPULAR'; position:absolute; top:0; right:0;
  background:var(--g600); color:white; font-size:0.6rem; font-weight:700;
  letter-spacing:1px; padding:3px 12px;
  border-radius:0 var(--radius) 0 var(--radius-sm);
}
.pkg-amount { font-family:'Cormorant Garamond',serif; font-size:2rem; font-weight:700; color:var(--b800); }
.pkg-rate   { font-size:1.1rem; font-weight:700; color:var(--g600); margin:8px 0; }
.pkg-sub    { font-size:0.8rem; color:var(--n500); margin-bottom:14px; }
.pkg-feature{ font-size:0.8rem; color:var(--n600); padding:4px 0; display:flex; align-items:center; gap:6px; text-align:left; }
.pkg-feature::before { content:'✓'; color:var(--g600); font-weight:700; flex-shrink:0; }

/* ── RANKS ── */
.rank-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(190px,1fr)); gap:14px; }
.rank-card {
  background:white; border:1px solid var(--n200); border-radius:var(--radius);
  padding:18px; transition:var(--transition);
}
.rank-card:hover { border-color:var(--g400); box-shadow:var(--shadow-sm); }
.rank-icon { width:44px; height:44px; border-radius:10px; display:flex; align-items:center; justify-content:center; font-size:1.3rem; margin-bottom:10px; }
.rank-name  { font-weight:700; font-size:0.95rem; color:var(--b800); }
.rank-req   { font-size:0.78rem; color:var(--n500); margin-top:3px; }
.rank-perks { margin-top:8px; display:flex; flex-direction:column; gap:3px; }
.rank-perk  { font-size:0.75rem; color:var(--g700); display:flex; align-items:center; gap:5px; }
.rank-perk::before { content:'›'; }

/* ── PROGRESS BAR ── */
.progress-track { height:6px; background:var(--n200); border-radius:3px; overflow:hidden; }
.progress-fill  { height:100%; border-radius:3px; background:linear-gradient(90deg,var(--g600),var(--b400)); transition:width 0.6s ease; }

/* ── WALLET CARD ── */
.wallet-hero {
  background:linear-gradient(135deg,var(--b800) 0%,var(--b700) 50%,var(--g900) 100%);
  border-radius:var(--radius-lg); padding:32px; color:white; position:relative; overflow:hidden;
}
.wallet-hero::before {
  content:''; position:absolute; top:-60px; right:-60px;
  width:220px; height:220px; border-radius:50%;
  background:radial-gradient(circle,rgba(11,138,101,0.2),transparent 70%);
}
.wallet-label  { font-size:0.78rem; opacity:0.6; text-transform:uppercase; letter-spacing:1.5px; margin-bottom:6px; }
.wallet-amount { font-family:'Cormorant Garamond',serif; font-size:2.8rem; font-weight:700; line-height:1; }
.wallet-sub    { font-size:0.85rem; opacity:0.6; margin-top:4px; font-family:'JetBrains Mono',monospace; }
.wallet-split  { display:grid; grid-template-columns:1fr 1fr; gap:16px; margin-top:24px; padding-top:20px; border-top:1px solid rgba(255,255,255,0.12); }
.wallet-split-item .lbl { font-size:0.72rem; opacity:0.5; margin-bottom:3px; }
.wallet-split-item .val { font-size:1.1rem; font-weight:600; }
.wallet-actions { display:flex; gap:10px; margin-top:20px; flex-wrap:wrap; }

/* ── STEP WIZARD ── */
.step-bar { display:flex; gap:8px; margin-bottom:28px; }
.step-seg { flex:1; height:3px; border-radius:2px; background:var(--n200); transition:var(--transition); }
.step-seg.active { background:var(--g600); }
.step-seg.done   { background:var(--g400); }
.step-pane { display:none; }
.step-pane.active { display:block; }

/* ── SIDEBAR (dashboard) ── */
.sidebar {
  position:fixed; left:0; top:0; bottom:0; width:252px;
  background:white; border-right:1px solid var(--n200);
  display:flex; flex-direction:column; z-index:500;
  box-shadow:var(--shadow-xs);
}
.sidebar-logo { padding:18px 20px 16px; border-bottom:1px solid var(--n200); }
.sidebar-logo img { height:34px; }
.sidebar-nav  { flex:1; overflow-y:auto; padding:12px 10px; }
.sidebar-section { font-size:0.65rem; font-weight:700; letter-spacing:2px; text-transform:uppercase; color:var(--n400); padding:14px 12px 6px; }
.sidebar-link {
  display:flex; align-items:center; gap:10px; padding:10px 12px;
  border-radius:var(--radius-sm); text-decoration:none; color:var(--n600);
  font-size:0.86rem; font-weight:500; margin-bottom:1px; transition:var(--transition);
}
.sidebar-link:hover  { background:var(--n50); color:var(--n900); }
.sidebar-link.active { background:var(--g50); color:var(--g700); font-weight:600; }
.sidebar-link.active .link-icon { color:var(--g600); }
.link-icon { font-size:1.05rem; width:20px; text-align:center; color:var(--n400); }
.link-badge { margin-left:auto; background:var(--g600); color:white; font-size:0.65rem; font-weight:700; padding:1px 6px; border-radius:100px; }
.sidebar-foot { padding:14px 20px; border-top:1px solid var(--n200); }
.user-pill { display:flex; align-items:center; gap:10px; }
.user-avatar { width:34px; height:34px; border-radius:50%; background:linear-gradient(135deg,var(--g600),var(--b500)); display:flex; align-items:center; justify-content:center; font-weight:700; font-size:0.82rem; color:white; flex-shrink:0; }
.user-name { font-size:0.86rem; font-weight:600; color:var(--n800); }
.user-rank { font-size:0.72rem; color:var(--g600); }

/* ── DASH LAYOUT ── */
.dash-shell { display:grid; grid-template-columns:252px 1fr; min-height:100vh; }
.dash-main  { margin-left:252px; padding:28px 32px; background:var(--n50); min-height:100vh; }
.dash-topbar { display:flex; justify-content:space-between; align-items:flex-start; margin-bottom:28px; }
.dash-title   { font-family:'Cormorant Garamond',serif; font-size:1.7rem; font-weight:700; color:var(--b800); }
.dash-sub     { font-size:0.85rem; color:var(--n500); margin-top:2px; }
.notif-btn {
  width:38px; height:38px; border-radius:var(--radius-sm);
  background:white; border:1px solid var(--n200);
  display:flex; align-items:center; justify-content:center;
  cursor:pointer; position:relative; transition:var(--transition);
}
.notif-btn:hover { border-color:var(--g500); }
.notif-dot { position:absolute; top:7px; right:7px; width:7px; height:7px; border-radius:50%; background:var(--g600); }

/* Stat cards row */
.stat-row { display:grid; grid-template-columns:repeat(4,1fr); gap:16px; margin-bottom:24px; }
@media(max-width:1100px){ .stat-row{grid-template-columns:repeat(2,1fr);} }
.stat-card { background:white; border:1px solid var(--n200); border-radius:var(--radius); padding:20px; box-shadow:var(--shadow-xs); }
.stat-top  { display:flex; justify-content:space-between; align-items:flex-start; margin-bottom:12px; }
.stat-lbl  { font-size:0.75rem; color:var(--n500); font-weight:600; text-transform:uppercase; letter-spacing:0.5px; }
.stat-ico  { width:36px; height:36px; border-radius:8px; display:flex; align-items:center; justify-content:center; font-size:1.1rem; }
.stat-val  { font-family:'Cormorant Garamond',serif; font-size:1.7rem; font-weight:700; color:var(--b800); line-height:1; }
.stat-chg  { font-size:0.78rem; color:var(--n500); margin-top:4px; }

/* Contract rows */
.contract-card { background:white; border:1px solid var(--n200); border-radius:var(--radius); padding:16px 20px; margin-bottom:10px; display:grid; grid-template-columns:1fr auto auto; gap:16px; align-items:center; }
.contract-card:hover { border-color:var(--g300); box-shadow:var(--shadow-xs); }

/* Ref level item */
.ref-level-row { display:flex; justify-content:space-between; align-items:center; padding:12px 0; border-bottom:1px solid var(--n100); }
.ref-level-row:last-child { border-bottom:none; }

/* ── EXCHANGE PAGE ── */
.live-indicator { display:inline-flex; align-items:center; gap:6px; font-size:0.78rem; color:var(--success); }
.live-dot { width:7px; height:7px; border-radius:50%; background:var(--success); animation:blink 1.8s ease-in-out infinite; }
@keyframes blink{ 0%,100%{opacity:1} 50%{opacity:0.25} }

/* ── FOOTER ── */
footer {
  background:var(--b800); color:rgba(255,255,255,0.85);
  padding:64px 0 28px;
}
.footer-grid { display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:40px; margin-bottom:48px; }
.footer-col h4 { font-size:0.75rem; font-weight:700; text-transform:uppercase; letter-spacing:1.8px; color:var(--g400); margin-bottom:14px; }
.footer-col a  { display:block; color:rgba(255,255,255,0.55); text-decoration:none; font-size:0.86rem; margin-bottom:9px; transition:var(--transition); }
.footer-col a:hover { color:rgba(255,255,255,0.9); }
.footer-desc   { font-size:0.86rem; color:rgba(255,255,255,0.45); line-height:1.7; margin:10px 0 18px; max-width:280px; }
.footer-bottom { border-top:1px solid rgba(255,255,255,0.08); padding-top:22px; display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:10px; }
.footer-bottom p { font-size:0.8rem; color:rgba(255,255,255,0.3); }
.social-links  { display:flex; gap:10px; }
.social-link   { width:34px; height:34px; border-radius:7px; border:1px solid rgba(255,255,255,0.1); display:flex; align-items:center; justify-content:center; color:rgba(255,255,255,0.45); font-size:0.85rem; text-decoration:none; transition:var(--transition); }
.social-link:hover { border-color:var(--g500); color:var(--g400); }
@media(max-width:768px){ .footer-grid{grid-template-columns:1fr 1fr;} }
@media(max-width:500px){ .footer-grid{grid-template-columns:1fr;} }

/* ── UTILITY ── */
.flex          { display:flex; }
.flex-center   { display:flex; align-items:center; justify-content:center; }
.flex-between  { display:flex; align-items:center; justify-content:space-between; }
.gap-8  { gap:8px; }
.gap-12 { gap:12px; }
.gap-16 { gap:16px; }
.gap-24 { gap:24px; }
.mt-8   { margin-top:8px; }
.mt-12  { margin-top:12px; }
.mt-16  { margin-top:16px; }
.mt-24  { margin-top:24px; }
.mt-32  { margin-top:32px; }
.mb-8   { margin-bottom:8px; }
.mb-16  { margin-bottom:16px; }
.mb-24  { margin-bottom:24px; }
.bold   { font-weight:700; }
.w-full { width:100%; }
.hidden { display:none !important; }
.relative { position:relative; }
.overflow-x-auto { overflow-x:auto; }

/* ── RESPONSIVE DASH ── */
@media(max-width:900px){
  .dash-shell { grid-template-columns:1fr; }
  .sidebar { display:none; }
  .dash-main { margin-left:0; padding:20px 16px; }
  .stat-row  { grid-template-columns:1fr 1fr; }
}

/* ── SCROLL REVEAL ── */
.reveal { opacity:0; transform:translateY(18px); transition:opacity 0.5s ease,transform 0.5s ease; }
.reveal.visible { opacity:1; transform:translateY(0); }

/* ── LOADING SPINNER ── */
.spinner { width:20px; height:20px; border:2px solid var(--n200); border-top-color:var(--g600); border-radius:50%; animation:spin 0.7s linear infinite; display:inline-block; }
@keyframes spin{ to{transform:rotate(360deg)} }

/* ── TABS ── */
.tab-bar { display:flex; background:var(--n100); border-radius:var(--radius-sm); padding:4px; }
.tab-btn { flex:1; padding:9px; text-align:center; border-radius:6px; cursor:pointer; font-size:0.85rem; font-weight:500; color:var(--n600); transition:var(--transition); border:none; background:transparent; }
.tab-btn.active { background:white; color:var(--n900); box-shadow:var(--shadow-xs); font-weight:600; }

/* ── PIN INPUT ── */
.pin-row { display:flex; gap:8px; justify-content:center; }
.pin-digit {
  width:46px; height:54px; text-align:center;
  font-family:'JetBrains Mono',monospace; font-size:1.4rem;
  border:1.5px solid var(--n300); border-radius:var(--radius-sm);
  background:white; color:var(--n900); outline:none; transition:var(--transition);
}
.pin-digit:focus { border-color:var(--g600); box-shadow:0 0 0 3px rgba(11,138,101,0.12); }

/* ── COMING SOON TAG ── */
.cs-tag { display:inline-block; font-size:0.62rem; font-weight:700; text-transform:uppercase; letter-spacing:1px; background:var(--b100); color:var(--b600); border-radius:100px; padding:2px 7px; vertical-align:middle; margin-left:5px; }
