/* SteelCtrl — Projects Portal & Project Cards
   Source: SteelCtrl_v5_EBEESCORP.html L332–383
   Sections: Portal Top Nav, Project Table Row, Project Card, Misc Utilities
   Depends on: tokens.css
   ─────────────────────────────────────────── */

/* ── PORTAL (Projects List) ── */
.portal-topnav{height:54px;background:var(--base);border-bottom:1px solid var(--line);display:flex;align-items:center;padding:0 24px;gap:16px;flex-shrink:0;position:sticky;top:0;z-index:20}
.portal-logo{display:flex;align-items:center;gap:10px}
.portal-nav-links{display:flex;align-items:center;gap:2px}
.portal-nav-link{padding:6px 12px;font-size:12px;font-weight:500;color:var(--txt2);cursor:pointer;border-radius:5px;transition:all .15s}
.portal-nav-link:hover{color:var(--txt);background:rgba(255,255,255,0.04)}
.portal-nav-link.active{color:var(--gold);background:var(--gold-dim)}
.portal-body{padding:28px 32px}
.portal-heading{font-family:var(--display);font-size:26px;font-weight:700;margin-bottom:4px}
.portal-subheading{font-size:12px;color:var(--txt2);margin-bottom:24px}
.search-row{display:flex;align-items:center;gap:10px;margin-bottom:16px}
.search-box{position:relative;flex:1;max-width:360px}
.search-box i{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--txt3);font-size:16px}
.search-input{background:var(--raised);border:1px solid var(--line2);color:var(--txt);padding:8px 12px 8px 36px;border-radius:6px;font-size:12px;width:100%;transition:border-color .15s}
.search-input:focus{border-color:var(--gold);outline:none}
.search-input::placeholder{color:var(--txt3)}
.filter-btn{display:flex;align-items:center;gap:6px;padding:7px 12px;border:1px solid var(--line2);background:var(--raised);color:var(--txt2);border-radius:6px;cursor:pointer;font-size:11px;transition:all .15s}
.filter-btn:hover{border-color:var(--line3);color:var(--txt)}
.project-table-wrap{background:var(--raised);border:1px solid var(--line);border-radius:8px;overflow:hidden}
.project-table-row{display:grid;grid-template-columns:1fr 120px 130px 110px 110px 120px 80px 60px;align-items:center;padding:12px 16px;border-bottom:1px solid var(--line);cursor:pointer;transition:background .15s;gap:12px}
.project-table-row:last-child{border-bottom:none}
.project-table-row:hover{background:rgba(255,255,255,0.025)}
.project-table-header{background:var(--base);font-size:9px;letter-spacing:1.5px;text-transform:uppercase;color:var(--txt3);padding:10px 16px;display:grid;grid-template-columns:1fr 120px 130px 110px 110px 120px 80px 60px;gap:12px;border-bottom:1px solid var(--line)}
.proj-name{font-size:13px;font-weight:600;color:var(--txt);margin-bottom:3px}
.proj-meta{font-size:10px;color:var(--txt3)}
.proj-mt{font-family:var(--mono);font-size:13px;font-weight:500}
.proj-progress-mini{margin-top:5px}

/* ── PROJECT CARD ── */
.project-card{background:var(--raised);border:1px solid var(--line);border-radius:10px;overflow:hidden;cursor:pointer;transition:all .2s;position:relative}
.project-card:hover{border-color:var(--gold-glow);transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,0.3)}
.pc-accent{height:3px;width:100%}
.pc-body{padding:18px}
.pc-code{font-family:var(--mono);font-size:9px;color:var(--txt3);letter-spacing:2px;margin-bottom:6px}
.pc-name{font-family:var(--display);font-size:14px;font-weight:700;margin-bottom:10px;line-height:1.3}
.pc-stats{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-bottom:12px}
.pc-stat{text-align:center;padding:8px;background:var(--float);border-radius:6px}
.pc-stat-v{font-family:var(--mono);font-size:14px;font-weight:600}
.pc-stat-l{font-size:9px;color:var(--txt3);letter-spacing:1px;text-transform:uppercase;margin-top:2px}
.pc-footer{display:flex;align-items:center;justify-content:space-between;padding-top:10px;border-top:1px solid var(--line)}

/* ── MISC UTILITIES ── */
.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}
.justify-between{justify-content:space-between}.gap-6{gap:6px}.gap-8{gap:8px}.gap-10{gap:10px}
.gap-12{gap:12px}.gap-14{gap:14px}.flex-1{flex:1}.min-w-0{min-width:0}.w-full{width:100%}
.mb-6{margin-bottom:6px}.mb-8{margin-bottom:8px}.mb-10{margin-bottom:10px}.mb-12{margin-bottom:12px}
.mb-14{margin-bottom:14px}.mb-16{margin-bottom:16px}.mt-8{margin-top:8px}.mt-12{margin-top:12px}
.mt-16{margin-top:16px}.p-12{padding:12px}.p-16{padding:16px}.hidden{display:none!important}
.overflow-hidden{overflow:hidden}.text-right{text-align:right}.text-center{text-align:center}
.font-mono{font-family:var(--mono)}.font-display{font-family:var(--display)}.uppercase{text-transform:uppercase}
.truncate{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

