/* PromptForge — shared styles (NEON ORANGE theme)
   Token names kept for compatibility; --cyan now carries the neon-orange primary,
   --amber the brighter "live action" orange. Warm near-black ground.
   © 2026 jpprlk — Commercial License */
:root{
  --ink:#0E0A07;--panel:#1A130D;--panel-2:#241A12;--line:#3A2A1C;--line-soft:#241710;
  --cyan:#FF7A18;--cyan-dim:#7A4422;--amber:#FFB454;--hi:#FBEEE3;--lo:#C2A48E;--lo-2:#86694F;
  --ok:#5AD98E;--err:#FF6B5C;--radius:10px;
  --mono:'JetBrains Mono',ui-monospace,monospace;--sans:'Inter',system-ui,sans-serif;
  --disp:'Space Grotesk',var(--sans);
}
@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@500;600;700&family=Inter:wght@400;500;600&family=JetBrains+Mono:wght@400;500;700&display=swap');
*{box-sizing:border-box}html,body{height:100%}
body{margin:0;font-family:var(--sans);color:var(--hi);background:var(--ink)}
[hidden]{display:none!important}
.grid-bg{position:fixed;inset:0;z-index:0;pointer-events:none;
  background-image:linear-gradient(var(--line-soft) 1px,transparent 1px),linear-gradient(90deg,var(--line-soft) 1px,transparent 1px);
  background-size:34px 34px;opacity:.4;
  -webkit-mask-image:radial-gradient(120% 90% at 70% 0%,#000 30%,transparent 100%);mask-image:radial-gradient(120% 90% at 70% 0%,#000 30%,transparent 100%)}
a{color:var(--cyan);text-decoration:none}a:hover{text-decoration:underline}
.muted{color:var(--lo)}code{font-family:var(--mono);color:var(--amber);background:rgba(255,180,84,.08);padding:1px 5px;border-radius:4px;font-size:.88em}

.topbar{position:relative;z-index:2;display:flex;align-items:center;justify-content:space-between;
  height:58px;padding:0 22px;border-bottom:1px solid var(--line);background:linear-gradient(180deg,rgba(19,35,61,.85),rgba(10,19,34,.6));backdrop-filter:blur(6px)}
.brand{display:flex;align-items:center;gap:10px}
.mark{color:var(--cyan);font-size:19px;text-shadow:0 0 14px rgba(255,122,24,.5)}
.wordmark{font-family:var(--disp);font-weight:700;letter-spacing:.5px;font-size:17px}
.wordmark em{font-style:normal;font-weight:500;color:var(--lo)}
.nav{display:flex;gap:18px;align-items:center;font-family:var(--mono);font-size:13px}
.nav a{color:var(--lo)}.nav a.active{color:var(--hi)}.nav a:hover{text-decoration:none;color:var(--hi)}

.app-main{position:relative;z-index:1;max-width:920px;margin:0 auto;padding:30px 22px 60px}
.auth-main{position:relative;z-index:1;min-height:calc(100% - 0px);display:flex;align-items:center;justify-content:center;padding:24px}
.auth-bg{background:radial-gradient(120% 80% at 70% 0%,#23160C,#0E0A07)}

.page-head{margin-bottom:22px}
.page-head h1{font-family:var(--disp);font-weight:700;font-size:26px;margin:0 0 6px;letter-spacing:-.3px}
h1,h2{font-family:var(--disp)}h2{font-size:17px;margin:0 0 12px}

.card{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:22px;margin-bottom:18px}
.card.narrow{max-width:520px}
.card.auth{width:360px;padding:30px}
.card.install{width:440px;padding:30px;margin:6vh auto}
.card.auth .brand,.card.install .brand{margin-bottom:18px}

.form{display:flex;flex-direction:column;gap:13px;margin-top:6px}
.form label{display:flex;flex-direction:column;gap:6px;font-size:13px;color:var(--lo);font-family:var(--mono)}
.form input,.form select{font-family:var(--sans);font-size:14px;color:var(--hi);background:var(--ink);border:1px solid var(--line);border-radius:8px;padding:11px 13px}
.form input:focus,.form select:focus{outline:none;border-color:var(--cyan-dim);box-shadow:0 0 0 3px rgba(255,122,24,.08)}
hr{border:none;border-top:1px solid var(--line);margin:16px 0}

.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;font-family:var(--disp);font-weight:600;font-size:14px;
  color:var(--ink);background:var(--amber);border:none;border-radius:9px;padding:11px 18px;cursor:pointer;transition:.15s}
.btn:hover{filter:brightness(1.06);text-decoration:none}
.btn.small{padding:7px 13px;font-size:13px}
.btn.ghost{background:transparent;color:var(--lo);border:1px solid var(--line)}
.btn.ghost:hover{color:var(--hi);border-color:var(--cyan-dim);filter:none}
.btn.disabled{background:var(--line);color:var(--lo-2);pointer-events:none}

.flash{padding:11px 15px;border-radius:9px;margin-bottom:18px;font-size:14px;font-family:var(--mono)}
.flash-ok{background:rgba(84,216,139,.1);border:1px solid var(--ok);color:var(--ok)}
.flash-err{background:rgba(242,112,110,.1);border:1px solid var(--err);color:var(--err)}
.err{color:var(--err);font-family:var(--mono);font-size:13px}
.notice{background:rgba(255,180,84,.08);border:1px solid var(--amber);color:var(--amber);padding:12px 15px;border-radius:9px;margin-bottom:18px;font-size:14px}

.stack-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}
.stack-card{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:18px;display:flex;flex-direction:column;gap:8px}
.stack-card:hover{border-color:var(--cyan-dim)}
.stack-name{font-family:var(--disp);font-weight:600;font-size:16px}
.stack-desc{color:var(--lo);font-size:13px;line-height:1.5;flex:1}
.stack-foot{display:flex;align-items:center;justify-content:space-between;margin-top:8px}
.price{font-family:var(--mono);font-size:12px;color:var(--cyan)}

.reqs{display:flex;flex-direction:column;gap:6px;margin:16px 0}
.req{font-family:var(--mono);font-size:13px;display:flex;gap:9px;align-items:center}
.req.ok span{color:var(--ok)}.req.bad span{color:var(--err)}

.tbl{width:100%;border-collapse:collapse;font-size:13px}
.tbl th,.tbl td{text-align:left;padding:8px 10px;border-bottom:1px solid var(--line-soft)}
.tbl th{font-family:var(--mono);font-size:11px;letter-spacing:1px;text-transform:uppercase;color:var(--lo-2)}

@media(max-width:520px){.card.auth,.card.install{width:100%}.nav{gap:12px;font-size:12px}}
