/* =========================================================
   SOFTWARES LAKE — MAIN STYLESHEET
   Design system: "Verified Archive" — ink navy / warm paper,
   amber + green accents, Space Grotesk + Inter + JetBrains Mono
   ========================================================= */

:root{
  --ink:#10151F;
  --ink-soft:#1A222F;
  --ink-line: rgba(255,255,255,0.08);
  --paper:#F7F5F0;
  --paper-soft:#EFEBE2;
  --paper-line: rgba(16,21,31,0.09);
  --amber:#E8A23D;
  --amber-deep:#C9821F;
  --green:#3DDC84;
  --green-deep:#1F9D5C;
  --red:#E25555;
  --text-onlight:#1A1F29;
  --text-onlight-mute:#5B6372;
  --text-ondark:#EDEFF3;
  --text-ondark-mute:#9AA3B2;

  --bg: var(--paper);
  --bg-soft: var(--paper-soft);
  --line: var(--paper-line);
  --surface:#FFFFFF;
  --text: var(--text-onlight);
  --text-mute: var(--text-onlight-mute);

  --radius-s:10px;
  --radius-m:16px;
  --radius-l:24px;
  --shadow-sm: 0 1px 2px rgba(16,21,31,0.06), 0 1px 1px rgba(16,21,31,0.04);
  --shadow-md: 0 8px 24px rgba(16,21,31,0.08), 0 2px 6px rgba(16,21,31,0.04);
  --shadow-lg: 0 24px 60px rgba(16,21,31,0.16), 0 6px 16px rgba(16,21,31,0.08);

  --font-display:'Space Grotesk', sans-serif;
  --font-body:'Inter', sans-serif;
  --font-mono:'JetBrains Mono', monospace;
}
[data-theme="dark"]{
  --bg: var(--ink);
  --bg-soft: var(--ink-soft);
  --line: var(--ink-line);
  --surface:#171E2B;
  --text: var(--text-ondark);
  --text-mute: var(--text-ondark-mute);
}

*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  background:var(--bg);
  color:var(--text);
  font-family:var(--font-body);
  transition:background .4s ease,color .4s ease;
  overflow-x:hidden;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
button{font-family:inherit;cursor:pointer;border:none;background:none;}
ul,ol{list-style:none;}
.mono{font-family:var(--font-mono);}
.wrap{max-width:1240px;margin:0 auto;padding:0 28px;}
.wrap-narrow{max-width:1080px;margin:0 auto;padding:0 28px;}

@media (prefers-reduced-motion: reduce){
  *{animation-duration:0.01ms !important; animation-iteration-count:1 !important; transition-duration:0.01ms !important;}
}

