*{margin:0;padding:0;box-sizing:border-box}body{height:100vh;width:100vw;background:#fff;color:#181818}#root{height:100%;width:100%;overflow:hidden;position:relative}.base-layout{display:flex;height:100%;min-height:0;width:100%;font-family:system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,sans-serif;background:#fff;color:#181818}.base-layout__sidebar{flex-shrink:0;width:280px;box-sizing:border-box;display:flex;flex-direction:column;gap:1rem;padding:1rem;background:#fff;border-right:1px solid #e0e0e0;overflow:auto}.base-layout__brand{margin:0;font-size:1.25rem;font-weight:800;line-height:1.3;letter-spacing:-.02em}.base-layout__nav{flex:1;min-height:0}.base-layout__sidebar-footer{flex-shrink:0;display:flex;flex-direction:column;gap:.75rem;margin-top:auto;padding-top:.25rem}.base-layout__sidebar-divider{border:none;border-top:1px solid #e0e0e0;margin:0}.base-layout__sidebar-footer-loading{margin:0;font-size:.75rem;color:#00000073}.base-layout__sidebar-user{display:flex;flex-direction:row;align-items:flex-start;gap:.75rem}.base-layout__sidebar-avatar{flex-shrink:0;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:#d4e3c5;color:#365128;font-size:.875rem;font-weight:600;line-height:1}.base-layout__sidebar-user-text{display:flex;flex-direction:column;gap:.125rem;min-width:0}.base-layout__sidebar-user-role,.base-layout__sidebar-user-id{font-size:.75rem;line-height:1.25;color:#00000073}.base-layout__sidebar-user-name{font-size:.875rem;font-weight:600;line-height:1.2;color:#000000de;word-break:break-word}.base-layout__sidebar-actions{display:flex;flex-direction:column;gap:.5rem}.base-layout__sidebar-btn{width:100%;box-sizing:border-box;margin:0;padding:.5rem .75rem;font:inherit;font-size:.8125rem;font-weight:500;color:#5a7a47;background:#fff;border:1px solid #d0d0d0;border-radius:9999px;cursor:pointer;transition:background-color .15s ease,border-color .15s ease}.base-layout__sidebar-btn:hover{background:#5a7a470f;border-color:#b8b8b8}.base-layout__sidebar-btn:focus-visible{outline:2px solid #5a7a47;outline-offset:2px}.base-layout__sidebar-btn--compact{font-size:.75rem;padding:.4rem .65rem}.base-layout__nav-list{list-style:none;margin:0;padding:0}.base-layout__nav-link{display:flex;align-items:center;gap:.75rem;min-height:48px;box-sizing:border-box;padding:.5rem .75rem;margin-bottom:.375rem;font-size:1rem;font-weight:400;line-height:1.5;color:#000000de;text-decoration:none;border-radius:10px;background:transparent;transition:background-color .15s ease}.base-layout__nav-link:hover{background:#d5e3c8}.base-layout__nav-link--active{background:#bfd4ab;font-weight:500}.base-layout__nav-link--active:hover{background:#bfd4ab}.base-layout__nav-icon{display:flex;flex-shrink:0;width:24px;height:24px;color:#0000008a}.base-layout__nav-link--active .base-layout__nav-icon{color:#000000de}.base-layout__main{flex:1;min-width:0;min-height:0;overflow:auto;padding:1.75rem 2rem}.home-page h1{font-size:1.35rem;font-weight:600;margin-bottom:.35rem}.home-page .subtitle{font-size:.9rem;color:#4e4e4e;margin-bottom:1.5rem}.profile-dl{margin:1rem 0 0;display:grid;grid-template-columns:minmax(0,38%) 1fr;gap:.5rem 1rem;font-size:.92rem}.profile-dl dt{color:#4e4e4e;font-weight:500}.profile-dl dd{margin:0;color:#181818;word-break:break-word}.home-section{margin-top:1.75rem}.home-section:first-of-type{margin-top:.5rem}.home-section-title{font-size:1.05rem;font-weight:600;margin:0 0 .75rem}.home-muted{font-size:.9rem;color:#4e4e4e;margin:0}.home-actions-row{display:flex;flex-wrap:wrap;gap:.65rem .85rem;margin-top:1.25rem}.home-page .home-actions-row button,.home-page .home-dialog-actions button,.home-page>.actions button{display:inline-flex;align-items:center;justify-content:center;min-width:8.5rem;padding:.65rem 1.15rem;border-radius:8px;font-size:.95rem;font-weight:600;line-height:1.2;cursor:pointer;transition:background-color .15s ease,border-color .15s ease,color .15s ease,box-shadow .15s ease,opacity .15s ease}.home-page .home-actions-row button:focus-visible,.home-page .home-dialog-actions button:focus-visible,.home-page>.actions button:focus-visible{outline:2px solid #5a7a4a;outline-offset:2px}.home-page .home-actions-row button.primary,.home-page .home-dialog-actions button.primary{border:none;background:#8fb076;color:#181818;box-shadow:0 1px 2px #18181814}.home-page .home-actions-row button.primary:hover:not(:disabled),.home-page .home-dialog-actions button.primary:hover:not(:disabled){background:#7f9770}.home-page .home-actions-row button.primary:active:not(:disabled),.home-page .home-dialog-actions button.primary:active:not(:disabled){background:#728864}.home-page .home-actions-row button.secondary,.home-page .home-dialog-actions button.secondary,.home-page>.actions button.secondary{background:#fff;color:#181818;border:1px solid #bccbab;box-shadow:0 1px 2px #1818180f}.home-page .home-actions-row button.secondary:hover:not(:disabled),.home-page .home-dialog-actions button.secondary:hover:not(:disabled),.home-page>.actions button.secondary:hover:not(:disabled){background:#f7f7f7;border-color:#a8b896}.home-page .home-actions-row button.secondary:active:not(:disabled),.home-page .home-dialog-actions button.secondary:active:not(:disabled),.home-page>.actions button.secondary:active:not(:disabled){background:#efefef}.home-page .home-actions-row button:disabled,.home-page .home-dialog-actions button:disabled,.home-page>.actions button:disabled{opacity:.55;cursor:not-allowed;box-shadow:none}.home-page>.actions{display:flex;flex-wrap:wrap;gap:.65rem .85rem;margin-top:2rem;padding-top:1.25rem;border-top:1px solid #e4e4e4}.modules-list{margin:0;padding-left:1.25rem;font-size:.92rem;line-height:1.5}.alert-info{background:#e8f4fc;border:1px solid #b8d9f0;color:#143e5c;padding:.65rem .85rem;border-radius:6px;margin-bottom:1rem;font-size:.9rem}.home-edit-dialog{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);margin:0;width:min(420px,calc(100vw - 2rem));max-width:min(420px,100vw - 2rem);max-height:min(90vh,calc(100dvh - 2rem));overflow:auto;border:1px solid #ccc;border-radius:8px;padding:0;box-shadow:0 8px 24px #0000001f}.home-edit-dialog::backdrop{background:#00000059}.home-edit-dialog form,.home-reset-confirm-inner{padding:1.25rem 1.35rem}.home-reset-confirm-body{font-size:.9rem;line-height:1.5;color:#333;margin:0 0 1rem}.home-reset-confirm-body p{margin:0 0 .65rem}.home-reset-confirm-body p:last-child{margin-bottom:0}.home-edit-dialog h3{margin:0 0 .35rem;font-size:1.1rem;font-weight:600}.home-dialog-hint{font-size:.85rem;color:#4e4e4e;margin:0 0 1rem}.home-field{margin-bottom:1rem}.home-field label{display:block;font-size:.88rem;font-weight:500;margin-bottom:.35rem}.home-field input{width:100%;box-sizing:border-box;padding:.5rem .65rem;font-size:.95rem;border:1px solid #c8c8c8;border-radius:6px}.home-field-hint{font-size:.8rem;color:#666;margin:.35rem 0 0}.home-dialog-actions{display:flex;justify-content:flex-end;flex-wrap:wrap;gap:.65rem .85rem;margin-top:1.25rem}.otp-row{display:flex;gap:.5rem;justify-content:space-between;margin-top:.5rem}.otp-cell{width:100%;max-width:3rem;aspect-ratio:1;text-align:center;font-size:1.25rem;font-weight:600;border-radius:8px;border:1px solid #b8c8aa;background:#fff;color:#181818}.otp-cell:focus{outline:2px solid #8fb076;outline-offset:0;border-color:#8fb076}.otp-cell[aria-invalid=true]{border-color:#7f9770}.login-page{position:relative;min-height:100%;display:flex;align-items:center;justify-content:center;padding:1.5rem;font-family:system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,sans-serif;background:#fff;color:#181818}.login-page__lang-switcher{position:absolute;top:1rem;right:1.5rem;z-index:1}.lang-switcher{position:relative;display:inline-block}.lang-switcher__toggle{display:inline-flex;align-items:center;gap:.35rem;margin:0;padding:.4rem .55rem .4rem .65rem;border-radius:8px;border:1px solid #bccbab;font-size:.8rem;font-weight:600;letter-spacing:.02em;cursor:pointer;background:#fff;color:#181818}.lang-switcher__toggle:hover{background:#f3f8ee}.lang-switcher__chevron{display:inline-block;width:0;height:0;border-left:4px solid transparent;border-right:4px solid transparent;border-top:5px solid #4e4e4e;margin-top:1px;transition:transform .15s ease}.lang-switcher__toggle[aria-expanded=true] .lang-switcher__chevron{transform:rotate(180deg)}.lang-switcher__menu{position:absolute;top:calc(100% + 4px);right:0;min-width:9rem;margin:0;padding:.25rem 0;list-style:none;border-radius:8px;border:1px solid #bccbab;background:#fff;box-shadow:0 8px 24px #5f814a33;z-index:10}.lang-switcher__item{margin:0}.lang-switcher__option{display:flex;width:100%;align-items:baseline;justify-content:space-between;gap:.75rem;margin:0;padding:.45rem .75rem;border:none;font:inherit;text-align:left;cursor:pointer;background:transparent;color:#181818}.lang-switcher__option:hover{background:#f3f8ee}.lang-switcher__option--active{background:#dce9d0}.lang-switcher__option--active:hover{background:#c8ddb8}.lang-switcher__option-label{font-weight:600;font-size:.8rem;letter-spacing:.02em}.lang-switcher__option-hint{font-size:.72rem;color:#4e4e4e;white-space:nowrap}.login-card{width:100%;max-width:400px;background:#f3f8ee;border:1px solid #bccbab;border-radius:12px;padding:2rem;box-shadow:0 20px 50px #5f814a2e}.login-card-wide{max-width:520px}.login-card h1{font-size:1.35rem;font-weight:600;margin-bottom:.35rem}.login-card .subtitle{font-size:.9rem;color:#4e4e4e;margin-bottom:1.5rem}.field{margin-bottom:1rem}.field label{display:block;font-size:.8rem;font-weight:500;margin-bottom:.35rem;color:#4e4e4e}.field input{width:100%;padding:.65rem .75rem;border-radius:8px;border:1px solid #b8c8aa;background:#fff;color:#181818;font-size:1rem}.field input:focus{outline:2px solid #8fb076;outline-offset:0;border-color:#8fb076}.field input[aria-invalid=true]{border-color:#7f9770}.field-error{font-size:.78rem;color:#4e4e4e;margin-top:.35rem}.alert{padding:.65rem .75rem;border-radius:8px;font-size:.88rem;margin-bottom:1rem}.alert-error{background:#f3f8ee;border:1px solid #bccbab;color:#181818}.alert-success{background:#dce9d0;border:1px solid #8fb076;color:#181818}.actions{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:1.25rem}.actions-stack{flex-direction:column}.actions button{flex:1;min-width:120px;padding:.65rem 1rem;border-radius:8px;border:none;font-size:.95rem;font-weight:600;cursor:pointer;background:#8fb076;color:#181818}.actions button:hover:not(:disabled){background:#7f9770}.actions button:disabled{opacity:.55;cursor:not-allowed}.actions .secondary{background:#fff;color:#181818;border:1px solid #bccbab}.actions .secondary:hover:not(:disabled){background:#f7f7f7;color:#181818}.auth-switch{margin-top:1.25rem;text-align:center;font-size:.88rem}.auth-switch a{color:#8fb076;text-decoration:none}.auth-switch a:hover{text-decoration:underline}a.auth-link-button{display:inline-flex;align-items:center;justify-content:center;flex:1;min-width:120px;padding:.65rem 1rem;border-radius:8px;font-size:.95rem;font-weight:600;text-decoration:none;background:#8fb076;color:#181818}a.auth-link-button:hover{background:#7f9770}a.auth-link-button.secondary{background:#fff;color:#181818;border:1px solid #bccbab}a.auth-link-button.secondary:hover{background:#f7f7f7;color:#181818}.not-found-page h1{font-size:1.35rem;font-weight:600;margin-bottom:.35rem}.not-found-page .subtitle{font-size:.9rem;color:#4e4e4e;margin-bottom:1.5rem}.not-found-link{max-width:220px}
