*{box-sizing:border-box}body,html{margin:0;padding:0;font-family:Inter,Arial,sans-serif;background:#f8fafc;color:#0f172a}.layout{min-height:100vh;display:grid;grid-template-columns:260px 1fr}.sidebar{background:#0f172a;color:#e2e8f0;padding:1rem}.sidebar h1{margin:0 0 1.2rem;font-size:1rem}.menu{display:grid;grid-gap:.5rem;gap:.5rem}.menu a{color:#cbd5e1;padding:.55rem .7rem;border-radius:8px}.menu a:hover{background:#1e293b}.content{padding:1.25rem}.card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:1rem}.header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.login-form{display:grid;grid-gap:.7rem;gap:.7rem;margin-top:1rem;max-width:420px}.login-form input{width:100%;padding:.7rem .75rem;border:1px solid #cbd5e1;border-radius:8px}.login-form button{border:none;border-radius:8px;background:#1d4ed8;color:#fff;padding:.7rem .8rem;font-weight:600;cursor:pointer}.info{color:#475569;font-size:.9rem}.badge{display:inline-flex;background:#dbeafe;color:#1d4ed8;border-radius:999px;padding:.2rem .55rem;font-size:.75rem;font-weight:700}.toolbar{display:flex;align-items:center;gap:.5rem}.ghost-btn{border:1px solid #cbd5e1;border-radius:8px;background:#fff;color:#334155;padding:.45rem .7rem;cursor:pointer}.catalog-grid{display:grid;grid-template-columns:1fr 1fr 1.2fr;grid-gap:1rem;gap:1rem;margin-top:1rem}.list-card{border:1px solid #e2e8f0;border-radius:10px;overflow:hidden}.list-card h4{margin:0;padding:.7rem .8rem;background:#f8fafc;border-bottom:1px solid #e2e8f0}.list-scroll{max-height:360px;overflow:auto}.row-btn{width:100%;text-align:left;background:#fff;border:none;border-bottom:1px solid #f1f5f9;padding:.65rem .75rem;cursor:pointer}.row-btn:hover{background:#f8fafc}.row-btn.active{background:#eff6ff;color:#1d4ed8;font-weight:600}.row-btn-wrap{display:flex;align-items:center;border-bottom:1px solid #f1f5f9}.row-btn-wrap .row-btn{flex:1 1;border-bottom:none}.row-btn-wrap.active .row-btn{background:#eff6ff;color:#1d4ed8;font-weight:600}.row-actions{display:flex;gap:.25rem;padding:0 .5rem}.ghost-btn.small{padding:.3rem .5rem;font-size:.8rem}.attr{border-bottom:1px solid #f1f5f9;padding:.65rem .75rem}.attr small{color:#64748b}@media (max-width:900px){.catalog-grid,.layout{grid-template-columns:1fr}}