/* ===================== HEADER ===================== */
header.site-header{
  position:sticky; top:0; z-index:100;
  background:transparent;
  transition:background .35s ease, box-shadow .35s ease, padding .35s ease;
  padding:22px 0;
}
header.site-header.scrolled{
  background:var(--bg);
  box-shadow:0 1px 0 var(--line), 0 12px 30px -16px rgba(0,0,0,0.25);
  padding:13px 0;
}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:24px;}
.logo{display:flex;align-items:center;gap:10px;font-family:var(--font-display);font-weight:700;font-size:19px;letter-spacing:-0.01em;}
.logo img{height:34px;width:auto;border-radius:9px;}
.logo-mark{
  width:34px;height:34px;border-radius:9px;
  background:linear-gradient(135deg,var(--amber) 0%, var(--green) 130%);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-mono);font-weight:500;font-size:13px;color:var(--ink);
  flex-shrink:0;
}
nav.main-nav{display:flex;align-items:center;gap:30px;}
nav.main-nav ul{display:flex;align-items:center;gap:30px;}
nav.main-nav a{font-size:14.5px;font-weight:500;color:var(--text-mute);transition:color .2s;position:relative;}
nav.main-nav a:hover{color:var(--text);}
.header-actions{display:flex;align-items:center;gap:14px;}
.icon-btn{
  width:38px;height:38px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  color:var(--text-mute);transition:background .2s,color .2s;
  flex-shrink:0;
}
.icon-btn:hover{background:var(--bg-soft);color:var(--text);}
.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:11px 20px;border-radius:30px;
  font-weight:600;font-size:14px;
  transition:transform .25s cubic-bezier(.2,.8,.2,1), box-shadow .25s ease, background .25s ease;
}
.btn-primary{ background:var(--ink); color:#fff; }
[data-theme="dark"] .btn-primary{ background: var(--paper); color:var(--ink);}
.btn-primary:hover{transform:translateY(-2px); box-shadow:var(--shadow-md);}
.btn-stamp{
  background:linear-gradient(135deg,var(--green) 0%, var(--green-deep) 100%);
  color:#06251A;
}
.btn-stamp:hover{transform:translateY(-2px); box-shadow:0 10px 24px -6px rgba(61,220,132,0.55);}
.btn-ghost{ background:var(--bg-soft); color:var(--text); }
.btn-ghost:hover{background:var(--line);}
.btn-outline{border:1px solid var(--line); color:var(--text);}
.btn-outline:hover{background:var(--bg-soft);}

.nav-toggle{display:none;}
@media (max-width:920px){
  nav.main-nav{position:fixed;inset:0;top:0;background:var(--bg);flex-direction:column;justify-content:center;align-items:center;gap:0;transform:translateY(-100%);transition:transform .4s cubic-bezier(.2,.8,.2,1);z-index:90;}
  nav.main-nav.open{transform:translateY(0);}
  nav.main-nav ul{flex-direction:column;gap:28px;}
  nav.main-nav a{font-size:22px;}
  .nav-toggle{display:flex;}
  .header-actions .btn-primary{display:none;}
}

/* ===================== HERO / SLIDER ===================== */
.hero{position:relative;padding:64px 0 40px;overflow:hidden;}
.hero-bg{
  position:absolute; inset:0; z-index:0;
  background:
    radial-gradient(ellipse 70% 60% at 80% 0%, rgba(232,162,61,0.16), transparent 60%),
    radial-gradient(ellipse 60% 50% at 10% 30%, rgba(61,220,132,0.12), transparent 60%);
  animation:driftGlow 16s ease-in-out infinite alternate;
}
@keyframes driftGlow{ 0%{background-position:0% 0%, 0% 0%;} 100%{background-position:6% 4%, -6% -4%;} }
.grain-line{
  position:absolute; inset:0; z-index:0; opacity:0.5; pointer-events:none;
  background-image: linear-gradient(var(--line) 1px, transparent 1px);
  background-size: 100% 42px;
  mask-image: linear-gradient(to bottom, black, transparent 70%);
}
.hero-inner{position:relative;z-index:1;}
.trust-row{display:flex; flex-wrap:wrap; gap:10px; margin-bottom:28px;}
.trust-chip{
  display:flex;align-items:center;gap:7px;
  padding:7px 13px; border-radius:20px;
  background:var(--surface); border:1px solid var(--line);
  font-size:12.5px; font-weight:600; color:var(--text-mute);
  box-shadow:var(--shadow-sm);
}
.trust-chip .dot{width:6px;height:6px;border-radius:50%;background:var(--green);box-shadow:0 0 0 3px rgba(61,220,132,0.18);}

.slider-stage{
  position:relative; border-radius:var(--radius-l); background:var(--surface);
  border:1px solid var(--line); box-shadow:var(--shadow-lg); overflow:hidden;
}
.slides{display:flex; transition:transform .6s cubic-bezier(.2,.8,.2,1);}
.slide{ min-width:100%; display:grid; grid-template-columns:1.1fr 0.9fr; align-items:center; padding:52px 56px; gap:36px; }
.slide-eyebrow{
  font-family:var(--font-mono); font-size:12.5px; letter-spacing:.06em;
  color:var(--amber-deep); font-weight:500; text-transform:uppercase;
  display:flex; align-items:center; gap:8px;
}
[data-theme="dark"] .slide-eyebrow{color:var(--amber);}
.slide-eyebrow::before{content:"";width:16px;height:1px;background:currentColor;}
.slide h1, .slide h2{
  font-family:var(--font-display); font-weight:700;
  font-size:clamp(28px,4vw,44px); line-height:1.08; letter-spacing:-0.015em;
  margin:14px 0 14px;
}
.slide p.tagline{ color:var(--text-mute); font-size:16px; line-height:1.55; max-width:440px; margin-bottom:26px;}
.slide-cta{display:flex; align-items:center; gap:16px; flex-wrap:wrap;}
.slide-meta{display:flex; gap:18px; margin-top:22px; flex-wrap:wrap;}
.meta-item{font-size:12.5px; color:var(--text-mute);}
.meta-item b{font-family:var(--font-mono); color:var(--text); font-weight:500;}
.slide-visual{
  position:relative; aspect-ratio:1/1; max-width:280px; margin:0 auto;
  border-radius:28px; display:flex; align-items:center; justify-content:center;
  background:linear-gradient(155deg, var(--bg-soft), transparent);
}
.app-icon-big{
  width:64%; aspect-ratio:1/1; border-radius:22px; overflow:hidden;
  display:flex; align-items:center; justify-content:center;
  font-family:var(--font-display); font-weight:700; font-size:42px; color:#fff;
  box-shadow:var(--shadow-lg); animation:floatIcon 5s ease-in-out infinite;
}
.app-icon-big img{width:100%;height:100%;object-fit:cover;}
@keyframes floatIcon{ 0%,100%{transform:translateY(0) rotate(0deg);} 50%{transform:translateY(-10px) rotate(-2deg);} }
.stamp-ring{
  position:absolute; top:-10px; right:-6px; width:74px;height:74px; border-radius:50%;
  border:2px dashed var(--green); display:flex; align-items:center; justify-content:center;
  font-family:var(--font-mono); font-size:9px; font-weight:500; color:var(--green-deep);
  text-align:center; line-height:1.2; padding:6px; transform:rotate(8deg); background:var(--surface);
}
[data-theme="dark"] .stamp-ring{color:var(--green);}
.slider-controls{ position:absolute; bottom:22px; left:56px; right:56px; display:flex; align-items:center; justify-content:space-between; z-index:2; }
.dots{display:flex; gap:8px;}
.dot-btn{width:22px;height:4px;border-radius:3px;background:var(--line);transition:background .3s,width .3s;}
.dot-btn.active{background:var(--amber); width:32px;}
.arrows{display:flex; gap:8px;}
.arrow-btn{
  width:38px;height:38px;border-radius:50%; background:var(--surface); border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center; transition:background .2s, transform .2s;
}
.arrow-btn:hover{background:var(--bg-soft); transform:scale(1.06);}
@media (max-width:760px){
  .slide{grid-template-columns:1fr; padding:36px 24px 100px; text-align:left;}
  .slide-visual{margin:0; max-width:160px;}
  .slider-controls{left:24px; right:24px; bottom:18px;}
}

/* ===================== STATS ===================== */
.stats{padding:64px 0 20px;}
.stats-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:20px;}
.stat-card{
  background:var(--surface); border:1px solid var(--line); border-radius:var(--radius-m);
  padding:26px 22px; box-shadow:var(--shadow-sm);
  opacity:0; transform:translateY(18px); transition:opacity .6s ease, transform .6s ease;
}
.stat-card.in-view{opacity:1; transform:translateY(0);}
.stat-icon{ width:38px;height:38px;border-radius:10px; display:flex;align-items:center;justify-content:center; margin-bottom:14px; background:var(--bg-soft); font-size:18px;}
.stat-num{font-family:var(--font-display); font-weight:700; font-size:30px; letter-spacing:-0.01em;}
.stat-label{font-size:13px; color:var(--text-mute); margin-top:4px;}
@media (max-width:760px){.stats-grid{grid-template-columns:repeat(2,1fr);}}

