.login-container{display:flex;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2,#f093fb);position:relative;overflow:hidden}.login-left-panel{flex:1;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:60px 40px;position:relative;background:transparent;overflow:hidden}.login-left-panel:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(circle at 30% 50%,rgba(102,126,234,.2),transparent 50%),radial-gradient(circle at 70% 80%,rgba(118,75,162,.2),transparent 50%);animation:pulse-glow 4s ease-in-out infinite}@keyframes pulse-glow{0%,to{opacity:.5}50%{opacity:.8}}.avatar-container{position:relative;width:100%;max-width:400px;height:400px;display:flex;align-items:center;justify-content:center;margin-bottom:40px}.avatar-3d{width:280px;height:280px;position:relative;transform-style:preserve-3d;animation:float-3d 6s ease-in-out infinite}@keyframes float-3d{0%,to{transform:translateY(0) rotateY(0) rotateX(5deg)}50%{transform:translateY(-20px) rotateY(10deg) rotateX(-5deg)}}.avatar-main{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;position:relative;box-shadow:0 20px 60px #0000004d,0 0 0 20px #ffffff1a,0 0 0 40px #ffffff0d,inset 0 0 60px #fff3}.avatar-face{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:180px;height:180px}.avatar-eye{position:absolute;width:24px;height:32px;background:#fff;border-radius:50%;top:60px;animation:blink 4s infinite}.avatar-eye-left{left:50px}.avatar-eye-right{right:50px}.avatar-eye:after{content:"";position:absolute;width:12px;height:12px;background:#1a202c;border-radius:50%;top:8px;left:6px;animation:look-around 8s infinite}@keyframes blink{0%,90%,to{height:32px}95%{height:4px}}@keyframes look-around{0%,to{transform:translate(0)}25%{transform:translate(4px,2px)}50%{transform:translateY(4px)}75%{transform:translate(-4px,2px)}}.avatar-mouth{position:absolute;bottom:50px;left:50%;transform:translate(-50%);width:60px;height:30px;border:4px solid white;border-top:none;border-radius:0 0 60px 60px}.avatar-shine{position:absolute;top:20%;left:30%;width:80px;height:80px;background:radial-gradient(circle,rgba(255,255,255,.4),transparent);border-radius:50%;animation:shine 3s ease-in-out infinite}@keyframes shine{0%,to{opacity:.3;transform:scale(1)}50%{opacity:.6;transform:scale(1.2)}}.avatar-floating-elements{position:absolute;width:100%;height:100%;top:0;left:0}.floating-icon{position:absolute;filter:drop-shadow(0 4px 8px rgba(0,0,0,.2));animation:float-icon 4s ease-in-out infinite}.floating-icon.icon-1{top:10%;left:10%;animation-delay:0s}.floating-icon.icon-2{top:20%;right:15%;animation-delay:1.3s}.floating-icon.icon-3{bottom:15%;left:20%;animation-delay:2.6s}@keyframes float-icon{0%,to{transform:translateY(0) rotate(0) scale(1);opacity:.8}50%{transform:translateY(-30px) rotate(10deg) scale(1.1);opacity:1}}.login-left-content{text-align:center;color:#fff;z-index:1;position:relative;max-width:500px;animation:fade-in-up .8s ease-out .3s both}@keyframes fade-in-up{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.login-left-content h2{font-size:36px;font-weight:700;margin-bottom:12px;text-shadow:0 2px 10px rgba(0,0,0,.2);letter-spacing:-.5px}.platform-tagline{font-size:16px;line-height:1.5;opacity:.9;text-shadow:0 1px 5px rgba(0,0,0,.1);margin-bottom:40px}.features-carousel{position:relative;margin-top:32px;width:100%;max-width:450px;margin-left:auto;margin-right:auto}.carousel-container{position:relative;overflow:hidden;border-radius:16px;width:100%}.carousel-track{display:flex;transition:transform .5s cubic-bezier(.4,0,.2,1)}.carousel-slide{min-width:100%;flex-shrink:0;width:100%;box-sizing:border-box}.feature-card{padding:30px 24px;background:linear-gradient(135deg,#ffffff21,#ffffff12);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:16px;border:1px solid rgba(255,255,255,.18);text-align:center;box-shadow:0 6px 24px #0000001a,inset 0 1px #fff3;display:flex;flex-direction:column;align-items:center;width:100%;box-sizing:border-box}@keyframes fade-in-scale{0%{opacity:0;transform:scale(.97)}to{opacity:1;transform:scale(1)}}.feature-icon-large{display:flex;align-items:center;justify-content:center;width:60px;height:60px;margin:0 auto 20px;background:linear-gradient(135deg,#fff3,#ffffff1f);border-radius:14px;color:#fff;box-shadow:0 4px 12px #0000001a,inset 0 1px #ffffff4d;flex-shrink:0}.feature-card h3{font-size:21px;font-weight:700;margin:0 0 12px;color:#fff;text-shadow:0 2px 6px rgba(0,0,0,.2);line-height:1.3}.feature-card p{font-size:14px;line-height:1.6;margin:0;color:#ffffffe6;text-shadow:0 1px 2px rgba(0,0,0,.15);width:100%}.carousel-indicators{display:flex;justify-content:center;align-items:center;gap:8px;margin-top:20px;padding:0}.carousel-indicator{width:8px;height:8px;border-radius:50%;border:none;background:#ffffff40;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);padding:0;position:relative}.carousel-indicator:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:20px;height:20px;border-radius:50%;background:transparent;transition:background .3s ease}.carousel-indicator:hover:after{background:#ffffff1a}.carousel-indicator.active{background:#fff;width:28px;border-radius:4px;box-shadow:0 2px 8px #ffffff4d}.carousel-nav{display:flex;justify-content:space-between;position:absolute;top:50%;left:-20px;right:-20px;transform:translateY(-50%);pointer-events:none;z-index:10}.carousel-nav-btn{width:40px;height:40px;border-radius:50%;border:2px solid rgba(255,255,255,.3);background:#ffffff26;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease;pointer-events:all;box-shadow:0 3px 10px #00000026}.carousel-nav-btn:hover{background:#ffffff40;border-color:#ffffff73;transform:scale(1.05)}.carousel-nav-btn:active{transform:scale(.95)}.carousel-nav-btn svg{width:18px;height:18px}.login-right-panel{flex:1;display:flex;align-items:center;justify-content:center;padding:40px;background:transparent;position:relative;overflow-y:auto}.login-card{background:#fff;padding:48px 40px;border-radius:16px;box-shadow:0 4px 24px #00000014,0 1px 2px #0000000a;border:1px solid rgba(0,0,0,.06);width:100%;max-width:440px;position:relative;z-index:1;animation:slide-in-right .6s ease-out}.locale-switcher-container{position:absolute;top:20px;right:20px;z-index:10}@keyframes slide-in-right{0%{opacity:0;transform:translate(30px)}to{opacity:1;transform:translate(0)}}.login-header{text-align:left;margin-bottom:32px;padding-bottom:24px;border-bottom:1px solid #e2e8f0}.login-logo{display:inline-flex;margin-bottom:20px}.login-card h1{margin:0 0 8px;color:#1a202c;font-size:28px;font-weight:600;letter-spacing:-.3px;line-height:1.3}.login-subtitle{margin:0;color:#64748b;font-size:14px;font-weight:400;line-height:1.5}.login-form,.form-group{margin-bottom:24px}.input-wrapper input:focus+.password-toggle,.input-wrapper input:focus~.input-icon{color:#667eea}.password-toggle:focus{outline:2px solid #667eea;outline-offset:2px;border-radius:4px}.form-options{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;font-size:14px}.remember-me{display:flex;align-items:center;gap:8px;cursor:pointer;color:#475569;-webkit-user-select:none;user-select:none}.remember-me input[type=checkbox]{width:16px;height:16px;cursor:pointer;accent-color:#667eea;border:2px solid #cbd5e1;border-radius:4px}.remember-me input[type=checkbox]:checked{background-color:#667eea;border-color:#667eea}.remember-me span{font-weight:400;color:#475569}.forgot-password{color:#667eea;text-decoration:none;font-weight:500;transition:color .2s}.forgot-password:hover{color:#5568d3;text-decoration:underline}.login-button{width:100%;padding:14px 20px;background:#667eea;color:#fff;border:none;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:8px;box-shadow:0 2px 8px #667eea40;position:relative;overflow:hidden}.login-button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s}.login-button:hover:not(:disabled):before{left:100%}.login-button:hover:not(:disabled){background:#5568d3;box-shadow:0 4px 12px #667eea59}.login-button:active:not(:disabled){background:#4c5bc2;transform:translateY(1px)}.login-button:disabled{opacity:.7;cursor:not-allowed;transform:none}.login-button .spinner{animation:spin 1s linear infinite}.login-footer{margin-top:32px;padding-top:24px;border-top:1px solid #e2e8f0;text-align:center}.terms-privacy{margin:0 0 16px;font-size:12px;color:#64748b;line-height:1.6}.terms-privacy a{color:#667eea;text-decoration:none;font-weight:500}.terms-privacy a:hover{text-decoration:underline}.security-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;background:#f1f5f9;border-radius:6px;font-size:12px;color:#475569;font-weight:500}.security-badge svg{color:#10b981;flex-shrink:0}.sso-divider{display:flex;align-items:center;text-align:center;margin:32px 0 24px;color:#a0aec0;font-size:14px}.sso-divider:before,.sso-divider:after{content:"";flex:1;border-bottom:1px solid #e2e8f0}.sso-divider span{padding:0 16px;background:#fff;color:#64748b;font-size:13px}.sso-buttons{display:grid;align-content:center}.sso-button{display:flex;align-items:center;justify-content:center;gap:10px;padding:12px 16px;background:#fff;border:1px solid #e2e8f0;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;color:#334155;transition:all .2s;position:relative;overflow:hidden}.sso-button:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#667eea1a;transform:translate(-50%,-50%);transition:width .3s,height .3s}.sso-button:hover:before{width:300px;height:300px}.sso-button:hover{border-color:#cbd5e1;background:#f8fafc;box-shadow:0 2px 4px #0000000d}.sso-button:active{background:#f1f5f9;transform:translateY(1px)}.sso-button svg{flex-shrink:0;position:relative;z-index:1}.sso-button span{position:relative;z-index:1}.sso-button-google:hover{border-color:#4285f4}.sso-button-microsoft:hover{border-color:#0078d4}@media (max-width: 1024px){.login-left-content h2{font-size:28px}.login-left-content p{font-size:16px}.avatar-3d{width:240px;height:240px}.avatar-container{height:320px}}@media (max-width: 768px){.login-container{flex-direction:column}.login-left-panel{padding:40px 20px;min-height:40vh}.avatar-container{height:250px;margin-bottom:24px}.avatar-3d{width:200px;height:200px}.avatar-face{width:140px;height:140px}.avatar-eye{width:18px;height:24px;top:45px}.avatar-eye-left{left:40px}.avatar-eye-right{right:40px}.avatar-eye:after{width:8px;height:8px;top:6px;left:5px}.avatar-mouth{bottom:40px;width:45px;height:22px;border-width:3px}.login-left-content{max-width:100%}.login-left-content h2{font-size:24px;margin-bottom:8px}.platform-tagline{font-size:14px;margin-bottom:24px}.features-carousel{margin-top:24px;max-width:100%}.feature-card{padding:28px 20px}.feature-icon-large{width:56px;height:56px;margin-bottom:16px}.feature-card h3{font-size:20px;margin-bottom:10px}.feature-card p{font-size:13px;line-height:1.55}.carousel-nav{left:-12px;right:-12px}.carousel-nav-btn{width:36px;height:36px}.carousel-nav-btn svg{width:16px;height:16px}.login-right-panel{padding:20px;flex:1}.login-card{padding:36px 28px;border-radius:16px}.login-header{margin-bottom:28px;padding-bottom:20px}.login-card h1{font-size:26px}.form-options{flex-direction:column;align-items:flex-start;gap:12px}.login-footer{margin-top:28px;padding-top:20px}.sso-button{width:100%}.floating-icon{display:none}}@media (max-width: 480px){.login-left-panel{padding:30px 16px;min-height:35vh}.avatar-container{height:200px;margin-bottom:20px}.avatar-3d{width:160px;height:160px}.avatar-face{width:110px;height:110px}.avatar-eye{width:14px;height:18px;top:35px}.avatar-eye-left{left:30px}.avatar-eye-right{right:30px}.avatar-eye:after{width:6px;height:6px;top:4px;left:4px}.avatar-mouth{bottom:30px;width:35px;height:18px;border-width:2px}.login-left-content h2{font-size:20px}.platform-tagline{font-size:13px;margin-bottom:20px}.features-carousel{margin-top:20px;max-width:100%}.carousel-container{padding:4px}.feature-card{padding:24px 18px}.feature-icon-large{width:56px;height:56px;margin-bottom:16px}.feature-icon-large{width:52px;height:52px;margin-bottom:14px}.feature-card h3{font-size:18px;margin-bottom:8px}.feature-card p{font-size:12.5px;line-height:1.5}.carousel-nav{left:-8px;right:-8px}.carousel-nav-btn{width:32px;height:32px}.carousel-nav-btn svg{width:14px;height:14px}.login-card{padding:28px 20px}.login-header{margin-bottom:24px;padding-bottom:18px}.login-card h1{font-size:22px}.form-options{margin-bottom:20px}.login-footer{margin-top:24px;padding-top:18px}.terms-privacy{font-size:11px}}@media (prefers-reduced-motion: reduce){.avatar-3d,.floating-icon,.login-logo,.login-button:before,.sso-button:before,.avatar-shine,.avatar-eye,.avatar-eye:after,.login-left-panel:before,.feature-icon-large,.carousel-track{animation:none;transition:transform .3s ease}.login-card,.login-left-content,.feature-card,.error-message{animation:none}}.locale-switcher{position:relative}.locale-switcher.select{display:flex;align-items:center;gap:8px}.locale-switcher.select label{font-size:14px;color:#64748b;font-weight:500}.locale-select{padding:8px 12px;border:1px solid #e2e8f0;border-radius:8px;background:#fff;color:#1a202c;font-size:14px;cursor:pointer;transition:all .2s;min-width:140px}.locale-select:hover{border-color:#cbd5e1}.locale-select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.locale-switcher.dropdown{position:relative}.locale-switcher-button{display:flex;align-items:center;gap:8px;padding:8px 12px;border:1px solid #e2e8f0;border-radius:8px;background:#fff;color:#1a202c;font-size:14px;cursor:pointer;transition:all .2s;min-width:140px;justify-content:space-between}.locale-switcher-button:hover{border-color:#cbd5e1;background:#f8fafc}.locale-switcher-button:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.locale-flag{font-size:18px;line-height:1}.locale-name{flex:1;text-align:left}.dropdown-arrow{transition:transform .2s;color:#64748b}.dropdown-arrow.open{transform:rotate(180deg)}.dropdown-overlay{position:fixed;top:0;left:0;right:0;bottom:0;z-index:999}.dropdown-menu{position:absolute;top:calc(100% + 8px);left:0;right:0;background:#fff;border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 4px 12px #0000001a;z-index:1000;overflow:hidden;min-width:180px;max-height:300px;overflow-y:auto}.dropdown-item{display:flex;align-items:center;gap:10px;width:100%;padding:10px 12px;border:none;background:transparent;color:#1a202c;font-size:14px;text-align:left;cursor:pointer;transition:background .2s}.dropdown-item:hover{background:#f8fafc}.dropdown-item.active{background:#eff6ff;color:#667eea;font-weight:500}.dropdown-item .locale-flag{font-size:20px;width:24px;text-align:center}.dropdown-item .locale-name{flex:1}.dropdown-item svg{width:16px;height:16px;color:#667eea;flex-shrink:0}@media (max-width: 768px){.locale-switcher-button,.locale-select{min-width:120px;font-size:13px}.dropdown-menu{min-width:160px}}.auth-callback{min-height:calc(100vh - 40px);display:grid;place-items:center;padding:20px;background:radial-gradient(1200px 600px at 20% 10%,rgba(99,102,241,.16),transparent 60%),radial-gradient(900px 500px at 80% 20%,rgba(236,72,153,.12),transparent 60%),linear-gradient(180deg,#f1f5f9e6,#fff)}.auth-callback__card{width:min(520px,100%);border-radius:18px;border:1px solid var(--sa-border);background:#ffffffeb;box-shadow:var(--sa-shadow);padding:22px;text-align:center}.auth-callback__icon{width:44px;height:44px;margin:0 auto 10px;border-radius:999px;display:grid;place-items:center;background:#ef44441f;color:#b91c1c;font-weight:900;font-size:18px;border:1px solid rgba(239,68,68,.18)}.auth-callback__title{margin:0;font-size:20px;font-weight:800;letter-spacing:-.02em;color:var(--sa-text)}.auth-callback__subtitle{margin:10px 0 0;font-size:14px;line-height:1.5;color:var(--sa-muted)}.auth-callback__actions{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin-top:16px}.auth-callback__primary,.auth-callback__secondary{text-decoration:none;border-radius:12px;padding:10px 14px;font-size:13px;font-weight:700;border:1px solid rgba(15,23,42,.12)}.auth-callback__primary{background:#0f172a0f;color:var(--sa-text)}.auth-callback__primary:hover{background:#0f172a14}.auth-callback__secondary{background:#fff;color:var(--sa-primary-dark)}.auth-callback__secondary:hover{text-decoration:underline}.auth-callback__spinner{width:32px;height:32px;margin:0 auto 10px;border-radius:999px;border:3px solid rgba(15,23,42,.12);border-top-color:#0f172a85;animation:auth-callback-spin 1s linear infinite}@keyframes auth-callback-spin{to{transform:rotate(360deg)}}.dashboard-container{max-width:1200px;margin:0 auto}.dashboard-welcome{background:linear-gradient(180deg,#f1f5f9bf,#fff 55%);padding:22px;border-radius:16px;margin-bottom:16px;box-shadow:var(--sa-shadow);border:1px solid var(--sa-border)}.dashboard-welcome h2{color:var(--sa-text);margin-bottom:8px;letter-spacing:-.02em}.dashboard-welcome p{color:var(--sa-muted);margin:6px 0}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:14px}.dashboard-card{background:#ffffffe6;padding:18px;border-radius:16px;box-shadow:var(--sa-shadow-soft);border:1px solid var(--sa-border);transition:transform .12s ease,box-shadow .12s ease,border-color .12s ease}.dashboard-card--link{text-decoration:none;color:inherit;display:block;cursor:pointer}.dashboard-card:hover,.dashboard-card--link:hover{transform:translateY(-2px);box-shadow:var(--sa-shadow);border-color:#0f172a24}.dashboard-card h3{color:var(--sa-text);margin-bottom:8px;letter-spacing:-.01em}.dashboard-card p{color:var(--sa-muted);font-size:14px}.users-page{background:linear-gradient(180deg,#f1f5f9cc,#fff 55%);border-radius:16px;box-shadow:var(--sa-shadow);padding:22px;border:1px solid var(--sa-border)}.users-page__header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:12px}.users-page__headerActions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.users-page__title{margin:0 0 4px;font-size:22px;font-weight:650;letter-spacing:-.02em;color:var(--sa-text)}.users-page__subtitle{margin:0;font-size:14px;color:var(--sa-muted)}.users-page__loading,.users-page__error{padding:32px;text-align:center;color:var(--sa-muted)}.users-page__error{color:var(--sa-danger)}.users-page__toast{margin:10px 0 14px;padding:10px 12px;border-radius:12px;background:var(--sa-success-bg);border:1px solid var(--sa-success-border);color:var(--sa-success-text);font-size:13px}.users-page__primaryBtn{border-color:#2563eb40;background:linear-gradient(180deg,#2563eb,#1d4ed8);color:#fff;box-shadow:0 10px 22px #2563eb38;-webkit-appearance:none;-moz-appearance:none;appearance:none;border-radius:12px;padding:10px 14px;font-size:14px;font-weight:600;cursor:pointer;transition:transform .12s ease,background .12s ease,border-color .12s ease,box-shadow .12s ease,color .12s ease;white-space:nowrap;border-style:solid;border-width:1px}.users-page__primaryBtn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 14px 26px #2563eb3d}.users-page__secondaryBtn{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid var(--sa-border);border-radius:12px;padding:10px 14px;font-size:14px;font-weight:600;cursor:pointer;background:#ffffffe6;color:var(--sa-text);transition:transform .12s ease,background .12s ease,border-color .12s ease,box-shadow .12s ease,color .12s ease;white-space:nowrap}.users-page__secondaryBtn:hover:not(:disabled){background:#f1f5f9e6;border-color:#0f172a2e}.users-page__primaryBtn:disabled,.users-page__secondaryBtn:disabled{opacity:.65;cursor:not-allowed;transform:none}.users-page__create{margin-bottom:24px;padding:16px;border:1px solid var(--sa-border);border-radius:16px;background:#ffffffbf;box-shadow:var(--sa-shadow-soft)}.users-page__createHeader{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.users-page__modalForm{display:flex;flex-direction:column;gap:12px}.users-page__createTitle{font-size:14px;font-weight:700;color:var(--sa-text);letter-spacing:-.01em}.users-page__createHint{margin-top:2px;font-size:13px;color:var(--sa-muted)}.users-page__createForm{margin-top:16px;display:flex;flex-direction:column;gap:12px}.users-page__createGrid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.users-page__createLabel--full{grid-column:1 / -1}.users-page__createLabel{display:flex;flex-direction:column;gap:4px;font-size:13px;font-weight:650;color:var(--sa-text)}.users-page__createLabelHint{font-weight:500;color:var(--sa-muted);font-size:12px}.users-page__createInput{border:1px solid var(--sa-border);border-radius:12px;padding:10px 12px;font-size:14px;background:#fffffff2;color:var(--sa-text)}.users-page__createInput:focus{outline:none;border-color:#2563eb59;box-shadow:0 0 0 4px var(--sa-primary-soft)}.users-page__createError{margin:0;font-size:13px;color:var(--sa-danger)}.users-page__createFooter{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.users-page__createFooterActions{display:flex;align-items:center;gap:10px}.users-page__table-wrap{overflow-x:auto}.users-table{width:100%;border-collapse:collapse;font-size:14px}.users-table th,.users-table td{padding:12px 16px;text-align:left;border-bottom:1px solid #e4e6eb}.users-table th{font-weight:600;color:#65676b;background:#f7f8fa}.users-table tbody tr:hover{background:#f7f8fa}.users-table__role{display:inline-block;padding:4px 10px;border-radius:6px;font-size:12px;font-weight:500}.users-table__roleCell{display:flex;align-items:center;gap:10px}.users-table__saving{font-size:12px;color:#65676b}.users-table__roleSelect{border:1px solid #e4e6eb;border-radius:8px;padding:6px 10px;font-size:12px;background:#fff}.users-table__roleSelect:disabled{opacity:.7}.users-table__roleSelect--admin{background:#e8f0fe;color:#1967d2;border-color:#c7d2fe}.users-table__roleSelect--user{background:#e6f4ea;color:#137333;border-color:#bbf7d0}.users-table__role--admin{background:#e8f0fe;color:#1967d2}.users-table__role--user{background:#e6f4ea;color:#137333}.users-table__manageRoles{padding:6px 12px;border:1px solid #e4e6eb;border-radius:8px;background:#fff;font-size:12px;color:#1967d2;cursor:pointer}.users-table__manageRoles:hover,.users-table__expanded{background:#f7f8fa}.users-table__expandedCell{padding:16px 16px 20px;border-bottom:1px solid #e4e6eb;vertical-align:top}.users-table__loadingRoles{font-size:13px;color:#65676b}.users-table__assignedRoles{max-width:480px}.users-table__assignedTitle{margin:0 0 8px;font-size:13px;font-weight:600;color:#1a1d29}.users-table__assignedList{list-style:none;margin:0 0 12px;padding:0}.users-table__assignedEmpty{font-size:13px;color:#65676b}.users-table__assignedItem{display:flex;align-items:center;justify-content:space-between;padding:6px 0;font-size:13px;border-bottom:1px solid #e4e6eb}.users-table__removeRole{padding:4px 10px;border:1px solid #e4e6eb;border-radius:6px;background:#fff;font-size:12px;color:#b94a48;cursor:pointer}.users-table__removeRole:hover:not(:disabled){background:#fef2f2}.users-table__addRole{display:flex;gap:8px;align-items:center}.users-table__addRoleSelect{border:1px solid #e4e6eb;border-radius:8px;padding:6px 10px;font-size:13px;background:#fff;min-width:160px}.users-table__addRoleBtn{padding:6px 12px;border:none;border-radius:8px;background:#1967d2;color:#fff;font-size:12px;font-weight:500;cursor:pointer}.users-table__addRoleBtn:hover:not(:disabled){background:#1557b0}.users-table__addRoleBtn:disabled,.users-table__removeRole:disabled{opacity:.7;cursor:not-allowed}.sa-modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:grid;place-items:center;padding:18px}.sa-modal__backdrop{position:absolute;top:0;right:0;bottom:0;left:0;border:none;background:#0206178c;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);cursor:pointer}.sa-modal__panel{position:relative;width:min(720px,calc(100vw - 36px));max-height:min(84vh,820px);overflow:auto;border-radius:16px;background:#fffffff2;border:1px solid rgba(255,255,255,.35);box-shadow:0 30px 80px #0f172a59}.sa-modal__header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:16px 16px 12px;border-bottom:1px solid var(--sa-border);background:linear-gradient(180deg,#f1f5f9bf,#ffffff80)}.sa-modal__title{font-size:16px;font-weight:750;color:var(--sa-text);letter-spacing:-.01em}.sa-modal__desc{margin-top:2px;font-size:13px;color:var(--sa-muted)}.sa-modal__close{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:36px;height:36px;border-radius:12px;border:1px solid var(--sa-border);background:#ffffffe6;color:var(--sa-text);font-size:22px;line-height:32px;cursor:pointer}.sa-modal__close:hover{background:#f1f5f9e6;border-color:#0f172a2e}.sa-modal__body{padding:16px}.groups-page{background:linear-gradient(180deg,#f1f5f9cc,#fff 55%);border-radius:16px;box-shadow:var(--sa-shadow);padding:22px;border:1px solid var(--sa-border)}.groups-page__header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:12px}.groups-page__create{min-width:360px;max-width:640px;flex:1}.groups-page__createRow{display:flex;gap:10px;align-items:center;justify-content:flex-end;flex-wrap:wrap}.groups-page__input{border:1px solid var(--sa-border);border-radius:10px;padding:10px 12px;font-size:13px;background:#fffffff2;color:var(--sa-text);outline:none;min-width:180px}.groups-page__input:focus{border-color:#1967d299;box-shadow:0 0 0 3px #1967d21f}.groups-page__createBtn{border:1px solid rgba(25,103,210,.35);background:#1967d214;color:var(--sa-primary-dark);border-radius:10px;padding:10px 12px;font-size:13px;font-weight:700;cursor:pointer}.groups-page__createBtn:disabled{opacity:.6;cursor:not-allowed}.groups-page__createError{margin-top:8px;font-size:12px;color:var(--sa-danger);text-align:right}.groups-page__createHint{margin-top:8px;font-size:12px;color:var(--sa-muted);text-align:right}.groups-page__title{margin:0 0 4px;font-size:22px;font-weight:650;letter-spacing:-.02em;color:var(--sa-text)}.groups-page__subtitle{margin:0;font-size:14px;color:var(--sa-muted)}.groups-page__loading,.groups-page__error{padding:32px;text-align:center;color:var(--sa-muted)}.groups-page__error{color:var(--sa-danger)}.groups-page__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px}.group-card{border:1px solid var(--sa-border);border-radius:16px;padding:18px;transition:transform .12s ease,box-shadow .12s ease,border-color .12s ease;background:#ffffffe6;box-shadow:var(--sa-shadow-soft)}.group-card:hover{transform:translateY(-1px);border-color:#0f172a24;box-shadow:var(--sa-shadow)}.group-card__name{margin:0 0 8px;font-size:17px;font-weight:700;color:var(--sa-text);letter-spacing:-.01em}.group-card__description{margin:0 0 12px;font-size:14px;color:var(--sa-muted);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.group-card__description--muted{color:#64748bbf;font-style:italic}.group-card__meta{font-size:12px;color:var(--sa-muted);margin-bottom:14px;display:flex;gap:12px;flex-wrap:wrap}.group-card__date{margin-left:auto}.group-card__links{display:flex;flex-wrap:wrap;gap:12px}.group-card__link{display:inline-block;font-size:14px;font-weight:600;color:var(--sa-primary-dark);text-decoration:none}.group-card__link:hover{text-decoration:underline}.group-detail-page{background:linear-gradient(180deg,#f1f5f9cc,#fff 55%);border-radius:16px;box-shadow:var(--sa-shadow);padding:22px;border:1px solid var(--sa-border)}.group-detail-page__breadcrumb{font-size:14px;color:var(--sa-muted);margin-bottom:16px}.group-detail-page__breadcrumb a{color:var(--sa-primary-dark);text-decoration:none}.group-detail-page__breadcrumb a:hover{text-decoration:underline}.group-detail-page__breadcrumb-sep{margin:0 6px}.group-detail-page__title{margin:0 0 8px;font-size:22px;font-weight:650;letter-spacing:-.02em;color:var(--sa-text)}.group-detail-page__description{margin:0 0 24px;font-size:14px;color:var(--sa-muted);line-height:1.4}.group-detail-page__description--muted{color:#64748bbf;font-style:italic}.group-detail-page__section{margin-bottom:24px;padding-top:20px;border-top:1px solid var(--sa-border)}.group-detail-page__section-title{margin:0 0 12px;font-size:16px;font-weight:700;color:var(--sa-text);letter-spacing:-.01em}.group-detail-page__sectionHeader{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:12px}.group-detail-page__sectionHeader .group-detail-page__section-title{margin-bottom:0}.group-detail-page__keywords{list-style:none;margin:0 0 16px;padding:0;display:flex;flex-wrap:wrap;gap:8px}.group-detail-page__keyword-tag{background:#2563eb1a;border:1px solid rgba(37,99,235,.22);color:var(--sa-primary-dark);padding:6px 12px;border-radius:999px;font-size:14px}.group-detail-page__empty{margin:0 0 16px;font-size:14px;color:var(--sa-muted)}.group-detail-page__form{display:flex;gap:12px;flex-wrap:wrap;align-items:center;margin-bottom:8px}.group-detail-page__input{flex:1;min-width:200px;padding:10px 14px;font-size:14px;border:1px solid #e4e6eb;border-radius:8px}.group-detail-page__input:focus{outline:none;border-color:#1967d2}.group-detail-page__btn{padding:10px 18px;font-size:14px;font-weight:500;color:#fff;background:#1967d2;border:none;border-radius:8px;cursor:pointer}.group-detail-page__btn--secondary{background:#ffffffe6;color:var(--sa-text);border:1px solid var(--sa-border)}.group-detail-page__btn--secondary:hover:not(:disabled){background:#f1f5f9e6}.group-detail-page__btn:hover:not(:disabled){background:#1557b0}.group-detail-page__btn:disabled{opacity:.7;cursor:not-allowed}.group-detail-page__hint{margin:0;font-size:12px;color:#65676b}.group-detail-page__add-error{margin:8px 0 0;font-size:14px;color:#b94a48}.group-detail-page__actions{margin-top:24px;padding-top:20px;border-top:1px solid #e4e6eb}.group-detail-page__link{font-size:14px;font-weight:500;color:#1967d2;text-decoration:none}.group-detail-page__link:hover{text-decoration:underline}.group-detail-page__loading,.group-detail-page__error{padding:40px;text-align:center;color:#65676b}.group-detail-page__error{color:#b94a48}.group-detail-page__back{display:inline-block;margin-top:16px;font-size:14px;color:#1967d2;text-decoration:none}.group-detail-page__back:hover{text-decoration:underline}.group-detail-page__modalForm{display:flex;flex-direction:column;gap:12px}.group-detail-page__modalLabel{display:flex;flex-direction:column;gap:6px;font-size:13px;font-weight:650;color:var(--sa-text)}.group-detail-page__modalInput{padding:10px 14px;font-size:14px;border:1px solid var(--sa-border);border-radius:12px;background:#fffffff2;color:var(--sa-text);outline:none}.group-detail-page__modalInput:focus{border-color:#2563eb59;box-shadow:0 0 0 4px var(--sa-primary-soft)}.group-detail-page__modalActions{display:flex;align-items:center;justify-content:flex-end;gap:10px;flex-wrap:wrap}.blog-card{border:1px solid var(--sa-border);border-radius:16px;overflow:hidden;background:#ffffffe6;box-shadow:var(--sa-shadow-soft);transition:transform .12s ease,box-shadow .12s ease,border-color .12s ease;display:grid;grid-template-columns:180px 1fr;min-height:168px}.blog-card:hover{transform:translateY(-1px);border-color:#0f172a24;box-shadow:var(--sa-shadow)}.blog-card__imageLink{display:block;height:100%}.blog-card__image{width:100%;height:100%;object-fit:cover;display:block;background:#eef2f7}.blog-card__content{padding:14px 16px;display:flex;flex-direction:column;gap:10px}.blog-card__title{margin:0;font-size:16px;font-weight:750;letter-spacing:-.01em;color:var(--sa-text)}.blog-card__titleLink{color:inherit;text-decoration:none}.blog-card__titleLink:hover{text-decoration:underline}.blog-card__subTitle{margin:6px 0 0;font-size:13px;color:var(--sa-muted);line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.blog-card__tags{margin-top:10px;display:flex;flex-wrap:wrap;gap:8px}.blog-card__tag{border:1px solid rgba(15,23,42,.12);background:#0f172a08;border-radius:999px;padding:5px 9px;font-size:12px;color:#0f172adb}.blog-card__tag--muted{color:var(--sa-muted)}.blog-card__preview{margin:0;font-size:13px;color:#475569f2;line-height:1.45;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.blog-card__meta{font-size:12px;color:var(--sa-muted);display:flex;align-items:center;gap:8px;flex-wrap:wrap}.blog-card__dot{opacity:.65}.blog-card__actions{margin-top:auto;display:flex;align-items:center;gap:10px;flex-wrap:wrap}.blog-card__likeBtn{border:1px solid rgba(15,23,42,.12);background:#fff;border-radius:999px;padding:7px 10px;font-size:13px;cursor:pointer}.blog-card__likeBtn:disabled{opacity:.6;cursor:not-allowed}.blog-card__views{font-size:13px;color:var(--sa-muted)}.blog-card__editLink{margin-left:auto;font-size:13px;font-weight:650;color:var(--sa-primary-dark);text-decoration:none}.blog-card__editLink:hover{text-decoration:underline}@media (max-width: 700px){.blog-card{grid-template-columns:1fr}.blog-card__image{height:180px}}.blogs-page{background:linear-gradient(180deg,#f1f5f9cc,#fff 55%);border-radius:16px;box-shadow:var(--sa-shadow);padding:22px;border:1px solid var(--sa-border)}.blogs-page__header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:12px}.blogs-page__title{margin:0 0 4px;font-size:22px;font-weight:650;letter-spacing:-.02em;color:var(--sa-text)}.blogs-page__subtitle{margin:0;font-size:14px;color:var(--sa-muted)}.blogs-page__actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.blogs-page__selectLabel{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--sa-muted)}.blogs-page__select{border:1px solid var(--sa-border);border-radius:10px;padding:8px 10px;background:#fff}.blogs-page__tagsPicker{position:relative;display:inline-flex;align-items:center;gap:8px}.blogs-page__tagsBtn{display:inline-flex;align-items:center;justify-content:space-between;gap:10px;min-width:220px;height:40px;border:1px solid var(--sa-border);border-radius:10px;padding:0 12px;background:#fff;cursor:pointer}.blogs-page__tagsBtn:disabled{opacity:.6;cursor:not-allowed}.blogs-page__tagsBtnText{font-size:13px;color:var(--sa-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.blogs-page__chev{color:var(--sa-muted);font-size:12px}.blogs-page__tagsPopover{position:absolute;top:calc(100% + 8px);left:0;z-index:30;width:320px;background:#fff;border:1px solid var(--sa-border);border-radius:14px;box-shadow:0 18px 50px #0f172a24;overflow:hidden}.blogs-page__tagsPopoverTop{display:flex;align-items:center;gap:10px;padding:12px;border-bottom:1px solid rgba(15,23,42,.06);background:#f1f5f999}.blogs-page__tagsSearch{flex:1;height:34px;padding:0 10px;border:1px solid rgba(15,23,42,.12);border-radius:10px;outline:none}.blogs-page__tagsSearch:focus{border-color:#3b82f699;box-shadow:0 0 0 3px #3b82f626}.blogs-page__tagsActionBtn{border:1px solid rgba(15,23,42,.12);background:#0f172a0a;color:var(--sa-text);border-radius:10px;padding:7px 10px;font-size:12px;cursor:pointer}.blogs-page__tagsActionBtn:disabled{opacity:.55;cursor:not-allowed}.blogs-page__tagsList{max-height:260px;overflow:auto;padding:8px}.blogs-page__tagOption{display:grid;grid-template-columns:18px 1fr;grid-template-areas:"cb name" "cb slug";gap:2px 10px;align-items:center;padding:8px 10px;border-radius:12px;cursor:pointer}.blogs-page__tagOption:hover{background:#0f172a09}.blogs-page__tagOption input{grid-area:cb}.blogs-page__tagOptionName{grid-area:name;font-size:13px;color:var(--sa-text);line-height:1.1}.blogs-page__tagOptionSlug{grid-area:slug;font-size:11px;color:var(--sa-muted)}.blogs-page__tagsEmpty{padding:18px 12px;text-align:center;color:var(--sa-muted);font-size:13px}.blogs-page__tagsPopoverFooter{display:flex;justify-content:flex-end;padding:10px 12px 12px;border-top:1px solid rgba(15,23,42,.06);background:#f1f5f959}.blogs-page__tagChips{display:flex;align-items:center;gap:8px;flex-wrap:wrap;max-width:520px}.blogs-page__tagChip{border:1px solid rgba(15,23,42,.12);background:#0f172a0a;color:var(--sa-text);border-radius:999px;padding:6px 10px;font-size:12px;cursor:pointer}.blogs-page__tagChip:hover{background:#0f172a0f}.blogs-page__newBtn{display:inline-flex;align-items:center;gap:8px;border:1px solid rgba(15,23,42,.12);background:#0f172a0a;color:var(--sa-text);border-radius:12px;padding:9px 12px;font-size:13px;font-weight:650;text-decoration:none}.blogs-page__newBtn:hover{background:#0f172a0f}.blogs-page__grid{display:grid;grid-template-columns:1fr;gap:14px}.blogs-page__error,.blogs-page__empty{padding:32px;text-align:center;color:var(--sa-muted)}.blogs-page__error{color:var(--sa-danger)}.blogs-page__skeletonCard{height:168px;border-radius:16px;border:1px solid var(--sa-border);background:linear-gradient(90deg,#e2e8f08c,#e2e8f040,#e2e8f08c);background-size:200% 100%;animation:sa-skeleton 1.15s ease-in-out infinite}@keyframes sa-skeleton{0%{background-position:200% 0}to{background-position:-200% 0}}.blogs-page__pager{display:flex;align-items:center;justify-content:center;gap:12px;padding-top:16px}.blogs-page__pagerBtn{border:1px solid var(--sa-border);background:#fff;border-radius:10px;padding:8px 12px;cursor:pointer}.blogs-page__pagerBtn:disabled{opacity:.6;cursor:not-allowed}.blogs-page__pagerText{font-size:13px;color:var(--sa-muted)}.blog-detail-page{background:#fff;border-radius:16px;box-shadow:var(--sa-shadow);padding:22px;border:1px solid var(--sa-border)}.blog-detail-page__breadcrumb{font-size:13px;color:var(--sa-muted);margin-bottom:14px}.blog-detail-page__breadcrumb a{color:var(--sa-primary-dark);text-decoration:none}.blog-detail-page__breadcrumb a:hover{text-decoration:underline}.blog-detail-page__breadcrumb-sep{margin:0 8px;opacity:.6}.blog-detail-page__image{width:100%;max-height:360px;border-radius:16px;object-fit:cover;border:1px solid var(--sa-border);margin-bottom:16px;background:#eef2f7}.blog-detail-page__header{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;align-items:flex-start;margin-bottom:18px}.blog-detail-page__title{margin:0;font-size:24px;font-weight:800;letter-spacing:-.02em;color:var(--sa-text)}.blog-detail-page__subTitle{margin:8px 0 0;color:var(--sa-muted);font-size:14px;line-height:1.45}.blog-detail-page__tags{margin-top:12px;display:flex;flex-wrap:wrap;gap:8px}.blog-detail-page__tag{border:1px solid rgba(15,23,42,.12);background:#0f172a08;border-radius:999px;padding:6px 10px;font-size:12px;color:#0f172adb;text-decoration:none}.blog-detail-page__tag:hover{background:#0f172a0f}.blog-detail-page__meta{margin-top:10px;font-size:12px;color:var(--sa-muted);display:flex;flex-wrap:wrap;gap:8px;align-items:center}.blog-detail-page__dot{opacity:.65}.blog-detail-page__actions{display:flex;gap:10px;align-items:center}.blog-detail-page__likeBtn{border:1px solid rgba(15,23,42,.12);background:#fff;border-radius:999px;padding:9px 12px;cursor:pointer;font-size:13px}.blog-detail-page__likeBtn:disabled{opacity:.6;cursor:not-allowed}.blog-detail-page__editBtn{border:1px solid rgba(15,23,42,.12);background:#0f172a0a;border-radius:12px;padding:9px 12px;font-size:13px;font-weight:650;text-decoration:none;color:var(--sa-text)}.blog-detail-page__editBtn:hover{background:#0f172a0f}.blog-detail-page__content{color:#0f172aeb;line-height:1.65;font-size:14px;overflow-wrap:anywhere;white-space:pre-wrap}.blog-detail-page__loading,.blog-detail-page__error{padding:32px;text-align:center;color:var(--sa-muted)}.blog-detail-page__error{color:var(--sa-danger)}.tag-selector{display:grid;gap:6px}.tag-selector__label{font-size:13px;color:var(--sa-muted)}.tag-selector__control{border:1px solid var(--sa-border);border-radius:12px;padding:8px 10px;background:#fff;display:flex;flex-wrap:wrap;align-items:center;gap:8px;cursor:text}.tag-selector__control--open{box-shadow:0 0 0 3px #3b82f61f;border-color:#3b82f659}.tag-selector__chips{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.tag-selector__placeholder{font-size:13px;color:#64748bcc}.tag-selector__chip{border:1px solid rgba(15,23,42,.12);background:#0f172a08;border-radius:999px;padding:6px 10px;font-size:12px;color:#0f172ae6;cursor:pointer}.tag-selector__chipX{opacity:.65;margin-left:6px}.tag-selector__input{border:none;outline:none;font-size:13px;min-width:150px;flex:1}.tag-selector__menu{border:1px solid var(--sa-border);border-radius:12px;background:#fff;box-shadow:var(--sa-shadow);overflow:hidden;max-height:260px;overflow-y:auto}.tag-selector__menuItem{width:100%;text-align:left;padding:10px 12px;border:none;background:#fff;cursor:pointer;font-size:13px;display:flex;align-items:center;justify-content:space-between;gap:12px}.tag-selector__menuItem:hover{background:#0f172a0a}.tag-selector__menuItem:disabled{opacity:.55;cursor:not-allowed}.tag-selector__menuItem--muted{cursor:default;color:var(--sa-muted)}.tag-selector__menuItem--create{color:var(--sa-primary-dark);font-weight:650}.tag-selector__slug{font-size:12px;color:var(--sa-muted)}.blog-editor-page{background:#fff;border-radius:16px;box-shadow:var(--sa-shadow);padding:22px;border:1px solid var(--sa-border)}.blog-editor-page__breadcrumb{font-size:13px;color:var(--sa-muted);margin-bottom:14px}.blog-editor-page__breadcrumb a{color:var(--sa-primary-dark);text-decoration:none}.blog-editor-page__breadcrumb a:hover{text-decoration:underline}.blog-editor-page__breadcrumb-sep{margin:0 8px;opacity:.6}.blog-editor-page__header{display:flex;align-items:baseline;justify-content:space-between;gap:16px;margin-bottom:14px}.blog-editor-page__title{margin:0;font-size:22px;font-weight:750;letter-spacing:-.02em;color:var(--sa-text)}.blog-editor-page__form{display:grid;gap:12px}.blog-editor-page__label{display:grid;gap:6px;font-size:13px;color:var(--sa-muted)}.blog-editor-page__input,.blog-editor-page__textarea{border:1px solid var(--sa-border);border-radius:12px;padding:10px 12px;font-size:14px;background:#fff;color:var(--sa-text)}.blog-editor-page__textarea{resize:vertical;min-height:200px;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;line-height:1.45}.blog-editor-page__checkboxRow{display:flex;align-items:center;gap:10px;color:var(--sa-text);font-size:14px}.blog-editor-page__footer{display:flex;gap:12px;align-items:center;padding-top:6px}.blog-editor-page__primaryBtn{border:1px solid rgba(15,23,42,.12);background:#0f172a0f;border-radius:12px;padding:10px 14px;font-size:13px;font-weight:700;cursor:pointer}.blog-editor-page__primaryBtn:disabled{opacity:.6;cursor:not-allowed}.blog-editor-page__cancelBtn{color:var(--sa-primary-dark);text-decoration:none;font-size:13px;font-weight:650}.blog-editor-page__cancelBtn:hover{text-decoration:underline}.blog-editor-page__loading,.blog-editor-page__error{padding:32px;text-align:center;color:var(--sa-muted)}.blog-editor-page__error{color:var(--sa-danger);margin-bottom:12px}.multi-select{display:grid;gap:6px}.multi-select__label{font-size:13px;color:var(--sa-muted)}.multi-select__control{border:1px solid var(--sa-border);border-radius:12px;padding:8px 10px;background:#fff;display:flex;flex-wrap:wrap;align-items:center;gap:8px;cursor:text}.multi-select__control--open{box-shadow:0 0 0 3px #3b82f61f;border-color:#3b82f659}.multi-select__chips{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.multi-select__placeholder{font-size:13px;color:#64748bcc}.multi-select__chip{border:1px solid rgba(15,23,42,.12);background:#0f172a08;border-radius:999px;padding:6px 10px;font-size:12px;color:#0f172ae6;cursor:pointer}.multi-select__chipX{opacity:.65;margin-left:6px}.multi-select__input{border:none;outline:none;font-size:13px;min-width:150px;flex:1}.multi-select__menu{border:1px solid var(--sa-border);border-radius:12px;background:#fff;box-shadow:var(--sa-shadow);overflow:hidden;max-height:260px;overflow-y:auto}.multi-select__menuItem{width:100%;text-align:left;padding:10px 12px;border:none;background:#fff;cursor:pointer;font-size:13px;display:block}.multi-select__menuItem:hover{background:#0f172a0a}.multi-select__menuItem:disabled{opacity:.55;cursor:not-allowed}.multi-select__menuItem--muted{cursor:default;color:var(--sa-muted)}.multi-select__menuItemMain{display:grid;gap:2px}.multi-select__menuItemSubLabel{font-size:12px;color:var(--sa-muted)}.roles-page{--rp-bg: #ffffff;--rp-text: #0f172a;--rp-muted: #64748b;--rp-border: rgba(15, 23, 42, .1);--rp-card: rgba(255, 255, 255, .9);--rp-shadow: 0 12px 30px rgba(15, 23, 42, .08);--rp-shadow-soft: 0 6px 20px rgba(15, 23, 42, .06);--rp-primary: #2563eb;--rp-primary-dark: #1d4ed8;--rp-primary-soft: rgba(37, 99, 235, .1);--rp-danger: #b91c1c;--rp-success-bg: #ecfdf5;--rp-success-border: #a7f3d0;--rp-success-text: #065f46;background:linear-gradient(180deg,#f1f5f9cc,#fff 55%);border-radius:16px;box-shadow:var(--rp-shadow);padding:22px;border:1px solid var(--rp-border)}.roles-page__header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:12px}.roles-page__headerActions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.roles-page__title{margin:0 0 4px;font-size:22px;font-weight:650;letter-spacing:-.02em;color:var(--rp-text)}.roles-page__subtitle{margin:0;font-size:14px;color:var(--rp-muted)}.roles-page__loading,.roles-page__error{padding:32px;text-align:center;color:var(--rp-muted)}.roles-page__error{color:var(--rp-danger)}.roles-page__toast{margin:10px 0 14px;padding:10px 12px;border-radius:12px;background:var(--rp-success-bg);border:1px solid var(--rp-success-border);color:var(--rp-success-text);font-size:13px}.roles-page__primaryBtn,.roles-page__secondaryBtn{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid var(--rp-border);border-radius:12px;padding:10px 14px;font-size:14px;font-weight:600;cursor:pointer;transition:transform .12s ease,background .12s ease,border-color .12s ease,box-shadow .12s ease,color .12s ease;white-space:nowrap}.roles-page__primaryBtn{border-color:#2563eb40;background:linear-gradient(180deg,#2563eb,#1d4ed8);color:#fff;box-shadow:0 10px 22px #2563eb38}.roles-page__primaryBtn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 14px 26px #2563eb3d}.roles-page__primaryBtn:active:not(:disabled){transform:translateY(0)}.roles-page__secondaryBtn{background:#ffffffe6;color:var(--rp-text)}.roles-page__secondaryBtn:hover:not(:disabled){background:#f1f5f9e6;border-color:#0f172a2e}.roles-page__primaryBtn:disabled,.roles-page__secondaryBtn:disabled{opacity:.65;cursor:not-allowed;transform:none}.roles-page__create{margin:14px 0 18px;padding:16px;border:1px solid var(--rp-border);border-radius:16px;background:#ffffffbf;box-shadow:var(--rp-shadow-soft)}.roles-page__createHeader{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.roles-page__modalForm,.roles-page__modalPerms{display:flex;flex-direction:column;gap:12px}.roles-page__createTitle{font-size:14px;font-weight:700;color:var(--rp-text);letter-spacing:-.01em}.roles-page__createHint{margin-top:2px;font-size:13px;color:var(--rp-muted)}.roles-page__createForm{margin-top:16px;display:flex;flex-direction:column;gap:12px}.roles-page__createGrid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.roles-page__createLabel--full{grid-column:1 / -1}.roles-page__createLabel{display:flex;flex-direction:column;gap:4px;font-size:13px;font-weight:650;color:var(--rp-text)}.roles-page__createLabelHint{font-weight:500;color:var(--rp-muted);font-size:12px}.roles-page__createInput{padding:10px 12px;border:1px solid var(--rp-border);border-radius:12px;font-size:14px;background:#fffffff2;color:var(--rp-text);outline:none;transition:box-shadow .12s ease,border-color .12s ease}.roles-page__createInput:focus{border-color:#2563eb59;box-shadow:0 0 0 4px var(--rp-primary-soft)}.roles-page__createError{margin:0;font-size:13px;color:var(--rp-danger)}.roles-page__createFooter{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.roles-page__createFooterActions{display:flex;align-items:center;gap:10px}.roles-page__list{display:flex;flex-direction:column;gap:16px}.role-card{border:1px solid var(--rp-border);border-radius:16px;padding:18px;background:#ffffffe6;box-shadow:var(--rp-shadow-soft);transition:transform .12s ease,box-shadow .12s ease,border-color .12s ease}.role-card:hover{transform:translateY(-1px);box-shadow:var(--rp-shadow);border-color:#0f172a24}.role-card__header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px}.role-card__name{margin:0 0 4px;font-size:17px;font-weight:700;color:var(--rp-text);letter-spacing:-.01em}.role-card__meta{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.role-card__badge{font-size:12px;font-weight:650;color:var(--rp-text);background:#f1f5f9e6;border:1px solid var(--rp-border);padding:4px 8px;border-radius:999px}.role-card__badge--code{background:#2563eb1a;border-color:#2563eb38;color:var(--rp-primary-dark)}.role-card__description{margin:8px 0 0;font-size:14px;color:var(--rp-muted);line-height:1.4}.role-card__perms-preview{margin-top:12px;font-size:13px;color:var(--rp-muted)}.role-card__edit{margin-top:16px;padding-top:16px;border-top:1px solid var(--rp-border)}.role-card__edit-label{margin:0 0 10px;font-size:13px;font-weight:650;color:var(--rp-text)}.role-card__perms-list{list-style:none;margin:0 0 16px;padding:0;max-height:240px;overflow-y:auto;display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:10px}.role-card__permLabel{display:flex;align-items:flex-start;gap:10px;font-size:13px;cursor:pointer;padding:10px;border-radius:12px;border:1px solid var(--rp-border);background:#fffffff2;transition:background .12s ease,border-color .12s ease,box-shadow .12s ease}.role-card__permLabel:hover{border-color:#2563eb38;box-shadow:0 0 0 4px #2563eb0f}.role-card__permLabel--checked{background:#2563eb12;border-color:#2563eb3d}.role-card__perm input{flex-shrink:0;margin-top:1px}.role-card__permText{display:flex;flex-direction:column;gap:2px;min-width:0}.role-card__perm-code{font-weight:650;color:var(--rp-text);word-break:break-word}.role-card__perm-name{color:var(--rp-muted);word-break:break-word}.role-card__footer{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;border-top:1px solid var(--rp-border);padding-top:12px}.role-card__footerHint{font-size:13px;color:var(--rp-muted)}.role-card__footerActions{display:flex;align-items:center;gap:10px}@media (max-width: 820px){.roles-page{padding:16px}.roles-page__header{flex-direction:column;align-items:stretch}.roles-page__headerActions{justify-content:flex-start}.roles-page__createGrid{grid-template-columns:1fr}}.permissions-page{background:linear-gradient(180deg,#f1f5f9cc,#fff 55%);border-radius:16px;box-shadow:var(--sa-shadow);padding:22px;border:1px solid var(--sa-border)}.permissions-page__header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:12px}.permissions-page__headerActions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.permissions-page__title{margin:0 0 4px;font-size:22px;font-weight:650;letter-spacing:-.02em;color:var(--sa-text)}.permissions-page__subtitle{margin:0;font-size:14px;color:var(--sa-muted)}.permissions-page__toast{margin:10px 0 14px;padding:10px 12px;border-radius:12px;background:var(--sa-success-bg);border:1px solid var(--sa-success-border);color:var(--sa-success-text);font-size:13px}.permissions-page__primaryBtn{border-color:#2563eb40;background:linear-gradient(180deg,#2563eb,#1d4ed8);color:#fff;box-shadow:0 10px 22px #2563eb38;-webkit-appearance:none;-moz-appearance:none;appearance:none;border-radius:12px;padding:10px 14px;font-size:14px;font-weight:600;cursor:pointer;transition:transform .12s ease,background .12s ease,border-color .12s ease,box-shadow .12s ease,color .12s ease;white-space:nowrap;border-style:solid;border-width:1px}.permissions-page__primaryBtn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 14px 26px #2563eb3d}.permissions-page__secondaryBtn{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid var(--sa-border);border-radius:12px;padding:10px 14px;font-size:14px;font-weight:600;cursor:pointer;background:#ffffffe6;color:var(--sa-text);transition:transform .12s ease,background .12s ease,border-color .12s ease,box-shadow .12s ease,color .12s ease;white-space:nowrap}.permissions-page__secondaryBtn:hover:not(:disabled){background:#f1f5f9e6;border-color:#0f172a2e}.permissions-page__primaryBtn:disabled,.permissions-page__secondaryBtn:disabled{opacity:.65;cursor:not-allowed;transform:none}.permissions-page__create{margin-bottom:24px;padding:16px;border:1px solid var(--sa-border);border-radius:16px;background:#ffffffbf;box-shadow:var(--sa-shadow-soft)}.permissions-page__createHeader{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.permissions-page__modalForm{display:flex;flex-direction:column;gap:12px}.permissions-page__createTitle{font-size:14px;font-weight:700;color:var(--sa-text);letter-spacing:-.01em}.permissions-page__createHint{margin-top:2px;font-size:13px;color:var(--sa-muted)}.permissions-page__createForm{margin-top:16px;display:flex;flex-direction:column;gap:12px}.permissions-page__createGrid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.permissions-page__createLabel--full{grid-column:1 / -1}.permissions-page__createLabel{display:flex;flex-direction:column;gap:4px;font-size:13px;font-weight:650;color:var(--sa-text)}.permissions-page__createLabelHint{font-weight:500;color:var(--sa-muted);font-size:12px}.permissions-page__createInput{padding:10px 12px;border:1px solid var(--sa-border);border-radius:12px;font-size:14px;background:#fffffff2;color:var(--sa-text);outline:none}.permissions-page__createInput:focus{border-color:#2563eb59;box-shadow:0 0 0 4px var(--sa-primary-soft)}.permissions-page__createError{margin:0;font-size:13px;color:var(--sa-danger)}.permissions-page__createFooter{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.permissions-page__createFooterActions{display:flex;align-items:center;gap:10px}.permissions-page__loading,.permissions-page__error{padding:32px;text-align:center;color:var(--sa-muted)}.permissions-page__error{color:var(--sa-danger)}.permissions-page__table-wrap{overflow-x:auto}.permissions-table{width:100%;border-collapse:collapse;font-size:14px}.permissions-table th,.permissions-table td{padding:12px 16px;text-align:left;border-bottom:1px solid #e4e6eb}.permissions-table th{font-weight:600;color:#65676b;background:#f7f8fa}.permissions-table tbody tr:hover{background:#f7f8fa}.permissions-table__code{font-weight:500;color:#1a1d29}.permissions-page__desc{max-width:280px;color:#65676b}.permissions-page__menuSelect{padding:6px 10px;border:1px solid #e4e6eb;border-radius:6px;font-size:13px;min-width:140px}.permissions-page__actionsCell{width:1%;white-space:nowrap}.permissions-page__rowBtn{padding:6px 10px;border:1px solid var(--sa-border);border-radius:10px;background:#fffffff2;font-size:13px;cursor:pointer;color:var(--sa-primary-dark);font-weight:600;transition:background .12s ease,border-color .12s ease,box-shadow .12s ease,transform .12s ease}.permissions-page__rowBtn:hover{background:#f1f5f9e6;border-color:#0f172a2e}.menus-page{background:linear-gradient(180deg,#f1f5f9cc,#fff 55%);border-radius:16px;box-shadow:var(--sa-shadow);padding:22px;border:1px solid var(--sa-border)}.menus-page__header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:12px}.menus-page__headerActions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.menus-page__title{margin:0 0 4px;font-size:22px;font-weight:650;letter-spacing:-.02em;color:var(--sa-text)}.menus-page__subtitle{margin:0;font-size:14px;color:var(--sa-muted)}.menus-page__toast{margin:10px 0 14px;padding:10px 12px;border-radius:12px;background:var(--sa-success-bg);border:1px solid var(--sa-success-border);color:var(--sa-success-text);font-size:13px}.menus-page__primaryBtn{border-color:#2563eb40;background:linear-gradient(180deg,#2563eb,#1d4ed8);color:#fff;box-shadow:0 10px 22px #2563eb38;-webkit-appearance:none;-moz-appearance:none;appearance:none;border-radius:12px;padding:10px 14px;font-size:14px;font-weight:600;cursor:pointer;transition:transform .12s ease,background .12s ease,border-color .12s ease,box-shadow .12s ease,color .12s ease;white-space:nowrap;border-style:solid;border-width:1px}.menus-page__primaryBtn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 14px 26px #2563eb3d}.menus-page__secondaryBtn{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid var(--sa-border);border-radius:12px;padding:10px 14px;font-size:14px;font-weight:600;cursor:pointer;background:#ffffffe6;color:var(--sa-text);transition:transform .12s ease,background .12s ease,border-color .12s ease,box-shadow .12s ease,color .12s ease;white-space:nowrap}.menus-page__secondaryBtn:hover:not(:disabled){background:#f1f5f9e6;border-color:#0f172a2e}.menus-page__primaryBtn:disabled,.menus-page__secondaryBtn:disabled{opacity:.65;cursor:not-allowed;transform:none}.menus-page__create{margin-bottom:24px;padding:16px;border:1px solid var(--sa-border);border-radius:16px;background:#ffffffbf;box-shadow:var(--sa-shadow-soft)}.menus-page__createHeader{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.menus-page__modalForm{display:flex;flex-direction:column;gap:12px}.menus-page__createTitle{font-size:14px;font-weight:700;color:var(--sa-text);letter-spacing:-.01em}.menus-page__createHint{margin-top:2px;font-size:13px;color:var(--sa-muted)}.menus-page__createForm{margin-top:16px;display:flex;flex-direction:column;gap:12px}.menus-page__createGrid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.menus-page__createLabel--full{grid-column:1 / -1}.menus-page__createLabel{display:flex;flex-direction:column;gap:4px;font-size:13px;font-weight:650;color:var(--sa-text)}.menus-page__createLabelHint{font-weight:500;color:var(--sa-muted);font-size:12px}.menus-page__createInput,.menus-page__createSelect{padding:10px 12px;border:1px solid var(--sa-border);border-radius:12px;font-size:14px;background:#fffffff2;color:var(--sa-text);outline:none}.menus-page__createInput:focus,.menus-page__createSelect:focus{border-color:#2563eb59;box-shadow:0 0 0 4px var(--sa-primary-soft)}.menus-page__createError{margin:0;font-size:13px;color:var(--sa-danger)}.menus-page__createFooter{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.menus-page__createFooterActions{display:flex;align-items:center;gap:10px}.menus-page__loading,.menus-page__error{padding:32px;text-align:center;color:var(--sa-muted)}.menus-page__error{color:var(--sa-danger)}.menus-page__tree{margin-top:16px}.menus-page__tree-item{padding:10px 12px;border:1px solid var(--sa-border);border-radius:12px;margin-bottom:8px;background:#ffffffe6;display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;box-shadow:var(--sa-shadow-soft);transition:transform .12s ease,box-shadow .12s ease,border-color .12s ease}.menus-page__tree-item:hover{transform:translateY(-1px);box-shadow:var(--sa-shadow);border-color:#0f172a24}.menus-page__tree-item--child{border-left:3px solid rgba(37,99,235,.6)}.menus-page__tree-item-info{flex:1;min-width:0}.menus-page__tree-item-name{font-weight:700;color:var(--sa-text);letter-spacing:-.01em}.menus-page__tree-item-meta{font-size:12px;color:var(--sa-muted);margin-top:2px}.menus-page__tree-item-actions{display:flex;gap:8px}.menus-page__tree-item-btn{padding:6px 10px;border:1px solid var(--sa-border);border-radius:10px;background:#fffffff2;font-size:13px;cursor:pointer;color:var(--sa-primary-dark);font-weight:600;transition:background .12s ease,border-color .12s ease,box-shadow .12s ease,transform .12s ease}.menus-page__tree-item-btn:hover{background:#f1f5f9e6;border-color:#0f172a2e}.menus-page__tree-item-btn--sub{background:#2563eb14;border-color:#2563eb2e}.menus-page__tree-item-btn--sub:hover{background:#2563eb1f;border-color:#2563eb38}.menus-page__tree-item-btn--danger{color:var(--sa-danger)}.menus-page__tree-item-btn--danger:hover{background:#b91c1c14;border-color:#b91c1c2e}.menus-page__empty{padding:24px;text-align:center;color:#65676b;font-size:14px}.menus-page__help{margin-top:24px;padding:16px;background:#f0f9ff;border:1px solid #bae6fd;border-radius:10px;font-size:13px;color:#0c4a6e}.menus-page__help h3{margin:0 0 8px;font-size:14px;font-weight:600}.menus-page__help p{margin:0 0 8px}.menus-page__help p:last-child{margin-bottom:0}.group-questions-page{background:#fff;border-radius:10px;box-shadow:0 2px 8px #00000014;padding:24px}.group-questions-page__breadcrumb{font-size:13px;color:#65676b;margin-bottom:16px}.group-questions-page__breadcrumb a{color:#1967d2;text-decoration:none}.group-questions-page__breadcrumb a:hover{text-decoration:underline}.group-questions-page__breadcrumb-sep{margin:0 6px;color:#b0b3b8}.group-questions-page__title{margin:0 0 4px;font-size:22px;font-weight:600;color:#1a1d29}.group-questions-page__subtitle{margin:0 0 20px;font-size:14px;color:#65676b}.group-questions-page__newBanner{width:100%;border:1px solid rgba(25,103,210,.25);background:#1967d214;color:#1967d2;border-radius:12px;padding:10px 12px;font-size:13px;font-weight:700;cursor:pointer;margin:0 0 14px}.group-questions-page__newBanner:hover{background:#1967d21f}.group-questions-page__filters{margin:0 0 18px}.group-questions-page__filtersLabel{font-size:13px;color:#65676b;display:flex;align-items:center;gap:10px}.group-questions-page__filtersRow{display:flex;align-items:center;gap:14px;flex-wrap:wrap}.group-questions-page__searchInput{border:1px solid #e4e6eb;border-radius:8px;padding:8px 10px;font-size:13px;background:#fff;color:#1a1d29;outline:none;min-width:220px}.group-questions-page__searchInput:focus{border-color:#1967d2}.group-questions-page__searchField{display:inline-flex;align-items:center;gap:8px}.group-questions-page__searchClear{border:none;background:transparent;color:#1967d2;font-size:13px;font-weight:600;cursor:pointer;padding:4px 6px;border-radius:6px}.group-questions-page__searchClear:hover{background:#1967d214}.group-questions-page__filtersSelect{border:1px solid #e4e6eb;border-radius:8px;padding:8px 10px;font-size:13px;background:#fff;color:#1a1d29;outline:none}.group-questions-page__filtersSelect:focus{border-color:#1967d2}.group-questions-page__loading,.group-questions-page__error{padding:40px;text-align:center;color:#65676b}.group-questions-page__error{color:#b94a48}.group-questions-page__table-wrap{overflow-x:auto}.group-questions-page__pager{margin-top:16px;display:flex;justify-content:center}.group-questions-page__pagerBtn{border:1px solid #e4e6eb;border-radius:10px;padding:10px 14px;background:#fff;color:#1a1d29;cursor:pointer}.group-questions-page__pagerBtn:disabled{opacity:.6;cursor:not-allowed}.questions-table{width:100%;border-collapse:collapse;font-size:14px}.questions-table th,.questions-table td{padding:12px 16px;text-align:left;border-bottom:1px solid #e4e6eb;vertical-align:top}.questions-table th{font-weight:600;color:#65676b;background:#f7f8fa}.questions-table tbody tr:hover{background:#f7f8fa}.questions-table__title-link{display:block;font-weight:500;color:#1967d2;text-decoration:none;margin-bottom:4px}.questions-table__title-link:hover{text-decoration:underline}.questions-table__body-preview{display:block;font-size:12px;color:#65676b;line-height:1.3}.questions-table__empty{text-align:center;color:#65676b;font-size:14px;padding:28px 16px!important}.questions-table__search-hit{background:#ffe6788c;color:inherit;padding:0 1px;border-radius:2px}.question-detail-page{max-width:900px;margin:0 auto}.question-detail-page__breadcrumb{font-size:13px;color:#65676b;margin-bottom:20px}.question-detail-page__breadcrumb a{color:#1967d2;text-decoration:none}.question-detail-page__breadcrumb a:hover{text-decoration:underline}.question-detail-page__breadcrumb-sep{margin:0 6px;color:#b0b3b8}.question-detail-page__loading,.question-detail-page__error{padding:40px;text-align:center;color:#65676b}.question-detail-page__error{color:#b94a48}.question-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;padding:24px;margin-bottom:24px;border:1px solid #e4e6eb}.question-card__main{display:flex;gap:20px;align-items:flex-start}.question-card__content{flex:1;min-width:0}.question-card__title{margin:0 0 12px;font-size:24px;font-weight:600;color:#1a1d29;line-height:1.3}.question-card__body{margin:0 0 16px;font-size:15px;line-height:1.6;color:#333;white-space:pre-wrap}.question-card__meta{display:flex;flex-wrap:wrap;align-items:center;gap:16px;font-size:13px;color:#65676b}.question-card__author{font-weight:500;color:#1a1d29}.question-card__stats{margin-left:auto}.vote-block{display:flex;flex-direction:column;align-items:center;gap:4px;flex-shrink:0}.vote-block__btn{width:36px;height:28px;border:1px solid #e4e6eb;background:#fff;border-radius:6px;cursor:pointer;font-size:12px;color:#65676b;display:flex;align-items:center;justify-content:center;transition:background .2s,color .2s}.vote-block__btn:hover:not(:disabled){background:#f0f2f5;color:#1967d2}.vote-block__btn:disabled{opacity:.6;cursor:not-allowed}.vote-block__btn--up:hover:not(:disabled){color:#238636}.vote-block__btn--down:hover:not(:disabled){color:#cf222e}.vote-block__score{font-size:16px;font-weight:600;color:#1a1d29;min-width:28px;text-align:center}.answers-section{margin-top:32px}.answers-section__title{margin:0 0 16px;font-size:20px;font-weight:600;color:#1a1d29}.answers-section__empty{color:#65676b;font-size:14px;padding:24px;background:#f7f8fa;border-radius:10px}.answer-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;padding:24px;margin-bottom:20px;border:1px solid #e4e6eb}.answer-card__main{display:flex;gap:20px;align-items:flex-start}.answer-card__content{flex:1;min-width:0}.answer-card__accepted{display:inline-block;padding:4px 10px;background:#e6f4ea;color:#137333;font-size:12px;font-weight:600;border-radius:6px;margin-bottom:10px}.answer-card__body{margin:0 0 12px;font-size:15px;line-height:1.6;color:#333;white-space:pre-wrap}.answer-card__meta{display:flex;flex-wrap:wrap;align-items:center;gap:12px;font-size:13px;color:#65676b}.answer-card__reply-btn{background:none;border:none;color:#1967d2;cursor:pointer;font-size:13px;padding:0}.answer-card__reply-btn:hover{text-decoration:underline}.answer-card__reply-form{margin-top:16px;padding-top:16px;border-top:1px solid #e4e6eb}.answer-card__reply-input{width:100%;padding:12px;border:1px solid #e4e6eb;border-radius:8px;font-size:14px;font-family:inherit;resize:vertical;margin-bottom:10px}.answer-card__reply-input:focus{outline:none;border-color:#1967d2;box-shadow:0 0 0 2px #1967d233}.answer-card__reply-actions{display:flex;gap:10px}.answer-card__reply-submit,.answer-card__reply-cancel{padding:8px 16px;border-radius:6px;font-size:13px;cursor:pointer}.answer-card__reply-submit{background:#1967d2;color:#fff;border:none}.answer-card__reply-submit:hover:not(:disabled){background:#1557b0}.answer-card__reply-submit:disabled{opacity:.6;cursor:not-allowed}.answer-card__reply-cancel{background:#fff;color:#65676b;border:1px solid #e4e6eb}.answer-card__reply-cancel:hover{background:#f0f2f5}.answer-card__comments{margin-top:20px;padding-top:20px;border-top:1px solid #e4e6eb}.answer-card__comments-title{margin:0 0 12px;font-size:14px;font-weight:600;color:#65676b}.comment-item{margin-bottom:12px}.comment-item__main{display:flex;gap:12px;align-items:flex-start}.comment-item--depth-1,.comment-item--depth-2{margin-left:24px;padding-left:16px;border-left:2px solid #e4e6eb}.comment-item__body{flex:1;min-width:0}.comment-item__text{margin:0 0 6px;font-size:14px;line-height:1.5;color:#333}.comment-item__meta{display:flex;flex-wrap:wrap;align-items:center;gap:10px;font-size:12px;color:#65676b}.comment-item__reply-btn{background:none;border:none;color:#1967d2;cursor:pointer;font-size:12px;padding:0}.comment-item__reply-btn:hover{text-decoration:underline}.comment-item__reply-form{margin-top:10px}.comment-item__reply-input{width:100%;padding:10px;border:1px solid #e4e6eb;border-radius:6px;font-size:13px;font-family:inherit;resize:vertical;margin-bottom:8px}.comment-item__reply-input:focus{outline:none;border-color:#1967d2}.comment-item__reply-actions{display:flex;gap:8px}.comment-item__reply-submit,.comment-item__reply-cancel{padding:6px 12px;border-radius:6px;font-size:12px;cursor:pointer}.comment-item__reply-submit{background:#1967d2;color:#fff;border:none}.comment-item__reply-submit:hover:not(:disabled){background:#1557b0}.comment-item__reply-submit:disabled{opacity:.6;cursor:not-allowed}.comment-item__reply-cancel{background:#fff;color:#65676b;border:1px solid #e4e6eb}.comment-item__reply-cancel:hover{background:#f0f2f5}.comment-item__replies{margin-top:8px}.legal-page{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2,#f093fb);padding:40px 20px;display:flex;justify-content:center;align-items:flex-start}.legal-container{background:#fff;border-radius:16px;box-shadow:0 4px 24px #00000014,0 1px 2px #0000000a;border:1px solid rgba(0,0,0,.06);max-width:900px;width:100%;padding:48px 56px;margin:0 auto}.legal-header{text-align:center;margin-bottom:48px;padding-bottom:32px;border-bottom:2px solid #e2e8f0}.legal-logo{display:inline-flex;margin-bottom:24px}.legal-header h1{margin:0 0 12px;color:#1a202c;font-size:36px;font-weight:700;letter-spacing:-.5px;line-height:1.2}.legal-subtitle{margin:0;color:#64748b;font-size:15px;font-weight:400}.legal-content{line-height:1.8;color:#334155}.legal-section{margin-bottom:40px}.legal-section:last-of-type{margin-bottom:0}.legal-section h2{color:#1a202c;font-size:24px;font-weight:600;margin:0 0 16px;padding-top:8px;line-height:1.4}.legal-section h3{color:#1e293b;font-size:18px;font-weight:600;margin:24px 0 12px;line-height:1.4}.legal-section p{margin:0 0 16px;color:#475569;font-size:15px;line-height:1.7}.legal-section ul{margin:16px 0;padding-left:24px;color:#475569}.legal-section li{margin-bottom:12px;font-size:15px;line-height:1.7}.legal-section strong{color:#1e293b;font-weight:600}.legal-footer{margin-top:56px;padding-top:32px;border-top:1px solid #e2e8f0;text-align:center}.legal-footer p{margin:0;color:#64748b;font-size:14px}.legal-footer a{color:#667eea;text-decoration:none;font-weight:500;margin:0 8px}.legal-footer a:hover{text-decoration:underline}@media (max-width: 768px){.legal-page{padding:24px 16px}.legal-container{padding:32px 28px}.legal-header{margin-bottom:32px;padding-bottom:24px}.legal-header h1{font-size:28px}.legal-section{margin-bottom:32px}.legal-section h2{font-size:22px}.legal-section h3{font-size:17px}.legal-footer{margin-top:40px;padding-top:24px}}@media (max-width: 480px){.legal-container{padding:24px 20px}.legal-header h1{font-size:24px}.legal-section h2{font-size:20px}.legal-section p,.legal-section li{font-size:14px}}.input-wrapper input{width:100%;padding:14px 16px 14px 48px;border:2px solid #e2e8f0;border-radius:12px;font-size:15px;background:#fff;color:#1a202c;transition:all .2s;outline:none}.success-container strong{color:#1a202c;font-weight:600}.success-note{color:#64748b!important;font-size:14px!important;margin-bottom:32px!important}@media (max-width: 480px){.auth-page-container{padding:24px 16px}.auth-card{padding:28px 20px}.auth-header{margin-bottom:24px;padding-bottom:18px}.auth-card h1{font-size:22px}}.auth-page-container{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2,#f093fb);display:flex;align-items:center;justify-content:center;padding:40px 20px}.auth-card{background:#fff;padding:48px 40px;border-radius:16px;box-shadow:0 4px 24px #00000014,0 1px 2px #0000000a;border:1px solid rgba(0,0,0,.06);width:100%;max-width:440px;position:relative;z-index:1;animation:slide-in .6s ease-out}@keyframes slide-in{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.back-link{display:inline-flex;align-items:center;gap:8px;color:#667eea;text-decoration:none;font-size:14px;font-weight:500;margin-bottom:24px;transition:color .2s}.back-link:hover{color:#5568d3;text-decoration:underline}.auth-header{text-align:left;margin-bottom:32px;padding-bottom:24px;border-bottom:1px solid #e2e8f0}.auth-logo{display:inline-flex;margin-bottom:20px}.auth-card h1{margin:0 0 8px;color:#1a202c;font-size:28px;font-weight:600;letter-spacing:-.3px;line-height:1.3}.auth-subtitle{margin:0;color:#64748b;font-size:14px;font-weight:400;line-height:1.5}.auth-form,.form-group{margin-bottom:24px}.form-group label{display:block;margin-bottom:8px;color:#2d3748;font-weight:600;font-size:14px;letter-spacing:.01em}.input-wrapper{position:relative;display:flex;align-items:center}.input-icon{position:absolute;left:16px;color:#a0aec0;pointer-events:none;z-index:1;transition:color .2s}.input-wrapper input{width:100%;padding:14px 48px;border:2px solid #e2e8f0;border-radius:12px;font-size:15px;background:#fff;color:#1a202c;transition:all .2s;outline:none}.input-wrapper input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.input-wrapper input:focus~.input-icon{color:#667eea}.input-wrapper input.error{border-color:#fc8181}.input-wrapper input.error:focus{border-color:#fc8181;box-shadow:0 0 0 3px #fc81811a}.password-toggle{position:absolute;right:16px;background:none;border:none;color:#a0aec0;cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;transition:color .2s;z-index:1}.password-toggle:hover{color:#667eea}.password-requirements{margin-top:12px;padding:12px;background:#f8fafc;border-radius:8px;border:1px solid #e2e8f0}.requirements-label{margin:0 0 8px;color:#475569;font-size:13px;font-weight:500}.requirements-list{margin:0;padding-left:20px;list-style:none}.requirements-list li{margin-bottom:6px;color:#64748b;font-size:12px;line-height:1.5;position:relative}.requirements-list li:before{content:"○";position:absolute;left:-16px;color:#cbd5e1}.requirements-list li.met{color:#10b981}.requirements-list li.met:before{content:"✓";color:#10b981;font-weight:700}.error-message{display:flex;align-items:center;gap:10px;color:#e53e3e;margin-bottom:20px;padding:12px 16px;background:#fed7d7;border:1px solid #feb2b2;border-radius:12px;font-size:14px;animation:shake .4s}.error-message svg{flex-shrink:0}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-8px)}75%{transform:translate(8px)}}.error-container{text-align:center;padding:20px 0}.error-icon{display:flex;justify-content:center;margin-bottom:24px}.error-container h2{margin:0 0 12px;color:#1a202c;font-size:24px;font-weight:600}.error-container p{margin:0 0 24px;color:#475569;font-size:15px;line-height:1.6}.back-to-login-link{display:inline-block;margin-top:16px;color:#667eea;text-decoration:none;font-size:14px;font-weight:500}.back-to-login-link:hover{text-decoration:underline}.auth-button{width:100%;padding:14px 20px;background:#667eea;color:#fff;border:none;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:8px;box-shadow:0 2px 8px #667eea40;text-decoration:none}.auth-button:hover:not(:disabled){background:#5568d3;box-shadow:0 4px 12px #667eea59}.auth-button:active:not(:disabled){background:#4c5bc2;transform:translateY(1px)}.auth-button:disabled{opacity:.7;cursor:not-allowed}.auth-button .spinner{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.success-container{text-align:center;padding:20px 0}.success-icon{display:flex;justify-content:center;margin-bottom:24px}.success-container h2{margin:0 0 12px;color:#1a202c;font-size:24px;font-weight:600}.success-container p{margin:0 0 16px;color:#475569;font-size:15px;line-height:1.6}.success-note{color:#64748b!important;font-size:14px!important}.auth-footer{margin-top:24px;padding-top:24px;border-top:1px solid #e2e8f0;text-align:center}.auth-footer p{margin:0;color:#64748b;font-size:14px}.auth-footer a{color:#667eea;text-decoration:none;font-weight:500}.auth-footer a:hover{text-decoration:underline}@media (max-width: 768px){.auth-card{padding:36px 28px}.auth-header{margin-bottom:28px;padding-bottom:20px}.auth-card h1{font-size:26px}}@media (max-width: 480px){.auth-page-container{padding:24px 16px}.auth-card{padding:28px 20px}.auth-header{margin-bottom:24px;padding-bottom:18px}.auth-card h1{font-size:22px}.password-requirements{padding:10px}.requirements-list li{font-size:11px}}.dashboard-layout{min-height:100vh;background:#f0f2f5;display:flex}.dashboard-layout__header{background:#fff;color:#1a1d29;padding:0 20px;height:56px;display:flex;align-items:center;gap:12px;border-bottom:1px solid #e4e6eb}.dashboard-layout__content{flex:1;min-width:0;display:flex;flex-direction:column}.dashboard-layout__headerLeft{min-width:0}.dashboard-layout__nav-loading,.dashboard-layout__nav-error{padding:8px 14px;font-size:13px;color:#b0b3b8}.dashboard-layout__nav-error{color:#f28b82}.dashboard-layout__sidebar{width:260px;background:#1a1d29;color:#e4e6eb;display:flex;flex-direction:column;padding:14px 12px;box-shadow:2px 0 12px #0000001f}.dashboard-layout__brand{font-size:16px;font-weight:700;letter-spacing:-.02em;padding:10px 12px;margin-bottom:10px}.dashboard-layout__sideNav{display:flex;flex-direction:column;gap:6px;padding:0 4px}.dashboard-layout__sideNavItem{display:block}.dashboard-layout__sideNavRow{display:flex;align-items:center;gap:8px}.dashboard-layout__sideNavLink{flex:1;padding:10px 12px;color:#b0b3b8;text-decoration:none;border-radius:8px;font-size:14px;font-weight:600;transition:color .2s,background .2s;line-height:1.2;min-width:0}.dashboard-layout__sideNavLink:hover{color:#e4e6eb;background:#ffffff14}.dashboard-layout__sideNavLink--active{color:#fff;background:#ffffff1f}.dashboard-layout__sideNavToggle{width:34px;height:34px;display:inline-flex;align-items:center;justify-content:center;border:1px solid rgba(255,255,255,.12);border-radius:8px;background:transparent;color:#b0b3b8;cursor:pointer;transition:background .2s,color .2s,border-color .2s}.dashboard-layout__sideNavToggle:hover{background:#ffffff14;color:#e4e6eb;border-color:#ffffff2e}.dashboard-layout__sideSubnav{margin:6px 0 2px 12px;padding-left:10px;border-left:2px solid rgba(255,255,255,.12);display:flex;flex-direction:column;gap:4px}.dashboard-layout__sideSubnav--nested{margin-left:0;margin-top:4px;margin-bottom:0;border-left-color:#ffffff14}.dashboard-layout__sideSubnavLink{padding:8px 12px;color:#b0b3b8;text-decoration:none;border-radius:8px;font-size:13px;font-weight:500;transition:color .2s,background .2s}.dashboard-layout__sideSubnavLink:hover{color:#e4e6eb;background:#ffffff14}.dashboard-layout__sideSubnavLink--active{color:#fff;background:#ffffff1f}.dashboard-layout__actions{margin-left:auto;display:flex;align-items:center;gap:16px}.dashboard-layout__avatar{width:32px;height:32px;border-radius:50%;object-fit:cover}.dashboard-layout__user{font-size:13px;color:#65676b}.dashboard-layout__logout{padding:6px 14px;background:transparent;color:#65676b;border:1px solid #e4e6eb;border-radius:6px;font-size:13px;cursor:pointer;transition:background .2s,color .2s}.dashboard-layout__logout:hover{background:#f7f8fa;color:#1a1d29}.dashboard-layout__main{padding:24px;max-width:1400px;margin:0 auto;width:100%}*{margin:0;padding:0;box-sizing:border-box}:root{--sa-bg: #f8fafc;--sa-surface: #ffffff;--sa-surface-soft: rgba(255, 255, 255, .85);--sa-text: #0f172a;--sa-muted: #64748b;--sa-border: rgba(15, 23, 42, .1);--sa-shadow: 0 12px 30px rgba(15, 23, 42, .08);--sa-shadow-soft: 0 6px 20px rgba(15, 23, 42, .06);--sa-primary: #2563eb;--sa-primary-dark: #1d4ed8;--sa-primary-soft: rgba(37, 99, 235, .1);--sa-success-bg: #ecfdf5;--sa-success-border: #a7f3d0;--sa-success-text: #065f46;--sa-danger: #b91c1c;--sa-warning: #b45309}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--sa-bg);color:var(--sa-text)}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.sa-surface{background:linear-gradient(180deg,#f1f5f9bf,#fff 55%);border:1px solid var(--sa-border);border-radius:16px;box-shadow:var(--sa-shadow)}.sa-toast{border-radius:12px;background:var(--sa-success-bg);border:1px solid var(--sa-success-border);color:var(--sa-success-text)}.sa-btn-primary,.sa-btn-secondary{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid var(--sa-border);border-radius:12px;padding:10px 14px;font-size:14px;font-weight:600;cursor:pointer;transition:transform .12s ease,background .12s ease,border-color .12s ease,box-shadow .12s ease,color .12s ease;white-space:nowrap}.sa-btn-primary{border-color:#2563eb40;background:linear-gradient(180deg,#2563eb,#1d4ed8);color:#fff;box-shadow:0 10px 22px #2563eb38}.sa-btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 14px 26px #2563eb3d}.sa-btn-secondary{background:#ffffffe6;color:var(--sa-text)}.sa-btn-secondary:hover:not(:disabled){background:#f1f5f9e6;border-color:#0f172a2e}.sa-btn-primary:disabled,.sa-btn-secondary:disabled{opacity:.65;cursor:not-allowed;transform:none}.sa-input,.sa-select{padding:10px 12px;border:1px solid var(--sa-border);border-radius:12px;font-size:14px;background:#fffffff2;color:var(--sa-text);outline:none;transition:box-shadow .12s ease,border-color .12s ease}.sa-input:focus,.sa-select:focus{border-color:#2563eb59;box-shadow:0 0 0 4px var(--sa-primary-soft)}
