/* ═══════════════════════════════════════════
   JUSTICE UGO — PROJECT TOOLS SHARED CSS
   Warm editorial: cream / orange / serif
   ═══════════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@300;400;500;600;700&family=Space+Mono:ital,wght@0,400;0,700;1,400&display=swap');

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --cream:#F4F1EC;--cream-dk:#E8E4DC;--cream-dkr:#D8D3C8;
  --orange:#000000;--orange-dk:#1a1a1a;--yellow:#E8E4DC;
  --black:#0A0A0A;--brown:#3a3a3a;--brown-lt:#777777;
  --white:#FFFFFF;--border:#BBBBBB;--border-dk:#333333;
  --text:#0A0A0A;--muted:#666666;
  --success:#2D6A4F;--danger:#9B2226;
  --radius:2px;--radius-lg:3px;
}
html{scroll-behavior:smooth}
body{background:var(--cream);color:var(--text);font-family:'Space Grotesk',sans-serif;line-height:1.6;min-height:100vh}
a{color:inherit;text-decoration:none}
button{cursor:pointer;font-family:inherit}
h1,h2,h3,h4{font-family:'Space Grotesk',sans-serif;line-height:1.2;color:var(--black)}
.mono{font-family:'Space Mono',monospace}

/* ── Tool shell ─────────────────────────── */
.tool-shell{display:flex;flex-direction:column;min-height:100vh}

/* ── Tool nav ───────────────────────────── */
.tool-nav{
  background:var(--white);border-bottom:3px solid var(--black);
  padding:0 24px;height:56px;display:flex;align-items:center;gap:16px;
  position:sticky;top:0;z-index:50;flex-shrink:0;
}
.tool-nav-logo{font-family:'Space Grotesk',sans-serif;font-weight:900;font-size:18px;color:var(--black)}
.tool-nav-logo span{color:var(--orange)}
.tool-nav-title{font-family:'Space Mono',monospace;font-size:12px;color:var(--brown);letter-spacing:1px}
.tool-nav-links{margin-left:auto;display:flex;gap:16px;align-items:center}
.tool-nav-links a{font-size:13px;font-weight:500;color:var(--brown);transition:color .15s}
.tool-nav-links a:hover{color:var(--orange)}
.tool-nav-back{
  display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:600;
  color:var(--brown);border:1px solid var(--border-dk);border-radius:var(--radius);
  padding:5px 12px;background:var(--white);transition:all .15s;
}
.tool-nav-back:hover{border-color:var(--orange);color:var(--orange)}

/* ── Tool body ──────────────────────────── */
.tool-body{flex:1;padding:32px 24px;max-width:960px;margin:0 auto;width:100%}
.tool-header{margin-bottom:28px}
.tool-badge{
  display:inline-block;background:var(--orange);color:var(--white);
  font-family:'Space Mono',monospace;font-size:10px;letter-spacing:2px;
  text-transform:uppercase;padding:3px 10px;border-radius:2px;margin-bottom:10px;
}
.tool-title{font-family:'Space Grotesk',sans-serif;font-size:40px;font-weight:900;color:var(--black);line-height:1;margin-bottom:8px}
.tool-subtitle{font-size:16px;color:var(--muted);line-height:1.6;max-width:620px}

/* ── Cards ──────────────────────────────── */
.card{background:var(--white);border:2px solid var(--black);border-radius:var(--radius);overflow:hidden;margin-bottom:20px;box-shadow:4px 4px 0 var(--black)}
.card-header{
  background:var(--black);border-bottom:2px solid var(--black);color:var(--white);
  padding:10px 18px;display:flex;align-items:center;justify-content:space-between;
}
.card-title{font-family:'Space Mono',monospace;font-size:12px;font-weight:500;letter-spacing:1px;color:var(--black)}
.card-body{padding:20px}
.card-2{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.card-3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}

/* ── Forms ──────────────────────────────── */
label{display:block;font-family:'Space Mono',monospace;font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);margin-bottom:6px}
input,textarea,select{
  width:100%;background:var(--cream);border:2px solid var(--border-dk);
  border-radius:var(--radius);padding:10px 14px;font-size:14px;
  font-family:'Space Grotesk',sans-serif;color:var(--text);outline:none;
  transition:border-color .15s;margin-bottom:12px;
}
input:focus,textarea:focus,select:focus{border-color:var(--orange);background:var(--white)}
textarea{resize:vertical;min-height:80px;line-height:1.6}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.form-row-3{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}

