:root{--color-primary:#123b2f;--color-primary-hover:#0e2e24;--color-primary-light:#123b2f14;--color-primary-border:#123b2f33;--color-bg:#fff;--color-bg-secondary:#f7f7f6;--color-bg-tertiary:#efefed;--color-border:#e4e4e2;--color-border-strong:#c8c8c4;--color-text:#1a1a1a;--color-text-secondary:#6b6b68;--color-text-placeholder:#a8a8a4;--color-text-inverse:#fff;--color-success:#1a7a4a;--color-success-bg:#1a7a4a14;--color-warning:#a05c00;--color-warning-bg:#a05c0014;--color-danger:#c0392b;--color-danger-bg:#c0392b14;--color-info:#1a5fa0;--color-info-bg:#1a5fa014;--shadow-sm:0 1px 3px #0000000f, 0 1px 2px #0000000a;--shadow-md:0 4px 12px #00000014, 0 2px 4px #0000000a;--shadow-lg:0 8px 24px #0000001a, 0 4px 8px #0000000a;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--space-8:32px;--space-10:40px;--space-12:48px;--radius-sm:6px;--radius-md:10px;--radius-lg:14px;--radius-xl:20px;--radius-full:9999px;--font-sans:-apple-system, BlinkMacSystemFont, "SF Pro Text", "Segoe UI", system-ui, sans-serif;--font-mono:ui-monospace, "SF Mono", Menlo, Consolas, monospace;--text-xs:11px;--text-sm:13px;--text-base:15px;--text-md:17px;--text-lg:20px;--text-xl:24px;--text-2xl:30px;--transition:.15s ease}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;font-size:16px}body{font-family:var(--font-sans);font-size:var(--text-base);color:var(--color-text);background:var(--color-bg);line-height:1.5}#root{min-height:100vh}a{color:inherit;text-decoration:none}button{cursor:pointer;background:0 0;border:none;font-family:inherit}input,textarea,select{font-family:inherit;font-size:inherit}h1,h2,h3,h4,h5,h6{color:var(--color-text);font-weight:600;line-height:1.25}.btn{justify-content:center;align-items:center;gap:var(--space-2);height:38px;padding:0 var(--space-4);border-radius:var(--radius-md);font-size:var(--text-sm);cursor:pointer;transition:background var(--transition), opacity var(--transition), box-shadow var(--transition);white-space:nowrap;border:none;font-family:inherit;font-weight:500;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--color-primary);color:var(--color-text-inverse)}.btn-primary:hover:not(:disabled){background:var(--color-primary-hover)}.btn-secondary{background:var(--color-bg);color:var(--color-text);border:1px solid var(--color-border)}.btn-secondary:hover:not(:disabled){background:var(--color-bg-secondary)}.btn-danger{background:var(--color-danger);color:#fff}.btn-danger:hover:not(:disabled){background:#a93226}.btn-ghost{color:var(--color-text-secondary);background:0 0}.btn-ghost:hover:not(:disabled){background:var(--color-bg-secondary);color:var(--color-text)}.btn-sm{height:32px;padding:0 var(--space-3);font-size:var(--text-xs)}.btn-icon{border-radius:var(--radius-md);width:36px;height:36px;padding:0}.form-group{gap:var(--space-2);flex-direction:column;display:flex}.form-label{font-size:var(--text-sm);color:var(--color-text);font-weight:500}.form-label-optional{color:var(--color-text-secondary);margin-left:4px;font-weight:400}.form-input,.form-select,.form-textarea{width:100%;padding:0 var(--space-4);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg);color:var(--color-text);font-size:var(--text-base);transition:border-color var(--transition), box-shadow var(--transition);outline:none;font-family:inherit}.form-input,.form-select{height:40px}.form-textarea{padding:var(--space-3) var(--space-4);resize:vertical;min-height:100px;line-height:1.5}.form-input::placeholder,.form-textarea::placeholder{color:var(--color-text-placeholder)}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.form-input:disabled,.form-select:disabled,.form-textarea:disabled{background:var(--color-bg-secondary);opacity:.6;cursor:not-allowed}.form-hint{font-size:var(--text-xs);color:var(--color-text-secondary)}.form-error{font-size:var(--text-xs);color:var(--color-danger)}.form-row{gap:var(--space-4);grid-template-columns:1fr 1fr;display:grid}.form-actions{justify-content:flex-end;gap:var(--space-3);margin-top:var(--space-4);padding-top:var(--space-4);border-top:1px solid var(--color-border);display:flex}.form-stack{gap:var(--space-4);flex-direction:column;display:flex}.table-wrapper{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.table{border-collapse:collapse;width:100%}.table th{padding:var(--space-3) var(--space-4);text-align:left;font-size:var(--text-xs);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px;background:var(--color-bg-secondary);border-bottom:1px solid var(--color-border);white-space:nowrap;font-weight:600}.table td{padding:var(--space-4);font-size:var(--text-sm);color:var(--color-text);border-bottom:1px solid var(--color-border);vertical-align:middle}.table tr:last-child td{border-bottom:none}.table tbody tr{transition:background var(--transition)}.table tbody tr:hover{background:var(--color-bg-secondary)}.table-actions{align-items:center;gap:var(--space-1);display:flex}.toolbar{align-items:center;gap:var(--space-3);margin-bottom:var(--space-4);flex-wrap:wrap;display:flex}.toolbar-right{align-items:center;gap:var(--space-3);margin-left:auto;display:flex}.card{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-6)}.stat-card{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-5) var(--space-6);gap:var(--space-2);flex-direction:column;display:flex}.stat-card-label{font-size:var(--text-sm);color:var(--color-text-secondary)}.stat-card-value{font-size:var(--text-2xl);color:var(--color-text);letter-spacing:-.5px;font-weight:700}.stat-card-sub{font-size:var(--text-xs);color:var(--color-text-secondary)}.stat-card-sub.positive{color:var(--color-success)}.stats-grid{gap:var(--space-4);margin-bottom:var(--space-6);grid-template-columns:repeat(auto-fill,minmax(200px,1fr));display:grid}.filter-select{height:38px;padding:0 var(--space-4);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg);color:var(--color-text);font-size:var(--text-sm);cursor:pointer;transition:border-color var(--transition);outline:none;font-family:inherit}.filter-select:focus{border-color:var(--color-primary)}.period-tabs{background:var(--color-bg-secondary);border-radius:var(--radius-md);gap:2px;padding:3px;display:flex}.period-tab{border-radius:calc(var(--radius-md) - 2px);font-size:var(--text-xs);color:var(--color-text-secondary);transition:background var(--transition), color var(--transition);padding:5px 14px;font-weight:500}.period-tab:hover{color:var(--color-text)}.period-tab--active{background:var(--color-bg);color:var(--color-text);box-shadow:var(--shadow-sm)}.pagination{justify-content:flex-end;align-items:center;gap:var(--space-1);padding:var(--space-3) var(--space-2);border-top:1px solid var(--color-border);flex-wrap:wrap;display:flex}.pagination-info{font-size:var(--text-sm);color:var(--color-text-secondary);margin-right:auto}@media (max-width:520px){.pagination{-webkit-overflow-scrolling:touch;padding:var(--space-3) var(--space-2);flex-wrap:nowrap;justify-content:flex-start;overflow-x:auto}.pagination-info{white-space:nowrap;flex-shrink:0}.pagination-btn{min-width:30px;height:30px;font-size:var(--text-xs);flex-shrink:0}.pagination-ellipsis{min-width:16px;height:30px;font-size:var(--text-xs);flex-shrink:0}}.pagination-btn{min-width:32px;height:32px;padding:0 var(--space-2);border-radius:var(--radius-md);font-size:var(--text-sm);color:var(--color-text-secondary);cursor:pointer;transition:background var(--transition), color var(--transition), border-color var(--transition);background:0 0;border:1px solid #0000;justify-content:center;align-items:center;font-weight:500;display:inline-flex}.pagination-btn:hover:not(:disabled){background:var(--color-bg-secondary);color:var(--color-text)}.pagination-btn:disabled{opacity:.35;cursor:not-allowed}.pagination-btn--active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.pagination-btn--active:hover{background:var(--color-primary);color:#fff}.pagination-ellipsis{min-width:32px;height:32px;font-size:var(--text-sm);color:var(--color-text-secondary);justify-content:center;align-items:center;display:inline-flex}.mobile-cards{display:none}.mobile-card{padding:var(--space-4);border-bottom:1px solid var(--color-border);gap:var(--space-2);flex-direction:column;display:flex}.mobile-card:last-child{border-bottom:none}.mobile-card-title{font-size:var(--text-sm);color:var(--color-text);font-weight:600;line-height:1.4}.mobile-card-sub{font-size:var(--text-xs);color:var(--color-text-secondary)}.mobile-card-meta{align-items:center;gap:var(--space-2);flex-wrap:wrap;display:flex}.mobile-card-preview{font-size:var(--text-xs);color:var(--color-text-secondary);-webkit-line-clamp:2;-webkit-box-orient:vertical;line-height:1.5;display:-webkit-box;overflow:hidden}.mobile-card-actions{gap:var(--space-2);margin-top:var(--space-1);flex-wrap:wrap;display:flex}@media (max-width:768px){.table-wrapper{-webkit-overflow-scrolling:touch;overflow-x:auto}.table{min-width:540px}.table-desktop-only{display:none}.mobile-cards{display:block}.toolbar{align-items:stretch;gap:var(--space-2);flex-direction:column}.filter-select{width:100%}.page-header{align-items:flex-start;gap:var(--space-3);flex-direction:column}.page-header-action{width:100%}.page-header-action .btn{justify-content:center;width:100%}.stats-grid{grid-template-columns:repeat(2,1fr)}.stats-grid>*{min-width:0}.dashboard-grid{grid-template-columns:1fr}.dashboard-grid>*{min-width:0}.dashboard-header-actions{align-items:stretch;gap:var(--space-2);flex-direction:column;width:100%}.period-tabs{-webkit-overflow-scrolling:touch;overflow-x:auto}.btn-export-pdf{justify-content:center;width:100%}.modal-overlay{padding:var(--space-2);align-items:flex-end}.modal-box{border-radius:var(--radius-lg) var(--radius-lg) 0 0;max-height:92vh;width:100%!important;max-width:100%!important}.form-row{grid-template-columns:1fr}.form-actions{flex-wrap:wrap}.form-actions .btn{flex:1;justify-content:center;min-width:120px}.table-actions{flex-wrap:wrap;gap:4px}}@media (max-width:480px){.stats-grid{grid-template-columns:1fr}}.sidebar{background:var(--color-bg);border-right:1px solid var(--color-border);flex-direction:column;flex-shrink:0;width:240px;min-height:100vh;display:flex}.sidebar-header{padding:var(--space-6) var(--space-5);border-bottom:1px solid var(--color-border)}.sidebar-logo-row{justify-content:space-between;align-items:center;display:flex}.sidebar-logo{align-items:center;gap:var(--space-3);display:flex}.sidebar-logo-text{font-size:var(--text-md);color:var(--color-text);letter-spacing:-.3px;font-weight:700}.sidebar-nav{padding:var(--space-4) var(--space-3);flex-direction:column;flex:1;gap:2px;display:flex;overflow-y:auto}.sidebar-link{align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);font-size:var(--text-sm);color:var(--color-text-secondary);transition:background var(--transition), color var(--transition);white-space:nowrap;font-weight:500;display:flex}.sidebar-link:hover{background:var(--color-bg-secondary);color:var(--color-text)}.sidebar-link--active,.sidebar-link--active:hover{background:var(--color-primary-light);color:var(--color-primary)}.sidebar-footer{padding:var(--space-4) var(--space-3);border-top:1px solid var(--color-border);align-items:center;gap:var(--space-3);display:flex}.sidebar-user{align-items:center;gap:var(--space-3);flex:1;min-width:0;display:flex}.sidebar-user-avatar{border-radius:var(--radius-full);background:var(--color-primary);width:32px;height:32px;color:var(--color-text-inverse);font-size:var(--text-sm);flex-shrink:0;justify-content:center;align-items:center;font-weight:600;display:flex}.sidebar-user-info{flex-direction:column;min-width:0;display:flex}.sidebar-user-name{font-size:var(--text-sm);color:var(--color-text);text-overflow:ellipsis;white-space:nowrap;font-weight:500;overflow:hidden}.sidebar-user-role{font-size:var(--text-xs);color:var(--color-text-secondary)}.sidebar-logout{border-radius:var(--radius-md);width:32px;height:32px;color:var(--color-text-secondary);transition:background var(--transition), color var(--transition);flex-shrink:0;justify-content:center;align-items:center;display:flex}.sidebar-logout:hover{background:var(--color-danger-bg);color:var(--color-danger)}.sidebar-lang{padding:var(--space-3) 0 0;gap:4px;display:flex}.sidebar-lang-btn{border-radius:var(--radius-sm);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition);text-align:center;background:0 0;border:1px solid #0000;flex:1;padding:4px 0;font-size:11px;font-weight:600}.sidebar-lang-btn:hover{background:var(--color-bg-secondary);color:var(--color-text)}.sidebar-lang-btn--active{background:var(--color-primary-light);color:var(--color-primary);border-color:var(--color-primary)}.sidebar-close-btn{border-radius:var(--radius-sm);width:28px;height:28px;color:var(--color-text-secondary);cursor:pointer;background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;margin-left:auto;font-size:14px;display:none}.sidebar-close-btn:hover{background:var(--color-bg-secondary);color:var(--color-text)}@media (max-width:768px){.sidebar{z-index:300;height:100vh;transition:transform .25s;position:fixed;top:0;left:0;transform:translate(-100%);box-shadow:2px 0 16px #0000001f}.sidebar--open{transform:translate(0)}.sidebar-close-btn{display:flex}}.layout{background:var(--color-bg-secondary);min-height:100vh;display:flex}.layout-main{min-width:0;padding:var(--space-8);flex:1;overflow-y:auto}.mobile-menu-btn{z-index:200;border-radius:var(--radius-md);background:var(--color-bg);border:1px solid var(--color-border);cursor:pointer;flex-direction:column;justify-content:center;align-items:center;gap:5px;width:40px;height:40px;display:none;position:fixed;top:14px;left:14px;box-shadow:0 1px 4px #00000014}.mobile-menu-btn span{background:var(--color-text);border-radius:2px;width:18px;height:2px;display:block}.sidebar-overlay{z-index:299;background:#00000059;display:none;position:fixed;top:0;bottom:0;left:0;right:0}@media (max-width:768px){.layout-main{padding:var(--space-4);padding-top:64px}.mobile-menu-btn{display:flex}.sidebar-overlay{display:block}}.login-page{background:var(--color-bg-secondary);justify-content:center;align-items:center;min-height:100vh;display:flex}.login-card{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-xl);width:100%;max-width:380px;padding:var(--space-12) var(--space-8);box-shadow:var(--shadow-lg);flex-direction:column;align-items:center;display:flex}.login-logo{margin-bottom:var(--space-5)}.login-title{font-size:var(--text-xl);color:var(--color-text);letter-spacing:-.5px;margin-bottom:var(--space-1);font-weight:700}.login-subtitle{font-size:var(--text-sm);color:var(--color-text-secondary);margin-bottom:var(--space-4)}.login-lang-switcher{margin-bottom:var(--space-6);gap:6px;display:flex}.login-lang-btn{border-radius:var(--radius-sm);font-size:var(--text-sm);color:var(--color-text-secondary);border:1px solid var(--color-border);cursor:pointer;transition:all var(--transition);background:0 0;padding:4px 12px;font-weight:600}.login-lang-btn:hover{background:var(--color-bg-secondary);color:var(--color-text)}.login-lang-btn--active{background:var(--color-primary-light);color:var(--color-primary);border-color:var(--color-primary)}.login-form{gap:var(--space-4);flex-direction:column;width:100%;display:flex}.login-field{gap:var(--space-2);flex-direction:column;display:flex}.login-field label{font-size:var(--text-sm);color:var(--color-text);font-weight:500}.login-field input{width:100%;height:42px;padding:0 var(--space-4);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg);color:var(--color-text);font-size:var(--text-base);transition:border-color var(--transition), box-shadow var(--transition);outline:none}.login-field input::placeholder{color:var(--color-text-placeholder)}.login-field input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.login-field input:disabled{opacity:.5;cursor:not-allowed}.login-error{font-size:var(--text-sm);color:var(--color-danger);text-align:center}.login-submit{background:var(--color-primary);width:100%;height:42px;color:var(--color-text-inverse);border-radius:var(--radius-md);font-size:var(--text-base);margin-top:var(--space-2);transition:background var(--transition), opacity var(--transition);font-weight:500}.login-submit:hover:not(:disabled){background:var(--color-primary-hover)}.login-submit:disabled{opacity:.6;cursor:not-allowed}.page-header{justify-content:space-between;align-items:flex-start;gap:var(--space-4);margin-bottom:var(--space-6);display:flex}.page-header-text{gap:var(--space-1);flex-direction:column;display:flex}.page-header-title{font-size:var(--text-xl);color:var(--color-text);letter-spacing:-.4px;font-weight:700}.page-header-subtitle{font-size:var(--text-sm);color:var(--color-text-secondary)}.page-header-action{align-items:center;gap:var(--space-3);flex-shrink:0;display:flex}.spinner{padding:var(--space-10,40px) var(--space-6,24px);justify-content:center;align-items:center;gap:7px;width:100%;display:flex}.spinner--sm{padding:var(--space-4,16px) var(--space-4,16px);gap:5px}.spinner--lg{padding:var(--space-14,56px) var(--space-6,24px);gap:10px}.spinner-dot{background:var(--color-primary,#22c55e);border-radius:50%;width:9px;height:9px;animation:1.3s cubic-bezier(.45,.05,.55,.95) infinite spinner-pulse;display:block}.spinner--sm .spinner-dot{width:6px;height:6px}.spinner--lg .spinner-dot{width:12px;height:12px}.spinner-dot:first-child{animation-delay:0s}.spinner-dot:nth-child(2){animation-delay:.18s}.spinner-dot:nth-child(3){animation-delay:.36s}@keyframes spinner-pulse{0%,60%,to{opacity:.25;transform:scale(.5)}30%{opacity:1;transform:scale(1)}}.dashboard-page{max-width:1200px}.dashboard-header-actions{align-items:center;gap:var(--space-3);flex-wrap:wrap;display:flex}.btn-export-pdf{background:var(--color-primary);color:#fff;border-radius:var(--radius);font-size:var(--text-sm);cursor:pointer;transition:opacity var(--transition);white-space:nowrap;border:none;align-items:center;gap:6px;padding:7px 14px;font-weight:500;display:inline-flex}.btn-export-pdf:hover:not(:disabled){opacity:.85}.btn-export-pdf:disabled{opacity:.5;cursor:not-allowed}.dashboard-grid{gap:var(--space-4);grid-template-columns:1fr 1fr;display:grid}.dashboard-chart-card,.dashboard-questions-card{grid-column:1/-1}.dashboard-section-title{font-size:var(--text-base);color:var(--color-text);margin-bottom:var(--space-4);font-weight:600}.dashboard-muted{font-size:var(--text-sm);color:var(--color-text-secondary);padding:var(--space-4) 0}.dashboard-chart{align-items:flex-end;height:160px;display:flex}.dashboard-chart-placeholder{width:100%;height:100%;font-size:var(--text-sm);color:var(--color-text-secondary);justify-content:center;align-items:center;display:flex}.bar-chart{align-items:flex-end;gap:6px;width:100%;height:100%;display:flex}.bar-chart-col{align-items:center;gap:var(--space-2);flex-direction:column;flex:1;justify-content:flex-end;height:100%;display:flex}.bar-chart-bar{background:var(--color-primary);width:100%;min-height:4px;transition:opacity var(--transition);border-radius:3px 3px 0 0}.bar-chart-bar:hover{opacity:.8}.bar-chart-label{font-size:var(--text-xs);color:var(--color-text-secondary);white-space:nowrap;text-overflow:ellipsis;max-width:100%;overflow:hidden}.dashboard-rank-list{gap:var(--space-3);flex-direction:column;list-style:none;display:flex}.dashboard-rank-item{align-items:center;gap:var(--space-3);font-size:var(--text-sm);display:flex}.dashboard-rank-num{width:20px;font-size:var(--text-xs);color:var(--color-text-secondary);flex-shrink:0;font-weight:600}.dashboard-rank-label{color:var(--color-text);flex:1}.dashboard-rank-value{color:var(--color-primary);font-weight:600}.dashboard-questions-list{list-style:none}.dashboard-question-item{padding:var(--space-3) 0;border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;gap:var(--space-4);display:flex}.dashboard-question-item:last-child{border-bottom:none}.dashboard-question-text{font-size:var(--text-sm);color:var(--color-text);flex:1}.dashboard-question-count{font-size:var(--text-xs);color:var(--color-text-secondary);flex-shrink:0}@media (max-width:768px){.dashboard-grid{grid-template-columns:1fr!important}.dashboard-grid>*{min-width:0}.dashboard-header-actions{align-items:stretch;gap:var(--space-2);flex-direction:column;width:100%}.period-tabs{-webkit-overflow-scrolling:touch;overflow-x:auto}.btn-export-pdf{justify-content:center;width:100%}.bar-chart-label{font-size:10px}.dashboard-rank-item{gap:var(--space-2)}.dashboard-rank-label{word-break:break-word;min-width:0}.dashboard-rank-value{flex-shrink:0}}@media (max-width:480px){.stats-grid{grid-template-columns:repeat(2,1fr)!important}.stats-grid>*{min-width:0}}.search-input{align-items:center;display:flex;position:relative}.search-input .search-icon{color:var(--color-text-placeholder);pointer-events:none;position:absolute;left:12px}.search-input input{border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg);height:38px;color:var(--color-text);font-size:var(--text-sm);width:260px;transition:border-color var(--transition), box-shadow var(--transition);outline:none;padding:0 36px}.search-input input::placeholder{color:var(--color-text-placeholder)}.search-input input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.search-input-clear{color:var(--color-text-placeholder);transition:color var(--transition);align-items:center;display:flex;position:absolute;right:10px}.search-input-clear:hover{color:var(--color-text)}.badge{border-radius:var(--radius-full);font-size:var(--text-xs);white-space:nowrap;align-items:center;padding:2px 8px;font-weight:500;display:inline-flex}.badge--success{background:var(--color-success-bg);color:var(--color-success)}.badge--warning{background:var(--color-warning-bg);color:var(--color-warning)}.badge--danger{background:var(--color-danger-bg);color:var(--color-danger)}.badge--info{background:var(--color-info-bg);color:var(--color-info)}.badge--neutral{background:var(--color-bg-tertiary);color:var(--color-text-secondary)}.badge--primary{background:var(--color-primary-light);color:var(--color-primary)}.modal-overlay{z-index:1000;padding:var(--space-6);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#00000059;justify-content:center;align-items:center;display:flex;position:fixed;top:0;bottom:0;left:0;right:0}.modal-box{background:var(--color-bg);border-radius:var(--radius-xl);width:100%;box-shadow:var(--shadow-lg);flex-direction:column;max-height:calc(100vh - 48px);display:flex;overflow:hidden}.modal-header{padding:var(--space-6);border-bottom:1px solid var(--color-border);flex-shrink:0;justify-content:space-between;align-items:center;display:flex}.modal-title{font-size:var(--text-md);color:var(--color-text);font-weight:600}.modal-close{border-radius:var(--radius-md);width:32px;height:32px;color:var(--color-text-secondary);transition:background var(--transition), color var(--transition);justify-content:center;align-items:center;display:flex}.modal-close:hover{background:var(--color-bg-secondary);color:var(--color-text)}.modal-body{padding:var(--space-6);overflow-y:auto}.confirm-message{font-size:var(--text-base);color:var(--color-text-secondary);margin-bottom:var(--space-6);line-height:1.6}.confirm-actions{justify-content:flex-end;gap:var(--space-3);display:flex}.empty-state{padding:var(--space-12) var(--space-6);justify-content:center;align-items:center;gap:var(--space-3);text-align:center;flex-direction:column;display:flex}.empty-state-icon{color:var(--color-border-strong);margin-bottom:var(--space-2)}.empty-state-title{font-size:var(--text-base);color:var(--color-text);font-weight:500}.empty-state-desc{font-size:var(--text-sm);color:var(--color-text-secondary);max-width:320px}.empty-state-action{margin-top:var(--space-2)}.institution-name-cell{align-items:center;gap:var(--space-2);display:flex}.institution-logo{border-radius:var(--radius-sm);object-fit:contain;flex-shrink:0;width:24px;height:24px}.institutions-delete-btn{color:var(--color-danger)}.institutions-delete-btn:hover{background:var(--color-danger-bg);color:var(--color-danger)}.inst-cards{display:none}.inst-card{padding:var(--space-4);border-bottom:1px solid var(--color-border);gap:var(--space-2);flex-direction:column;display:flex}.inst-card:last-child{border-bottom:none}.inst-card-name{font-size:var(--text-sm);color:var(--color-text);font-weight:600;line-height:1.4}.inst-card-meta{align-items:center;gap:var(--space-2);flex-wrap:wrap;display:flex}.inst-card-type,.inst-card-city{font-size:var(--text-xs);color:var(--color-text-secondary)}.inst-card-city:before{content:"•";margin-right:var(--space-2)}.inst-card-actions{gap:var(--space-2);margin-top:var(--space-1);flex-wrap:wrap;display:flex}@media (max-width:768px){.inst-cards{display:block}}.managers-page{max-width:1200px}.managers-name-cell{font-weight:500}.managers-email-cell{color:var(--color-text-secondary)}.managers-institutions-cell{white-space:normal;max-width:260px;line-height:1.4}.managers-no-institutions{color:var(--color-text-placeholder)}.managers-success-banner{background:var(--color-success-bg);color:var(--color-success);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);font-size:var(--text-sm);margin-bottom:var(--space-4);border:1px solid #1a7a4a33}.manager-form-checkboxes{gap:var(--space-2);max-height:200px;padding:var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-secondary);flex-direction:column;display:flex;overflow-y:auto}.manager-form-checkbox-item{align-items:center;gap:var(--space-2);font-size:var(--text-sm);cursor:pointer;padding:var(--space-1) 0;display:flex}.manager-form-checkbox-item input[type=checkbox]{cursor:pointer;width:16px;height:16px;accent-color:var(--color-primary);flex-shrink:0}.manager-form-empty{font-size:var(--text-sm);color:var(--color-text-secondary);padding:var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-secondary)}.ai-prompt-page{max-width:1200px}.ai-prompt-loading{padding:var(--space-8);text-align:center;color:var(--color-text-secondary);font-size:var(--text-sm)}.ai-prompt-layout{gap:var(--space-4);grid-template-columns:1fr 320px;align-items:start;display:grid}.ai-prompt-main{gap:var(--space-4);flex-direction:column;display:flex}.ai-prompt-sidebar{top:var(--space-6);position:-webkit-sticky;position:sticky}.ai-prompt-section-title{font-size:var(--text-base);color:var(--color-text);margin-bottom:var(--space-3);font-weight:600}.ai-prompt-muted{font-size:var(--text-sm);color:var(--color-text-secondary)}.ai-prompt-readonly-hint{margin-bottom:var(--space-3)}.ai-prompt-textarea{min-height:220px;font-family:var(--font-mono);font-size:var(--text-sm);resize:vertical;line-height:1.6}.ai-prompt-preview{background:var(--color-bg-secondary);min-height:300px;color:var(--color-text-secondary)}.ai-prompt-success{font-size:var(--text-sm);color:var(--color-success);margin-top:var(--space-3)}.ai-prompt-error{font-size:var(--text-sm);color:var(--color-danger,#ef4444);margin-top:var(--space-3)}.ai-prompt-editor-actions{justify-content:flex-end;gap:var(--space-3);margin-top:var(--space-4);padding-top:var(--space-4);border-top:1px solid var(--color-border);display:flex}.ai-prompt-test-row{gap:var(--space-3);display:flex}.ai-prompt-test-row .form-input{flex:1}.ai-prompt-test-response{margin-top:var(--space-4);padding:var(--space-4);background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md)}.ai-prompt-test-response-label{font-size:var(--text-xs);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:var(--space-2);font-weight:600}.ai-prompt-test-response-text{font-size:var(--text-sm);color:var(--color-text);white-space:pre-wrap;line-height:1.6}.ai-prompt-history-list{flex-direction:column;gap:0;list-style:none;display:flex}.ai-prompt-history-item{gap:var(--space-1);padding:var(--space-3) 0;border-bottom:1px solid var(--color-border);flex-direction:column;display:flex}.ai-prompt-history-item:last-child{border-bottom:none}.ai-prompt-history-meta{align-items:center;gap:var(--space-2);display:flex}.ai-prompt-history-version{font-size:var(--text-sm);color:var(--color-text);font-weight:600}.ai-prompt-history-date,.ai-prompt-history-author{font-size:var(--text-xs);color:var(--color-text-secondary)}.ai-prompt-revert-btn{margin-top:var(--space-1);color:var(--color-danger);align-self:flex-start}.ai-prompt-revert-btn:hover:not(:disabled){background:var(--color-danger-bg);color:var(--color-danger)}.ai-prompt-history-item--current{background:var(--color-bg-secondary);border-radius:var(--radius-sm);padding-left:var(--space-2);padding-right:var(--space-2)}.ai-prompt-current-badge{font-size:var(--text-xs);color:var(--color-success);background:var(--color-success-bg,#dcfce7);border-radius:10px;padding:1px 6px;font-weight:500}.ai-prompt-revert-badge{font-size:var(--text-xs);color:var(--color-text-secondary);margin-left:var(--space-1);font-weight:400}@media (max-width:768px){.ai-prompt-layout{grid-template-columns:1fr}.ai-prompt-sidebar{position:static}.ai-prompt-test-row{flex-direction:column}.ai-prompt-test-row .btn{justify-content:center;width:100%}.ai-prompt-editor-actions{flex-direction:column}.ai-prompt-editor-actions .btn{justify-content:center;width:100%}}.dialog-logs-page{gap:var(--spacing-6);flex-direction:column;display:flex}.dialog-date{white-space:nowrap;color:var(--color-text-secondary);font-size:var(--font-size-sm)}.dialog-attention-icon{color:var(--color-warning);display:inline-flex}.dialog-delete-btn{color:var(--color-danger)}.dialog-delete-btn:hover{background:var(--color-danger-bg)}.dialog-chat{gap:var(--spacing-3);max-height:520px;padding:var(--spacing-2) 0;flex-direction:column;display:flex;overflow-y:auto}.dialog-chat-empty{text-align:center;color:var(--color-text-secondary);padding:var(--spacing-8) 0}.dialog-message{gap:var(--spacing-1);flex-direction:column;display:flex}.dialog-message--user{align-items:flex-end}.dialog-message--bot{align-items:flex-start}.dialog-message-bubble{max-width:72%;padding:var(--spacing-3) var(--spacing-4);border-radius:var(--radius-lg);gap:var(--spacing-2);flex-direction:column;display:flex}.dialog-message--user .dialog-message-bubble{background:var(--color-primary);color:#fff;border-bottom-right-radius:var(--radius-sm)}.dialog-message--user .dialog-message-text{color:#fff}.dialog-message--bot .dialog-message-bubble{background:var(--color-surface-secondary);color:var(--color-text-primary);border-bottom-left-radius:var(--radius-sm)}.dialog-message-text{font-size:var(--font-size-sm);margin:0;line-height:1.5}.dialog-message-type{display:flex}.dialog-message-time{font-size:var(--font-size-xs);color:var(--color-text-tertiary);padding:0 var(--spacing-1)}.institution-requests-page{gap:var(--spacing-6);flex-direction:column;display:flex}.ireq-text-cell{max-width:360px;color:var(--color-text-secondary);font-size:var(--font-size-sm)}.ireq-date{white-space:nowrap;color:var(--color-text-secondary);font-size:var(--font-size-sm)}.ireq-reject-btn{color:var(--color-danger)}.ireq-reject-btn:hover{background:var(--color-danger-bg)}.tabs{border-bottom:1px solid var(--color-border);margin-bottom:var(--space-6);gap:0;display:flex}.tabs-item{align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);font-size:var(--text-sm);color:var(--color-text-secondary);transition:color var(--transition), border-color var(--transition);border-bottom:2px solid #0000;margin-bottom:-1px;font-weight:500;display:flex}.tabs-item:hover{color:var(--color-text)}.tabs-item--active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.tabs-count{background:var(--color-bg-tertiary);color:var(--color-text-secondary);font-size:var(--text-xs);border-radius:var(--radius-full);padding:1px 6px;font-weight:500}.tabs-item--active .tabs-count{background:var(--color-primary-light);color:var(--color-primary)}.user-profiles-page{gap:var(--spacing-6);flex-direction:column;display:flex}.up-name-cell{font-weight:var(--font-weight-medium)}.up-tg-cell{font-family:var(--font-mono,monospace);font-size:var(--font-size-sm);color:var(--color-text-secondary)}.up-institutions-cell{max-width:200px;font-size:var(--font-size-sm);color:var(--color-text-secondary)}.up-date-cell{white-space:nowrap;color:var(--color-text-secondary);font-size:var(--font-size-sm)}.up-block-btn{color:var(--color-danger)}.up-block-btn:hover{background:var(--color-danger-bg)}.up-profile{gap:var(--spacing-5);flex-direction:column;display:flex}.up-profile-info{gap:var(--spacing-3);padding-bottom:var(--spacing-4);border-bottom:1px solid var(--color-border);flex-direction:column;display:flex}.up-profile-row{gap:var(--spacing-4);align-items:baseline;display:flex}.up-profile-label{width:120px;font-size:var(--font-size-sm);color:var(--color-text-secondary);flex-shrink:0}.up-profile-value{font-size:var(--font-size-sm);color:var(--color-text-primary)}.up-profile-tags{gap:var(--spacing-2);flex-wrap:wrap;display:flex}.up-profile-tab-content{min-height:120px}.up-empty-list{color:var(--color-text-secondary);font-size:var(--font-size-sm);padding:var(--spacing-4) 0}.up-dialogs-list,.up-applications-list{gap:var(--spacing-2);flex-direction:column;margin:0;padding:0;list-style:none;display:flex}.up-dialog-item{gap:var(--spacing-4);padding:var(--spacing-2) var(--spacing-3);background:var(--color-surface-secondary);border-radius:var(--radius-md);align-items:baseline;display:flex}.up-dialog-date{font-size:var(--font-size-xs);color:var(--color-text-tertiary);flex-shrink:0}.up-dialog-preview{font-size:var(--font-size-sm);color:var(--color-text-secondary);text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.up-application-item{padding:var(--spacing-2) var(--spacing-3);background:var(--color-surface-secondary);border-radius:var(--radius-md);justify-content:space-between;align-items:center;display:flex}.up-app-name{font-size:var(--font-size-sm);color:var(--color-text-primary)}.up-app-date{font-size:var(--font-size-xs);color:var(--color-text-tertiary)}.support-page{gap:var(--spacing-6);flex-direction:column;display:flex}.support-preview-cell{max-width:360px;color:var(--color-text-secondary);font-size:var(--font-size-sm)}.support-date{white-space:nowrap;color:var(--color-text-secondary);font-size:var(--font-size-sm)}.support-modal-content{gap:var(--spacing-5);flex-direction:column;display:flex}.support-modal-meta{gap:var(--spacing-3);padding-bottom:var(--spacing-4);border-bottom:1px solid var(--color-border);flex-direction:column;display:flex}.support-modal-row{gap:var(--spacing-4);align-items:center;display:flex}.support-modal-label{width:110px;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);margin:0 0 var(--spacing-2);flex-shrink:0}.support-modal-message{gap:var(--spacing-2);flex-direction:column;display:flex}.support-modal-text{font-size:var(--font-size-sm);color:var(--color-text-primary);white-space:pre-wrap;background:var(--color-surface-secondary);border-radius:var(--radius-md);padding:var(--spacing-4);margin:0;line-height:1.6}.support-modal-actions{gap:var(--spacing-3);padding-top:var(--spacing-2);border-top:1px solid var(--color-border);flex-direction:column;display:flex}.support-status-buttons{gap:var(--spacing-3);display:flex}.specialties-page{gap:var(--space-6);flex-direction:column;display:flex}.faculty-list{gap:var(--space-3);flex-direction:column;display:flex}.faculty-item{border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-bg);overflow:hidden}.faculty-item--open{border-color:var(--color-primary-border)}.faculty-row{padding:var(--space-4) var(--space-5);align-items:center;gap:var(--space-3);display:flex}.faculty-toggle{align-items:center;gap:var(--space-3);color:var(--color-text);font-size:var(--text-base);text-align:left;flex:1;font-weight:500;display:flex}.faculty-toggle:hover{color:var(--color-primary)}.faculty-name{flex:1}.faculty-body{border-top:1px solid var(--color-border);background:var(--color-bg-secondary);padding:var(--space-4) var(--space-5);gap:var(--space-4);flex-direction:column;display:flex}.faculty-body-toolbar{justify-content:space-between;align-items:center;display:flex}.faculty-specialty-count{font-size:var(--text-sm);color:var(--color-text-secondary)}.specialty-empty{justify-content:center;align-items:center;gap:var(--space-3);padding:var(--space-6);color:var(--color-text-secondary);font-size:var(--text-sm);display:flex}.specialties-delete-btn{color:var(--color-danger)}.specialties-delete-btn:hover:not(:disabled){background:var(--color-danger-bg);color:var(--color-danger)}.kb-page{gap:var(--space-6);flex-direction:column;display:flex}.kb-header-actions{gap:var(--space-3);display:flex}.kb-section{gap:var(--space-3);flex-direction:column;display:flex}.kb-material-list{gap:var(--space-2);flex-direction:column;display:flex}.kb-material-item{align-items:center;gap:var(--space-4);padding:var(--space-4) var(--space-5);background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-lg);transition:border-color var(--transition);display:flex}.kb-material-item:hover{border-color:var(--color-border-strong)}.kb-material-icon{background:var(--color-bg-secondary);border-radius:var(--radius-md);width:40px;height:40px;color:var(--color-text-secondary);flex-shrink:0;justify-content:center;align-items:center;display:flex}.kb-material-info{gap:var(--space-1);flex-direction:column;flex:1;min-width:0;display:flex}.kb-material-title{font-size:var(--text-sm);color:var(--color-text);white-space:nowrap;text-overflow:ellipsis;font-weight:500;overflow:hidden}.kb-material-meta{align-items:center;gap:var(--space-2);display:flex}.kb-material-date{font-size:var(--text-xs);color:var(--color-text-secondary)}.kb-delete-btn{color:var(--color-danger);flex-shrink:0}.kb-delete-btn:hover:not(:disabled){background:var(--color-danger-bg);color:var(--color-danger)}.kb-faq-list{gap:var(--space-2);flex-direction:column;display:flex}.kb-faq-item{align-items:flex-start;gap:var(--space-4);padding:var(--space-4) var(--space-5);background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-lg);display:flex}.kb-faq-content{flex:1;min-width:0}.kb-faq-question{font-size:var(--text-sm);color:var(--color-text);margin-bottom:var(--space-1);font-weight:500}.kb-faq-answer{font-size:var(--text-sm);color:var(--color-text-secondary);-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.kb-faq-actions{align-items:center;gap:var(--space-2);flex-shrink:0;display:flex}.kb-toggle{cursor:pointer;align-items:center;display:inline-flex;position:relative}.kb-toggle input{opacity:0;width:0;height:0;position:absolute}.kb-toggle-track{background:var(--color-border-strong);border-radius:var(--radius-full);width:36px;height:20px;transition:background var(--transition);position:relative}.kb-toggle-track:after{content:"";background:var(--color-bg);border-radius:var(--radius-full);width:16px;height:16px;transition:transform var(--transition);box-shadow:var(--shadow-sm);position:absolute;top:2px;left:2px}.kb-toggle input:checked+.kb-toggle-track{background:var(--color-primary)}.kb-toggle input:checked+.kb-toggle-track:after{transform:translate(16px)}.kb-file-input{height:auto;padding:var(--space-3) var(--space-4);cursor:pointer}@media (max-width:768px){.kb-faq-item{gap:var(--space-3);flex-direction:column}.kb-faq-actions{align-self:flex-start}.kb-material-item{flex-wrap:wrap}.kb-material-info{flex:60%}}.deadlines-page{gap:var(--space-6);flex-direction:column;display:flex}.deadlines-delete-btn{color:var(--color-danger)}.deadlines-delete-btn:hover:not(:disabled){background:var(--color-danger-bg);color:var(--color-danger)}.deadline-audience{gap:var(--space-5);display:flex}.deadline-radio{align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--color-text);cursor:pointer;display:flex}.broadcasts-page{gap:var(--space-6);flex-direction:column;display:flex}.broadcasts-text-cell{white-space:nowrap;text-overflow:ellipsis;max-width:320px;overflow:hidden}.broadcasts-delete-btn{color:var(--color-danger)}.broadcasts-delete-btn:hover:not(:disabled){background:var(--color-danger-bg);color:var(--color-danger)}.broadcast-textarea{min-height:140px}.broadcast-options{gap:var(--space-2);flex-direction:column;display:flex}.broadcast-radio{align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--color-text);cursor:pointer;display:flex}.broadcast-checkboxes{gap:var(--space-2);padding:var(--space-3);background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);flex-direction:column;max-height:180px;display:flex;overflow-y:auto}.broadcast-checkbox{align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--color-text);cursor:pointer;display:flex}.broadcast-preview{padding:var(--space-3) var(--space-4);background:var(--color-info-bg);border:1px solid var(--color-info);border-radius:var(--radius-md);font-size:var(--text-sm);color:var(--color-info)}.applications-page{gap:var(--space-6);flex-direction:column;display:flex}.applications-name-cell{font-weight:500}.applications-reject-btn{color:var(--color-danger)}.applications-reject-btn:hover:not(:disabled){background:var(--color-danger-bg);color:var(--color-danger)}.applications-comment-cell{white-space:nowrap;text-overflow:ellipsis;max-width:220px;color:var(--color-text-secondary);overflow:hidden}.manager-users-page{gap:var(--space-6);flex-direction:column;display:flex}.manager-users-name{font-weight:500}.manager-users-tg{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--color-text-secondary)}.manager-users-block-btn{color:var(--color-danger)}.manager-users-block-btn:hover:not(:disabled){background:var(--color-danger-bg);color:var(--color-danger)}.support-message-cell{white-space:nowrap;text-overflow:ellipsis;max-width:240px;color:var(--color-text-secondary);overflow:hidden}.user-profile-modal{gap:var(--space-4);flex-direction:column;display:flex}.user-profile-row{font-size:var(--text-sm);padding-bottom:var(--space-3);border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;display:flex}.user-profile-row:last-child{border-bottom:none}.user-profile-label{font-size:var(--text-sm);color:var(--color-text-secondary);font-weight:500}.user-profile-applications{gap:var(--space-2);flex-direction:column;display:flex}.user-profile-app-list{gap:var(--space-2);padding:var(--space-3);background:var(--color-bg-secondary);border-radius:var(--radius-md);flex-direction:column;display:flex}.user-profile-app-item{font-size:var(--text-sm);justify-content:space-between;align-items:center;display:flex}.support-modal{gap:var(--space-4);flex-direction:column;display:flex}.support-full-message{gap:var(--space-2);padding:var(--space-4);background:var(--color-bg-secondary);border-radius:var(--radius-md);font-size:var(--text-sm);flex-direction:column;line-height:1.6;display:flex}