/* ===================== SECTIONS ===================== */
.section{padding:56px 0;}
.section-head{display:flex; align-items:flex-end; justify-content:space-between; margin-bottom:28px; gap:20px;}
.section-eyebrow{font-family:var(--font-mono); font-size:12px; color:var(--amber-deep); text-transform:uppercase; letter-spacing:.07em; font-weight:500;}
[data-theme="dark"] .section-eyebrow{color:var(--amber);}
.section-title{font-family:var(--font-display); font-size:clamp(22px,3vw,30px); font-weight:700; letter-spacing:-0.01em; margin-top:6px;}
.view-all{font-size:13.5px; font-weight:600; color:var(--text-mute); display:flex; align-items:center; gap:6px; white-space:nowrap;}
.view-all:hover{color:var(--text);}

.track{ display:flex; gap:16px; overflow-x:auto; scroll-snap-type:x mandatory; padding-bottom:6px; scrollbar-width:none; }
.track::-webkit-scrollbar{display:none;}
.track > *{scroll-snap-align:start; flex-shrink:0;}

/* ===================== CATEGORY GRID ===================== */
.cat-grid{display:grid; grid-template-columns:repeat(5,1fr); gap:14px;}
.cat-card{
  background:var(--surface); border:1px solid var(--line); border-radius:var(--radius-m);
  padding:20px 16px; text-align:left;
  transition:transform .3s cubic-bezier(.2,.8,.2,1), box-shadow .3s ease, border-color .3s ease;
}
.cat-card:hover{transform:translateY(-5px); box-shadow:var(--shadow-md); border-color:transparent;}
.cat-icon{
  width:42px;height:42px;border-radius:11px; margin-bottom:14px;
  display:flex;align-items:center;justify-content:center; font-size:19px;
  background:var(--bg-soft); transition:transform .35s cubic-bezier(.34,1.56,.64,1);
}
.cat-card:hover .cat-icon{transform:rotate(-8deg) scale(1.08);}
.cat-name{font-weight:600; font-size:14.5px; margin-bottom:3px;}
.cat-count{font-family:var(--font-mono); font-size:11.5px; color:var(--text-mute);}
@media (max-width:980px){.cat-grid{grid-template-columns:repeat(3,1fr);}}
@media (max-width:600px){.cat-grid{grid-template-columns:repeat(2,1fr);}}