/* ── Buttons ────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;gap:8px;padding:10px 20px;
  border-radius:var(--radius);font-size:14px;font-weight:600;
  border:2px solid transparent;transition:all .15s;cursor:pointer;
  font-family:'Space Grotesk',sans-serif;white-space:nowrap;
}
.btn-orange{background:var(--black);color:var(--white);border:2px solid var(--black);box-shadow:3px 3px 0 #444}
.btn-orange:hover{background:var(--white);color:var(--black);transform:translate(-2px,-2px);box-shadow:5px 5px 0 var(--black)}
.btn-outline{background:transparent;color:var(--black);border:2px solid var(--black)}
.btn-outline:hover{background:var(--black);color:var(--white)}
.btn-black{background:var(--black);color:var(--white);border-color:var(--black)}
.btn-black:hover{background:var(--brown)}
.btn-sm{padding:7px 14px;font-size:13px}
.btn-full{width:100%;justify-content:center}
.btn-row{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:12px}

/* ── Output / terminal boxes ────────────── */
.output-box{
  background:var(--black);border:2px solid var(--black);border-radius:var(--radius);
  padding:16px;font-family:'Space Mono',monospace;font-size:13px;
  color:#e8d5b0;min-height:80px;overflow-y:auto;line-height:1.8;
  max-height:420px;
}
.output-box::-webkit-scrollbar{width:4px}
.output-box::-webkit-scrollbar-track{background:var(--black)}
.output-box::-webkit-scrollbar-thumb{background:#3d2b1f;border-radius:2px}
.output-line{padding:1px 0}
.out-ok   {color:#4ade80}
.out-warn {color:#fbbf24}
.out-err  {color:#f87171}
.out-info {color:#93c5fd}
.out-muted{color:#6b7280}
.out-head {color:#e8d5b0;border-bottom:1px solid #3d2b1f;padding-bottom:6px;margin-bottom:6px}

/* ── Progress bar ───────────────────────── */
.progress-wrap{margin-bottom:12px}
.progress-track{height:6px;background:var(--cream-dkr);border-radius:3px;overflow:hidden}
.progress-fill{height:100%;background:var(--orange);border-radius:3px;width:0%;transition:width .2s}
.progress-label{font-family:'Space Mono',monospace;font-size:11px;color:var(--muted);margin-top:5px}

/* ── Stat cards ─────────────────────────── */
.stats-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:12px;margin-bottom:20px}
.stat{background:var(--white);border:2px solid var(--black);border-radius:var(--radius-lg);padding:14px;text-align:center}
.stat-num{font-family:'Space Grotesk',sans-serif;font-size:36px;font-weight:900;color:var(--orange);line-height:1}
.stat-label{font-family:'Space Mono',monospace;font-size:10px;text-transform:uppercase;letter-spacing:1px;color:var(--muted);margin-top:4px}

/* ── Payload chips / tags ───────────────── */
.chip-row{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:12px}
.chip{
  background:var(--cream-dk);border:1px solid var(--border-dk);
  color:var(--brown);font-family:'Space Mono',monospace;font-size:11px;
  padding:4px 10px;border-radius:2px;cursor:pointer;transition:all .15s;
}
.chip:hover,.chip.active{background:var(--orange);border-color:var(--orange-dk);color:var(--white)}

/* ── Tables ─────────────────────────────── */
.data-table{width:100%;border-collapse:collapse;font-size:13px}
.data-table th{
  background:var(--yellow);border:1px solid var(--border);
  padding:8px 12px;text-align:left;font-family:'Space Mono',monospace;
  font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:var(--brown);
}
.data-table td{border:1px solid var(--border);padding:8px 12px;background:var(--white);font-family:'Space Mono',monospace;font-size:12px;vertical-align:middle}
.data-table tr:hover td{background:var(--cream-dk)}
.data-table .highlight td{background:#fff7e6}

/* ── Strength / score meter ─────────────── */
.score-bar-wrap{margin:8px 0}
.score-bar-track{height:8px;background:var(--cream-dkr);border-radius:4px;overflow:hidden}
.score-bar-fill{height:100%;border-radius:4px;transition:width .5s ease,background .5s}
.score-label{display:flex;justify-content:space-between;font-family:'Space Mono',monospace;font-size:12px;margin-bottom:4px}

/* ── Info / warning boxes ───────────────── */
.info-box{
  background:#fff7e6;border:2px solid var(--yellow);border-radius:var(--radius);
  padding:12px 16px;font-size:13px;color:var(--brown);margin-bottom:16px;
  display:flex;gap:10px;align-items:flex-start;
}
.warn-box{background:#fef2f2;border:2px solid #fca5a5;border-radius:var(--radius);padding:12px 16px;font-size:13px;color:var(--danger);margin-bottom:16px}
.success-box{background:#f0fdf4;border:2px solid #86efac;border-radius:var(--radius);padding:12px 16px;font-size:13px;color:var(--success);margin-bottom:16px}

/* ── Badge / status pills ───────────────── */
.badge{display:inline-block;padding:2px 9px;border-radius:2px;font-family:'Space Mono',monospace;font-size:10px;letter-spacing:1px;text-transform:uppercase;font-weight:500}
.badge-orange{background:var(--orange);color:var(--white)}
.badge-yellow{background:var(--yellow);color:var(--black)}
.badge-green{background:#dcfce7;color:var(--success);border:1px solid #86efac}
.badge-red{background:#fef2f2;color:var(--danger);border:1px solid #fca5a5}
.badge-outline{background:transparent;border:1px solid var(--border-dk);color:var(--muted)}

/* ── Tabs ───────────────────────────────── */
.tabs{display:flex;border-bottom:2px solid var(--black);margin-bottom:0}
.tab-btn{
  padding:10px 20px;font-size:13px;font-weight:600;cursor:pointer;
  color:var(--muted);border-bottom:3px solid transparent;margin-bottom:-2px;
  background:none;border-top:none;border-left:none;border-right:none;
  font-family:'Space Grotesk',sans-serif;transition:all .15s;
}
.tab-btn:hover{color:var(--black)}
.tab-btn.active{color:var(--orange);border-bottom-color:var(--orange)}
.tab-pane{display:none;padding-top:20px}
.tab-pane.active{display:block}

/* ── Code display ───────────────────────── */
.code-display{
  background:var(--black);color:#e8d5b0;border-radius:var(--radius);
  padding:14px 16px;font-family:'Space Mono',monospace;font-size:12px;
  line-height:1.8;overflow-x:auto;margin:8px 0;
}
.hl-inject{color:#f87171;font-weight:500}
.hl-safe{color:#4ade80}
.hl-key{color:#fbbf24}
.hl-val{color:#93c5fd}

/* ── Responsive ─────────────────────────── */
@media(max-width:768px){
  .card-2,.card-3{grid-template-columns:1fr}
  .form-row,.form-row-3{grid-template-columns:1fr}
  .tool-body{padding:20px 16px}
  .tool-title{font-size:30px}
  .tool-nav{padding:0 16px}
}
