
  :root {
    --bg: #f5f7fb;
    --surface: #ffffff;
    --border: #e8ecf4;
    --accent: #1e5ef3;
    --accent-light: rgba(30,94,243,0.07);
    --green: #0fa472;
    --green-light: rgba(15,164,114,0.08);
    --text: #0c1322;
    --text2: #5a6478;
    --muted: #9aa0b0;
    --shadow: 0 1px 3px rgba(12,19,34,0.05), 0 4px 20px rgba(12,19,34,0.05);
    --shadow-md: 0 4px 24px rgba(12,19,34,0.09);
    --purple: #475569;
  }
  * { margin:0; padding:0; box-sizing:border-box; }
  html { height: 100%; overflow-x: hidden; }
  body {
    background: var(--bg);
    color: var(--text);
    font-family: 'Inter', sans-serif;
    font-size: 13px;
    height: 100%;
    display: flex;
    flex-direction: column;
    -webkit-font-smoothing: antialiased;
  }
  /* Scrollable content wrapper — no overflow on body so position:fixed works on all iOS */
  #app-scroll {
    flex: 1;
    overflow-y: auto;
    overflow-x: hidden;
    -webkit-overflow-scrolling: touch;
    overflow-anchor: none; /* prevent scroll anchoring when async content loads above the viewport */
  }

  /* NAV — lives outside #app-scroll so it is always visible */
  nav {
    position: relative; z-index: 100; flex-shrink: 0;
    background: rgba(255,255,255,0.98);
    border-bottom: 1px solid var(--border);
  }
  .nav-inner {
    max-width: 1100px; margin: 0 auto;
    padding: 0 36px;
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    align-items: center;
    height: 72px;
  }
  .nav-right {
    display: flex; align-items: center; justify-content: flex-end; gap: 8px;
  }
  .logo { display: flex; align-items: center; gap: 0; cursor: pointer; }
  .logo-name {
    font-family: 'Cabinet Grotesk', sans-serif; font-weight: 800;
    font-size: 16px; letter-spacing: 0.16em;
    text-transform: uppercase; color: var(--text);
  }
  .logo-tag { font-size: 9px; color: var(--muted); letter-spacing: 0.12em; text-transform: uppercase; margin-top: 2px; }

  .nav-links { display: flex; align-items: center; gap: 4px; }
  .nav-link {
    padding: 7px 14px; border-radius: 8px;
    font-size: 12px; font-weight: 500; color: var(--text2);
    cursor: pointer; border: none; background: none;
    font-family: 'Inter', sans-serif;
    transition: all 0.16s;
  }
  .nav-link:hover { background: var(--bg); color: var(--text); }
  .nav-link.active { background: var(--accent-light); color: var(--accent); font-weight: 600; }

  /* Dropdown */
  .nav-dropdown { position: relative; }
  .nav-dropdown-trigger { display: flex; align-items: center; }
  .nav-dropdown-menu {
    display: none; position: absolute; top: calc(100% + 8px); left: 0;
    background: var(--surface); border: 1px solid var(--border);
    border-radius: 14px; padding: 6px; min-width: 200px;
    box-shadow: var(--shadow-md); z-index: 200;
  }
  .nav-dropdown-menu.open { display: flex; flex-direction: column; gap: 2px; }
  .nav-dropdown-item {
    display: flex; align-items: center; gap: 10px;
    padding: 9px 10px; border-radius: 9px; border: none;
    background: none; cursor: pointer; text-align: left; width: 100%;
    transition: background 0.15s;
  }
  .nav-dropdown-item:hover { background: var(--bg); }
  .nav-dropdown-item svg { flex-shrink: 0; color: var(--accent); }

  /* WALLET MODAL */
  .wallet-overlay {
    display: none; position: fixed; inset: 0; z-index: 999;
    background: rgba(12,19,34,0.55); backdrop-filter: blur(4px);
    align-items: center; justify-content: center;
  }
  .wallet-overlay.open { display: flex; }
  .wallet-modal {
    background: var(--surface); border-radius: 20px;
    border: 1px solid var(--border);
    box-shadow: 0 24px 60px rgba(12,19,34,0.18);
    width: 420px; max-width: calc(100vw - 32px);
    padding: 28px;
    animation: modalIn 0.2s ease;
  }
  @keyframes modalIn {
    from { opacity:0; transform: translateY(12px) scale(0.97); }
    to   { opacity:1; transform: translateY(0) scale(1); }
  }
  .wallet-modal-header {
    display: flex; align-items: center; justify-content: space-between;
    margin-bottom: 6px;
  }
  .wallet-modal-title {
    font-family: 'Cabinet Grotesk', sans-serif; font-weight: 700;
    font-size: 16px; color: var(--text);
  }
  .wallet-modal-close {
    width: 28px; height: 28px; border-radius: 8px;
    border: 1px solid var(--border); background: transparent;
    cursor: pointer; font-size: 15px; color: var(--text2);
    display: flex; align-items: center; justify-content: center;
    transition: background 0.15s;
  }
  .wallet-modal-close:hover { background: var(--bg); }
  .wallet-modal-sub {
    font-size: 12px; color: var(--text2); margin-bottom: 20px;
  }
  .wallet-list { display: flex; flex-direction: column; gap: 8px; }
  .wallet-item {
    display: flex; align-items: center; gap: 12px;
    padding: 11px 14px; border-radius: 12px;
    border: 1px solid var(--border);
    cursor: pointer; transition: all 0.15s;
    background: var(--surface);
  }
  .wallet-item:hover { border-color: var(--accent); background: var(--accent-light); }
  .wallet-item.disabled { opacity: 0.45; cursor: not-allowed; }
  .wallet-item.disabled:hover { border-color: var(--border); background: var(--surface); }
  .wallet-icon {
    width: 36px; height: 36px; border-radius: 10px;
    background: var(--bg); border: 1px solid var(--border);
    display: flex; align-items: center; justify-content: center;
    overflow: hidden; flex-shrink: 0;
  }
  .wallet-icon img { width: 24px; height: 24px; object-fit: contain; }
  .wallet-info { flex: 1; }
  .wallet-name { font-size: 13px; font-weight: 600; color: var(--text); line-height: 1; }
  .compat-pills { display: flex; gap: 4px; flex-shrink: 0; }
  .compat-pill {
    font-size: 10px; font-weight: 600; padding: 2px 8px;
    border-radius: 20px; border: 1px solid transparent;
  }
  .compat-pill.mobile  { background: rgba(15,164,114,0.08); color: #0a7a5a; border-color: rgba(15,164,114,0.2); }
  .compat-pill.desktop { background: rgba(30,94,243,0.07); color: var(--accent); border-color: rgba(30,94,243,0.15); }
  .wallet-divider {
    font-size: 10px; font-weight: 600; color: var(--muted);
    text-transform: uppercase; letter-spacing: 0.08em;
    margin: 12px 0 4px; padding: 0 2px;
  }
  .wallet-modal-footer {
    margin-top: 18px; padding-top: 14px;
    border-top: 1px solid var(--border);
    font-size: 11px; color: var(--text2); line-height: 1.6; text-align: center;
  }

  .btn-connect {
    background: var(--accent); color: #fff; border: none;
    padding: 9px 20px; border-radius: 9px;
    font-family: 'Inter', sans-serif; font-size: 12px; font-weight: 600;
    letter-spacing: 0.04em; cursor: pointer;
    box-shadow: 0 2px 10px rgba(30,94,243,0.22);
    transition: all 0.18s;
  }
  .btn-connect:hover { background: #1750d6; box-shadow: 0 4px 18px rgba(30,94,243,0.3); }

  /* PAGES */
  .page { display: none; }
  .page.active { display: block; }

  .page .global-disclaimer {
    padding: 0 0 24px 0;
    text-align: center;
    display: none;
  }
  .page.active .global-disclaimer {
    display: block;
  }
  .global-disclaimer-inner {
    max-width: 1100px;
    margin: 0 auto;
    padding: 32px 28px 0;
    border-top: 1px solid var(--border);
  }
  .global-disclaimer p {
    font-size: 10px;
    color: var(--muted);
    line-height: 1.7;
    margin: 0;
  }

  .container { max-width: 1100px; margin: 0 auto; padding: 0 28px 48px; }

  @keyframes up {
    from { transform: translateY(14px); }
    to   { transform: translateY(0); }
  }
  /* Animations only on desktop — mobile always starts visible */
  @media (min-width: 761px) {
    .anim   { animation: up 0.35s ease both; }
    .anim-1 { animation: up 0.35s ease 0.05s both; }
    .anim-2 { animation: up 0.35s ease 0.10s both; }
    .anim-3 { animation: up 0.35s ease 0.15s both; }
    .anim-4 { animation: up 0.35s ease 0.20s both; }
  }
  #page-mission * { opacity: 1 !important; transform: none !important; animation: none !important; }

  /* ===================== HOME ===================== */
  .hero {
    text-align: center;
    padding: 52px 0 64px;
  }
  .hero-pill {
    display: inline-flex; align-items: center; gap: 7px;
    background: var(--green-light); border: 1px solid rgba(15,164,114,0.2);
    color: #0a7a5a; padding: 6px 14px; border-radius: 100px;
    font-size: 11px; font-weight: 500; letter-spacing: 0.06em;
    margin-bottom: 24px;
  }
  .dot { width:6px; height:6px; border-radius:50%; background:var(--green); animation: blink 2s infinite; }
  @keyframes blink { 0%,100%{opacity:1} 50%{opacity:0.3} }

  .hero h1 {
    font-family: 'Cabinet Grotesk', sans-serif; font-weight: 800;
    font-size: 80px; letter-spacing: -0.025em;
    line-height: 1.1; margin-bottom: 20px; color: var(--text);
  }
  .hero h1 span { color: var(--accent); }
  .hero p {
    font-size: 16px; color: var(--text2); line-height: 1.7;
    max-width: 620px; margin: 0 auto 36px; text-align: center;
  }
  .hero-btns { display: flex; justify-content: center; gap: 12px; }
  .btn-primary {
    background: var(--accent); color: #fff; border: none;
    padding: 14px 28px; border-radius: 11px;
    font-family: 'Inter', sans-serif; font-size: 13px; font-weight: 600;
    cursor: pointer; box-shadow: 0 3px 14px rgba(30,94,243,0.28);
    transition: all 0.18s;
  }
  .btn-primary:hover { background:#1750d6; transform:translateY(-1px); box-shadow: 0 6px 22px rgba(30,94,243,0.32); }
  .btn-primary.btn-dimmed { background: var(--surface); color: var(--text); border: 1px solid var(--border); box-shadow: none; transform: none; transition: all 0.18s; }
  .btn-secondary.btn-how-active { background: #1750d6; color: #fff; border-color: #1750d6; transform:translateY(-1px); box-shadow: 0 6px 22px rgba(30,94,243,0.32); }
  .btn-secondary {
    background: var(--surface); color: var(--text);
    border: 1px solid var(--border); padding: 14px 28px;
    border-radius: 11px; font-family: 'Inter', sans-serif;
    font-size: 13px; font-weight: 600; cursor: pointer;
    transition: all 0.18s;
  }
  .btn-secondary:hover { background: #1750d6; color: #fff; border-color: #1750d6; transform:translateY(-1px); box-shadow: 0 6px 22px rgba(30,94,243,0.32); }

  /* Hero stats */
  .hero-stats {
    display: grid; grid-template-columns: repeat(3,1fr);
    gap: 14px; margin-top: 56px;
  }
  .hs {
    background: var(--surface); border: 1px solid var(--border);
    border-radius: 16px; padding: 24px;
    box-shadow: var(--shadow); text-align: center;
    transition: box-shadow 0.2s, transform 0.2s;
  }
  .hs:hover { transform:translateY(-2px); box-shadow: var(--shadow-md); }
  .hs-val { font-family:'Inter',sans-serif; font-weight:700; font-size:30px; color:var(--text); margin-bottom:6px; }
  .hs-val.green { color: var(--green); }
  .hs-label { font-size:11px; color:var(--muted); font-weight:500; letter-spacing:0.08em; text-transform:uppercase; }

  /* How it works strip */
  .how-strip {
    background: var(--surface); border: 1px solid var(--border);
    border-radius: 20px; padding: 44px 48px;
    box-shadow: var(--shadow); margin-top: 16px;
  }
  .how-strip h2 {
    font-family:'Cabinet Grotesk',sans-serif; font-weight:700; font-size:22px;
    color:var(--text); margin-bottom:8px;
  }
  .how-strip .sub { font-size:13px; color:var(--text2); margin-bottom:40px; }

  .steps { display:grid; grid-template-columns:repeat(3,1fr); gap:32px; }
  .step { display:flex; flex-direction:column; gap:14px; }
  .step-num {
    width:36px; height:36px; border-radius:10px;
    background:var(--accent-light); border:1px solid rgba(30,94,243,0.15);
    display:flex; align-items:center; justify-content:center;
    font-family:'Cabinet Grotesk',sans-serif; font-weight:700; font-size:14px; color:var(--accent);
  }
  .step h3 { font-size:14px; font-weight:600; color:var(--text); }
  .step p { font-size:12px; color:var(--text2); line-height:1.65; }

  /* ===================== STAKE ===================== */
  .stake-page { padding-top: 48px; }
  .scanner-page { padding-top: 48px; }

  .rate-bar {
    background: var(--surface); border: 1px solid var(--border);
    border-radius: 16px; padding: 20px 28px;
    display: flex; align-items: center; justify-content: space-between;
    box-shadow: var(--shadow); margin-bottom: 20px;
  }
  .rb-item { text-align: center; }
  .rb-item:first-child { text-align: left; }
  .rb-item:last-child { text-align: right; }
  .rb-label { font-size:10px; color:var(--muted); font-weight:500; letter-spacing:0.1em; text-transform:uppercase; margin-bottom:5px; }
  .rb-val { font-family:'Inter',sans-serif; font-weight:700; font-size:20px; color:var(--text); }
  .rb-val.green { color: var(--green); font-size:26px; }
  .rb-val span { font-size:12px; color:var(--muted); font-family:'Inter',sans-serif; font-weight:400; margin-left:3px; }
  .rb-div { width:1px; height:40px; background:var(--border); }

  .stake-grid { display:grid; grid-template-columns:1fr 340px; gap:20px; }

  .card {
    background:var(--surface); border:1px solid var(--border);
    border-radius:20px; padding:28px; box-shadow:var(--shadow);
  }
  .card h2 { font-family:'Cabinet Grotesk',sans-serif; font-weight:700; font-size:16px; color:var(--text); margin-bottom:4px; }
  .card .sub { font-size:11px; color:var(--muted); margin-bottom:22px; }
  .card-div { height:1px; background:var(--border); margin-bottom:22px; }

  .input-box {
    background:var(--bg); border:1.5px solid var(--border);
    border-radius:13px; padding:18px 18px 16px;
    margin-bottom:12px; transition:border-color 0.18s;
  }
  .input-box:focus-within { border-color:rgba(30,94,243,0.35); }
  .input-meta {
    display:flex; justify-content:space-between;
    font-size:10px; color:var(--muted);
    margin-bottom:10px; letter-spacing:0.06em; text-transform:uppercase;
  }
  .input-row { display:flex; align-items:center; gap:10px; }
  .token-tag {
    display:flex; align-items:center; gap:7px;
    background:var(--accent-light); border:1px solid rgba(30,94,243,0.14);
    padding:7px 13px; border-radius:9px;
    font-size:12px; font-weight:600; color:var(--accent); white-space:nowrap;
  }
  .tdot { width:14px; height:14px; border-radius:50%; background:linear-gradient(135deg,var(--accent),var(--green)); }
  .num-input {
    background:none; border:none; outline:none;
    font-family:'Inter',sans-serif; font-size:28px; font-weight:700;
    color:var(--text); width:100%; text-align:right;
  }
  .max-btn {
    background:none; border:1px solid var(--border);
    color:var(--accent); padding:3px 9px; border-radius:6px;
    font-size:10px; font-weight:600; cursor:pointer;
    font-family:'Inter',sans-serif; transition:background 0.15s;
  }
  .max-btn:hover { background:var(--accent-light); }

  .proj {
    background:linear-gradient(135deg,rgba(30,94,243,0.04),rgba(15,164,114,0.04));
    border:1px solid var(--border); border-radius:13px;
    padding:20px 22px; margin-bottom:18px;
    display:grid; grid-template-columns:1fr 1px 1fr; gap:0; align-items:center;
  }
  .proj-item { padding:0 18px; text-align:center; }
  .proj-item:first-child { padding-left:2px; text-align:left; }
  .proj-item:last-child { padding-right:2px; text-align:right; }
  .proj-div { width:1px; height:36px; background:var(--border); }
  .proj-label { font-size:10px; color:var(--muted); font-weight:500; letter-spacing:0.09em; text-transform:uppercase; margin-bottom:5px; }
  .proj-val { font-family:'Inter',sans-serif; font-weight:700; font-size:20px; color:var(--text); }
  .proj-val.green { color:var(--green); }
  .proj-sub { font-size:10px; color:var(--muted); margin-top:2px; }

  .btn-stake {
    width:100%; background:var(--accent); color:#fff; border:none;
    padding:15px; border-radius:12px;
    font-family:'Inter',sans-serif; font-weight:600; font-size:13px;
    letter-spacing:0.04em; cursor:pointer;
    box-shadow:0 3px 14px rgba(30,94,243,0.25); transition:all 0.18s;
  }
  .btn-stake:hover { background:#1750d6; transform:translateY(-1px); box-shadow:0 6px 22px rgba(30,94,243,0.32); }
  .stake-note { text-align:center; font-size:11px; color:var(--muted); margin-top:10px; line-height:1.6; }

  /* My position card */
  .pos-card { display:flex; flex-direction:column; gap:0; }
  .pos-row {
    display:flex; justify-content:space-between; align-items:center;
    padding:14px 0; border-bottom:1px solid var(--border);
  }
  .pos-row:last-of-type { border-bottom:none; }
  .pos-label { font-size:11px; color:var(--muted); font-weight:500; }
  .pos-val { font-size:13px; font-weight:600; color:var(--text); }
  .pos-val.green { color:var(--green); }
  .pos-val.blue { color:var(--accent); }

  .payout-strip {
    margin-top:16px; padding:14px 16px;
    background:var(--green-light); border:1px solid rgba(15,164,114,0.18);
    border-radius:11px; display:flex; justify-content:space-between; align-items:center;
  }
  .ps-label { font-size:11px; color:#0a7a5a; font-weight:500; }
  .ps-val { font-family:'Inter',sans-serif; font-weight:700; font-size:18px; color:var(--green); }

  /* ===================== POOLS ===================== */
  .pools-page { padding-top: 48px; }
  .page-header { margin-bottom: 32px; }
  .page-header h1 { font-family:'Cabinet Grotesk',sans-serif; font-weight:800; font-size:28px; color:var(--text); margin-bottom:8px; }
  .page-header p { font-size:13px; color:var(--text2); line-height:1.6; max-width:520px; }

  .pools-summary {
    display:grid; grid-template-columns:repeat(3,1fr);
    gap:14px; margin-bottom:28px;
  }
  .ps-card {
    background:var(--surface); border:1px solid var(--border);
    border-radius:15px; padding:20px 22px; box-shadow:var(--shadow);
  }
  .psc-label { font-size:10px; color:var(--muted); font-weight:500; letter-spacing:0.1em; text-transform:uppercase; margin-bottom:8px; }
  .psc-val { font-family:'Inter',sans-serif; font-weight:700; font-size:22px; color:var(--text); }
  .psc-val.green { color:var(--green); }

  .pools-table {
    background:var(--surface); border:1px solid var(--border);
    border-radius:18px; box-shadow:var(--shadow); overflow:hidden;
  }

  /* -- Stake / Pools / Scanner sub-navigation tabs -- */
  .stake-tabs {
    display: flex; gap: 3px;
    background: var(--surface); border: 1px solid var(--border);
    border-radius: 12px; padding: 4px; margin-bottom: 28px;
    box-shadow: var(--shadow);
  }
  .stake-tab {
    flex: 1; display: flex; align-items: center; justify-content: center; gap: 6px;
    padding: 9px 12px; border: none; background: none; border-radius: 9px;
    font-family: 'Inter', sans-serif; font-size: 12px; font-weight: 500;
    color: var(--muted); cursor: pointer; transition: all 0.15s; white-space: nowrap;
  }
  .stake-tab:hover { color: var(--text2); background: var(--bg); }
  .stake-tab.active { background: var(--accent); color: #fff; font-weight: 600; }
  @media(max-width:480px) {
    .stake-tab { font-size: 11px; padding: 8px 6px; gap: 3px; }
    .stake-tab svg { display: none; }
  }
  .pools-empty {
    padding:52px 24px; text-align:center;
  }
  .pools-empty-icon {
    font-size:32px; color:var(--border); margin-bottom:12px;
  }
  .pools-empty-title {
    font-size:15px; font-weight:600; color:var(--text); margin-bottom:6px;
  }
  .pools-empty-sub {
    font-size:13px; color:var(--muted); max-width:340px; margin:0 auto; line-height:1.6;
  }
  .pt-head {
    display:grid; grid-template-columns:2fr 1fr 1fr 1fr 1fr 100px;
    padding:14px 24px; border-bottom:1px solid var(--border);
    background:var(--bg);
  }
  .pt-head span { font-size:10px; font-weight:500; color:var(--muted); letter-spacing:0.1em; text-transform:uppercase; }

  .pool-row {
    display:grid; grid-template-columns:2fr 1fr 1fr 1fr 1fr 100px;
    padding:9px 20px; border-bottom:1px solid var(--border);
    align-items:center; transition:background 0.15s;
  }
  .pool-row:last-child { border-bottom:none; }
  .pool-row:hover { background:var(--bg); }

  .pool-group-label {
    padding:10px 20px 4px; font-size:10px; font-weight:600;
    letter-spacing:0.08em; text-transform:uppercase; color:var(--muted);
    border-bottom:1px solid var(--border); background:var(--bg);
  }
  .pool-group-label:not(:first-child) { border-top:1px solid var(--border); margin-top:2px; }

  .pool-name-wrap { display:flex; align-items:center; gap:10px; }
  .pool-icon {
    width:28px; height:28px; border-radius:8px;
    display:flex; align-items:center; justify-content:center;
    font-size:13px; flex-shrink:0;
  }
  .pi-blue { background:var(--accent-light); }
  .pi-green { background:var(--green-light); }
  .pi-purple { background:rgba(124,58,237,0.08); }

  .pool-name { font-size:13px; font-weight:600; color:var(--text); margin-bottom:2px; }
  .pool-proto { font-size:10px; color:var(--muted); }

  .pool-cell { font-size:12px; color:var(--text); font-weight:500; }
  .pool-cell.green { color:var(--green); font-weight:600; }
  .pool-cell.muted { color:var(--muted); }

  .risk-badge {
    display:inline-flex; padding:3px 10px; border-radius:6px;
    font-size:10px; font-weight:600; letter-spacing:0.04em;
  }
  .risk-low { background:var(--green-light); color:#0a7a5a; }
  .risk-med { background:rgba(245,158,11,0.09); color:#b45309; }

  .alloc-bar-wrap { display:flex; align-items:center; gap:8px; }
  .alloc-bar-bg { flex:1; height:4px; background:var(--border); border-radius:2px; }
  .alloc-bar { height:4px; border-radius:2px; background:var(--accent); }
  .alloc-num { font-size:10px; color:var(--muted); white-space:nowrap; min-width:28px; text-align:right; }

  /* ===================== HOW ===================== */
  .how-page { padding-top: 48px; }

  .how-hero { text-align:left; padding-bottom:56px; }
  .how-hero h1 { font-family:'Cabinet Grotesk',sans-serif; font-weight:800; font-size:28px; color:var(--text); margin-bottom:8px; letter-spacing:-0.02em; }
  .how-hero p { font-size:13px; color:var(--text2); line-height:1.6; max-width:520px; margin:0; }

  .how-steps {
    display:flex; flex-direction:column; gap:14px;
    margin-bottom:14px;
  }
  .how-step {
    background:var(--surface); border:1px solid var(--border);
    border-radius:16px; padding:14px 32px;
    display:flex; align-items:flex-start; gap:24px;
    box-shadow:var(--shadow); transition:box-shadow 0.2s;
  }
  .how-step:hover { box-shadow:var(--shadow-md); }
  .hs-num {
    width:40px; height:40px; border-radius:11px; flex-shrink:0;
    background:var(--accent-light); border:1px solid rgba(30,94,243,0.15);
    display:flex; align-items:center; justify-content:center;
    font-family:'Cabinet Grotesk',sans-serif; font-weight:800; font-size:15px; color:var(--accent);
  }
  .hs-content h3 { font-size:15px; font-weight:600; color:var(--text); margin-bottom:7px; }
  .hs-content p { font-size:13px; color:var(--text2); line-height:1.65; }

  .faq { background:var(--surface); border:1px solid var(--border); border-radius:18px; padding:32px; box-shadow:var(--shadow); }
  .faq h2 { font-family:'Cabinet Grotesk',sans-serif; font-weight:700; font-size:18px; color:var(--text); margin-bottom:24px; }
  .faq-item { padding:16px 0; border-bottom:1px solid var(--border); }
  .faq-item:last-child { border-bottom:none; padding-bottom:0; }
  .faq-q { font-size:13px; font-weight:600; color:var(--text); margin-bottom:7px; }
  .faq-a { font-size:12px; color:var(--text2); line-height:1.65; }

  /* =====================================================================
     RESPONSIVE / MOBILE  — comprehensive breakpoints
     760px  = tablet landscape / small desktop
     600px  = tablet portrait
     480px  = large phone
     380px  = small phone
     ===================================================================== */

  @media(max-width:760px) {
    /* ── Nav ── */
    .nav-inner { padding: 0 20px; height: 60px; grid-template-columns: 1fr auto 1fr; }
    .nav-links { display: flex; justify-content: center; align-items: center; }
    .nav-links > .nav-link, .nav-links > .nav-dropdown { display: none; }
    .nav-hamburger { display: flex; }
    .nav-right .btn-connect { font-size:11px; padding:7px 14px; }
    /* Remove backdrop-filter on mobile: iOS Safari white-screen repaint bug with sticky+backdrop-filter */
    nav { backdrop-filter: none; -webkit-backdrop-filter: none; background: rgba(255,255,255,0.98); }
    .mobile-nav { backdrop-filter: none; -webkit-backdrop-filter: none; background: rgba(255,255,255,0.98); }
    .nav-mobile-menu { backdrop-filter: none; -webkit-backdrop-filter: none; background: rgba(255,255,255,0.98); }

    /* ── Container ── */
    .container { padding: 0 16px 40px; }

    /* ── Hero ── */
    .hero { padding-top: 40px; padding-bottom: 0; }
    .hero h1 { font-size: 56px; line-height: 1.12; }
    .hero p { font-size: 14px; margin: 0 0 28px; }
    .hero-btns { flex-direction: column; align-items: stretch; gap: 10px; }
    .btn-primary, .btn-secondary { width: 100%; text-align: center; padding: 14px 20px; }
    .hero-stats { grid-template-columns: 1fr 1fr; gap: 10px; margin-top: 32px; }
    .hs { padding: 18px 14px; }
    .hs-val { font-size: 24px; }

    /* ── How-it-works strip (homepage) ── */
    .how-strip { padding: 28px 20px; }
    .steps { grid-template-columns: 1fr; gap: 24px; }

    /* ── Pools summary ── */
    .pools-summary { grid-template-columns: 1fr 1fr; gap: 10px; }

    /* ── Pools table: hide last 3 cols on tablet ── */
    .pt-head, .pool-row { grid-template-columns: 2fr 1fr 1fr; }
    .pt-head span:nth-child(n+4), .pool-row > *:nth-child(n+4) { display: none; }

    /* ── Stake grid ── */
    .stake-grid { grid-template-columns: 1fr; }
    .stake-page { padding-top: 32px; }

    /* ── Rate bar ── */
    .rate-bar { flex-wrap: wrap; gap: 16px; padding: 16px 20px; justify-content: flex-start; }
    .rb-div { display: none; }
    .rb-item { text-align: left; flex: 1 1 calc(50% - 8px); min-width: 100px; }
    .rb-item:first-child, .rb-item:last-child { text-align: left; }

    /* ── Lock tiles ── */
    .lock-grid { grid-template-columns: repeat(2, 1fr); gap: 10px; }

    /* ── Multisig widget ── */
    .msw-grid { grid-template-columns: 1fr; }
    .msw-header { flex-direction: column; align-items: flex-start; gap: 10px; }

    /* ── Page header ── */
    .page-header h1 { font-size: 22px; }

    /* ── How-it-works page ── */
    .how-hero h1 { font-size: 22px; }
    .how-step { gap: 14px; padding: 20px; }
    .hs-num { width: 28px; height: 28px; font-size: 12px; flex-shrink: 0; }

    /* ── Distribution tables ── */
    #page-distribution .thr-grid { grid-template-columns: 1fr; }
    #page-distribution .thr-col { border-right: none; border-bottom: 1px solid var(--border); }
    #page-distribution .thr-col:last-child { border-bottom: none; }
    #page-distribution .s-thead { display: none; }

    /* ── FAQ ── */
    .faq { padding: 20px 16px; }
  }

  @media(max-width:600px) {
    /* ── Hero ── */
    .hero h1 { font-size: 46px; }
    .hero-stats { grid-template-columns: 1fr; }

    /* ── Pools table: show only name + APSY on phone ── */
    .pt-head, .pool-row { grid-template-columns: 2fr 1fr; }
    .pt-head span:nth-child(n+3), .pool-row > *:nth-child(n+3) { display: none; }
    .pt-head span:nth-child(3), .pool-row > *:nth-child(3) { display: block; }

    /* ── Stake lock tiles: 2 columns ── */
    .lock-grid { grid-template-columns: repeat(2, 1fr); }

    /* ── Rate bar: all items full width ── */
    .rb-item { flex: 1 1 100%; }

    /* ── How-it-works: two-col grids stack ── */
    .how-step > .hs-content > div[style*="grid-template-columns:1fr 1fr"] {
      grid-template-columns: 1fr !important;
    }

    /* ── Multisig signatories ── */
    .msw-header .msw-badge { align-self: flex-start; }

    /* ── How it works rollback table ── */
    .how-step div[style*="grid-template-columns:1.2fr"] {
      grid-template-columns: 1fr 1fr !important;
    }
    .how-step div[style*="grid-template-columns:1.2fr"] > *:nth-child(4) { display: none; }
  }

  @media(max-width:480px) {
    /* ── Nav ── */
    .nav-inner { padding: 0 14px; }
    .logo-tag { display: none; }

    /* ── Hero ── */
    .hero h1 { font-size: 38px; }
    .hero p { font-size: 13px; }
    .hero-pill { font-size: 10px; padding: 5px 12px; }

    /* ── Container ── */
    .container { padding: 0 12px 32px; }

    /* ── Stake ── */
    .card { padding: 18px 14px; }
    .num-input { font-size: 22px; }
    .lock-grid { grid-template-columns: 1fr 1fr; gap: 8px; }
    .lock-tile { padding: 12px 8px; }

    /* ── How-it-works income table ── */
    .how-step div[style*="grid-template-columns:1fr 80px 80px 80px"] {
      grid-template-columns: 1fr 60px 60px !important;
    }
    .how-step div[style*="grid-template-columns:1fr 80px 80px 80px"] > *:nth-child(4),
    .how-step div[style*="grid-template-columns:1fr 80px 80px 80px"] > *:nth-child(5) { display: none !important; }

    /* ── FAQ ── */
    .faq { padding: 16px 12px; }
    .faq-q { font-size: 12px; }

    /* ── Pools table ── */
    .pt-head, .pool-row { grid-template-columns: 1fr 1fr; }
    .pools-summary { grid-template-columns: 1fr; }

    /* ── Page header ── */
    .page-header h1 { font-size: 20px; }
    .page-header p { font-size: 12px; }
  }

  @media(max-width:380px) {
    .hero h1 { font-size: 32px; }
    .lock-grid { grid-template-columns: 1fr; }
    .btn-primary, .btn-secondary { padding: 13px 16px; font-size: 12px; }
  }

  /* ── Mobile bottom navigation bar ──────────────────────────────────── */
  /* Shows key nav items at the bottom on mobile, replaces hidden top nav */
  .mobile-nav {
    display: none;
    /* No position:fixed — it is a flex child of body, always at the bottom */
    width: 100%;
    flex-shrink: 0;
    z-index: 200;
    background: rgba(255,255,255,0.98);
    border-top: 1px solid var(--border);
    padding: 6px 0 max(6px, env(safe-area-inset-bottom));
    justify-content: space-around;
    align-items: center;
  }
  .mobile-nav-item {
    display: flex; flex-direction: column; align-items: center; gap: 3px;
    padding: 5px 10px; border-radius: 10px;
    border: none; background: none; cursor: pointer;
    font-family: 'Inter', sans-serif; font-size: 11px; font-weight: 500;
    color: var(--muted); transition: color 0.15s;
    min-width: 52px;
  }
  .mobile-nav-item svg { flex-shrink: 0; }
  .mobile-nav-item.active { color: var(--accent); }
  .mobile-nav-item:active { background: var(--bg); }

  @media(max-width:760px) {
    .mobile-nav { display: flex; }
    /* No padding-bottom needed — mobile nav is a flex child of body, not overlaid */
    /* Hide the connect wallet button text on small screens, keep icon */
    .btn-connect span.btn-connect-label { display: none; }
  }

  /* ===== MOBILE HAMBURGER + DROPDOWN ===== */
  .nav-hamburger {
    display: none;
    background: none; border: none; cursor: pointer;
    padding: 6px 10px; border-radius: 8px;
    color: var(--text); align-items: center; justify-content: center;
    gap: 5px; font-size: 13px; font-weight: 600;
    font-family: 'Inter', sans-serif;
  }
  .nav-hamburger:active { background: var(--bg); }
  .nav-mobile-menu {
    display: none;
    position: absolute; top: 100%; left: 0; right: 0;
    background: rgba(255,255,255,0.98);
    backdrop-filter: blur(12px);
    border-bottom: 1px solid var(--border);
    padding: 6px 0 14px;
    flex-direction: column;
    z-index: 150;
    box-shadow: 0 8px 24px rgba(0,0,0,0.08);
  }
  .nav-mobile-menu.open { display: flex; }
  .nav-mobile-item {
    padding: 13px 24px; text-align: left;
    background: none; border: none; cursor: pointer;
    font-size: 15px; font-weight: 500; color: var(--text);
    font-family: 'Inter', sans-serif; transition: background 0.1s;
  }
  .nav-mobile-item:active { background: var(--surface); }

  /* ===== WALLET CONNECTED BUTTON ===== */
  .btn-wallet-connected {
    display: none; align-items: center; gap: 8px;
    background: var(--surface); color: var(--text);
    border: 1px solid var(--border); padding: 7px 14px;
    border-radius: 9px; font-family: 'Inter', sans-serif;
    font-size: 12px; font-weight: 600; cursor: pointer;
    margin-left: 8px; transition: all 0.18s; position: relative;
    box-shadow: var(--shadow);
  }
  .btn-wallet-connected:hover { border-color: rgba(30,94,243,0.3); background: var(--bg); }
  .btn-wallet-connected.visible { display: flex; }
  .wallet-connected-dot {
    width: 7px; height: 7px; border-radius: 50%;
    background: var(--green); flex-shrink: 0;
    box-shadow: 0 0 0 2px rgba(15,164,114,0.2);
  }
  .wallet-connected-logo {
    width: 16px; height: 16px; border-radius: 4px;
    object-fit: contain; flex-shrink: 0;
  }
  .wallet-connected-addr { letter-spacing: 0.03em; }

  /* ===== WALLET DROPDOWN ===== */
  .wallet-dropdown {
    display: none; position: absolute; top: calc(100% + 8px); right: 0;
    background: var(--surface); border: 1px solid var(--border);
    border-radius: 14px; box-shadow: 0 8px 32px rgba(12,19,34,0.14);
    width: 240px; z-index: 200; overflow: hidden;
    animation: dropIn 0.15s ease;
  }
  @keyframes dropIn {
    from { opacity:0; transform:translateY(-6px) scale(0.98); }
    to   { opacity:1; transform:translateY(0) scale(1); }
  }
  .wallet-dropdown.open { display: block; }
  .wd-header {
    padding: 14px 16px 10px;
    border-bottom: 1px solid var(--border);
    background: var(--bg);
  }
  .wd-header-label { font-size: 10px; color: var(--muted); font-weight: 500; letter-spacing: 0.08em; text-transform: uppercase; margin-bottom: 6px; }
  .wd-wallet-info { display: flex; align-items: center; gap: 8px; }
  .wd-wallet-logo { width: 20px; height: 20px; border-radius: 6px; object-fit: contain; }
  .wd-wallet-name { font-size: 12px; font-weight: 600; color: var(--text); }
  .wd-item {
    display: flex; align-items: center; gap: 10px;
    padding: 11px 16px; cursor: pointer;
    font-size: 12px; color: var(--text); font-weight: 500;
    transition: background 0.13s; border: none; background: none;
    width: 100%; text-align: left; font-family: 'Inter', sans-serif;
  }
  .wd-item:hover { background: var(--bg); }
  .wd-item svg { flex-shrink: 0; color: var(--text2); }
  .wd-item.danger { color: #dc2626; }
  .wd-item.danger svg { color: #dc2626; }
  .wd-divider { height: 1px; background: var(--border); margin: 2px 0; }
  .wd-copied { color: var(--green) !important; }

  /* ===== QR MODAL ===== */
  .qr-overlay {
    display: none; position: fixed; inset: 0; z-index: 1000;
    background: rgba(12,19,34,0.55); backdrop-filter: blur(4px);
    align-items: center; justify-content: center;
  }
  .qr-overlay.open { display: flex; }
  .qr-modal {
    background: var(--surface); border-radius: 20px;
    border: 1px solid var(--border);
    box-shadow: 0 24px 60px rgba(12,19,34,0.18);
    width: 320px; max-width: calc(100vw - 32px);
    padding: 28px; text-align: center;
    animation: modalIn 0.2s ease;
  }
  .qr-modal h3 { font-family: 'Cabinet Grotesk', sans-serif; font-weight: 700; font-size: 15px; margin-bottom: 6px; color: var(--text); }
  .qr-modal p { font-size: 11px; color: var(--text2); margin-bottom: 20px; line-height: 1.6; }
  .qr-placeholder {
    width: 180px; height: 180px; background: var(--bg);
    border: 2px dashed var(--border); border-radius: 12px;
    display: flex; align-items: center; justify-content: center;
    margin: 0 auto 18px; font-size: 11px; color: var(--muted);
  }
  .qr-deeplinks { display: flex; flex-direction: column; gap: 8px; }
  .qr-deeplink-btn {
    display: flex; align-items: center; gap: 10px;
    padding: 11px 14px; border-radius: 10px;
    border: 1px solid var(--border); cursor: pointer;
    background: var(--surface); transition: all 0.15s;
    font-family: 'Inter', sans-serif; font-size: 12px; font-weight: 500;
    color: var(--text); text-decoration: none;
  }
  .qr-deeplink-btn:hover { border-color: var(--accent); background: var(--accent-light); }

  /* ═══════════════════════════════════════════
     ANTI-PHISHING BANNER
     ═══════════════════════════════════════════ */
  .phishing-banner {
    background: linear-gradient(90deg, rgba(15,164,114,0.06), rgba(30,94,243,0.04));
    border-bottom: 1px solid rgba(15,164,114,0.15);
    padding: 7px 28px;
    display: flex; align-items: center; justify-content: center; gap: 8px;
    font-size: 11px; color: var(--text2); font-family: 'Inter', sans-serif;
    position: relative; z-index: 99; flex-shrink: 0;
  }
  .phishing-banner .pb-lock {
    color: var(--green); flex-shrink: 0;
  }
  .phishing-banner .pb-url {
    font-weight: 700; color: var(--text);
    background: rgba(15,164,114,0.1); border: 1px solid rgba(15,164,114,0.18);
    border-radius: 5px; padding: 1px 7px; letter-spacing: 0.02em;
    font-size: 11px;
  }
  .phishing-banner .pb-warn {
    color: var(--muted); font-weight: 400;
  }

  /* ═══════════════════════════════════════════
     STAKE CONFIRMATION MODAL
     ═══════════════════════════════════════════ */
  .confirm-overlay {
    display: none; position: fixed; inset: 0; z-index: 1001;
    background: rgba(12,19,34,0.6); backdrop-filter: blur(5px);
    align-items: center; justify-content: center;
  }
  .confirm-overlay.open { display: flex; }
  .confirm-modal {
    background: var(--surface); border-radius: 20px;
    border: 1px solid var(--border);
    box-shadow: 0 24px 60px rgba(12,19,34,0.2);
    width: 420px; max-width: calc(100vw - 32px);
    padding: 28px;
    animation: modalIn 0.2s ease;
  }
  .confirm-header {
    display: flex; align-items: center; gap: 12px; margin-bottom: 20px;
  }
  .confirm-icon {
    width: 42px; height: 42px; border-radius: 12px; flex-shrink: 0;
    background: rgba(245,158,11,0.1); border: 1px solid rgba(245,158,11,0.2);
    display: flex; align-items: center; justify-content: center; font-size: 18px;
  }
  .confirm-title {
    font-family: 'Cabinet Grotesk', sans-serif; font-weight: 700; font-size: 15px; color: var(--text);
  }
  .confirm-subtitle { font-size: 11px; color: var(--text2); margin-top: 2px; }

  .confirm-detail-box {
    background: var(--bg); border: 1px solid var(--border);
    border-radius: 13px; padding: 16px 18px; margin-bottom: 14px;
  }
  .confirm-row {
    display: flex; justify-content: space-between; align-items: flex-start;
    padding: 8px 0; border-bottom: 1px solid var(--border); gap: 12px;
  }
  .confirm-row:last-child { border-bottom: none; padding-bottom: 0; }
  .confirm-row:first-child { padding-top: 0; }
  .cr-label { font-size: 11px; color: var(--muted); font-weight: 500; flex-shrink: 0; }
  .cr-val { font-size: 12px; font-weight: 600; color: var(--text); text-align: right; word-break: break-all; }
  .cr-val.green { color: var(--green); }
  .cr-val.mono { font-family: 'Courier New', monospace; font-size: 10px; color: var(--text2); }

  .confirm-warning {
    background: rgba(245,158,11,0.07); border: 1px solid rgba(245,158,11,0.2);
    border-radius: 10px; padding: 12px 14px; margin-bottom: 18px;
    font-size: 11px; color: #92400e; line-height: 1.6;
    display: flex; gap: 9px; align-items: flex-start;
  }
  .confirm-warning svg { flex-shrink: 0; margin-top: 1px; }

  .confirm-btns { display: flex; gap: 10px; }
  .btn-confirm-cancel {
    flex: 1; background: var(--surface); color: var(--text);
    border: 1px solid var(--border); padding: 12px;
    border-radius: 10px; font-family: 'Inter', sans-serif;
    font-size: 12px; font-weight: 600; cursor: pointer;
    transition: all 0.15s;
  }
  .btn-confirm-cancel:hover { border-color: rgba(30,94,243,0.3); color: var(--accent); }
  .btn-confirm-stake {
    flex: 2; background: var(--accent); color: #fff;
    border: none; padding: 12px; border-radius: 10px;
    font-family: 'Inter', sans-serif; font-size: 12px; font-weight: 600;
    cursor: pointer; transition: all 0.18s;
    box-shadow: 0 2px 10px rgba(30,94,243,0.22);
    position: relative; overflow: hidden;
  }
  .btn-confirm-stake:disabled {
    background: var(--muted); cursor: not-allowed; box-shadow: none;
  }
  .btn-confirm-stake:not(:disabled):hover {
    background: #1750d6; box-shadow: 0 4px 18px rgba(30,94,243,0.3);
  }
  .confirm-countdown {
    position: absolute; inset: 0; background: rgba(90,100,120,0.85);
    display: flex; align-items: center; justify-content: center;
    font-size: 13px; font-weight: 700; color: #fff; border-radius: 10px;
    transition: opacity 0.3s;
  }
  .confirm-countdown.hidden { opacity: 0; pointer-events: none; }

  /* ═══════════════════════════════════════════
     SQUADS MULTISIG TRANSPARENCY WIDGET
     ═══════════════════════════════════════════ */
  .multisig-widget {
    background: var(--surface);
    border: 1.5px solid rgba(99,102,241,0.2);
    border-radius: 20px;
    padding: 28px 32px;
    box-shadow: var(--shadow);
    margin-bottom: 14px;
    position: relative;
    overflow: hidden;
  }
  .multisig-widget::before {
    content: '';
    position: absolute; top: 0; left: 0; right: 0; height: 3px;
    background: linear-gradient(90deg, #6366f1, var(--accent), var(--green));
  }
  .msw-header {
    display: flex; align-items: center; justify-content: space-between;
    margin-bottom: 20px; flex-wrap: wrap; gap: 12px;
  }
  .msw-title-group { display: flex; align-items: center; gap: 12px; }
  .msw-shield {
    width: 40px; height: 40px; border-radius: 12px; flex-shrink: 0;
    background: rgba(99,102,241,0.1); border: 1px solid rgba(99,102,241,0.2);
    display: flex; align-items: center; justify-content: center; font-size: 18px;
  }
  .msw-title {
    font-family: 'Cabinet Grotesk', sans-serif; font-weight: 700;
    font-size: 15px; color: var(--text);
  }
  .msw-sub { font-size: 11px; color: var(--text2); margin-top: 2px; }
  .msw-badge {
    display: flex; align-items: center; gap: 6px;
    background: rgba(99,102,241,0.08); border: 1px solid rgba(99,102,241,0.18);
    border-radius: 100px; padding: 5px 12px;
    font-size: 11px; font-weight: 700; color: #6366f1;
    flex-shrink: 0;
  }
  .msw-badge-dot {
    width: 6px; height: 6px; border-radius: 50%;
    background: #6366f1; animation: blink 2.5s infinite;
  }
  .msw-grid {
    display: grid; grid-template-columns: 1fr 1fr;
    gap: 12px; margin-bottom: 20px;
  }
  @media(max-width:640px) { .msw-grid { grid-template-columns: 1fr; } }
  .msw-card {
    background: var(--bg); border: 1px solid var(--border);
    border-radius: 13px; padding: 16px 18px;
  }
  .msw-card-label {
    font-size: 10px; color: var(--muted); font-weight: 600;
    letter-spacing: 0.09em; text-transform: uppercase; margin-bottom: 8px;
  }
  .msw-card-val {
    font-family: 'Inter', sans-serif; font-weight: 700;
    font-size: 22px; color: var(--text);
  }
  .msw-card-val.purple { color: #6366f1; }
  .msw-card-val.green  { color: var(--green); }
  .msw-address-box {
    background: var(--bg); border: 1px solid var(--border);
    border-radius: 12px; padding: 14px 16px; margin-bottom: 16px;
  }
  .msw-address-label {
    font-size: 10px; color: var(--muted); font-weight: 600;
    letter-spacing: 0.09em; text-transform: uppercase; margin-bottom: 7px;
  }
  .msw-address-row {
    display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
  }
  .msw-address-val {
    font-family: 'Courier New', monospace; font-size: 12px;
    color: var(--text); font-weight: 500; flex: 1;
    min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
  }
  .msw-copy-btn {
    background: none; border: 1px solid var(--border);
    border-radius: 7px; padding: 4px 10px;
    font-size: 10px; font-weight: 600; color: var(--text2);
    cursor: pointer; font-family: 'Inter', sans-serif;
    transition: all 0.15s; flex-shrink: 0;
  }
  .msw-copy-btn:hover { border-color: var(--accent); color: var(--accent); background: var(--accent-light); }
  .msw-links {
    display: flex; gap: 8px; flex-wrap: wrap;
  }
  .msw-link {
    display: inline-flex; align-items: center; gap: 6px;
    background: var(--surface); border: 1px solid var(--border);
    border-radius: 8px; padding: 7px 14px;
    font-size: 11px; font-weight: 600; color: var(--text2);
    text-decoration: none; transition: all 0.15s; cursor: pointer;
  }
  .msw-link:hover { border-color: var(--accent); color: var(--accent); background: var(--accent-light); }
  .msw-balance-loading {
    display: inline-block; width: 60px; height: 14px;
    background: linear-gradient(90deg, var(--border) 25%, var(--bg) 50%, var(--border) 75%);
    background-size: 200% 100%; border-radius: 4px;
    animation: shimmer 1.4s infinite;
  }
  @keyframes shimmer {
    0%   { background-position: 200% 0; }
    100% { background-position: -200% 0; }
  }

  /* ═══════════════════════════════════════════════════════
     STREAMFLOW STAKING DASHBOARD extra styles
     ═══════════════════════════════════════════════════════ */

  /* Lock period tier selector */
  .lock-grid {
    display: grid; grid-template-columns: repeat(4, 1fr);
    gap: 7px; margin-bottom: 16px;
  }
  @media(max-width:600px) { .lock-grid { grid-template-columns: repeat(2,1fr); } }
  .lock-tile {
    border: 1.5px solid var(--border); border-radius: 11px;
    padding: 10px 8px; text-align: center; cursor: pointer;
    transition: all 0.15s; background: var(--surface);
    position: relative; overflow: hidden;
    display: flex; flex-direction: column; align-items: center; justify-content: center;
  }
  .lock-tile:hover { border-color: var(--accent); background: var(--accent-light); }
  .lock-tile.selected {
    border-color: var(--accent); background: var(--accent-light);
    box-shadow: 0 0 0 3px rgba(30,94,243,0.12);
  }
  .lock-tile-days { font-family:'Inter',sans-serif; font-weight:600; font-size:14px; color:var(--text); letter-spacing:-0.01em; }
  .lock-tile-mul  { font-size:11px; font-weight:500; color:var(--accent); margin-top:3px; }
  .lock-tile-apsy  { font-size:10px; color:var(--muted); margin-top:1px; font-weight:400; }
  .lock-tile-best {
    position:absolute; top:5px; right:5px;
    background:var(--green); color:#fff;
    font-size:8px; font-weight:700; border-radius:4px;
    padding:1px 5px; letter-spacing:0.04em;
  }

  /* Pool stats bar */
  .pool-stats-bar {
    display:grid; grid-template-columns:repeat(3,1fr);
    gap:10px; margin-bottom:20px;
  }
  .psb-card {
    background:var(--bg); border:1px solid var(--border);
    border-radius:12px; padding:13px 16px; text-align:center;
  }
  .psb-label { font-size:9px; font-weight:600; color:var(--muted); letter-spacing:0.1em; text-transform:uppercase; margin-bottom:5px; }
  .psb-val   { font-family:'Inter',sans-serif; font-weight:700; font-size:17px; color:var(--text); }
  .psb-val.green { color:var(--green); }

  /* Position card enhancements */
  .pos-section-title {
    font-size:10px; font-weight:600; color:var(--muted);
    letter-spacing:0.09em; text-transform:uppercase;
    padding:10px 0 6px; border-bottom:1px solid var(--border);
    margin-bottom:2px;
  }
  .pos-countdown {
    font-family:'Inter',sans-serif; font-weight:700;
    font-size:13px; color:var(--accent);
  }
  .pos-multiplier {
    display:inline-flex; align-items:center;
    background:rgba(30,94,243,0.08); border:1px solid rgba(30,94,243,0.18);
    border-radius:6px; padding:2px 8px;
    font-size:11px; font-weight:700; color:var(--accent);
  }

  /* Action buttons */
  .stake-actions { display:flex; flex-direction:column; gap:8px; margin-top:16px; }
  .btn-claim {
    width:100%; background:var(--green); color:#fff; border:none;
    padding:13px; border-radius:11px;
    font-family:'Inter',sans-serif; font-weight:600; font-size:13px;
    cursor:pointer; transition:all 0.18s;
    box-shadow:0 2px 10px rgba(15,164,114,0.25);
    display:flex; align-items:center; justify-content:center; gap:8px;
  }
  .btn-claim:hover:not(:disabled) { background:#0a8a5e; transform:translateY(-1px); box-shadow:0 4px 16px rgba(15,164,114,0.32); }
  .btn-claim:disabled  { background:var(--muted); cursor:not-allowed; box-shadow:none; transform:none; }
  .btn-unstake {
    width:100%; background:var(--surface); color:var(--text);
    border:1.5px solid var(--border); padding:12px;
    border-radius:11px; font-family:'Inter',sans-serif;
    font-weight:600; font-size:13px; cursor:pointer;
    transition:all 0.18s;
    display:flex; align-items:center; justify-content:center; gap:8px;
  }
  .btn-unstake:hover:not(:disabled) { border-color:#dc2626; color:#dc2626; background:rgba(220,38,38,0.05); }
  .btn-unstake:disabled { opacity:0.45; cursor:not-allowed; }
  .btn-unstake.locked  { opacity:0.45; cursor:not-allowed; }

  /* TX status overlay */
  .tx-status-overlay {
    display:none; position:fixed; inset:0; z-index:2000;
    background:rgba(12,19,34,0.65); backdrop-filter:blur(6px);
    align-items:center; justify-content:center;
  }
  .tx-status-overlay.open { display:flex; }
  .tx-status-box {
    background:var(--surface); border-radius:20px;
    border:1px solid var(--border);
    box-shadow:0 24px 60px rgba(12,19,34,0.22);
    width:360px; max-width:calc(100vw - 32px);
    padding:32px 28px; text-align:center;
    animation:modalIn 0.2s ease;
  }
  .tx-spinner {
    width:44px; height:44px; border-radius:50%;
    border:3px solid var(--border);
    border-top-color:var(--accent);
    animation:spin 0.8s linear infinite;
    margin:0 auto 18px;
  }
  @keyframes spin { to { transform:rotate(360deg); } }
  .tx-status-title { font-family:'Cabinet Grotesk',sans-serif; font-weight:700; font-size:16px; color:var(--text); margin-bottom:7px; }
  .tx-status-sub   { font-size:12px; color:var(--text2); line-height:1.6; }
  .tx-status-icon  { font-size:36px; margin-bottom:14px; }
  .tx-status-link  {
    display:inline-flex; align-items:center; gap:6px;
    color:var(--accent); font-size:11px; font-weight:600;
    text-decoration:none; margin-top:12px;
    padding:7px 14px; border:1px solid rgba(30,94,243,0.2);
    border-radius:8px; background:var(--accent-light);
  }

  /* Cooldown ring on buttons */
  .cooldown-bar {
    height:3px; border-radius:2px; background:var(--border);
    overflow:hidden; margin-top:8px;
  }
  .cooldown-fill {
    height:100%; background:var(--accent);
    border-radius:2px; transition:width 1s linear;
  }

  /* Simulation warning */
  .sim-error {
    background:rgba(220,38,38,0.07); border:1px solid rgba(220,38,38,0.2);
    border-radius:10px; padding:11px 14px; margin-top:10px;
    font-size:11px; color:#dc2626; line-height:1.6;
    display:none; align-items:flex-start; gap:8px;
  }
  .sim-error.visible { display:flex; }
  .sim-error svg { flex-shrink:0; margin-top:1px; }

  /* Refresh pulse */
  @keyframes pulse-green {
    0%,100% { opacity:1; }
    50% { opacity:0.4; }
  }
  .live-dot {
    display:inline-block; width:6px; height:6px; border-radius:50%;
    background:var(--green); vertical-align:middle; margin-right:5px;
    animation:pulse-green 2s infinite;
  }
  /* ═══════════════════════════════════
     DISTRIBUTION PAGE
     ═══════════════════════════════════ */
/* HEADER */
  #page-distribution .hdr {display:flex;align-items:flex-start;gap:14px;margin-bottom:28px;}
  #page-distribution .hdr-icon {width:44px;height:44px;border-radius:13px;background:var(--accent-light);border:1px solid rgba(30,94,243,0.15);display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0;}
  #page-distribution .hdr-title {font-family:'Cabinet Grotesk',sans-serif;font-weight:800;font-size:22px;color:var(--text);margin-bottom:5px;}
  #page-distribution .hdr-sub {font-size:12px;color:var(--text2);line-height:1.65;max-width:540px;}
  #page-distribution .hdr-tag {display:inline-flex;align-items:center;gap:6px;background:var(--green-light);border:1px solid rgba(15,164,114,0.2);color:#0a7a5a;padding:4px 12px;border-radius:100px;font-size:10px;font-weight:600;letter-spacing:0.07em;text-transform:uppercase;margin-top:10px;}
  
  #page-distribution 50% {opacity:0.3}#page-distribution }

  /* PHASE TABS */
  .tabs {display:grid;grid-template-columns:1fr 1fr 1fr;gap:5px;background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:5px;margin-bottom:20px;}
  #page-distribution .tab {flex:1;padding:10px 6px;border-radius:9px;border:1px solid var(--border);background:var(--bg);cursor:pointer;font-family:'Inter',sans-serif;transition:all 0.18s;text-align:center;}
  #page-distribution .tab:hover {background:var(--accent-light);border-color:rgba(30,94,243,0.2);}
  #page-distribution .tab.active {background:var(--accent);box-shadow:0 2px 10px rgba(30,94,243,0.22);border-color:var(--accent);}
  #page-distribution .tab-label {font-size:12px;font-weight:600;color:var(--text2);display:block;margin-bottom:2px;transition:color 0.18s;}
  #page-distribution .tab.active .tab-label {color:#fff;}
  #page-distribution .tab-weeks {font-size:10px;color:var(--muted);display:block;transition:color 0.18s;}
  #page-distribution .tab.active .tab-weeks {color:rgba(255,255,255,0.6);}

  /* STREAM TABLE */
  #page-distribution .stream-card {background:var(--surface);border:1px solid var(--border);border-radius:18px;overflow:hidden;box-shadow:var(--shadow);margin-bottom:14px;}
  #page-distribution .s-thead {display:grid;grid-template-columns:1fr 90px 90px 90px 72px;padding:9px 20px;background:var(--bg);border-bottom:1px solid var(--border);}
  #page-distribution .th {font-size:10px;font-weight:600;letter-spacing:0.09em;text-transform:uppercase;color:var(--muted);}
  #page-distribution .th.g {color:var(--green);text-align:right;}
  #page-distribution .th.p {color:var(--purple);text-align:right;}
  #page-distribution .th.b {color:var(--accent);text-align:right;}
  #page-distribution .th.m {color:var(--muted);text-align:right;}
  #page-distribution .s-row {border-bottom:1px solid var(--border);transition:background 0.15s;}
  #page-distribution .s-row:last-child {border-bottom:none;}
  #page-distribution .s-row:hover {background:rgba(30,94,243,0.018);}
  #page-distribution .s-top {display:grid;grid-template-columns:1fr 90px 90px 90px 72px;padding:13px 20px;align-items:center;}
  #page-distribution .s-name-wrap {display:flex;align-items:center;gap:9px;}
  #page-distribution .s-icon {width:28px;height:28px;border-radius:8px;border:1px solid var(--border);background:var(--bg);display:flex;align-items:center;justify-content:center;font-size:13px;flex-shrink:0;}
  #page-distribution .s-name {font-size:13px;font-weight:600;color:var(--text);}
  #page-distribution .s-type {font-size:10px;color:var(--muted);margin-top:1px;}
  #page-distribution .pct {font-size:13px;font-weight:700;text-align:right;transition:all 0.35s ease;}
  #page-distribution .pct.g {color:var(--green);}
  #page-distribution .pct.p {color:var(--purple);}
  #page-distribution .pct.b {color:var(--accent);}
  #page-distribution .pct.m {color:var(--muted);}
  #page-distribution .pct.dash {color:var(--muted);font-weight:400;}
  #page-distribution .s-bar-wrap {padding:0 20px 12px;}
  #page-distribution .s-bar {display:flex;height:4px;border-radius:99px;overflow:hidden;gap:1.5px;}
  #page-distribution .bar-seg {border-radius:99px;transition:width 0.45s cubic-bezier(0.4,0,0.2,1);}
  #page-distribution .bg {background:var(--green);}
  #page-distribution .bp {background:var(--purple);}
  #page-distribution .bb {background:var(--accent);}
  #page-distribution .bm {background:#dde2ee;}

  /* TREASURY YIELD NOTICE */
  #page-distribution .yield-notice {margin:12px 20px 20px;padding:11px 16px;border-radius:10px;font-size:11px;line-height:1.6;border:1px solid;transition:all 0.35s ease;}
  #page-distribution .yield-notice.locked {background:rgba(156,163,175,0.06);border-color:rgba(156,163,175,0.2);color:var(--muted);}
  #page-distribution .yield-notice.active {background:rgba(15,164,114,0.06);border-color:rgba(15,164,114,0.2);color:#0a7a5a;}

  /* TOTALS */
  #page-distribution .totals {background:linear-gradient(135deg,rgba(30,94,243,0.04),rgba(15,164,114,0.04));border:1px solid var(--border);border-radius:14px;padding:18px 22px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;margin-bottom:14px;}
  #page-distribution .total-apsy {font-family:'Inter',sans-serif;font-weight:600;font-size:34px;color:var(--green);line-height:1;letter-spacing:-0.02em;transition:all 0.35s ease;}
  #page-distribution .total-apsy-lbl {font-size:12px;color:var(--text2);margin-top:4px;line-height:1.5;}
  #page-distribution .total-apsy-sub {font-size:10px;color:var(--muted);}
  #page-distribution .totals-right {display:flex;gap:22px;flex-wrap:wrap;}
  #page-distribution .ti {text-align:right;}
  #page-distribution .ti-val {font-family:'Inter',sans-serif;font-weight:600;font-size:15px;color:var(--text);letter-spacing:-0.01em;transition:all 0.35s ease;}
  #page-distribution .ti-val.g {color:var(--green);}
  #page-distribution .ti-val.p {color:var(--purple);}
  #page-distribution .ti-val.b {color:var(--accent);}
  #page-distribution .ti-lbl {font-size:10px;color:var(--muted);margin-top:2px;letter-spacing:0.06em;text-transform:uppercase;}

  /* TIMELINE */
  #page-distribution .tl-card {background:var(--surface);border:1px solid var(--border);border-radius:18px;overflow:hidden;box-shadow:var(--shadow);margin-bottom:14px;}
  #page-distribution .tl-hdr {padding:14px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;}
  #page-distribution .tl-title {font-family:'Inter',sans-serif;font-weight:600;font-size:13px;color:var(--text);}
  #page-distribution .tl-sub {font-size:10px;color:var(--muted);margin-top:2px;}
  #page-distribution .tl-head {display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr 1fr 1fr;background:var(--bg);border-bottom:1px solid var(--border);}
  #page-distribution .th2 {padding:8px 12px;font-size:10px;font-weight:600;color:var(--muted);letter-spacing:0.08em;text-transform:uppercase;border-right:1px solid var(--border);}
  #page-distribution .th2:last-child {border-right:none;}
  #page-distribution .tl-row {display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr 1fr 1fr;border-bottom:1px solid var(--border);cursor:pointer;transition:background 0.15s;}
  #page-distribution .tl-row:last-child {border-bottom:none;}
  #page-distribution .tl-row:hover {background:var(--accent-light);}
  #page-distribution .tl-row.active-row {background:var(--accent-light);}
  #page-distribution .tc {padding:11px 12px;font-size:12px;border-right:1px solid var(--border);}
  #page-distribution .tc:last-child {border-right:none;}
  #page-distribution .tc-name {font-weight:600;color:var(--text);}
  #page-distribution .tc-weeks {font-size:10px;color:var(--muted);margin-top:1px;}
  #page-distribution .tc-val {font-weight:700;text-align:center;}
  #page-distribution .tc-val.g {color:var(--green);}
  #page-distribution .tc-val.p {color:var(--purple);}
  #page-distribution .tc-val.b {color:var(--accent);}
  #page-distribution .pi {width:6px;height:6px;border-radius:50%;background:var(--accent);display:inline-block;margin-right:6px;animation:blink 2s infinite;}

  /* TREASURY THRESHOLDS */
  #page-distribution .thr-card {background:var(--surface);border:1px solid var(--border);border-radius:18px;overflow:hidden;box-shadow:var(--shadow);margin-bottom:14px;}
  #page-distribution .thr-hdr {padding:14px 20px;border-bottom:1px solid var(--border);}
  #page-distribution .thr-title {font-family:'Inter',sans-serif;font-weight:600;font-size:13px;color:var(--text);}
  #page-distribution .thr-sub {font-size:10px;color:var(--muted);margin-top:2px;}
  #page-distribution .thr-grid {display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-bottom:1px solid var(--border);}
  #page-distribution .thr-col {padding:16px 14px;border-right:1px solid var(--border);transition:background 0.2s;}
  #page-distribution .thr-col:last-child {border-right:none;}
  #page-distribution .thr-col:hover {background:var(--bg);}
  #page-distribution .thr-col.unlocked {background:var(--green-light);}
  #page-distribution .thr-amount {font-family:'Inter',sans-serif;font-weight:600;font-size:16px;color:var(--text);letter-spacing:-0.01em;margin-bottom:6px;}
  #page-distribution .thr-badge {display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:20px;font-size:10px;font-weight:600;margin-bottom:10px;}
  #page-distribution .thr-badge.locked {background:var(--bg);color:var(--muted);border:1px solid var(--border);}
  #page-distribution .thr-badge.unlocked {background:var(--green-light);color:var(--green);border:1px solid rgba(15,164,114,0.2);}
  #page-distribution .thr-row {display:flex;justify-content:space-between;padding:3px 0;font-size:11px;}
  #page-distribution .thr-lbl {color:var(--muted);}
  #page-distribution .thr-val {font-weight:600;}
  #page-distribution .thr-val.g {color:var(--green);}
  #page-distribution .thr-val.b {color:var(--accent);}
  #page-distribution .thr-val.p {color:var(--purple);}
  #page-distribution .thr-val.m {color:var(--muted);}
  #page-distribution .thr-week {font-size:10px;color:var(--muted);margin-top:8px;padding-top:8px;border-top:1px solid var(--border);}

  /* MILESTONES */
  #page-distribution .ms-card {background:var(--surface);border:1px solid var(--border);border-radius:18px;overflow:hidden;box-shadow:var(--shadow);margin-bottom:14px;}
  #page-distribution .ms-hdr {padding:14px 20px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;}
  #page-distribution .ms-title {font-family:'Inter',sans-serif;font-weight:600;font-size:13px;color:var(--text);}
  #page-distribution .ms-track {padding:18px 20px;display:flex;gap:6px;align-items:center;flex-wrap:wrap;}
  #page-distribution .ms-item {display:flex;flex-direction:column;align-items:center;gap:5px;flex:1;min-width:95px;padding:12px 8px;border:1px solid var(--border);border-radius:12px;background:var(--bg);transition:all 0.18s;}
  #page-distribution .ms-item:hover {border-color:var(--accent);background:var(--accent-light);}
  #page-distribution .ms-amt {font-family:'Inter',sans-serif;font-weight:600;font-size:14px;color:var(--text);letter-spacing:-0.01em;}
  #page-distribution .ms-wk {font-size:10px;color:var(--muted);}
  #page-distribution .ms-apsy {font-size:11px;font-weight:600;color:var(--green);background:var(--green-light);border:1px solid rgba(15,164,114,0.15);padding:2px 7px;border-radius:20px;}
  #page-distribution .ms-arr {color:var(--muted);font-size:14px;flex-shrink:0;}

  /* CHART */
  #page-distribution .chart-card {background:var(--surface);border:1px solid var(--border);border-radius:18px;overflow:hidden;box-shadow:var(--shadow);margin-bottom:14px;}
  #page-distribution .chart-hdr {padding:14px 20px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;}
  #page-distribution .chart-title {font-family:'Cabinet Grotesk',sans-serif;font-weight:700;font-size:13px;color:var(--text);}
  #page-distribution .chart-legend {display:flex;gap:14px;}
  #page-distribution .cl-item {display:flex;align-items:center;gap:5px;font-size:10px;color:var(--muted);}
  #page-distribution .cl-dot {width:8px;height:8px;border-radius:50%;}
  #page-distribution .chart-wrap {padding:20px 20px 16px;position:relative;}
  #page-distribution canvas {width:100%!important;}

  /* NOTE */
  #page-distribution .note {font-size:11px;color:var(--muted);line-height:1.65;padding:0 2px;}
  #page-distribution .note strong {color:var(--text2);}

  @keyframes fadeUp{from{opacity:0;transform:translateY(10px);}to{opacity:1;transform:translateY(0);}}
  #page-distribution .stream-card, #page-distribution .totals, #page-distribution .tl-card, #page-distribution .thr-card, #page-distribution .ms-card, #page-distribution .chart-card {animation:fadeUp 0.4s ease both;}
  #page-distribution .stream-card {animation-delay:0.05s;}
  #page-distribution .totals {animation-delay:0.1s;}
  #page-distribution .tl-card {animation-delay:0.15s;}
  #page-distribution .thr-card {animation-delay:0.2s;}
  #page-distribution .ms-card {animation-delay:0.25s;}
  #page-distribution .chart-card {animation-delay:0.3s;}

  /* ═══════════════════════════════════
     CALCULATOR PAGE
     ═══════════════════════════════════ */
/* HEADER */
  #page-calculator .hdr {display:flex;align-items:flex-start;gap:14px;margin-bottom:28px;}
  #page-calculator .hdr-icon {width:44px;height:44px;border-radius:13px;background:var(--accent-light);border:1px solid rgba(30,94,243,0.15);display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0;}
  #page-calculator .hdr-title {font-family:'Cabinet Grotesk',sans-serif;font-weight:800;font-size:22px;color:var(--text);margin-bottom:5px;}
  #page-calculator .hdr-sub {font-size:12px;color:var(--text2);line-height:1.65;max-width:560px;}
  #page-calculator .hdr-tag {display:inline-flex;align-items:center;gap:6px;background:var(--green-light);border:1px solid rgba(15,164,114,0.2);color:#0a7a5a;padding:4px 12px;border-radius:100px;font-size:10px;font-weight:600;letter-spacing:0.07em;text-transform:uppercase;margin-top:10px;}
  
  #page-calculator 50% {opacity:0.3}#page-calculator }

  /* CARDS */
  .card {background:var(--surface);border:1px solid var(--border);border-radius:18px;overflow:hidden;box-shadow:var(--shadow);margin-bottom:24px;}
  #page-calculator .card-hdr {padding:14px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;}
  #page-calculator .card-title {font-family:'Inter',sans-serif;font-weight:600;font-size:13px;color:var(--text);}
  #page-calculator .card-sub {font-size:10px;color:var(--muted);}

  /* CONTROLS */
  #page-calculator .ctrl-body {padding:24px 24px 20px;display:grid;grid-template-columns:1fr 1fr 1fr;gap:28px;align-items:start;}
  @media(max-width:700px) {#page-calculator .ctrl-body {grid-template-columns:1fr 1fr;}} @media(max-width:480px){#page-calculator .ctrl-body {grid-template-columns:1fr;}}

  #page-calculator .ctrl-block {display:flex;flex-direction:column;gap:12px;}
  #page-calculator .ctrl-lbl-row {display:flex;justify-content:space-between;align-items:baseline;margin-bottom:4px;}
  #page-calculator .ctrl-lbl {font-size:11px;font-weight:500;color:var(--text2);}
  #page-calculator .ctrl-bigval {font-family:'Inter',sans-serif;font-weight:700;font-size:20px;color:var(--text);letter-spacing:-0.02em;}
  #page-calculator .ctrl-bigval .unit {font-size:12px;color:var(--muted);font-weight:400;}

  #page-calculator input[type=range] {-webkit-appearance:none;width:100%;height:4px;border-radius:99px;background:var(--border);outline:none;cursor:pointer;}
  #page-calculator input[type=range]::-webkit-slider-thumb {-webkit-appearance:none;width:18px;height:18px;border-radius:50%;background:#fff;border:2px solid var(--accent);box-shadow:0 2px 6px rgba(30,94,243,0.25);cursor:pointer;transition:transform 0.15s;}
  #page-calculator input[type=range]:hover::-webkit-slider-thumb {transform:scale(1.2);}
  #page-calculator .slider-scale {display:flex;justify-content:space-between;font-size:9px;color:var(--muted);margin-top:4px;letter-spacing:0.02em;}

  #page-calculator .mode-row {display:flex;background:var(--bg);border:1px solid var(--border);border-radius:10px;overflow:hidden;padding:3px;gap:3px;}
  #page-calculator .mode-btn {flex:1;padding:8px 10px;border:none;border-radius:7px;background:transparent;cursor:pointer;font-family:'Inter',sans-serif;font-size:11px;font-weight:500;color:var(--muted);transition:all 0.15s;text-align:center;}
  #page-calculator .mode-btn.on {background:var(--surface);color:var(--accent);font-weight:600;box-shadow:0 1px 4px rgba(12,19,34,0.07);}
  #page-calculator .mode-hint {font-size:10px;color:var(--muted);line-height:1.55;padding-top:2px;}

  /* APSY TOTALS */
  #page-calculator .totals {background:linear-gradient(135deg,rgba(30,94,243,0.04),rgba(15,164,114,0.04));border:1px solid var(--border);border-radius:18px;padding:18px 22px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;margin-bottom:24px;box-shadow:var(--shadow);}
  #page-calculator .total-apsy {font-family:'Inter',sans-serif;font-weight:600;font-size:30px;color:var(--green);line-height:1;letter-spacing:-0.02em;transition:all 0.3s ease;}
  #page-calculator .total-apsy .unit {font-size:16px;color:var(--muted);font-weight:400;vertical-align:middle;}
  #page-calculator .total-apsy-lbl {font-size:12px;color:var(--text2);margin-top:5px;line-height:1.5;}
  #page-calculator .total-apsy-sub {font-size:10px;color:var(--muted);}
  #page-calculator .totals-right {display:flex;flex-direction:column;gap:6px;}
  #page-calculator .ti {text-align:right;}
  #page-calculator .ti-val {font-family:'Inter',sans-serif;font-weight:600;font-size:14px;letter-spacing:-0.01em;transition:all 0.3s;white-space:nowrap;}
  #page-calculator .ti-val.g {color:var(--green);}
  #page-calculator .ti-val.p {color:var(--purple);}
  #page-calculator .ti-val.b {color:var(--accent);}
  #page-calculator .ti-lbl {font-size:10px;color:var(--muted);margin-top:1px;letter-spacing:0.06em;text-transform:uppercase;}

  /* PHASE PILLS */
  #page-calculator .phase-pills {display:grid;grid-template-columns:repeat(3,1fr);}
  #page-calculator .phase-pill {padding:20px 22px 18px;border-right:1px solid var(--border);transition:background 0.15s;display:flex;flex-direction:column;}
  #page-calculator .phase-pill:last-child {border-right:none;}
  #page-calculator .phase-pill:hover {background:var(--bg);}
  #page-calculator .pp-name {font-size:11px;font-weight:600;color:var(--text2);margin-bottom:2px;}
  #page-calculator .pp-weeks {font-size:10px;color:var(--muted);margin-bottom:12px;}
  #page-calculator .pp-apsy {font-family:'Inter',sans-serif;font-weight:600;font-size:22px;line-height:1;letter-spacing:-0.02em;transition:all 0.3s;}
  #page-calculator .pp-apsy .unit {font-size:12px;font-weight:400;color:var(--muted);}
  #page-calculator .pp-apsy.hi {color:var(--green);}
  #page-calculator .pp-apsy.mid {color:var(--accent);}
  #page-calculator .pp-apsy.lo {color:var(--amber);}
  #page-calculator .pp-apsy.dim {color:var(--muted);}
  #page-calculator .pp-detail {font-size:10px;color:var(--muted);margin-top:6px;line-height:1.6;transition:all 0.3s;flex:1;}
  #page-calculator .pp-bar {height:3px;background:var(--border);border-radius:99px;margin-top:12px;overflow:hidden;}
  #page-calculator .pp-bar-fill {height:100%;border-radius:99px;background:var(--green);transition:width 0.4s ease;}

  /* BENCHMARK */
  #page-calculator .bench-body { padding: 4px 0; }
  #page-calculator .bench-item { display: grid; grid-template-columns: 180px 1fr 52px; align-items: center; gap: 16px; padding: 12px 22px; border-bottom: 1px solid var(--border); transition: background 0.15s; }
  #page-calculator .bench-item:last-child { border-bottom: none; }
  #page-calculator .bench-item:hover { background: var(--bg); }
  #page-calculator .bench-name { font-size: 12px; font-weight: 500; color: var(--text2); display: flex; align-items: center; gap: 8px; }
  #page-calculator .bench-dot { width: 7px; height: 7px; border-radius: 50%; flex-shrink: 0; }
  #page-calculator .bench-track { height: 5px; background: var(--border); border-radius: 99px; overflow: hidden; }
  #page-calculator .bench-fill { height: 100%; border-radius: 99px; transition: width 0.55s cubic-bezier(0.4,0,0.2,1); }
  #page-calculator .bench-pct { font-family: 'Inter', sans-serif; font-weight: 700; font-size: 13px; letter-spacing: -0.02em; color: var(--muted); text-align: right; }
  #page-calculator .bench-pylon { background: var(--accent-light); border-top: 1.5px solid rgba(30,94,243,0.12); }
  #page-calculator .bench-pylon .bench-name { font-weight: 600; color: var(--text); }
  #page-calculator .bench-pylon .bench-pct { color: var(--accent); }
  #page-calculator .insight { margin: 8px 20px 18px; padding: 13px 16px; border-radius: 11px; font-size: 11px; line-height: 1.7; border: 1px solid; }
  #page-calculator .ins-g { background: rgba(15,164,114,0.05); border-color: rgba(15,164,114,0.18); color: #0a5c3e; border-left: 3px solid var(--green); }
  #page-calculator .ins-w { background: rgba(217,119,6,0.05); border-color: rgba(217,119,6,0.18); color: #7a4500; border-left: 3px solid #d97706; }
  #page-calculator .ins-i { background: var(--accent-light); border-color: rgba(30,94,243,0.15); color: #1a3a80; border-left: 3px solid var(--accent); }

  /* HERO PHASE TABS */
  #page-calculator .hero-tab {flex:1;padding:8px 10px;border:none;border-radius:7px;background:transparent;cursor:pointer;font-family:'Inter',sans-serif;font-size:11px;font-weight:500;color:var(--muted);transition:all 0.15s;text-align:center;}
  #page-calculator .hero-tab:hover {background:rgba(255,255,255,0.5);color:var(--text2);}
  #page-calculator .hero-tab.active {background:var(--accent);color:#fff;font-weight:600;box-shadow:0 2px 8px rgba(30,94,243,0.22);}

  /* CHART */
  #page-calculator .chart-hdr {padding:14px 20px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;}
  #page-calculator .chart-title {font-family:'Inter',sans-serif;font-weight:600;font-size:13px;color:var(--text);}
  #page-calculator .chart-legend {display:flex;gap:14px;}
  #page-calculator .cl-item {display:flex;align-items:center;gap:5px;font-size:10px;color:var(--muted);}
  #page-calculator .cl-dot {width:8px;height:8px;border-radius:50%;}
  #page-calculator .chart-wrap {padding:20px 20px 14px;} #page-calculator canvas {width:100%!important;}

  #page-calculator .note {font-size:11px;color:var(--muted);line-height:1.65;}
  #page-calculator .note strong {color:var(--text2);}

  @keyframes fadeUp{from{opacity:0;transform:translateY(10px);}to{opacity:1;transform:translateY(0);}}
  #page-calculator .card,
  #page-calculator .totals { margin-bottom: 14px; }
  #page-calculator .card, #page-calculator .totals {animation:fadeUp 0.4s ease both;}
  #page-calculator .totals {animation-delay:0.05s;}
  #page-calculator .card:nth-child(4) {animation-delay:0.08s;}
  #page-calculator .card:nth-child(5) {animation-delay:0.11s;}
  #page-calculator .card:nth-child(6) {animation-delay:0.14s;}
  #page-calculator .card:nth-child(7) {animation-delay:0.17s;}
  #page-calculator .card:nth-child(8) {animation-delay:0.20s;}

  /* ═══════════════════════════════════════════════
     MOBILE RESPONSIVENESS — MISSING BREAKPOINTS
     ═══════════════════════════════════════════════ */

  /* ── Timeline table: collapse 6 cols → 3 cols → 2 cols ── */
  @media(max-width:760px) {
    #page-distribution .tl-head,
    #page-distribution .tl-row { grid-template-columns: 2fr 1fr 1fr; }
    #page-distribution .th2:nth-child(n+4),
    #page-distribution .tc:nth-child(n+4) { display: none; }
  }
  @media(max-width:480px) {
    #page-distribution .tl-head,
    #page-distribution .tl-row { grid-template-columns: 2fr 1fr; }
    #page-distribution .th2:nth-child(n+3),
    #page-distribution .tc:nth-child(n+3) { display: none; }
  }

  /* ── Benchmark items: drop fixed 180px label col ── */
  @media(max-width:600px) {
    #page-calculator .bench-item { grid-template-columns: 1fr 52px; gap: 10px; padding: 10px 14px; }
  }
  @media(max-width:380px) {
    #page-calculator .bench-item { grid-template-columns: 1fr auto; gap: 8px; padding: 10px 12px; }
  }

  /* ── Phase pills: 3 cols → 2 cols → 1 col ── */
  @media(max-width:600px) {
    #page-calculator .phase-pills { grid-template-columns: repeat(2,1fr); }
    #page-calculator .phase-pill:nth-child(2) { border-right: none; }
    #page-calculator .phase-pill:nth-child(odd) { border-right: 1px solid var(--border); }
  }
  @media(max-width:380px) {
    #page-calculator .phase-pills { grid-template-columns: 1fr; }
    #page-calculator .phase-pill { border-right: none; border-bottom: 1px solid var(--border); }
    #page-calculator .phase-pill:last-child { border-bottom: none; }
  }

  /* ── Lock grid: 1 col on small phones ── */
  @media(max-width:380px) {
    .lock-grid { grid-template-columns: 1fr; }
  }

  /* ── Phishing banner: compact on mobile ── */
  @media(max-width:480px) {
    .phishing-banner { padding: 6px 12px; font-size: 10px; }
    .pb-warn:last-of-type { display: none; }
  }

  /* ── Disable entrance animations on mobile so content is immediately visible ── */
  @media(max-width:760px) {
    .anim, .anim-1, .anim-2, .anim-3, .anim-4 {
      animation: none !important;
      transform: none !important;
    }
  }

  /* ── Treasury thresholds: already collapses at 760px, ensure padding OK ── */
  @media(max-width:480px) {
    #page-distribution .thr-col { padding: 12px 10px; }
    #page-distribution .thr-amount { font-size: 14px; }
  }

  /* ══════════════════════════════════════════════════════════════
     MOBILE FIXES — calculator fee table + mcap/fee row
     ══════════════════════════════════════════════════════════════ */

  /* Stack the market-cap slider + fee-income table vertically on mobile */
  @media(max-width:600px) {
    .mcap-fee-row { grid-template-columns: 1fr !important; gap: 16px !important; }
  }

  /* Fee table: collapse 4 cols → 2 cols (source + weekly), hide rate + annual */
  @media(max-width:480px) {
    .fee-grid-row { grid-template-columns: 1fr 1fr !important; }
    .fee-grid-row > *:nth-child(2),
    .fee-grid-row > *:nth-child(4) { display: none !important; }
  }

  /* Pool size label + value: drop fixed min-widths on mobile */
  @media(max-width:600px) {
    .pool-meter-lbl { min-width: 0 !important; }
    #lbl-pool-size  { min-width: 0 !important; font-size: 10px !important; text-align: right; }
    .pool-meter-row { flex-wrap: wrap !important; gap: 6px !important; }
    .pool-meter-row input[type=range] { width: 100% !important; }
  }

  /* Distribution stream table: collapse 5 cols → 3 → 2 on mobile */
  @media(max-width:760px) {
    #page-distribution .s-top { grid-template-columns: 1fr 72px 72px; }
    #page-distribution .s-top > *:nth-child(4),
    #page-distribution .s-top > *:nth-child(5) { display: none; }
  }
  @media(max-width:480px) {
    #page-distribution .s-top { grid-template-columns: 1fr 64px; }
    #page-distribution .s-top > *:nth-child(3),
    #page-distribution .s-top > *:nth-child(4),
    #page-distribution .s-top > *:nth-child(5) { display: none; }
    #page-distribution .s-top { padding: 11px 14px; }
    #page-distribution .s-bar-wrap { padding: 0 14px 10px; }
  }

  /* Phishing banner: wrap on very narrow screens */
  @media(max-width:400px) {
    .phishing-banner { flex-wrap: wrap; justify-content: center; padding: 5px 10px; gap: 4px; }
  }

  /* Slider scale labels: prevent overflow */
  @media(max-width:480px) {
    #page-calculator .slider-scale { font-size: 8px; letter-spacing: 0; }
  }

  /* Home page allocation table: collapse 5 cols → 3 → 2 on mobile */
  @media(max-width:760px) {
    #page-home [style*="grid-template-columns:1fr 72px 72px 72px 56px"] {
      grid-template-columns: 1fr 72px 72px !important;
    }
    #page-home [style*="grid-template-columns:1fr 72px 72px 72px 56px"] > *:nth-child(4),
    #page-home [style*="grid-template-columns:1fr 72px 72px 72px 56px"] > *:nth-child(5) { display: none !important; }
  }
  @media(max-width:400px) {
    #page-home [style*="grid-template-columns:1fr 72px 72px 72px 56px"] {
      grid-template-columns: 1fr 72px !important;
    }
    #page-home [style*="grid-template-columns:1fr 72px 72px 72px 56px"] > *:nth-child(3),
    #page-home [style*="grid-template-columns:1fr 72px 72px 72px 56px"] > *:nth-child(4),
    #page-home [style*="grid-template-columns:1fr 72px 72px 72px 56px"] > *:nth-child(5) { display: none !important; }
  }

  /* Long note paragraph: ensure word-wrap */
  p.note { overflow-wrap: break-word; word-break: break-word; }

  /* Nav logo: prevent overflow on tiny phones */
  @media(max-width:360px) {
    .nav-inner { height: auto !important; min-height: 56px; padding-top: 6px; padding-bottom: 6px; }
  }
