/* ═══════════════════════════════════════════════════
   modules.css — All new feature module styles
   Limit Orders, Perps, Predict, Lottery, NFT,
   Launchpad, Governance, Platform extras
   Uses existing design vars — NO color/font changes
═══════════════════════════════════════════════════ */

/* ── SHARED MODULE LAYOUT ── */
.mod-layout{display:grid;grid-template-columns:1fr 1fr;gap:16px;max-width:1100px;margin:0 auto}
.mod-layout-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px;max-width:1200px;margin:0 auto}
.mod-layout-single{max-width:560px;margin:0 auto}
@media(max-width:900px){.mod-layout,.mod-layout-3{grid-template-columns:1fr}}
.mod-card{background:var(--panel);border:1px solid var(--panelborder);border-radius:16px;padding:18px;backdrop-filter:blur(12px);position:relative;overflow:hidden}
.mod-card::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(240,185,11,.2),transparent)}
.mod-title{font-weight:800;font-size:.92rem;margin-bottom:14px;display:flex;align-items:center;gap:8px}
.mod-sub{font-size:.68rem;color:var(--muted);margin-top:-10px;margin-bottom:14px}
.mod-row{display:flex;gap:8px;margin-bottom:10px}
.mod-field{flex:1}
.mod-label{font-size:.64rem;color:var(--muted);margin-bottom:4px;text-transform:uppercase;letter-spacing:.4px;font-weight:600}
.mod-input{width:100%;padding:9px 12px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:10px;color:var(--text);font-size:.82rem;font-family:var(--mono);outline:none;transition:border .2s;box-sizing:border-box}
.mod-input:focus{border-color:rgba(240,185,11,.35)}
.mod-select{width:100%;padding:9px 12px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:10px;color:var(--text);font-size:.82rem;font-family:var(--mono);outline:none;appearance:none;cursor:pointer;box-sizing:border-box;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center}
.mod-select option{background:#0d1b2a;color:var(--text)}
.mod-btn{padding:11px 16px;border:none;border-radius:12px;font-size:.82rem;font-weight:800;cursor:pointer;transition:all .2s;font-family:var(--font);display:flex;align-items:center;justify-content:center;gap:6px;width:100%}
.mod-btn-gold{background:var(--gold);color:#000}.mod-btn-gold:hover{background:#ffd026;box-shadow:0 6px 20px rgba(240,185,11,.4);transform:translateY(-1px)}
.mod-btn-green{background:linear-gradient(135deg,#10B981,#059669);color:#fff}.mod-btn-green:hover{box-shadow:0 6px 20px rgba(16,185,129,.4)}
.mod-btn-red{background:linear-gradient(135deg,#EF4444,#DC2626);color:#fff}.mod-btn-red:hover{box-shadow:0 6px 20px rgba(239,68,68,.4)}
.mod-btn-cyan{background:linear-gradient(135deg,#06B6D4,#0891B2);color:#fff}.mod-btn-cyan:hover{box-shadow:0 6px 20px rgba(6,182,212,.4)}
.mod-btn-outline{background:rgba(255,255,255,.04);color:var(--text);border:1px solid rgba(255,255,255,.1)}.mod-btn-outline:hover{background:rgba(240,185,11,.08);border-color:rgba(240,185,11,.3);color:var(--gold)}
.mod-btn:disabled{opacity:.4;cursor:not-allowed;transform:none!important;box-shadow:none!important}
.mod-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:6px;font-size:.62rem;font-weight:700}
.mod-badge-green{background:rgba(16,185,129,.12);color:#10B981;border:1px solid rgba(16,185,129,.2)}
.mod-badge-gold{background:rgba(240,185,11,.1);color:var(--gold);border:1px solid rgba(240,185,11,.2)}
.mod-badge-red{background:rgba(239,68,68,.1);color:#EF4444;border:1px solid rgba(239,68,68,.2)}
.mod-badge-cyan{background:rgba(0,212,255,.08);color:var(--cyan);border:1px solid rgba(0,212,255,.2)}
.mod-divider{border:none;border-top:1px solid rgba(255,255,255,.06);margin:14px 0}
.mod-info-row{display:flex;justify-content:space-between;font-size:.74rem;padding:4px 0;color:var(--muted)}.mod-info-row span:last-child{color:var(--text);font-weight:600;font-family:var(--mono)}
.mod-tabs{display:flex;gap:4px;margin-bottom:14px}.mod-tab{padding:7px 14px;border-radius:8px;border:1px solid rgba(255,255,255,.08);background:none;color:var(--muted);font-size:.72rem;font-weight:600;cursor:pointer;font-family:var(--font);transition:all .15s}.mod-tab.active,.mod-tab:hover{background:rgba(240,185,11,.1);color:var(--gold);border-color:rgba(240,185,11,.3)}
.mod-empty{text-align:center;padding:30px;color:var(--muted);font-size:.78rem}
.mod-list{max-height:400px;overflow-y:auto;scrollbar-width:thin;scrollbar-color:rgba(240,185,11,.2) transparent}

/* ── ORDER BOOK ── */
.ob-row{display:flex;align-items:center;gap:8px;padding:6px 10px;border-radius:8px;margin-bottom:4px;font-size:.72rem;transition:background .15s;cursor:pointer}
.ob-row:hover{background:rgba(255,255,255,.04)}
.ob-row.buy{border-left:3px solid #10B981;background:rgba(16,185,129,.03)}
.ob-row.sell{border-left:3px solid #EF4444;background:rgba(239,68,68,.03)}
.ob-side{font-weight:800;min-width:36px;font-size:.64rem;text-transform:uppercase}
.ob-row.buy .ob-side{color:#10B981}.ob-row.sell .ob-side{color:#EF4444}
.ob-pair{font-weight:600;flex:1}.ob-price{font-family:var(--mono);font-weight:600;min-width:80px;text-align:right}
.ob-amt{font-family:var(--mono);color:var(--muted);min-width:70px;text-align:right}
.ob-status{font-size:.58rem;min-width:50px;text-align:right}
.ob-status.open{color:var(--gold)}.ob-status.filled{color:#10B981}.ob-status.expired{color:var(--muted)}
.ob-cancel{background:none;border:1px solid rgba(239,68,68,.2);color:#EF4444;font-size:.58rem;padding:2px 8px;border-radius:5px;cursor:pointer;font-family:var(--font)}.ob-cancel:hover{background:rgba(239,68,68,.1)}

/* ── PERP POSITION ── */
.perp-pos{padding:10px 12px;border:1px solid rgba(255,255,255,.06);border-radius:12px;margin-bottom:8px}
.perp-pos-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}
.perp-pos-pair{font-weight:700;font-size:.82rem}.perp-pos-side{font-weight:800;font-size:.68rem;text-transform:uppercase}
.perp-pos-side.long{color:#10B981}.perp-pos-side.short{color:#EF4444}
.perp-pos-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:6px}
.perp-pos-stat{text-align:center}.perp-pos-label{font-size:.56rem;color:var(--muted);text-transform:uppercase}.perp-pos-val{font-size:.78rem;font-weight:700;font-family:var(--mono)}
.perp-lev-btns{display:flex;gap:4px;flex-wrap:wrap}
.perp-lev-btn{padding:5px 10px;border-radius:6px;border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.03);color:var(--muted);font-size:.66rem;font-weight:700;cursor:pointer;font-family:var(--mono)}.perp-lev-btn.active,.perp-lev-btn:hover{background:rgba(240,185,11,.1);border-color:rgba(240,185,11,.3);color:var(--gold)}
/* ── MODERN PERPS BUTTONS (LONG, SHORT, Close All) ── */
.perp-btn-long,.perp-btn-short,.perp-btn-close{padding:10px 20px;border-radius:12px;font-size:.8rem;font-weight:800;cursor:pointer;transition:all .2s ease;font-family:var(--font);border:none;box-shadow:0 2px 8px rgba(0,0,0,.15)}
.perp-btn-long{background:linear-gradient(135deg,#10B981 0%,#059669 100%);color:#fff;box-shadow:0 4px 14px rgba(16,185,129,.35)}.perp-btn-long:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(16,185,129,.45)}
.perp-btn-long.outline{background:rgba(255,255,255,.04);color:#10B981;border:2px solid rgba(16,185,129,.4);box-shadow:none}.perp-btn-long.outline:hover{background:rgba(16,185,129,.08);border-color:#10B981}
.perp-btn-short{background:linear-gradient(135deg,#EF4444 0%,#DC2626 100%);color:#fff;box-shadow:0 4px 14px rgba(239,68,68,.35)}.perp-btn-short:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(239,68,68,.45)}
.perp-btn-short.outline{background:rgba(255,255,255,.04);color:#EF4444;border:2px solid rgba(239,68,68,.4);box-shadow:none}.perp-btn-short.outline:hover{background:rgba(239,68,68,.08);border-color:#EF4444}
.perp-btn-close{background:linear-gradient(135deg,#EF4444 0%,#B91C1C 100%);color:#fff;padding:6px 14px;font-size:.7rem;border-radius:10px;box-shadow:0 3px 10px rgba(239,68,68,.3)}.perp-btn-close:hover{transform:translateY(-1px);box-shadow:0 5px 16px rgba(239,68,68,.4)}

/* ── PREDICTION CARDS ── */
.pred-card{border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:14px;margin-bottom:10px;transition:border-color .2s}
.pred-card:hover{border-color:rgba(240,185,11,.2)}
.pred-q{font-weight:700;font-size:.84rem;margin-bottom:8px;line-height:1.4}
.pred-meta{display:flex;gap:12px;font-size:.64rem;color:var(--muted);margin-bottom:10px;flex-wrap:wrap}
.pred-opts{display:flex;gap:8px}.pred-opt{flex:1;padding:10px;border-radius:10px;border:1.5px solid rgba(255,255,255,.08);text-align:center;cursor:pointer;transition:all .2s}
.pred-opt:hover{border-color:rgba(240,185,11,.2);background:rgba(240,185,11,.03)}
.pred-opt.yes:hover,.pred-opt.yes.active{border-color:#10B981;background:rgba(16,185,129,.08)}
.pred-opt.no:hover,.pred-opt.no.active{border-color:#EF4444;background:rgba(239,68,68,.08)}
.pred-opt-label{font-weight:700;font-size:.76rem;margin-bottom:2px}.pred-opt-odds{font-family:var(--mono);font-size:.82rem;font-weight:800}
.pred-opt.yes .pred-opt-odds{color:#10B981}.pred-opt.no .pred-opt-odds{color:#EF4444}
.pred-pool{font-size:.62rem;color:var(--muted);margin-top:3px}

/* ── LOTTERY ── */
.lotto-ball{width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:.88rem;font-family:var(--mono);box-shadow:inset 0 -3px 6px rgba(0,0,0,.3),0 2px 8px rgba(0,0,0,.2)}
.lotto-balls{display:flex;gap:8px;justify-content:center;margin:16px 0;flex-wrap:wrap}
.lotto-ticket{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:12px;margin-bottom:8px;display:flex;align-items:center;justify-content:space-between}
.lotto-nums{display:flex;gap:4px}.lotto-num{width:28px;height:28px;border-radius:50%;background:rgba(240,185,11,.1);border:1px solid rgba(240,185,11,.2);display:flex;align-items:center;justify-content:center;font-size:.66rem;font-weight:700;font-family:var(--mono);color:var(--gold)}

/* ── NFT GRID ── */
.nft-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px}
.nft-item{border:1px solid rgba(255,255,255,.08);border-radius:14px;overflow:hidden;cursor:pointer;transition:all .2s}
.nft-item:hover{border-color:rgba(240,185,11,.3);transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.3)}
.nft-img{width:100%;aspect-ratio:1;background:linear-gradient(135deg,rgba(240,185,11,.08),rgba(0,212,255,.08));display:flex;align-items:center;justify-content:center;font-size:2.5rem}
.nft-info{padding:10px 12px}.nft-name{font-weight:700;font-size:.76rem;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.nft-collection{font-size:.6rem;color:var(--muted)}.nft-price{font-weight:700;font-size:.78rem;color:var(--gold);margin-top:4px;font-family:var(--mono)}

/* ── LAUNCHPAD ── */
.launch-card{border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:16px;margin-bottom:12px;transition:border-color .2s}
.launch-card:hover{border-color:rgba(240,185,11,.2)}
.launch-head{display:flex;align-items:center;gap:12px;margin-bottom:12px}
.launch-icon{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.4rem;flex-shrink:0}
.launch-name{font-weight:800;font-size:.92rem}.launch-sym{font-size:.68rem;color:var(--muted)}
.launch-progress{height:8px;background:rgba(255,255,255,.06);border-radius:4px;overflow:hidden;margin:10px 0}
.launch-progress-bar{height:100%;border-radius:4px;background:linear-gradient(90deg,var(--gold),var(--cyan));transition:width .5s}

/* ── GOVERNANCE ── */
.gov-proposal{border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:14px;margin-bottom:10px;cursor:pointer;transition:border-color .2s}
.gov-proposal:hover{border-color:rgba(240,185,11,.2)}
.gov-proposal-id{font-size:.6rem;color:var(--muted);font-family:var(--mono)}
.gov-proposal-title{font-weight:700;font-size:.84rem;margin:4px 0;line-height:1.4}
.gov-vote-bar{height:6px;background:rgba(255,255,255,.06);border-radius:3px;overflow:hidden;margin:8px 0;display:flex}
.gov-vote-for{height:100%;background:#10B981;border-radius:3px 0 0 3px}.gov-vote-against{height:100%;background:#EF4444}
.gov-vote-counts{display:flex;justify-content:space-between;font-size:.64rem;font-family:var(--mono)}
.gov-vote-counts .for{color:#10B981}.gov-vote-counts .against{color:#EF4444}

/* ── PLATFORM FEATURE GRID ── */
.plat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px}
.plat-card{background:var(--panel);border:1px solid var(--panelborder);border-radius:14px;padding:16px;transition:all .2s}
.plat-card:hover{border-color:rgba(240,185,11,.2)}
.plat-card-icon{font-size:1.6rem;margin-bottom:8px}
.plat-card-title{font-weight:800;font-size:.84rem;margin-bottom:4px}
.plat-card-desc{font-size:.68rem;color:var(--muted);line-height:1.5;margin-bottom:10px}
.plat-card-status{font-size:.6rem;font-weight:700}
.plat-card-status.live{color:#10B981}.plat-card-status.soon{color:var(--gold)}.plat-card-status.active{color:var(--cyan)}
.plat-toggle-row{display:flex;align-items:center;justify-content:space-between;padding:6px 0}
.plat-toggle-label{font-size:.74rem}
