/* ============================================================
   The Walkers SMP — shared site styles
   Dark, sculk-touched. Amber default accent; plugin pages
   override --accent / --accent2 for their own identity.
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;700&family=Oxanium:wght@600;700;800&family=JetBrains+Mono:wght@400;500&display=swap');

*{margin:0;padding:0;box-sizing:border-box}

:root{
  --bg:#070910;
  --bg2:#0a0d16;
  --surface:#0e1018;
  --surface2:#12151f;
  --border:#1a1d26;
  --border2:#262a36;
  --text:#c9ccd6;
  --muted:#6a6f7e;
  --dim:#454a57;
  --accent:#f0a500;       /* default amber */
  --accent2:#ffce5c;
  --green:#3ecf6e;
  --red:#e05050;
  --blue:#5a9ef5;
  --display:'Oxanium',sans-serif;
  --body:'Space Grotesk',sans-serif;
  --mono:'JetBrains Mono',monospace;
}

body{
  background:var(--bg);
  color:var(--text);
  font-family:var(--body);
  min-height:100vh;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}

a{color:var(--accent);text-decoration:none;transition:color .15s}
a:hover{color:var(--accent2)}

/* subtle atmospheric backdrop */
body::before{
  content:"";position:fixed;inset:0;z-index:-2;
  background:
    radial-gradient(900px 500px at 80% -5%, color-mix(in srgb, var(--accent) 9%, transparent), transparent 70%),
    radial-gradient(700px 600px at 5% 10%, color-mix(in srgb, var(--blue) 5%, transparent), transparent 70%),
    var(--bg);
}
body::after{
  content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;opacity:.025;
  background-image:radial-gradient(var(--text) 1px, transparent 1px);
  background-size:3px 3px;
}

