/* ── Software page scoped styles ── */
.sw-page *, .sw-page *::before, .sw-page *::after { box-sizing:border-box; }
.sw-page {
  font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
  color:#1a1a1a; line-height:1.6;
  position:relative;
}

/* ── Ambient floating particles ── */
.sw-particles { position:fixed; inset:0; pointer-events:none; z-index:0; overflow:hidden; }
.sw-particle {
  position:absolute; border-radius:50%; opacity:0;
  animation:swFloat var(--dur,14s) ease-in-out infinite;
  animation-delay:var(--del,0s);
}
@keyframes swFloat {
  0%   { opacity:0; transform:translateY(100vh) scale(0) }
  10%  { opacity:1 }
  90%  { opacity:1 }
  100% { opacity:0; transform:translateY(-10vh) scale(1) }
}

/* ── Tab navigation ── */
.sw-tabs {
  display:flex; gap:6px; flex-wrap:wrap; justify-content:center;
  padding:18px 0 14px; margin-bottom:28px;
  position:relative; z-index:2;
  border-bottom:1px solid #e5e7eb;
}
.sw-tab {
  display:inline-flex; align-items:center; gap:8px;
  padding:10px 22px; border-radius:10px;
  background:transparent; border:1.5px solid transparent;
  font-size:14px; font-weight:600; color:#64748b;
  cursor:pointer; position:relative; overflow:hidden;
  transition:color 0.3s ease, background 0.3s ease, border-color 0.3s ease, box-shadow 0.3s ease, transform 0.3s cubic-bezier(.34,1.56,.64,1);
}
.sw-tab::after {
  content:''; position:absolute; bottom:0; left:50%; width:0; height:2.5px;
  background:linear-gradient(90deg,#6366f1,#3b82f6,#06b6d4);
  border-radius:2px; transition:width 0.35s cubic-bezier(.22,1,.36,1), left 0.35s cubic-bezier(.22,1,.36,1);
}
.sw-tab:not(.active):hover::after { width:60%; left:20%; }
.sw-tab:not(.active):hover {
  background:#f8fafc; color:#1e293b; border-color:#e2e8f0;
  box-shadow:0 4px 16px rgba(99,102,241,.08);
  transform:translateY(-2px);
}
.sw-tab:not(.active):hover .tab-icon { animation:swTabIconPop 0.4s cubic-bezier(.34,1.56,.64,1); }
@keyframes swTabIconPop { 0%{transform:scale(1)} 50%{transform:scale(1.25) rotate(-5deg)} 100%{transform:scale(1)} }
.sw-tab.active {
  background:#0f172a; color:#f8fafc; border-color:#0f172a;
  box-shadow:0 4px 20px rgba(15,23,42,.18);
}
.sw-tab.active::after { display:none; }
.sw-tab .tab-icon { font-size:15px; width:20px; text-align:center; transition:transform 0.3s ease; }
.sw-tab .tab-count {
  display:inline-flex; align-items:center; justify-content:center;
  min-width:22px; height:22px; padding:0 6px; border-radius:6px;
  background:rgba(0,0,0,.06); font-size:11px; font-weight:700;
  transition:background 0.3s ease, transform 0.3s ease;
}
.sw-tab:not(.active):hover .tab-count { background:rgba(99,102,241,.1); transform:scale(1.08); }
.sw-tab.active .tab-count { background:rgba(255,255,255,.12); }

/* ── Section headers ── */
.sw-section-hdr {
  display:flex; align-items:center; gap:12px;
  padding:18px 0 12px; margin-bottom:16px;
  border-bottom:1px solid #e5e7eb;
}
.sw-section-title { font-size:20px; font-weight:800; color:#0f172a; letter-spacing:-.02em; }
.sw-section-count { font-size:13px; color:#94a3b8; font-weight:600; margin-left:auto; }

/* ── Cards grid ── */
.sw-grid {
  display:grid; grid-template-columns:repeat(auto-fill, minmax(360px, 1fr));
  gap:20px; margin-bottom:36px;
  position:relative; z-index:1;
}

/* ── Card entrance ── */
@keyframes cardReveal {
  from { opacity:0; transform:translateY(30px); filter:blur(4px); }
  to   { opacity:1; transform:translateY(0); filter:blur(0); }
}
/* ── Card wrapper for animated border glow ── */
.sw-card {
  position:relative; border-radius:16px; padding:0;
  background:#fff; border:1px solid #e5e7eb;
  overflow:hidden;
  animation:cardReveal 0.8s cubic-bezier(.22,1,.36,1) both;
  display:flex; flex-direction:column;
  transition:border-color 0.35s ease, box-shadow 0.4s cubic-bezier(.22,1,.36,1), transform 0.35s cubic-bezier(.34,1.56,.64,1);
}
/* Spotlight radial glow — sits behind content */
.sw-card::before {
  content:''; position:absolute; top:-50%; left:-50%; width:200%; height:200%;
  background:radial-gradient(circle at 30% 30%, var(--sw-glow, rgba(99,102,241,.06)) 0%, transparent 60%);
  opacity:0; transition:opacity 0.5s ease;
  pointer-events:none; z-index:0;
}
.sw-card:hover::before { opacity:1; }
.sw-card:hover {
  border-color:#c7d2fe;
  box-shadow:
    0 4px 12px rgba(99,102,241,.06),
    0 12px 40px rgba(99,102,241,.10),
    0 0 0 1px rgba(99,102,241,.08);
  transform:translateY(-5px);
}
.sw-card[data-cat="library"] { --sw-glow:rgba(99,102,241,.07); }
.sw-card[data-cat="app"] { --sw-glow:rgba(16,185,129,.07); }
.sw-card[data-cat="app"]:hover {
  border-color:#a7f3d0;
  box-shadow:
    0 4px 12px rgba(16,185,129,.06),
    0 12px 40px rgba(16,185,129,.10),
    0 0 0 1px rgba(16,185,129,.08);
}

/* accent bar with animated gradient */
.sw-card-accent {
  position:absolute; top:0; left:0; right:0; height:3px;
  background-size:200% 100%;
  animation:swAccentFlow 3s ease-in-out infinite;
  transition:height 0.4s cubic-bezier(.22,1,.36,1), filter 0.4s ease;
  z-index:1;
}
.sw-card:hover .sw-card-accent { height:5px; filter:brightness(1.2) saturate(1.3); }
@keyframes swAccentFlow {
  0%,100% { background-position:0% 50%; }
  50% { background-position:100% 50%; }
}
.sw-card[data-cat="library"] .sw-card-accent { background:linear-gradient(90deg,#3b82f6,#6366f1,#818cf8,#6366f1,#3b82f6); background-size:200% 100%; }
.sw-card[data-cat="app"] .sw-card-accent { background:linear-gradient(90deg,#10b981,#06b6d4,#14b8a6,#06b6d4,#10b981); background-size:200% 100%; }

.sw-card-body { padding:24px 22px 16px; flex:1; position:relative; z-index:1; }
.sw-card-top {
  display:flex; align-items:flex-start; justify-content:space-between; gap:12px;
  margin-bottom:10px;
}
.sw-card-title {
  font-size:18px; font-weight:800; color:#0f172a; margin:0;
  letter-spacing:-.01em;
  transition:color 0.3s ease;
}
.sw-card[data-cat="library"]:hover .sw-card-title { color:#312e81; }
.sw-card[data-cat="app"]:hover .sw-card-title { color:#064e3b; }
.sw-card-cat-badge {
  display:inline-flex; align-items:center; gap:5px;
  padding:4px 10px; border-radius:6px;
  font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:.04em;
  white-space:nowrap; flex-shrink:0;
  transition:background 0.3s ease, color 0.3s ease, transform 0.3s cubic-bezier(.34,1.56,.64,1), box-shadow 0.3s ease;
}
.sw-card[data-cat="library"] .sw-card-cat-badge { background:#eff6ff; color:#3b82f6; }
.sw-card[data-cat="app"] .sw-card-cat-badge { background:#ecfdf5; color:#10b981; }
.sw-card:hover .sw-card-cat-badge { transform:scale(1.08); }
.sw-card[data-cat="library"]:hover .sw-card-cat-badge { background:#dbeafe; color:#1d4ed8; box-shadow:0 2px 8px rgba(59,130,246,.15); }
.sw-card[data-cat="app"]:hover .sw-card-cat-badge { background:#d1fae5; color:#047857; box-shadow:0 2px 8px rgba(16,185,129,.15); }

.sw-card-desc {
  font-size:14px; color:#64748b; margin:0 0 14px; line-height:1.65;
  display:-webkit-box; -webkit-line-clamp:3; -webkit-box-orient:vertical; overflow:hidden;
  transition:color 0.3s ease;
}
.sw-card:hover .sw-card-desc { color:#475569; }

/* ── Tags (informational pills) ── */
.sw-tags { display:flex; flex-wrap:wrap; gap:6px; align-items:center; margin-bottom:12px; }
.sw-tags-label {
  font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:.05em;
  color:#94a3b8; margin-right:4px;
}
.sw-tag {
  display:inline-flex; align-items:center; gap:5px;
  padding:4px 10px; border-radius:20px;
  background:#f1f5f9; border:1px dashed #d1d5db;
  font-size:11px; font-weight:600; color:#64748b;
  cursor:default; position:relative; overflow:hidden;
  transition:background 0.3s ease, border-color 0.3s ease, color 0.3s ease, transform 0.3s cubic-bezier(.34,1.56,.64,1), box-shadow 0.3s ease;
}
/* shimmer sweep on hover */
.sw-tag::before {
  content:''; position:absolute; top:0; left:-100%; width:100%; height:100%;
  background:linear-gradient(90deg, transparent, rgba(255,255,255,.6), transparent);
  transition:none;
}
.sw-tag:hover::before { left:100%; transition:left 0.5s ease; }
.sw-tag:hover {
  background:#e0e7ff; border-color:#a5b4fc; border-style:solid; color:#4338ca;
  transform:translateY(-2px);
  box-shadow:0 3px 10px rgba(99,102,241,.1);
}
.sw-tag:hover .tag-icon { animation:swTagIconBounce 0.4s cubic-bezier(.34,1.56,.64,1); }
@keyframes swTagIconBounce { 0%{transform:scale(1)} 40%{transform:scale(1.3)} 100%{transform:scale(1)} }
.sw-tag .tag-icon { font-size:12px; width:14px; text-align:center; transition:transform 0.3s ease; }

/* ── Available-on links ── */
.sw-links { display:flex; flex-wrap:wrap; gap:6px; align-items:center; margin-bottom:4px; }
.sw-links-label {
  font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:.05em;
  color:#94a3b8; margin-right:4px;
}
.sw-link-badge {
  display:inline-flex; align-items:center; gap:5px;
  padding:4px 12px; border-radius:20px;
  background:#fff; border:1px solid #e2e8f0;
  font-size:11px; font-weight:600; color:#475569;
  text-decoration:none; position:relative; overflow:hidden;
  transition:border-color 0.3s ease, color 0.3s ease, box-shadow 0.35s ease, transform 0.3s cubic-bezier(.34,1.56,.64,1);
}
/* sweep fill from left */
.sw-link-badge::before {
  content:''; position:absolute; top:0; left:0; width:0; height:100%;
  background:linear-gradient(135deg,#eef2ff,#e0e7ff);
  border-radius:inherit; transition:width 0.35s cubic-bezier(.22,1,.36,1);
  z-index:0;
}
.sw-link-badge:hover::before { width:100%; }
.sw-link-badge > span,
.sw-link-badge > i { position:relative; z-index:1; }
.sw-link-badge:hover {
  border-color:#818cf8; color:#3730a3;
  box-shadow:0 4px 14px rgba(99,102,241,.14);
  transform:translateY(-2px);
}
.sw-link-badge:hover .sw-link-arrow { opacity:1; transform:translate(2px, -1px); }
.sw-link-badge:hover .link-icon { animation:swLinkIconPulse 0.5s ease; }
@keyframes swLinkIconPulse { 0%{transform:scale(1)} 50%{transform:scale(1.3)} 100%{transform:scale(1)} }
.sw-link-badge .link-icon { font-size:12px; width:14px; text-align:center; transition:transform 0.3s ease; }
.sw-link-arrow { font-size:9px; opacity:.4; margin-left:2px; transition:opacity 0.3s ease, transform 0.3s ease; }

/* ── Card footer — all action links go here ── */
.sw-card-footer {
  display:flex; align-items:center; flex-wrap:wrap; gap:8px;
  padding:12px 22px; background:#fafbfc; border-top:1px solid #f1f5f9;
  position:relative; z-index:1;
  transition:background 0.3s ease;
}
.sw-card:hover .sw-card-footer { background:#f8fafc; }
.sw-action-link {
  display:inline-flex; align-items:center; gap:6px;
  padding:7px 14px; border-radius:8px;
  font-size:13px; font-weight:600; color:#475569;
  text-decoration:none;
  background:#fff; border:1px solid #e5e7eb;
  position:relative; overflow:hidden;
  transition:color 0.3s ease, border-color 0.3s ease, box-shadow 0.35s ease, transform 0.3s cubic-bezier(.34,1.56,.64,1);
}
/* dark sweep fill from left */
.sw-action-link::before {
  content:''; position:absolute; top:0; left:0; width:0; height:100%;
  background:#0f172a; border-radius:inherit;
  transition:width 0.35s cubic-bezier(.22,1,.36,1);
  z-index:0;
}
.sw-action-link:hover::before { width:100%; }
.sw-action-link > i,
.sw-action-link > span { position:relative; z-index:1; }
.sw-action-link:hover {
  color:#f8fafc; border-color:#0f172a;
  box-shadow:0 4px 16px rgba(15,23,42,.2);
  transform:translateY(-2px);
}
.sw-action-link:hover i { animation:swActionIconSlide 0.4s cubic-bezier(.34,1.56,.64,1); }
@keyframes swActionIconSlide { 0%{transform:translateX(0)} 30%{transform:translateX(-3px)} 100%{transform:translateX(0)} }
.sw-action-link i { font-size:14px; position:relative; z-index:1; transition:transform 0.3s ease; }

/* ── Empty state ── */
.sw-empty { text-align:center; padding:80px 20px; color:#94a3b8; }
.sw-empty-icon { font-size:42px; margin-bottom:16px; opacity:.4; }
.sw-empty-text { font-size:16px; font-weight:600; color:#64748b; }

/* ── Override global icons.css for sw-page ── */
.sw-page .fa,
.sw-page .fas,
.sw-page .fab,
.sw-page .far {
  padding:0 !important; font-size:inherit !important; width:auto !important;
  text-decoration:none !important;
  margin:0 !important; background:none !important;
  display:inline-block !important;
}

/* ── Responsive ── */
@media (max-width:768px) {
  .sw-grid { grid-template-columns:1fr; }
  .sw-tabs { gap:4px; }
  .sw-tab { padding:8px 14px; font-size:13px; }
}
