:root{font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;line-height:1.5;color:#1a1a1a;background:#f4f6f8}*{box-sizing:border-box}body{margin:0;min-height:100vh}a{color:#2563eb}button{cursor:pointer}.card{max-width:420px;margin:2rem auto;padding:1.5rem 1.75rem;background:#fff;border-radius:10px;box-shadow:0 4px 24px #0000000f}.card h1{margin:0 0 1rem;font-size:1.25rem}.field{margin-bottom:1rem}.field label{display:block;font-size:.875rem;margin-bottom:.35rem;color:#444}.field input{width:100%;padding:.5rem .65rem;border:1px solid #ccc;border-radius:6px;font-size:1rem}.btn{display:inline-block;padding:.55rem 1rem;border:none;border-radius:6px;font-size:.95rem;background:#2563eb;color:#fff}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{background:#64748b}.error{color:#b91c1c;font-size:.875rem;margin-top:.5rem}.app-shell{min-height:100vh;display:flex;flex-direction:column}.app-body{flex:1;min-height:0;display:flex;flex-direction:column}.top-bar{display:flex;align-items:center;gap:1rem;min-height:52px;padding:0 1.25rem;background:linear-gradient(180deg,#fff,#f8fafc);border-bottom:1px solid #e2e8f0;box-shadow:0 1px #0f172a0a}.top-bar__brand{display:flex;align-items:center;gap:.6rem}.top-bar__brand--link{text-decoration:none;color:inherit;border-radius:8px;outline-offset:2px}.top-bar__brand--link:hover .top-bar__title{color:#1d4ed8}.top-bar__logo{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:8px;font-weight:700;font-size:1.05rem;color:#fff;background:linear-gradient(135deg,#2563eb,#4f46e5);box-shadow:0 2px 8px #2563eb59}.top-bar__title{font-size:1.05rem;font-weight:600;letter-spacing:.02em;color:#0f172a}.top-bar__spacer{flex:1}.top-bar__actions{display:flex;align-items:center;gap:.75rem}.top-bar__user-line{font-size:.875rem;color:#334155;max-width:min(22rem,50vw);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.top-bar__logout{padding:.4rem .85rem;border-radius:6px;font-size:.875rem;font-weight:500;color:#475569;background:#f1f5f9;border:1px solid #e2e8f0;transition:background .15s ease,color .15s ease}.top-bar__logout:hover:not(:disabled){background:#e2e8f0;color:#0f172a}.top-bar__logout:disabled{opacity:.65;cursor:not-allowed}.layout{padding:1rem 1.25rem;max-width:640px;margin:0 auto}.main-frame{display:flex;flex:1;min-height:0;align-items:stretch}.sidebar{width:220px;flex-shrink:0;background:#fff;border-right:1px solid #e2e8f0;padding:1rem 0}.side-nav{display:flex;flex-direction:column;gap:.25rem}.nav-group{padding-bottom:.35rem}.nav-root{display:flex;align-items:center;justify-content:space-between;width:calc(100% - 1rem);margin:0 .5rem;padding:.45rem .65rem;border:none;border-radius:6px;font:inherit;text-align:left;cursor:pointer;color:#0f172a;background:transparent;transition:background .12s ease,color .12s ease}.nav-root:hover{background:#f1f5f9}.nav-root__label{font-size:.8rem;font-weight:600;letter-spacing:.04em}.nav-root__chevron{display:inline-block;width:0;height:0;border-left:5px solid transparent;border-right:5px solid transparent;border-top:6px solid #94a3b8;transition:transform .18s ease;transform:rotate(-90deg)}.nav-root--open .nav-root__chevron{transform:rotate(0)}.nav-group__children{padding-top:.2rem}.nav-link{display:block;padding:.5rem 1rem .5rem 1.25rem;margin:0 .5rem;border-radius:6px;font-size:.9rem;color:#334155;text-decoration:none;border-left:3px solid transparent;transition:background .12s ease,color .12s ease}.nav-link:hover{background:#f1f5f9;color:#0f172a}.nav-link.router-link-active{background:#eff6ff;color:#1d4ed8;font-weight:600;border-left-color:#2563eb}.main-content{flex:1;min-width:0;padding:1.25rem 1.5rem;overflow:auto}.page-panel{max-width:960px}.page-panel__title{margin:0 0 .5rem;font-size:1.35rem;font-weight:600;color:#0f172a}.page-panel__desc{margin:0;font-size:.95rem;color:#64748b;line-height:1.6}.card--in-main{max-width:640px;margin:1rem 0 0}