/* ── Header ────────────────────────────────────────────── */
header{
  background:color-mix(in srgb, var(--surface) 80%, transparent);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--border);
  padding:0 clamp(16px,4vw,40px);height:62px;
  display:flex;align-items:center;justify-content:space-between;
  position:sticky;top:0;z-index:100;
}
.brand{font-family:var(--display);font-size:20px;font-weight:800;color:#fff;letter-spacing:1.5px;display:flex;align-items:center;gap:9px}
.brand span{color:var(--accent)}
.brand .dot{width:9px;height:9px;border-radius:50%;background:var(--accent);box-shadow:0 0 12px var(--accent)}
.nav{display:flex;gap:8px;align-items:center}
.nav a{font-size:13px;font-weight:500;color:var(--muted);padding:7px 13px;border-radius:7px;transition:all .15s}
.nav a:hover{color:#fff;background:var(--surface2)}
.nav a.cta{background:var(--accent);color:#070910;font-weight:700}
.nav a.cta:hover{background:var(--accent2);color:#070910}

/* ── Buttons / chips ──────────────────────────────────── */
.btn{display:inline-flex;align-items:center;gap:8px;background:var(--accent);color:#070910;border:none;border-radius:8px;padding:11px 20px;font-family:var(--body);font-size:14px;font-weight:700;cursor:pointer;transition:all .18s}
.btn:hover{background:var(--accent2);color:#070910;transform:translateY(-1px)}
.btn.ghost{background:transparent;border:1px solid var(--border2);color:var(--text)}
.btn.ghost:hover{border-color:var(--accent);color:var(--accent);background:transparent}

/* ── Layout ───────────────────────────────────────────── */
.wrap{max-width:1000px;margin:0 auto;padding:0 clamp(16px,4vw,24px)}
.section{max-width:1000px;margin:0 auto;padding:clamp(48px,8vw,72px) clamp(16px,4vw,24px)}
.eyebrow{font-family:var(--mono);font-size:11px;font-weight:500;color:var(--accent);text-transform:uppercase;letter-spacing:3px;margin-bottom:12px}
h1,h2,h3,h4{font-family:var(--display);color:#fff;line-height:1.12}
.section h2{font-size:clamp(26px,4vw,34px);font-weight:800;margin-bottom:8px;letter-spacing:-.5px}
.lede{color:var(--muted);font-size:16px;max-width:620px;margin-bottom:32px}

/* ── Cards ────────────────────────────────────────────── */
.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:16px}
.card{
  background:linear-gradient(160deg, var(--surface) 0%, var(--bg2) 100%);
  border:1px solid var(--border);border-radius:14px;padding:24px;
  position:relative;overflow:hidden;transition:border-color .2s, transform .2s;
}
.card:hover{border-color:var(--border2);transform:translateY(-2px)}
.card .ic{font-size:30px;margin-bottom:14px;display:block}
.card h3{font-size:17px;font-weight:700;margin-bottom:7px}
.card p{font-size:13.5px;color:var(--muted);line-height:1.6}

/* plugin link-cards */
.plugin-card{cursor:pointer;text-decoration:none;display:block}
.plugin-card::after{content:"";position:absolute;inset:0 0 auto auto;width:120px;height:120px;background:radial-gradient(circle at top right, color-mix(in srgb, var(--accent) 22%, transparent), transparent 70%);opacity:0;transition:opacity .25s}
.plugin-card:hover::after{opacity:1}
.plugin-card .tag{display:inline-block;font-family:var(--mono);font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:var(--accent);border:1px solid color-mix(in srgb, var(--accent) 35%, transparent);border-radius:20px;padding:3px 10px;margin-top:14px}
.plugin-card .arrow{position:absolute;top:22px;right:22px;color:var(--dim);transition:all .2s;font-size:18px}
.plugin-card:hover .arrow{color:var(--accent);transform:translate(3px,-3px)}

/* ── Steps ────────────────────────────────────────────── */
.steps{display:flex;flex-direction:column;gap:12px}
.step{background:var(--surface);border:1px solid var(--border);border-radius:11px;padding:18px 20px;display:flex;gap:16px;align-items:flex-start}
.step-num{background:var(--accent);color:#070910;font-family:var(--display);font-weight:800;font-size:13px;border-radius:9px;min-width:28px;height:28px;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}
.step-body h4{font-size:14.5px;font-weight:700;margin-bottom:4px}
.step-body p{font-size:13.5px;color:var(--muted);line-height:1.55}
code{background:var(--surface2);border:1px solid var(--border);border-radius:5px;padding:2px 7px;font-family:var(--mono);font-size:12.5px;color:var(--accent2)}

/* ── Boxes ────────────────────────────────────────────── */
.note{border-radius:9px;padding:14px 18px;font-size:13.5px;line-height:1.55;margin-bottom:18px;border:1px solid}
.note.info{background:color-mix(in srgb, var(--green) 7%, transparent);border-color:color-mix(in srgb, var(--green) 25%, transparent);color:#9fdcb4}
.note.info strong{color:var(--green)}
.note.warn{background:color-mix(in srgb, var(--red) 7%, transparent);border-color:color-mix(in srgb, var(--red) 25%, transparent);color:#dba0a0}
.note.warn strong{color:var(--red)}
.note.dim{background:var(--surface);border-color:var(--border);color:var(--muted)}

/* ── IP bar ───────────────────────────────────────────── */
.ip-bar{display:inline-flex;align-items:center;gap:12px;background:var(--surface);border:1px solid var(--border2);border-radius:10px;padding:13px 20px;font-family:var(--mono);font-size:15px;color:#fff}
.ip-copy{background:none;border:1px solid var(--border2);color:var(--muted);border-radius:6px;padding:5px 11px;font-size:12px;font-family:var(--body);cursor:pointer;transition:all .15s}
.ip-copy:hover{color:#fff;border-color:var(--accent)}

/* ── Tabs ─────────────────────────────────────────────── */
.tabs{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:20px}
.tab{background:var(--surface);border:1px solid var(--border);color:var(--muted);border-radius:8px;padding:8px 16px;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s;font-family:var(--body)}
.tab:hover{color:var(--text);border-color:var(--border2)}
.tab.active{background:color-mix(in srgb, var(--accent) 14%, transparent);color:var(--accent);border-color:color-mix(in srgb, var(--accent) 40%, transparent)}
.tabpane{display:none}.tabpane.active{display:block}

/* ── Tables (commands) ────────────────────────────────── */
.cmd-table{width:100%;border-collapse:collapse;background:var(--surface);border:1px solid var(--border);border-radius:11px;overflow:hidden;font-size:13.5px}
.cmd-table th{text-align:left;padding:12px 16px;background:var(--surface2);color:var(--muted);font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:1px;border-bottom:1px solid var(--border)}
.cmd-table td{padding:11px 16px;border-bottom:1px solid var(--border);vertical-align:top}
.cmd-table tr:last-child td{border-bottom:none}
.cmd-table td:first-child{font-family:var(--mono);color:var(--accent2);white-space:nowrap}
.cmd-table td:nth-child(2){color:var(--muted)}

/* ── Divider / footer ─────────────────────────────────── */
.divider{border:none;border-top:1px solid var(--border);margin:0}
footer{text-align:center;padding:44px 20px;color:var(--muted);font-size:13px;border-top:1px solid var(--border);font-family:var(--mono)}
footer .sep{color:var(--dim);margin:0 8px}

/* ── Hero ─────────────────────────────────────────────── */
.hero{text-align:center;padding:clamp(60px,11vw,110px) 20px clamp(40px,7vw,64px)}
.hero h1{font-size:clamp(40px,8vw,78px);font-weight:800;letter-spacing:-2px;margin-bottom:18px}
.hero h1 span{color:var(--accent);text-shadow:0 0 40px color-mix(in srgb, var(--accent) 45%, transparent)}
.hero .lede{margin:0 auto 34px;font-size:clamp(15px,2vw,18px)}

/* plugin page hero band */
.phero{position:relative;overflow:hidden;border-bottom:1px solid var(--border);padding:clamp(48px,8vw,84px) 0}
.phero::before{content:"";position:absolute;inset:0;z-index:-1;background:radial-gradient(800px 380px at 50% -10%, color-mix(in srgb, var(--accent) 16%, transparent), transparent 70%)}
.phero .eyebrow{justify-content:center;text-align:center}
.phero h1{font-size:clamp(34px,6vw,60px);font-weight:800;letter-spacing:-1.5px;text-align:center}
.phero .lede{text-align:center;margin:14px auto 0;font-size:clamp(15px,2vw,18px)}
.phero-tags{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;margin-top:22px}
.phero-tags .t{font-family:var(--mono);font-size:11px;letter-spacing:1px;text-transform:uppercase;color:var(--muted);border:1px solid var(--border2);border-radius:20px;padding:5px 13px}

/* feature list (plugin pages) */
.feat{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}
.feat .f{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:20px 22px}
.feat .f .ic{font-size:24px;margin-bottom:10px;display:block}
.feat .f h4{font-size:15px;font-weight:700;margin-bottom:6px}
.feat .f p{font-size:13.5px;color:var(--muted);line-height:1.55}

/* back link */
.back{display:inline-flex;align-items:center;gap:7px;font-size:13px;color:var(--muted);margin-bottom:8px}
.back:hover{color:var(--accent)}

@media (max-width:560px){
  .nav a:not(.cta){display:none}
}

/* ── Drop-in image gallery ────────────────────────────── */
.gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px;margin-top:8px}
.gallery .gitem{position:relative;aspect-ratio:16/10;border:1px solid var(--border);border-radius:11px;overflow:hidden;cursor:pointer;background:var(--surface)}
.gallery .gitem img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .3s, opacity .3s;opacity:0}
.gallery .gitem img.loaded{opacity:1}
.gallery .gitem:hover img{transform:scale(1.06)}
.gallery .gitem::after{content:"";position:absolute;inset:0;box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--accent) 0%,transparent);transition:box-shadow .2s;border-radius:11px;pointer-events:none}
.gallery .gitem:hover::after{box-shadow:inset 0 0 0 2px color-mix(in srgb,var(--accent) 60%,transparent)}
.gallery-empty{color:var(--muted);font-size:14px;font-family:var(--mono);border:1px dashed var(--border2);border-radius:11px;padding:28px;text-align:center}
.gallery-empty code{color:var(--accent2)}

/* lightbox */
.lightbox{position:fixed;inset:0;z-index:1000;background:rgba(3,5,10,.92);backdrop-filter:blur(6px);display:none;align-items:center;justify-content:center;padding:30px;cursor:zoom-out}
.lightbox.open{display:flex}
.lightbox img{max-width:94vw;max-height:90vh;border-radius:10px;box-shadow:0 24px 80px rgba(0,0,0,.7);border:1px solid var(--border2)}
.lightbox .lb-close{position:absolute;top:20px;right:26px;color:var(--muted);font-size:30px;cursor:pointer;font-family:var(--display);line-height:1}
.lightbox .lb-close:hover{color:#fff}
.lightbox .lb-nav{position:absolute;top:50%;transform:translateY(-50%);color:var(--muted);font-size:44px;cursor:pointer;padding:0 18px;user-select:none;font-family:var(--display)}
.lightbox .lb-nav:hover{color:var(--accent)}
.lightbox .lb-prev{left:8px}.lightbox .lb-next{right:8px}
