
/* RJ Portaal – common.css */
:root{
  --bg:#020617;
  --panel:#0f172a;
  --panel-soft:#020617;
  --border:#1e293b;
  --text:#e5e7eb;
  --muted:#9ca3af;
  --accent:#38bdf8;
  --accent-2:#a855f7;
  --danger:#ef4444;
  --radius:14px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0;background:radial-gradient(circle at top,#1f2937 0,#020617 55%);color:var(--text);font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif}

.app{max-width:1400px;margin:24px auto;padding:18px;background:rgba(2,6,23,.75);border:1px solid var(--border);border-radius:24px;box-shadow:0 30px 90px rgba(0,0,0,.7)}

header{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1rem}
.brand{display:flex;align-items:center;gap:.8rem}
.brand img{width:48px;height:48px}
.brand-title h1{margin:0;font-size:1.1rem;letter-spacing:.08em}
.brand-title span{font-size:.8rem;color:var(--muted)}

.right-actions{display:flex;gap:.6rem;align-items:center}

.env-pill{padding:.2rem .7rem;border-radius:999px;font-size:.75rem;background:rgba(56,189,248,.15);border:1px solid rgba(56,189,248,.4)}

.tabs{display:flex;flex-wrap:wrap;gap:.3rem;margin:.6rem 0 1rem}
.tabs a{display:inline-flex;align-items:center;gap:.4rem;padding:.45rem .7rem;border-radius:999px;text-decoration:none;color:var(--text);font-size:.78rem;border:1px solid var(--border);background:rgba(15,23,42,.9)}
.tabs a.active,.tabs a:hover{border-color:var(--accent);box-shadow:0 0 0 1px rgba(56,189,248,.5)}
.tabs .dot{width:8px;height:8px;border-radius:50%;background:var(--accent)}

main{display:block}

.card{background:linear-gradient(180deg,rgba(15,23,42,.95),rgba(2,6,23,.95));border:1px solid var(--border);border-radius:var(--radius);padding:1rem;margin-bottom:1rem}
.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.6rem}
.card-header h2{margin:0;font-size:1rem}
.card-header small{color:var(--muted)}
.card-tag{font-size:.7rem;padding:.15rem .6rem;border-radius:999px;border:1px solid var(--border);background:rgba(56,189,248,.12)}

form label{display:flex;flex-direction:column;font-size:.75rem;color:var(--muted);gap:.25rem}
input,select,textarea{background:rgba(2,6,23,.9);border:1px solid var(--border);border-radius:999px;padding:.45rem .7rem;color:var(--text);font-size:.8rem}
textarea{border-radius:14px}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 1px rgba(56,189,248,.6)}

.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:.6rem}
.form-actions{display:flex;gap:.6rem;margin-top:.7rem;flex-wrap:wrap}

.btn{border-radius:999px;padding:.45rem 1rem;font-size:.75rem;border:1px solid transparent;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;gap:.3rem}
.btn-primary{background:linear-gradient(120deg,var(--accent),var(--accent-2));color:#020617;font-weight:600}
.btn-secondary{background:rgba(15,23,42,.95);border-color:var(--border);color:var(--text)}
.btn-outline{background:transparent;border-color:var(--border);color:var(--muted)}
.btn-danger{background:rgba(239,68,68,.15);border-color:rgba(239,68,68,.6);color:#fecaca}
.btn:hover{transform:translateY(-1px)}

table{width:100%;border-collapse:collapse;margin-top:.5rem}
th,td{font-size:.75rem;padding:.45rem .5rem;border-bottom:1px solid var(--border)}
th{color:var(--muted);font-weight:500;text-align:left}
tbody tr:hover{background:rgba(56,189,248,.05)}

.text-muted{color:var(--muted)}
.text-xs{font-size:.7rem}

@media(max-width:900px){
  .app{margin:10px;padding:12px}
  header{flex-direction:column;align-items:flex-start}
}
