/* ═══════════════════════════════════════════════════
   skills.css — Skills / Tools / Hardware page styles
   ═══════════════════════════════════════════════════ */

/* ── SKILLS GRID ── */
.skills-wide { display: flex; flex-wrap: wrap; justify-content: center; gap: 16px; }
.sk-card { padding: 22px 26px; width: 260px; flex: 0 0 260px; }
.sk-top { display: flex; justify-content: space-between; align-items: center; margin-bottom: 14px; }
.sk-name { font-size: 12.5px; font-weight: 600; color: var(--text-primary); }
.sk-num  { font-size: 24px; font-weight: 700; font-family: 'JetBrains Mono',monospace; color: transparent; background: linear-gradient(135deg, var(--accent), rgba(var(--accent-rgb),0.4)); -webkit-background-clip: text; background-clip: text; line-height: 1; }
.sk-track { height: 3px; border-radius: 100px; background: rgba(255,255,255,0.06); overflow: hidden; box-shadow: inset 1px 1px 3px rgba(0,0,0,0.3); }
.sk-fill  { height: 100%; width: 0; border-radius: 100px; background: linear-gradient(90deg, rgba(var(--accent-rgb),0.6), var(--accent)); box-shadow: 0 0 10px rgba(var(--accent-rgb),0.4); transition: width 1.4s cubic-bezier(.22,1,.36,1); }
.sk-tag   { display: inline-flex; margin-top: 12px; padding: 3px 10px; border-radius: 7px; font-size: 9.5px; letter-spacing: 0.12em; text-transform: uppercase; background: var(--accent-soft); color: var(--accent); font-weight: 600; }

/* ── TOOLS SECTION ── */
.tools-section { margin-bottom: 80px; }
.tools-category { margin-bottom: 48px; }
.cat-header { font-size: 11px; font-weight: 600; letter-spacing: 0.18em; text-transform: uppercase; color: var(--text-secondary); margin-bottom: 24px; display: flex; align-items: center; justify-content: center; gap: 16px; white-space: nowrap; }
.cat-header::before, .cat-header::after { content: ''; flex: 1; max-width: 120px; height: 1px; background: var(--glass-border); }
.tools-grid { display: flex; flex-wrap: wrap; justify-content: center; gap: 16px; }
.tool-card { padding: 22px 16px; border-radius: 18px; background: var(--glass-bg); border: 1px solid var(--glass-border); backdrop-filter: blur(18px); box-shadow: inset 0 1px 0 rgba(255,255,255,0.12), 5px 6px 18px var(--neo-dark), -3px -3px 10px var(--neo-light); display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 10px; text-align: center; text-decoration: none; width: 160px; height: 140px; flex: 0 0 160px; transition: transform .35s cubic-bezier(.34,1.4,.64,1), box-shadow .35s, border-color .25s; cursor: pointer; }
.tool-card:hover { transform: translateY(-6px) scale(1.04); border-color: rgba(var(--accent-rgb),0.3); box-shadow: inset 0 1px 0 rgba(255,255,255,0.18), 8px 12px 28px var(--neo-dark), 0 0 28px rgba(var(--accent-rgb),0.12); }
.tool-logo { width: 44px; height: 44px; border-radius: 12px; overflow: hidden; background: rgba(255,255,255,0.06); border: 1px solid var(--glass-border); display: flex; align-items: center; justify-content: center; box-shadow: inset 2px 2px 6px rgba(0,0,0,0.3); flex-shrink: 0; }
.tool-logo img { width: 100%; height: 100%; object-fit: contain; padding: 7px; }
.tool-logo .fallback { font-size: 16px; font-weight: 700; color: var(--accent); }
.tool-name { font-size: 11.5px; font-weight: 600; color: var(--text-primary); letter-spacing: 0.02em; line-height: 1.3; }
.tool-desc { font-size: 10px; color: var(--text-muted); letter-spacing: 0.04em; line-height: 1.4; }

/* ── HARDWARE GRID ── */
.hw-grid { display: flex; flex-wrap: wrap; justify-content: center; gap: 20px; }
.hw-card { padding: 22px 18px; border-radius: 20px; background: var(--glass-bg); border: 1px solid var(--glass-border); backdrop-filter: blur(18px); box-shadow: inset 0 1.5px 0 rgba(255,255,255,0.14), 6px 8px 22px var(--neo-dark), -3px -3px 10px var(--neo-light); display: flex; flex-direction: column; align-items: center; gap: 12px; text-align: center; text-decoration: none; width: 220px; flex: 0 0 220px; transition: transform .35s cubic-bezier(.34,1.4,.64,1), box-shadow .35s, border-color .25s; }
.hw-card:hover { transform: translateY(-6px) scale(1.04); border-color: rgba(var(--accent-rgb),0.3); box-shadow: inset 0 1.5px 0 rgba(255,255,255,0.18), 10px 16px 36px var(--neo-dark), 0 0 32px rgba(var(--accent-rgb),0.14); }
.hw-img-wrap { width: 100%; height: 130px; border-radius: 14px; overflow: hidden; background: rgba(0,0,0,0.55); border: 1px solid var(--glass-border); display: flex; align-items: center; justify-content: center; box-shadow: inset 2px 2px 8px rgba(0,0,0,0.4); position: relative; }
[data-theme="light"] .hw-img-wrap { background: rgba(18,20,28,0.82); border-color: rgba(255,255,255,0.3); }
.hw-img-wrap img { width: 100%; height: 100%; object-fit: contain; padding: 10px; transition: transform .4s cubic-bezier(.34,1.3,.64,1), filter .4s; filter: drop-shadow(0 4px 12px rgba(0,0,0,0.5)); }
.hw-card:hover .hw-img-wrap img { transform: scale(1.06) translateY(-3px); filter: drop-shadow(0 8px 20px rgba(var(--accent-rgb),0.25)); }
.hw-name { font-size: 12.5px; font-weight: 700; color: var(--text-primary); line-height: 1.35; }
.hw-cat  { font-size: 10px; font-weight: 600; letter-spacing: 0.12em; text-transform: uppercase; color: var(--accent); padding: 3px 10px; border-radius: 6px; background: var(--accent-soft); border: 1px solid rgba(var(--accent-rgb),0.2); }
.hw-desc { font-size: 11px; color: var(--text-muted); line-height: 1.6; white-space: pre-line; text-align: center; }
.hw-link { font-size: 10.5px; font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; color: var(--accent); text-decoration: none; display: flex; align-items: center; gap: 5px; opacity: 0.7; transition: opacity .2s; }
.hw-link:hover { opacity: 1; }
.hw-link svg { width: 10px; height: 10px; stroke: var(--accent); fill: none; stroke-width: 2.5; }

