*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background:#f5f5f7;color:#222;line-height:1.5}.app-layout{display:flex;min-height:100vh}.sidebar{width:240px;background:#1a1a2e;color:#fff;display:flex;flex-direction:column;padding:1rem 0;flex-shrink:0}.sidebar-brand{font-size:1.25rem;font-weight:700;padding:.5rem 1.25rem 1.5rem;letter-spacing:.05em}.sidebar nav{display:flex;flex-direction:column;gap:2px}.sidebar nav a{color:#ccc;text-decoration:none;padding:.6rem 1.25rem;font-size:.9rem;transition:background .15s ease-out,color .15s ease-out}.sidebar nav a:hover{background:#16213e;color:#fff}.sidebar nav a.active{background:#16213e;color:#fff;border-left:3px solid #4361ee;padding-left:calc(1.25rem - 3px)}.main-area{flex:1;display:flex;flex-direction:column}.top-bar{height:52px;background:#fff;border-bottom:1px solid #ddd;display:flex;align-items:center;justify-content:flex-end;padding:0 1.5rem;gap:1rem}.top-bar span{font-size:.85rem;color:#666}.page-content{flex:1;padding:2rem;max-width:1320px}input,select,textarea{font:inherit;padding:.5rem .75rem;border:1px solid #ccc;border-radius:4px;width:100%;transition:border-color .15s ease-out,box-shadow .15s ease-out}input,select{max-width:400px}textarea{max-width:100%;resize:vertical}input:focus,select:focus,textarea:focus{outline:none;border-color:#4361ee;box-shadow:0 0 0 3px #4361ee1f}label{display:block;margin-bottom:.25rem;font-weight:500;font-size:.9rem}.form-group{margin-bottom:1rem}button,.btn{font:inherit;cursor:pointer;padding:.5rem 1.25rem;border:none;border-radius:4px;font-size:.9rem;background:#4361ee;color:#fff;transition:background .15s ease-out,transform .1s ease-out}button:hover{background:#3a56d4}button:active{transform:scale(.97)}button:disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.btn-secondary{background:#6c757d}.btn-secondary:hover{background:#5a6268}.btn-danger{background:#dc3545}.btn-danger:hover{background:#c82333}.btn-sm{padding:.3rem .75rem;font-size:.8rem}table{width:100%;border-collapse:collapse;background:#fff;border-radius:6px;overflow:hidden}th,td{padding:.55rem .85rem;text-align:left;border-bottom:1px solid #e9eef5}th{background:#f1f5f9;font-weight:600;font-size:.75rem;color:#475569;text-transform:uppercase;letter-spacing:.05em;border-bottom:2px solid #e2e8f0}thead tr{border-bottom:2px solid #e2e8f0}tbody tr:nth-child(2n){background:#f8fafc}tbody tr{transition:background .1s ease-out}tbody tr:hover{background:#eff6ff}.row-item{padding:.6rem .75rem;border-bottom:1px solid #e9eef5;background:#fff}.row-item:nth-child(2n){background:#f8fafc}.row-item:last-child{border-bottom:none}.row-item:hover{background:#f0f9ff}.card-inner{background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;padding:.85rem 1rem;margin-bottom:.5rem}.card-inner:last-child{margin-bottom:0}.badge{display:inline-block;padding:.15rem .6rem;border-radius:10px;font-size:.75rem;font-weight:600}.badge-success{background:#d4edda;color:#155724}.badge-warning{background:#fff3cd;color:#856404}.badge-error{background:#f8d7da;color:#721c24}.card{background:#fff;border-radius:8px;padding:1.5rem;box-shadow:0 2px 8px #00000014,0 1px 2px #0000000d;border:1px solid #e2e8f0;margin-bottom:1.5rem}.login-wrapper{display:flex;align-items:center;justify-content:center;min-height:100vh;background:#1a1a2e}.login-card{background:#fff;border-radius:8px;padding:2.5rem;width:100%;max-width:380px}.login-card h1{margin-bottom:1.5rem;font-size:1.5rem}.step-indicator{display:flex;gap:.5rem;margin-bottom:2rem;flex-wrap:wrap}.step-dot{width:28px;height:28px;border-radius:50%;border:2px solid #ccc;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:600;transition:background .2s ease-out,border-color .2s ease-out}.step-dot.active{border-color:#4361ee;background:#4361ee;color:#fff}.step-dot.done{border-color:#28a745;background:#28a745;color:#fff}.error-msg{color:#dc3545;font-size:.85rem;margin-bottom:1rem}.tag-list{display:flex;flex-wrap:wrap;gap:.4rem}.tag{display:inline-flex;align-items:center;gap:.3rem;background:#e8eaf6;color:#3949ab;border-radius:12px;padding:.2rem .6rem;font-size:.8rem;font-weight:500}.tag-readonly{background:#f0f0f0;color:#555}.tag-remove{background:none;border:none;color:inherit;cursor:pointer;padding:0;font-size:1rem;line-height:1;opacity:.7;transition:opacity .1s ease-out}.tag-remove:hover{opacity:1;background:none}h1{font-size:1.6rem;margin-bottom:1rem}h2{font-size:1.2rem;margin-bottom:.75rem}p{margin-bottom:.75rem}.mt-1{margin-top:1rem}.flex-gap{display:flex;gap:.75rem}@keyframes spin{to{transform:rotate(360deg)}}@keyframes page-fade-in{0%{opacity:0}to{opacity:1}}.spinner{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.35);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite;vertical-align:middle}.spinner-dark{border-color:#00000026;border-top-color:#555}.page-content{animation:page-fade-in .2s cubic-bezier(.16,1,.3,1) both}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}