/* ===================== SOFTWARE CARDS ===================== */
.soft-card{
  width:248px; background:var(--surface); border:1px solid var(--line); border-radius:var(--radius-m);
  padding:20px; position:relative; overflow:hidden;
  transition:transform .3s cubic-bezier(.2,.8,.2,1), box-shadow .3s ease, opacity .5s ease;
}
.soft-card.in-view, .soft-card.in{opacity:1; transform:translateY(0);}
.soft-card:hover{transform:translateY(-6px); box-shadow:var(--shadow-lg);}
.soft-card.grid-card{width:auto;}
.soft-top{display:flex; align-items:flex-start; gap:12px; margin-bottom:14px;}
.soft-icon{
  width:50px;height:50px;border-radius:13px; flex-shrink:0; overflow:hidden;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-display); font-weight:700; font-size:18px; color:#fff;
  transition:transform .3s cubic-bezier(.34,1.56,.64,1);
}
.soft-icon img{width:100%;height:100%;object-fit:cover;}
.soft-card:hover .soft-icon{transform:rotate(-6deg);}
.soft-name{font-weight:600; font-size:15px; line-height:1.3;}
.soft-cat-tag{font-size:11px; color:var(--text-mute); margin-top:3px;}
.verify-seal{
  position:absolute; top:14px; right:14px; width:30px; height:30px; border-radius:50%;
  border:1.5px dashed var(--green-deep); display:flex; align-items:center; justify-content:center;
  color:var(--green-deep); font-size:13px; transform:rotate(6deg);
}
[data-theme="dark"] .verify-seal{border-color:var(--green); color:var(--green);}
.soft-meta-row{ display:flex; align-items:center; gap:10px; margin:12px 0 14px; font-family:var(--font-mono); font-size:11.5px; color:var(--text-mute); flex-wrap:wrap;}
.stars{color:var(--amber-deep); font-size:12px; letter-spacing:1px;}
[data-theme="dark"] .stars{color:var(--amber);}
.soft-actions{display:flex; gap:8px;}
.soft-actions .btn{flex:1; justify-content:center; padding:9px 12px; font-size:13px;}

/* ===================== CATEGORY BANNER (archive page) ===================== */
.cat-banner{
  position:relative; overflow:hidden; padding:54px 0 38px;
  background:
    radial-gradient(ellipse 60% 80% at 85% 0%, rgba(232,162,61,0.14), transparent 60%),
    radial-gradient(ellipse 50% 60% at 5% 100%, rgba(61,220,132,0.1), transparent 60%);
}
.crumb{font-size:13px; color:var(--text-mute); margin-bottom:18px;}
.crumb a:hover{color:var(--text);}
.cat-banner-row{display:flex; align-items:center; gap:20px; flex-wrap:wrap;}
.cat-banner-icon{
  width:64px;height:64px;border-radius:18px; background:linear-gradient(135deg,#5B8DEF,#3A66C4);
  display:flex;align-items:center;justify-content:center; font-size:28px; box-shadow:var(--shadow-md); flex-shrink:0; overflow:hidden;
}
.cat-banner-icon img{width:100%;height:100%;object-fit:cover;}
.cat-banner h1{font-family:var(--font-display); font-weight:700; font-size:clamp(26px,4vw,38px); letter-spacing:-0.015em;}
.cat-banner-sub{color:var(--text-mute); font-size:14.5px; margin-top:6px; display:flex; gap:16px; flex-wrap:wrap;}
.cat-banner-sub b{font-family:var(--font-mono); color:var(--text); font-weight:500;}

.filter-bar{
  display:flex; align-items:center; justify-content:space-between; gap:16px; flex-wrap:wrap;
  padding:18px 0; margin-bottom:28px; border-bottom:1px solid var(--line);
  position:sticky; top:71px; background:var(--bg); z-index:50;
}
.pill-row{display:flex; gap:8px; flex-wrap:wrap;}
.pill{
  padding:8px 16px; border-radius:20px; font-size:13.5px; font-weight:600;
  background:var(--surface); border:1px solid var(--line); color:var(--text-mute);
  transition:background .2s, color .2s, border-color .2s;
}
.pill:hover{color:var(--text);}
.pill.active{background:var(--ink); color:#fff; border-color:var(--ink);}
[data-theme="dark"] .pill.active{background:var(--paper); color:var(--ink);}
.result-count{font-size:13px; color:var(--text-mute); font-family:var(--font-mono);}

.soft-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:18px; padding-bottom:24px;}
@media (max-width:1080px){.soft-grid{grid-template-columns:repeat(3,1fr);}}
@media (max-width:760px){.soft-grid{grid-template-columns:repeat(2,1fr);}}
@media (max-width:480px){.soft-grid{grid-template-columns:1fr;}}

.skeleton-card{ background:var(--surface); border:1px solid var(--line); border-radius:var(--radius-m); padding:20px; height:172px; position:relative; overflow:hidden; }
.skeleton-card::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(100deg, transparent 30%, var(--bg-soft) 50%, transparent 70%);
  background-size:200% 100%; animation:shimmer 1.3s infinite;
}
@keyframes shimmer{0%{background-position:200% 0;} 100%{background-position:-50% 0;}}

