:root{--bg:#0f1720;--card:#0b1220;--accent:#60a5fa;--muted:#9aa6b2;--text:#e6eef6}
*{box-sizing:border-box}
html,body{height:100%}
body{font-family:Inter,ui-sans-serif,system-ui,Arial,Helvetica,sans-serif;margin:0;background:linear-gradient(180deg,#071026 0%, #08131a 100%);color:var(--text);display:flex;align-items:flex-start;justify-content:center;padding:36px}
.container{max-width:900px;background:rgba(255,255,255,0.03);padding:24px;border-radius:10px;box-shadow:0 6px 24px rgba(2,6,23,0.6);width:100%}
h1{margin:0 0 12px 0;font-size:1.6rem}
form label{display:flex;flex-direction:column;font-size:0.9rem;margin-bottom:6px}
.row{display:flex;gap:12px;flex-wrap:wrap}
.attrs{display:grid;grid-template-columns:repeat(3,minmax(120px,1fr));gap:8px}
#skills-container{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:8px}
.skill-row{display:flex;align-items:center;gap:6px;padding:6px;background:rgba(255,255,255,0.01);border-radius:4px}
.skill-label{display:flex;align-items:center;gap:6px;font-size:0.85rem;margin-bottom:0;flex:1}
.skill-base{font-size:0.8rem;color:var(--muted);font-weight:500}
input[type="checkbox"]{width:18px;height:18px;cursor:pointer}
input[type="text"],input[type="number"],select{padding:8px;border-radius:6px;border:1px solid rgba(255,255,255,0.06);background:rgba(255,255,255,0.02);color:var(--text)}
.controls{display:flex;gap:8px;align-items:center;margin-top:12px}
button{background:var(--accent);color:#022;border:none;padding:8px 12px;border-radius:8px;cursor:pointer}
button#download{background:#34d399}
button#randomize{background:#fbbf24}
input[type=file]{color:var(--muted)}
pre#output{margin-top:18px;background:rgba(0,0,0,0.25);padding:12px;border-radius:8px;color:var(--text);max-height:300px;overflow:auto}
.traits-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:10px}
.trait-card{padding:10px;background:rgba(255,255,255,0.02);border:1px solid rgba(255,255,255,0.06);border-radius:6px;cursor:pointer;transition:all 0.2s ease}
.trait-card:hover{background:rgba(255,255,255,0.05);border-color:rgba(255,255,255,0.12)}
.trait-card.selected{background:rgba(96,165,250,0.15);border-color:#60a5fa}
.trait-card-checkbox{width:18px;height:18px;cursor:pointer;margin-right:8px}
.trait-card-label{display:flex;align-items:flex-start;gap:8px;cursor:pointer;margin:0;margin-bottom:6px}
.trait-card-name{font-weight:600;color:#60a5fa}
.trait-card-description{font-size:0.8rem;color:var(--muted);line-height:1.4;margin-bottom:6px}
.trait-card-restrictions{font-size:0.75rem;color:#ff7b7b;font-style:italic;margin-top:4px}
.attribute-button-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px}
.attribute-button-item{display:flex;flex-direction:column;gap:6px}
.attribute-name{font-size:0.85rem;font-weight:600;color:#60a5fa;text-align:center}
.attribute-controls{display:flex;gap:4px;align-items:center;justify-content:center}
.attribute-btn{padding:6px 10px;background:rgba(255,255,255,0.05);border:1px solid rgba(255,255,255,0.1);border-radius:4px;color:var(--text);font-weight:600;cursor:pointer;font-size:0.9rem;transition:all 0.2s ease;flex:1;min-width:30px}
.attribute-btn:hover{background:rgba(255,255,255,0.1);border-color:rgba(255,255,255,0.2)}
.attribute-btn:active{background:rgba(96,165,250,0.2);border-color:#60a5fa}
.attribute-value{font-size:1.1rem;font-weight:700;color:#4CAF50;text-align:center;min-width:40px;padding:6px;background:rgba(76,175,80,0.1);border-radius:4px}
.attribute-info{font-size:0.75rem;color:var(--muted);text-align:center;line-height:1.3}
@media (max-width:640px){.attrs{grid-template-columns:repeat(2,1fr)}.row{flex-direction:column}.traits-grid{grid-template-columns:1fr}.attribute-button-grid{grid-template-columns:repeat(auto-fit,minmax(120px,1fr))}}
