html,body{min-height:100%}body{margin:0;font-family:Arial,sans-serif;background:#f5f7fa;color:#1f2933}.app-shell{min-height:100vh;display:flex;flex-direction:column}.main{flex:1;width:100%;padding:32px 0;display:flex}.content-card{box-shadow:0 6px 16px #0000000d;max-width:1100px;width:100%;margin:0 auto;padding:24px;background:#fff;border:1px solid #d6dbe1;border-radius:8px}.auth-login-wrapper{width:100%;display:flex;align-items:center;justify-content:center}h1,h2,h3{margin-top:0}.app-layout{min-height:100vh;display:flex;flex-direction:column;background:#f5f7fa}.app-header{height:64px;background:#1f3a5f;color:#fff;display:flex;align-items:center;justify-content:space-between;padding:0 24px}.app-header__brand{display:flex;align-items:center;gap:14px;font-weight:700}.app-header__brand img{height:34px;width:auto;display:block}.app-header__brand span{color:#fff;font-size:1.25rem;line-height:1}.app-header__user{display:flex;align-items:center;gap:16px;color:#fff}.app-header__user form{margin:0}.app-header__user button{border:1px solid #ffffff;background:transparent;color:#fff;border-radius:6px;padding:6px 12px;cursor:pointer}.app-header__user button:hover{background:#ffffff1f}.app-layout__body{flex:1;display:flex;min-height:0}.app-sidebar{width:240px;background:#e3dbdb;border-right:1px solid #e0e0e0;padding:24px 0}.app-sidebar a.active{background:#e0e0e5;color:#1f3a5f;font-weight:600}.app-sidebar__nav{display:flex;flex-direction:column}.app-sidebar__nav a{padding:12px 24px;color:#1f2933;text-decoration:none;font-weight:500}.app-sidebar__nav a:hover{background:#e9e9ec;color:#1f3a5f}.app-sidebar__group{display:flex;flex-direction:column}.app-sidebar__submenu{display:flex;flex-direction:column;margin-left:12px;border-left:2px solid #d0d0d5}.app-sidebar__submenu a{padding:8px 24px;font-size:.9rem}.app-sidebar__submenu a:hover{background:#f5f7fa;color:#1f3a5f}.app-sidebar__submenu a.active{font-weight:600;color:#1f3a5f}.app-layout__main{flex:1;padding:24px}.profile-form__actions{margin-bottom:32px}.app-footer{background:#1f3a5f;color:#ffffffb3;padding:8px 24px}.app-footer small{font-size:.8rem;opacity:.8}.app-footer a{color:#fffc;#color: #6b7280;text-decoration:none;transition:color .2s ease}.app-footer a:hover{color:#2f5f8f;text-decoration:underline}.app-footer p{margin:0 0 8px}.app-header__profile-link{color:#fff;text-decoration:none;font-weight:600}.app-header__profile-link:hover{text-decoration:underline}.profile-form__button{margin-top:16px}.form-alert--info{background:#eef3ff;border:1px solid #c9d7ff;color:#1f3a5f}.profile-form{width:100%}.profile-form__grid{display:grid;grid-template-columns:1fr;gap:16px}.auth-login__field{min-width:0}.auth-login__field input,.auth-login__field select,.auth-login__field textarea{width:100%;box-sizing:border-box}.role-badge--system{background:#f9a82529;color:#7a5200}.form-alert{padding:16px;border-radius:8px;margin-bottom:16px;font-weight:600}.form-alert--success{background:#2e7d321f;border:1px solid rgba(46,125,50,.24);color:#2e7d32}.alert{padding:12px 16px;border-radius:10px;margin-bottom:20px;font-weight:600}.alert--success{background:#22c55e1f;color:#166534}.header{background:#1f3a5f;color:#fff;padding:16px 24px;display:flex;align-items:center;gap:24px}.header__brand{display:flex;align-items:center;gap:10px;font-size:1.6rem;font-weight:700}.header__brand span{font-size:1.2rem;font-weight:600;line-height:1}.header__brand img{height:38px;display:block}.header__nav{flex:1;display:flex;align-items:center}.header__nav-left{display:flex;gap:16px}.header__nav-right{margin-left:auto}.header a{color:#fff;text-decoration:none;transition:color .2s ease,transform .1s ease}.header a:hover{color:#2f5f8f;transform:translateY(-1px)}.header a.active{font-weight:600;border-bottom:2px solid white}.login-btn{border:1px solid white;padding:4px 12px;border-radius:6px}.login-btn:hover{background:#fff;color:#1f3a5f}.footer{background:#1f3a5f;color:#ffffffb3;padding:8px 24px}.footer small{font-size:.8rem;opacity:.8}.footer a{color:#fffc;#color: #6b7280;text-decoration:none;transition:color .2s ease}.footer a:hover{color:#2f5f8f;text-decoration:underline}.footer p{margin:0 0 8px}.footer__top{display:flex;justify-content:space-between;align-items:center}.footer__version{font-size:.85rem;opacity:.7}.auth-login{width:100%;max-width:380px;margin:0 auto}.auth-login__header{text-align:center;margin-bottom:24px}.auth-login__header h2{margin:0 0 8px;color:#1f3a5f;font-size:1.6rem}.auth-login__header p{margin:0;color:#6b7280}.auth-login__form{display:flex;flex-direction:column;gap:16px}.auth-login__field{display:flex;flex-direction:column;gap:6px}.auth-login__field label{font-weight:600;color:#1f2933}.auth-login__field input,.auth-login__field select,.auth-login__field textarea{width:100%;box-sizing:border-box;border:1px solid #d6dbe1;border-radius:8px;padding:10px 12px;font:inherit}.auth-login__field input:focus,.auth-login__field select:focus,.auth-login__field textarea:focus{border-color:#1f3a5f;box-shadow:0 0 0 3px #1f3a5f26;outline:none}.auth-login__field input,.auth-login__field select{height:40px}.auth-login__field textarea{min-height:80px;resize:vertical}.auth-login__row{display:flex;justify-content:space-between;align-items:center;gap:16px;font-size:.9rem}.auth-login__row label{display:flex;align-items:center;gap:6px;color:#6b7280}.auth-login__register{text-align:center;font-size:.9rem;color:#6b7280}.auth-login__register a{color:#1f3a5f;font-weight:600;margin-left:4px}.auth-login__register a:hover{text-decoration:underline}.form-error{display:block;margin-top:4px;color:#c62828;font-size:.85rem}.form-alert{padding:10px 12px;border-radius:8px;font-size:.9rem}.form-alert--danger{color:#c62828;background:#c6282814;border:1px solid rgba(198,40,40,.2)}.button,.roles-table__button{border:0;border-radius:6px;background:#1f3a5f;color:#fff;padding:10px 12px;font-weight:700;cursor:pointer;transition:all .2s ease}.button:hover,.roles-table__button:hover{background:#2f5f8f;transform:translateY(-1px)}.button:active,.roles-table__button:active{transform:translateY(0)}.profile-form__actions{margin-top:16px}.roles-table__button{padding:5px 7px;font-size:.85rem}.roles-table__button--save{background:#1f3a5f;color:#fff}.roles-table__button--save:hover{background:#2f5f8f}.roles-table__button--delete{background:#c62828}.roles-table__button--delete:hover{opacity:.9}.roles-table__button--details{background:transparent;color:#1f3a5f;border:1px solid #1f3a5f}.roles-table__button--details:hover{background:#1f3a5f14}.role-details__actions{margin-left:140px;margin-top:8px}.user-edit__actions{display:flex;gap:8px;margin-top:24px}.button--secondary{background:transparent;color:#1f3a5f;border:1px solid #1f3a5f}.button--secondary:hover{background:#1f3a5f14}.auth-login__button{width:100%;padding:10px 16px;border:1px solid #1f3a5f;border-radius:6px;background:#1f3a5f;color:#fff;font-weight:700;cursor:pointer;-moz-appearance:none;appearance:none;-webkit-appearance:none}.roles-assignment{display:flex;flex-direction:column;gap:8px;margin-top:16px}.roles-assignment__item{display:flex;align-items:center;gap:8px}.role-badges{display:flex;flex-wrap:wrap;gap:4px}.role-badge{display:inline-flex;align-items:center;border-radius:999px;background:#1f3a5f1a;color:#1f3a5f;padding:4px 8px;font-size:.85rem;font-weight:700}.role-badge--empty{background:#6b72801f;color:#6b7280}.role-details{display:grid;gap:8px;margin-bottom:16px}.role-details input{width:320px;width:100%;max-width:320px}.role-details__row{display:grid;grid-template-columns:140px 1fr;align-items:center}.role-details__label{font-weight:700}.roles-table{width:100%;border-collapse:collapse;margin-top:16px}.roles-table th,.roles-table td{padding:10px 8px;text-align:left;vertical-align:middle;border-bottom:1px solid #d6dbe1}.roles-table th{font-weight:700;color:#1f2933}.roles-table__input{width:100%;box-sizing:border-box;border:1px solid #d6dbe1;border-radius:8px;padding:8px 10px;font:inherit}.roles-table__input:focus{border-color:#1f3a5f;box-shadow:0 0 0 3px #1f3a5f26;outline:none}.roles-table tbody tr:hover{background:#1f3a5f08}.roles-table__input{transition:border-color .2s ease,box-shadow .2s ease}.roles-table__actions{display:flex;gap:8px;align-items:center}.roles-table__protected{color:#6b7280;font-weight:600}.table-search-form{display:flex;gap:8px;margin:16px 0 24px}.roles-table__link{color:#1f3a5f;font-weight:700;text-decoration:none}.roles-table__input-group{display:flex;flex-direction:column;gap:4px}.roles-table__link{color:#1f3a5f;font-size:.85rem;font-weight:700;text-decoration:none}.roles-table__link:hover{text-decoration:underline}.pagination svg{width:16px;height:16px}nav[role=navigation] svg{width:16px;height:16px}nav[role=navigation]{margin-top:16px}.permission-group{margin-bottom:24px}.permission-group__list{display:flex;flex-direction:column;gap:10px}.permission-checkbox{display:flex;align-items:center;gap:8px}.profile-form select{width:100%;padding:10px 12px;border:1px solid #d6dbe1;border-radius:6px;font:inherit;background:#fff}.badge{display:inline-flex;align-items:center;padding:3px 8px;border-radius:999px;font-size:.85rem;font-weight:700;line-height:1;background:#f3f4f6;color:#1f2933}.badge--success{background:#22c55e1f;color:#166534}.badge--info{background:#2563eb1f;color:#1e3a8a}.badge--muted{background:#64748b1f;color:#334155}.category-row--inactive{opacity:.55}.category-row--inactive td{color:#64748b}.app-sidebar__group{margin-bottom:8px}.app-sidebar__toggle{width:100%;display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border:0;background:transparent;border-radius:10px;color:#1f2937;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.app-sidebar__toggle:hover{background:#f3f4f6}.app-sidebar__toggle.active{background:#e8eefc;color:#2563eb}.app-sidebar__submenu{margin-top:6px;margin-left:10px;padding-left:12px;border-left:1px solid #e5e7eb;display:flex;flex-direction:column;gap:6px}.app-sidebar__submenu--nested{margin-left:14px;margin-top:4px;margin-bottom:6px}.app-sidebar__submenu a{padding:8px 12px;border-radius:8px;color:#4b5563;text-decoration:none;font-size:14px;transition:all .18s ease}.app-sidebar__submenu a:hover{background:#f3f4f6}.app-sidebar__submenu a.active{background:#dbeafe;color:#2563eb;font-weight:600}.app-sidebar__chevron{transition:transform .2s ease;font-size:12px}.app-sidebar__chevron.open{transform:rotate(180deg)}[x-cloak]{display:none!important}.app-sidebar__submenu-toggle{width:100%;display:flex;justify-content:space-between;align-items:center;padding:9px 12px;border:0;background:transparent;border-radius:8px;font-size:14px;color:#374151;cursor:pointer}.app-sidebar__submenu-toggle:hover,.app-sidebar__submenu-toggle.active{background:#eef2ff;color:#1d4ed8}.app-sidebar__submenu--nested{margin-left:14px;margin-top:4px;margin-bottom:8px}.checkbox-card{display:flex;align-items:center;gap:10px;padding:10px 12px;border:1px solid #d6dbe1;border-radius:8px;background:#fff}.team-approver-summary{margin:.5rem 1.5rem 0;font-size:.9rem;opacity:.8}