.load-more-wrap{display:flex; justify-content:center; padding:24px 0 64px;}
#loadMoreBtn{
  padding:13px 30px; border-radius:30px; background:var(--surface); border:1px solid var(--line);
  font-weight:600; font-size:14px; display:flex; align-items:center; gap:10px;
  transition:transform .25s, box-shadow .25s, background .2s;
}
#loadMoreBtn:hover{transform:translateY(-2px); box-shadow:var(--shadow-md);}
.spinner{width:14px;height:14px;border-radius:50%; border:2px solid var(--line); border-top-color:var(--amber-deep); animation:spin .7s linear infinite; display:none;}
#loadMoreBtn.loading .spinner{display:inline-block;}
#loadMoreBtn.loading .lm-text{opacity:.6;}
@keyframes spin{to{transform:rotate(360deg);}}

/* ===================== SINGLE SOFTWARE PAGE ===================== */
.app-hero{
  display:grid; grid-template-columns:auto 1fr auto; gap:28px; align-items:center;
  padding:28px; border-radius:var(--radius-l); background:var(--surface); border:1px solid var(--line);
  box-shadow:var(--shadow-md); margin-bottom:36px;
}
.app-icon-hero{
  width:96px;height:96px;border-radius:22px; flex-shrink:0; overflow:hidden;
  background:linear-gradient(135deg,#FF7A3D,#E8602A);
  display:flex;align-items:center;justify-content:center; font-size:42px; color:#fff;
  box-shadow:var(--shadow-md); animation:popIn .5s cubic-bezier(.34,1.56,.64,1);
}
.app-icon-hero img{width:100%;height:100%;object-fit:cover;}
@keyframes popIn{from{transform:scale(.7) rotate(-8deg); opacity:0;} to{transform:scale(1) rotate(0); opacity:1;}}
.app-hero h1{font-family:var(--font-display); font-weight:700; font-size:clamp(24px,3.4vw,32px); letter-spacing:-0.01em;}
.app-badges{display:flex; gap:10px; margin:10px 0 12px; flex-wrap:wrap;}
.badge{font-size:12px; font-weight:600; padding:5px 11px; border-radius:14px; background:var(--bg-soft); color:var(--text-mute);}
.badge.verified{background:rgba(61,220,132,0.14); color:var(--green-deep);}
[data-theme="dark"] .badge.verified{color:var(--green);}
.app-meta-line{display:flex; gap:16px; flex-wrap:wrap; font-size:13px; color:var(--text-mute);}
.app-meta-line b{font-family:var(--font-mono); color:var(--text); font-weight:500;}
.dl-col{display:flex; flex-direction:column; gap:10px; align-items:stretch; min-width:200px;}
.btn-stamp-lg{
  background:linear-gradient(135deg,var(--green) 0%, var(--green-deep) 100%); color:#06251A;
  padding:15px 24px; font-size:15px; border-radius:14px; justify-content:center;
  animation:pulseGlow 2.6s ease-in-out infinite;
}
@keyframes pulseGlow{ 0%{box-shadow:0 0 0 0 rgba(61,220,132,0.45);} 70%{box-shadow:0 0 0 14px rgba(61,220,132,0);} 100%{box-shadow:0 0 0 0 rgba(61,220,132,0);} }
.btn-stamp-lg:hover{transform:translateY(-2px);}
.btn-outline-lg{border:1px solid var(--line); color:var(--text); padding:12px 20px; border-radius:14px; justify-content:center; font-size:13.5px;}
.btn-outline-lg:hover{background:var(--bg-soft);}
@media (max-width:760px){
  .app-hero{grid-template-columns:1fr; text-align:center;}
  .app-icon-hero{margin:0 auto;}
  .app-badges, .app-meta-line{justify-content:center;}
}

.tabs-nav{display:flex; gap:6px; overflow-x:auto; border-bottom:1px solid var(--line); margin-bottom:28px; scrollbar-width:none;}
.tabs-nav::-webkit-scrollbar{display:none;}
.tab-btn{
  padding:13px 18px; font-size:14px; font-weight:600; color:var(--text-mute); white-space:nowrap;
  border-bottom:2px solid transparent; transition:color .2s, border-color .2s;
}
.tab-btn:hover{color:var(--text);}
.tab-btn.active{color:var(--text); border-color:var(--amber-deep);}
[data-theme="dark"] .tab-btn.active{border-color:var(--amber);}
.tab-panel{display:none; animation:fadeUp .35s ease;}
.tab-panel.active{display:block;}
@keyframes fadeUp{from{opacity:0; transform:translateY(8px);} to{opacity:1; transform:translateY(0);}}

.panel-block{margin-bottom:28px;}
.panel-block h3{font-family:var(--font-display); font-weight:700; font-size:18px; margin-bottom:12px; letter-spacing:-0.01em;}
.panel-block p{color:var(--text-mute); line-height:1.7; font-size:15px; margin-bottom:14px;}

.feature-list{display:grid; grid-template-columns:1fr 1fr; gap:10px;}
.feature-list li{display:flex; gap:10px; font-size:14.5px; align-items:flex-start; padding:10px 14px; background:var(--surface); border:1px solid var(--line); border-radius:10px;}
@media (max-width:600px){.feature-list{grid-template-columns:1fr;}}

.step-list{counter-reset:step; display:flex; flex-direction:column; gap:14px;}
.step-list li{display:flex; gap:14px; align-items:flex-start;}
.step-num{
  counter-increment:step; flex-shrink:0; width:28px;height:28px;border-radius:50%; background:var(--bg-soft);
  display:flex;align-items:center;justify-content:center; font-family:var(--font-mono); font-size:12.5px; font-weight:500;
}
.step-num::before{content:counter(step);}
.step-text{font-size:14.5px; color:var(--text-mute); padding-top:3px;}

.sysreq-table{width:100%; border-collapse:collapse; font-size:14px;}
.sysreq-table tr{border-bottom:1px solid var(--line);}
.sysreq-table td{padding:11px 6px;}
.sysreq-table td:first-child{color:var(--text-mute); width:36%;}
.sysreq-table td:last-child{font-family:var(--font-mono); font-size:13px;}

.tip-card{ background:var(--bg-soft); border-radius:12px; padding:14px 16px; margin-bottom:10px; font-size:14px; display:flex; gap:10px; line-height:1.6; }

.proscons{display:grid; grid-template-columns:1fr 1fr; gap:18px;}
.pc-col{border-radius:var(--radius-m); padding:20px; border:1px solid var(--line);}
.pc-col.pros{background:rgba(61,220,132,0.06);}
.pc-col.cons{background:rgba(226,85,85,0.06);}
.pc-col h4{font-family:var(--font-display); font-size:15px; margin-bottom:14px; display:flex; align-items:center; gap:8px;}
.pc-col ul{display:flex; flex-direction:column; gap:10px;}
.pc-col li{display:flex; gap:10px; font-size:14px; line-height:1.5;}
.pc-icon{flex-shrink:0; width:18px; height:18px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:11px; margin-top:1px;}
.pros .pc-icon{background:var(--green); color:#06251A;}
.cons .pc-icon{background:var(--red); color:#fff;}
@media (max-width:640px){.proscons{grid-template-columns:1fr;}}

.gallery-track{display:flex; gap:14px; overflow-x:auto; scroll-snap-type:x mandatory; scrollbar-width:none; padding-bottom:6px;}
.gallery-track::-webkit-scrollbar{display:none;}
.shot{
  scroll-snap-align:start; flex-shrink:0; width:280px; aspect-ratio:16/10; border-radius:14px; overflow:hidden;
  background:linear-gradient(135deg, var(--bg-soft), var(--line)); border:1px solid var(--line);
  display:flex; align-items:center; justify-content:center; font-family:var(--font-mono); font-size:12px; color:var(--text-mute);
  cursor:zoom-in; transition:transform .25s ease;
}
.shot img{width:100%;height:100%;object-fit:cover;}
.shot:hover{transform:scale(1.02);}

.lightbox{ position:fixed; inset:0; background:rgba(8,10,14,0.92); z-index:200; display:none; align-items:center; justify-content:center; padding:40px; }
.lightbox.open{display:flex; animation:fadeUp .25s ease;}
.lightbox-img{
  width:min(800px,90vw); aspect-ratio:16/10; border-radius:16px; overflow:hidden;
  background:linear-gradient(135deg, #2A3242, #171E2B); display:flex; align-items:center; justify-content:center;
  color:#9AA3B2; font-family:var(--font-mono); font-size:13px;
}
.lightbox-img img{width:100%;height:100%;object-fit:contain;}
.lightbox-close{position:absolute; top:24px; right:28px; color:#fff; font-size:28px; width:44px; height:44px; border-radius:50%; background:rgba(255,255,255,0.08);}
.lightbox-nav{position:absolute; top:50%; transform:translateY(-50%); color:#fff; font-size:22px; width:48px;height:48px;border-radius:50%; background:rgba(255,255,255,0.08); display:flex;align-items:center;justify-content:center;}
.lightbox-prev{left:24px;} .lightbox-next{right:24px;}

.related-track{display:flex; gap:14px; overflow-x:auto; scroll-snap-type:x mandatory; scrollbar-width:none; padding-bottom:6px;}
.related-track::-webkit-scrollbar{display:none;}
.rel-card{
  scroll-snap-align:start; flex-shrink:0; width:200px;
  background:var(--surface); border:1px solid var(--line); border-radius:var(--radius-m); padding:16px;
  transition:transform .3s, box-shadow .3s;
}
.rel-card:hover{transform:translateY(-5px); box-shadow:var(--shadow-md);}
.rel-icon{width:42px;height:42px;border-radius:11px; overflow:hidden; display:flex; align-items:center; justify-content:center; color:#fff; font-family:var(--font-display); font-weight:700; font-size:15px; margin-bottom:10px;}
.rel-icon img{width:100%;height:100%;object-fit:cover;}
.rel-name{font-weight:600; font-size:14px;}
.rel-meta{font-size:11.5px; color:var(--text-mute); font-family:var(--font-mono); margin-top:4px;}

/* ===================== COMMENTS ===================== */
.comment-form-wrap{display:flex; gap:12px; margin-bottom:24px;}
.avatar-circle{width:42px;height:42px;border-radius:50%; background:var(--bg-soft); flex-shrink:0; display:flex; align-items:center; justify-content:center; font-size:16px; overflow:hidden;}
.avatar-circle img{width:100%;height:100%;object-fit:cover;}
.comment-input-wrap{flex:1;}
.comment-form-wrap textarea,
#commentform textarea,
#commentform input[type="text"],
#commentform input[type="email"]{
  width:100%; border:1px solid var(--line); border-radius:12px; padding:12px 14px; font-family:inherit; font-size:14px;
  background:var(--surface); color:var(--text); resize:vertical; min-height:64px; transition:border-color .2s; margin-bottom:10px;
}
#commentform textarea:focus,
#commentform input:focus{outline:none; border-color:var(--amber-deep);}
#commentform .form-submit input[type="submit"]{
  padding:11px 22px; border-radius:30px; background:var(--ink); color:#fff; font-weight:600; font-size:14px;
}
[data-theme="dark"] #commentform .form-submit input[type="submit"]{background:var(--paper); color:var(--ink);}
.comment-item{display:flex; gap:12px; padding:16px 0; border-top:1px solid var(--line);}
.comment-name{font-weight:600; font-size:14px;}
.comment-time{font-size:12px; color:var(--text-mute); margin-left:8px; font-weight:400;}
.comment-body{font-size:14px; color:var(--text-mute); margin-top:4px; line-height:1.6;}

/* ===================== STICKY MOBILE DOWNLOAD BAR ===================== */
.sticky-mobile-bar{
  display:none; position:fixed; bottom:0; left:0; right:0; z-index:150;
  background:var(--surface); border-top:1px solid var(--line); padding:12px 18px;
  box-shadow:0 -8px 24px rgba(0,0,0,0.08); align-items:center; justify-content:space-between; gap:12px;
}
.sticky-mobile-bar .info{font-size:12.5px;}
.sticky-mobile-bar .info b{display:block; font-size:14px;}
@media (max-width:760px){
  .sticky-mobile-bar.is-single{display:flex;}
  body.single-software{padding-bottom:74px;}
}

/* ===================== STATIC PAGES ===================== */
.page-banner{ padding:54px 0 38px; text-align:center;
  background: radial-gradient(ellipse 60% 80% at 50% 0%, rgba(232,162,61,0.12), transparent 60%);
}
.page-banner h1{font-family:var(--font-display); font-weight:700; font-size:clamp(28px,4vw,42px); letter-spacing:-0.015em;}
.page-content{max-width:760px; margin:0 auto; padding:20px 28px 60px; line-height:1.8; font-size:15.5px; color:var(--text-mute);}
.page-content h2{font-family:var(--font-display); color:var(--text); font-size:22px; margin:32px 0 14px;}
.page-content p{margin-bottom:16px;}
.contact-form-grid{display:grid; gap:16px; margin-top:24px;}
.float-field{position:relative;}
.float-field input, .float-field textarea{
  width:100%; padding:16px 14px 8px; border:1px solid var(--line); border-radius:12px; background:var(--surface);
  color:var(--text); font-family:inherit; font-size:15px;
}
.float-field label{position:absolute; left:14px; top:14px; font-size:13px; color:var(--text-mute); transition:all .2s; pointer-events:none;}
.float-field input:focus + label, .float-field input:not(:placeholder-shown) + label,
.float-field textarea:focus + label, .float-field textarea:not(:placeholder-shown) + label{
  top:6px; font-size:11px; color:var(--amber-deep);
}

/* ===================== SEARCH ===================== */
.search-overlay{
  position:fixed; inset:0; background:rgba(8,10,14,0.5); z-index:180; display:none;
  align-items:flex-start; justify-content:center; padding-top:14vh;
}
.search-overlay.open{display:flex; animation:fadeUp .2s ease;}
.search-box{ width:min(600px,90vw); background:var(--surface); border-radius:var(--radius-l); box-shadow:var(--shadow-lg); padding:8px; }
.search-box input{
  width:100%; padding:16px 18px; border:none; background:transparent; color:var(--text); font-size:17px; font-family:inherit;
}
.search-box input:focus{outline:none;}
.search-suggest{padding:0 8px 8px;}
.search-suggest a{display:block; padding:10px 12px; border-radius:10px; font-size:14px; color:var(--text-mute);}
.search-suggest a:hover{background:var(--bg-soft); color:var(--text);}

/* ===================== FOOTER ===================== */
footer.site-footer{ background:var(--ink); color:var(--text-ondark); padding:64px 0 28px; margin-top:40px; }
.footer-grid{display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr; gap:40px; padding-bottom:40px; border-bottom:1px solid var(--ink-line);}
.footer-brand p{color:var(--text-ondark-mute); font-size:14px; line-height:1.6; margin:16px 0 20px; max-width:280px;}
.footer-col h4{font-size:13px; text-transform:uppercase; letter-spacing:.06em; color:var(--text-ondark-mute); margin-bottom:16px; font-weight:600;}
.footer-col a{display:block; font-size:14px; color:var(--text-ondark); opacity:.82; margin-bottom:11px; transition:opacity .2s;}
.footer-col a:hover{opacity:1;}
.social-row{display:flex; gap:10px; margin-top:18px;}
.social-row a{width:36px;height:36px;border-radius:50%; background:rgba(255,255,255,0.06); display:flex; align-items:center; justify-content:center; margin:0;}
.footer-bottom{display:flex; justify-content:space-between; padding-top:24px; font-size:13px; color:var(--text-ondark-mute); flex-wrap:wrap; gap:10px;}
@media (max-width:880px){.footer-grid{grid-template-columns:1fr 1fr;}}
@media (max-width:560px){.footer-grid{grid-template-columns:1fr;}}

/* ===================== UTILITIES ===================== */
.reveal{opacity:0; transform:translateY(20px); transition:opacity .65s ease, transform .65s cubic-bezier(.2,.8,.2,1);}
.reveal.in-view{opacity:1; transform:translateY(0);}
a:focus-visible, button:focus-visible{outline:2px solid var(--amber); outline-offset:2px; border-radius:6px;}
.empty-state{text-align:center; padding:60px 20px; color:var(--text-mute);}
