@import url(https://fonts.googleapis.com/css2?family=Be+Vietnam+Pro:wght@400;500;600;700;800&display=swap);*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--sidebar-w:260px;--topbar-h:60px;--blue:#1a73e8;--blue-d:#1557b0;--blue-l:#e8f0fe;--sidebar-bg:#0f1f3d;--sidebar-active:#1e3a6e;--sidebar-text:#a0b0cc;--sidebar-text-active:#fff;--orange:#f59e0b;--orange-l:#fffbeb;--green:#10b981;--green-l:#ecfdf5;--red:#ef4444;--teal:#06b6d4;--gray-50:#f8fafc;--gray-100:#f1f5f9;--gray-200:#e2e8f0;--gray-300:#cbd5e1;--gray-400:#94a3b8;--gray-500:#64748b;--gray-700:#334155;--gray-900:#0f172a;--white:#fff;--font:"Be Vietnam Pro",sans-serif;--r:8px;--rlg:12px;--rxl:16px;--shadow:0 1px 3px #00000014,0 1px 2px #0000000f;--shadow-md:0 4px 16px #0000001a}body{background:#f8fafc;background:var(--gray-50);color:#0f172a;color:var(--gray-900);font-family:Be Vietnam Pro,sans-serif;font-family:var(--font);font-size:14px;line-height:1.6}a{color:inherit;text-decoration:none}button,input,select,textarea{font-family:Be Vietnam Pro,sans-serif;font-family:var(--font)}.layout{display:flex;min-height:100vh}.sidebar{background:#0f1f3d;background:var(--sidebar-bg);bottom:0;display:flex;flex-direction:column;left:0;overflow-x:hidden;overflow-y:auto;position:fixed;scrollbar-width:none;top:0;transition:width .25s ease,transform .25s ease;width:260px;z-index:100}.sidebar::-webkit-scrollbar{display:none}.sidebar-brand{align-items:center;border-bottom:1px solid #ffffff14;display:flex;gap:10px;padding:18px 20px 16px}.sidebar-brand img{background:#fff;border-radius:8px;border-radius:var(--r);height:36px;object-fit:contain;padding:3px;width:36px}.sidebar-brand-text{line-height:1.2}.sidebar-brand-name{color:#fff;font-size:15px;font-weight:700}.sidebar-brand-sub{color:#a0b0cc;color:var(--sidebar-text);font-size:11px}.sidebar-section{padding:16px 12px 4px}.sidebar-section-label{color:#a0b0cc80;font-size:10px;font-weight:700;letter-spacing:1px;margin-bottom:6px;padding:0 8px;text-transform:uppercase}.sidebar-item{align-items:center;background:none;border:none;border-radius:8px;border-radius:var(--r);color:#a0b0cc;color:var(--sidebar-text);cursor:pointer;display:flex;font-size:13.5px;font-weight:500;gap:10px;margin-bottom:2px;padding:9px 12px;text-align:left;transition:all .15s;width:100%}.sidebar-item:hover{background:#ffffff12;color:#fff}.sidebar-item.active{background:#1a73e8;background:var(--blue);color:#fff}.sidebar-item i{flex-shrink:0;font-size:17px;opacity:.8}.sidebar-item.active i{opacity:1}.sidebar-footer{border-top:1px solid #ffffff14;margin-top:auto;padding:12px}.sidebar-user{background:#ffffff0f;border-radius:8px;border-radius:var(--r);gap:10px;margin-bottom:8px;padding:10px 12px}.sidebar-avatar,.sidebar-user{align-items:center;display:flex}.sidebar-avatar{background:#1a73e8;background:var(--blue);border-radius:50%;color:#fff;flex-shrink:0;font-size:13px;font-weight:700;height:34px;justify-content:center;width:34px}.sidebar-user-name{color:#fff;font-size:13px;font-weight:600}.sidebar-user-role{color:#a0b0cc;color:var(--sidebar-text);font-size:11px}.main{display:flex;flex:1 1;flex-direction:column;margin-left:0;transition:margin-left .25s ease}.topbar{align-items:center;background:#fff;background:var(--white);border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--gray-200);box-shadow:0 1px 3px #00000014,0 1px 2px #0000000f;box-shadow:var(--shadow);display:flex;gap:12px;height:60px;height:var(--topbar-h);padding:0 24px;position:-webkit-sticky;position:sticky;top:0;z-index:50}.topbar-toggle{background:none;border:none;border-radius:8px;border-radius:var(--r);color:#64748b;color:var(--gray-500);cursor:pointer;padding:6px}.topbar-toggle:hover{background:#f1f5f9;background:var(--gray-100)}.topbar-toggle i{font-size:20px}.topbar-search{align-items:center;background:#f8fafc;background:var(--gray-50);border:1.5px solid #e2e8f0;border:1.5px solid var(--gray-200);border-radius:24px;display:flex;flex:1 1;gap:8px;max-width:480px;padding:7px 16px;transition:border-color .15s}.topbar-search:focus-within{background:#fff;background:var(--white);border-color:#1a73e8;border-color:var(--blue)}.topbar-search i{color:#94a3b8;color:var(--gray-400);font-size:16px}.topbar-search input{background:none;border:none;color:#334155;color:var(--gray-700);font-size:13.5px;outline:none;width:100%}.topbar-search input::placeholder{color:#94a3b8;color:var(--gray-400)}.topbar-right{gap:10px;margin-left:auto}.topbar-lang,.topbar-right{align-items:center;display:flex}.topbar-lang{background:#f1f5f9;background:var(--gray-100);border:none;border-radius:8px;border-radius:var(--r);color:#334155;color:var(--gray-700);cursor:pointer;font-size:12px;font-weight:600;gap:5px;padding:6px 10px}.topbar-notif{background:none;border:none;border-radius:50%;color:#64748b;color:var(--gray-500);cursor:pointer;padding:6px;position:relative}.topbar-notif:hover{background:#f1f5f9;background:var(--gray-100)}.topbar-notif i{font-size:20px}.notif-badge{background:#ef4444;background:var(--red);border:2px solid #fff;border:2px solid var(--white);border-radius:50%;font-size:10px;font-weight:700;height:18px;justify-content:center;position:absolute;right:2px;top:2px;width:18px}.notif-badge,.topbar-login{align-items:center;color:#fff;display:flex}.topbar-login{background:#1a73e8;background:var(--blue);border:none;border-radius:24px;cursor:pointer;font-size:13px;font-weight:600;gap:6px;padding:8px 16px;transition:background .15s}.topbar-login:hover{background:#1557b0;background:var(--blue-d)}.topbar-login i{font-size:15px}.page{flex:1 1;padding:24px}.hero-banner{background:linear-gradient(135deg,#1565c0,#1976d2 40%,#0288d1);border-radius:16px;border-radius:var(--rxl);margin-bottom:20px;overflow:hidden;padding:36px 40px;position:relative}.hero-banner:before{background:#ffffff0f;height:300px;right:-60px;top:-60px;width:300px}.hero-banner:after,.hero-banner:before{border-radius:50%;content:"";position:absolute}.hero-banner:after{background:#ffffff0a;bottom:-80px;height:200px;right:80px;width:200px}.hero-tag{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#ffffff26;border-radius:20px;color:#ffffffe6;display:inline-flex;font-size:12px;font-weight:600;gap:6px;margin-bottom:14px;padding:5px 12px}.hero-title{color:#fff;font-size:28px;font-weight:700;margin-bottom:4px}.hero-subtitle{color:#f59e0b;color:var(--orange);font-size:22px;font-weight:800;margin-bottom:10px}.hero-desc{color:#fffc;font-size:14px;margin-bottom:24px;max-width:520px}.hero-actions{display:flex;flex-wrap:wrap;gap:12px}.btn-hero-primary{align-items:center;background:#f59e0b;background:var(--orange);border:none;border-radius:24px;box-shadow:0 4px 12px #f59e0b66;color:#fff;color:var(--white);cursor:pointer;display:inline-flex;font-size:14px;font-weight:700;gap:6px;padding:11px 22px;transition:all .15s}.btn-hero-primary:hover{background:#e08e00;transform:translateY(-1px)}.btn-hero-secondary{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#ffffff26;border:1.5px solid #ffffff4d;border-radius:24px;color:#fff;cursor:pointer;display:inline-flex;font-size:14px;font-weight:700;gap:6px;padding:11px 22px;transition:all .15s}.btn-hero-secondary:hover{background:#ffffff40}.stats-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(4,1fr);margin-bottom:28px}.stat-card{align-items:flex-start;background:#fff;background:var(--white);border:1px solid #e2e8f0;border:1px solid var(--gray-200);border-radius:12px;border-radius:var(--rlg);box-shadow:0 1px 3px #00000014,0 1px 2px #0000000f;box-shadow:var(--shadow);display:flex;justify-content:space-between;padding:18px 20px}.stat-card-label{color:#94a3b8;color:var(--gray-400);font-size:10px;font-weight:700;letter-spacing:.5px;margin-bottom:8px;text-transform:uppercase}.stat-card-value{color:#0f172a;color:var(--gray-900);font-size:24px;font-weight:800}.stat-card-icon{align-items:center;border-radius:50%;display:flex;flex-shrink:0;font-size:20px;height:42px;justify-content:center;width:42px}.stat-icon-blue{background:#e8f0fe;background:var(--blue-l);color:#1a73e8;color:var(--blue)}.stat-icon-orange{background:#fffbeb;background:var(--orange-l);color:#f59e0b;color:var(--orange)}.stat-icon-green{background:#ecfdf5;background:var(--green-l);color:#10b981;color:var(--green)}.stat-icon-teal{background:#e0f7fa;color:#06b6d4;color:var(--teal)}.home-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 340px;min-width:0}.home-grid>*{min-width:0;overflow:hidden}.section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.section-title{color:#0f172a;color:var(--gray-900);font-size:17px;font-weight:700}.section-link{align-items:center;background:none;border:none;color:#1a73e8;color:var(--blue);cursor:pointer;display:flex;font-size:13px;font-weight:600;gap:4px}.section-link:hover{text-decoration:underline}.quick-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(3,1fr);margin-bottom:24px}.quick-card{background:#fff;background:var(--white);border:1px solid #e2e8f0;border:1px solid var(--gray-200);border-radius:12px;border-radius:var(--rlg);box-shadow:0 1px 3px #00000014,0 1px 2px #0000000f;box-shadow:var(--shadow);cursor:pointer;padding:16px;text-align:center;transition:all .15s}.quick-card:hover{border-color:#1a73e8;border-color:var(--blue);box-shadow:0 4px 16px #0000001a;box-shadow:var(--shadow-md);transform:translateY(-2px)}.quick-card-icon{display:block;font-size:28px;margin-bottom:8px}.quick-card h4{color:#334155;color:var(--gray-700);font-size:13px;font-weight:600}.news-card{background:#fff;background:var(--white);border:1px solid #e2e8f0;border:1px solid var(--gray-200);border-radius:12px;border-radius:var(--rlg);box-shadow:0 1px 3px #00000014,0 1px 2px #0000000f;box-shadow:var(--shadow);overflow:hidden;transition:box-shadow .15s}.news-card:hover{box-shadow:0 4px 16px #0000001a;box-shadow:var(--shadow-md)}.news-card-img{background:linear-gradient(135deg,#e8f0fe,#1a73e8);background:linear-gradient(135deg,var(--blue-l),var(--blue));height:200px;object-fit:cover;width:100%}.news-card-img-placeholder{align-items:center;background:linear-gradient(135deg,#1565c0,#0288d1);display:flex;font-size:60px;height:200px;justify-content:center;width:100%}.news-card-body{padding:16px}.news-card-meta{align-items:center;display:flex;gap:8px;margin-bottom:8px}.news-card-tag{border-radius:20px;display:inline-block;font-size:11px;font-weight:700;padding:2px 10px}.tag-blue{background:#e8f0fe;background:var(--blue-l);color:#1557b0;color:var(--blue-d)}.tag-green{background:#ecfdf5;background:var(--green-l);color:#065f46}.tag-orange{background:#fffbeb;background:var(--orange-l);color:#92400e}.tag-red{background:#fee2e2;color:#991b1b}.news-card-date{color:#94a3b8;color:var(--gray-400);font-size:12px}.news-card-title{font-size:16px;font-weight:700;line-height:1.4;margin-bottom:8px}.news-card-excerpt{-webkit-line-clamp:3;-webkit-box-orient:vertical;color:#64748b;color:var(--gray-500);display:-webkit-box;font-size:13px;line-height:1.6;overflow:hidden;overflow-wrap:break-word;word-break:break-word}.news-list-item{border-bottom:1px solid #f1f5f9;border-bottom:1px solid var(--gray-100);cursor:pointer;padding:14px 0}.news-list-item:last-child{border-bottom:none}.news-list-item:hover .news-list-title{color:#1a73e8;color:var(--blue)}.news-list-title{font-size:14px;font-weight:600;margin-bottom:4px;transition:color .12s}.news-list-meta{color:#94a3b8;color:var(--gray-400);display:flex;font-size:12px;gap:8px}.widget{background:#fff;background:var(--white);border:1px solid #e2e8f0;border:1px solid var(--gray-200);border-radius:12px;border-radius:var(--rlg);box-shadow:0 1px 3px #00000014,0 1px 2px #0000000f;box-shadow:var(--shadow);margin-bottom:16px;padding:18px}.event-item{border-bottom:1px solid #f1f5f9;border-bottom:1px solid var(--gray-100);display:flex;gap:14px;padding:10px 0}.event-item:last-child{border-bottom:none}.event-date-box{align-items:center;background:#e8f0fe;background:var(--blue-l);border-radius:8px;border-radius:var(--r);display:flex;flex-direction:column;flex-shrink:0;height:50px;justify-content:center;width:44px}.event-day{color:#1a73e8;color:var(--blue);font-size:18px;font-weight:800;line-height:1}.event-month{color:#1557b0;color:var(--blue-d);font-size:10px;font-weight:600;text-transform:uppercase}.event-info h5{font-size:13px;font-weight:600;line-height:1.3;margin-bottom:3px}.event-info p{color:#94a3b8;color:var(--gray-400);font-size:12px}.help-widget{background:linear-gradient(135deg,#1e3a6e,#0f1f3d);border-radius:12px;border-radius:var(--rlg);color:#fff;color:var(--white);padding:20px}.help-widget-icon{color:#f59e0b;color:var(--orange);display:block;font-size:24px;margin-bottom:8px}.help-widget h4{font-size:15px;font-weight:700;margin-bottom:6px}.help-widget p{color:#ffffffb3;font-size:12px;margin-bottom:14px}.btn{align-items:center;border:none;border-radius:8px;border-radius:var(--r);cursor:pointer;display:inline-flex;font-family:Be Vietnam Pro,sans-serif;font-family:var(--font);font-size:13px;font-weight:600;gap:6px;padding:8px 18px;transition:all .15s}.btn:disabled{cursor:not-allowed;opacity:.5}.btn-primary{background:#1a73e8;background:var(--blue);color:#fff}.btn-primary:hover{background:#1557b0;background:var(--blue-d)}.btn-secondary{background:#f1f5f9;background:var(--gray-100);border:1px solid #e2e8f0;border:1px solid var(--gray-200);color:#334155;color:var(--gray-700)}.btn-secondary:hover{background:#e2e8f0;background:var(--gray-200)}.btn-white{background:#fff;background:var(--white);border:1px solid #e2e8f0;border:1px solid var(--gray-200);color:#334155;color:var(--gray-700)}.btn-white:hover{background:#f8fafc;background:var(--gray-50)}.btn-outline{background:#0000;border:1.5px solid #1a73e8;border:1.5px solid var(--blue);color:#1a73e8;color:var(--blue)}.btn-danger{background:#fee2e2;border:1px solid #fecaca;color:#991b1b}.btn-success{background:#ecfdf5;background:var(--green-l);border:1px solid #a7f3d0;color:#065f46}.btn-orange{background:#f59e0b;background:var(--orange);color:#fff}.btn-orange:hover{background:#e08e00}.btn-sm{border-radius:8px;border-radius:var(--r);font-size:12px;padding:5px 12px}.btn-lg{font-size:15px;padding:12px 28px}.btn-full{justify-content:center;width:100%}.btn-round{border-radius:24px}.form-group{margin-bottom:16px}.form-label{color:#334155;color:var(--gray-700);display:block;font-size:12px;font-weight:700;letter-spacing:.3px;margin-bottom:6px;text-transform:uppercase}.form-input{background:#fff;background:var(--white);border:1.5px solid #e2e8f0;border:1.5px solid var(--gray-200);border-radius:8px;border-radius:var(--r);color:#0f172a;color:var(--gray-900);font-size:14px;outline:none;padding:10px 14px;transition:border-color .15s;width:100%}.form-input:focus{border-color:#1a73e8;border-color:var(--blue);box-shadow:0 0 0 3px #1a73e81a}.form-input::placeholder{color:#94a3b8;color:var(--gray-400)}textarea.form-input{line-height:1.6;min-height:90px;resize:vertical}select.form-input{cursor:pointer}.form-row{grid-gap:14px;display:grid;gap:14px;grid-template-columns:1fr 1fr}.alert{align-items:flex-start;border-radius:8px;border-radius:var(--r);display:flex;font-size:13px;gap:8px;margin-bottom:16px;padding:12px 16px}.alert i{flex-shrink:0;font-size:16px;margin-top:1px}.alert-info{background:#e8f0fe;background:var(--blue-l);border:1px solid #c2d9f8;color:#1557b0;color:var(--blue-d)}.alert-success{background:#ecfdf5;background:var(--green-l);border:1px solid #a7f3d0;color:#065f46}.alert-danger{background:#fee2e2;border:1px solid #fecaca;color:#991b1b}.alert-warning{background:#fffbeb;background:var(--orange-l);border:1px solid #fde68a;color:#92400e}.badge{border-radius:20px;display:inline-block;font-size:11px;font-weight:700;padding:2px 9px}.badge-blue{background:#e8f0fe;background:var(--blue-l);color:#1557b0;color:var(--blue-d)}.badge-green{background:#dcfce7;color:#166534}.badge-orange{background:#fffbeb;background:var(--orange-l);color:#92400e}.badge-red{background:#fee2e2;color:#991b1b}.badge-gray{background:#f1f5f9;background:var(--gray-100);color:#64748b;color:var(--gray-500)}.badge-teal{background:#e0f7fa;color:#00695c}.card{background:#fff;background:var(--white);border:1px solid #e2e8f0;border:1px solid var(--gray-200);border-radius:12px;border-radius:var(--rlg);box-shadow:0 1px 3px #00000014,0 1px 2px #0000000f;box-shadow:var(--shadow);padding:20px}.card-header{border-bottom:1px solid #f1f5f9;border-bottom:1px solid var(--gray-100);justify-content:space-between;margin-bottom:16px;padding-bottom:14px}.card-header,.card-title{align-items:center;display:flex}.card-title{font-size:16px;font-weight:700;gap:8px}.tabs{border-bottom:2px solid #e2e8f0;border-bottom:2px solid var(--gray-200);display:flex;gap:2px;margin-bottom:20px}.tab{background:none;border:none;border-bottom:3px solid #0000;color:#94a3b8;color:var(--gray-400);cursor:pointer;font-size:13px;font-weight:600;margin-bottom:-2px;padding:9px 16px;transition:all .15s}.tab.active,.tab:hover{color:#1a73e8;color:var(--blue)}.tab.active{border-bottom-color:#1a73e8;border-bottom-color:var(--blue)}.survey-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(2,1fr)}.survey-card{background:#fff;background:var(--white);border:1px solid #e2e8f0;border:1px solid var(--gray-200);border-radius:12px;border-radius:var(--rlg);box-shadow:0 1px 3px #00000014,0 1px 2px #0000000f;box-shadow:var(--shadow);padding:20px}.survey-card-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:8px}.survey-card-title{font-size:15px;font-weight:700}.survey-card-desc{color:#64748b;color:var(--gray-500);font-size:13px;line-height:1.5;margin-bottom:16px}.survey-votes{grid-gap:10px;display:grid;gap:10px;grid-template-columns:1fr 1fr;margin-bottom:12px}.vote-box{border:1px solid #e2e8f0;border:1px solid var(--gray-200);border-radius:8px;border-radius:var(--r);padding:12px}.vote-box.yes{background:#f0fdf4;border-color:#a7f3d0}.vote-box.no{background:#f8fafc;background:var(--gray-50)}.vote-label{color:#94a3b8;color:var(--gray-400);font-size:10px;font-weight:700;letter-spacing:.5px;margin-bottom:4px;text-transform:uppercase}.vote-count{color:#10b981;color:var(--green);font-size:22px;font-weight:800}.vote-count.no-count{color:#64748b;color:var(--gray-500)}.vote-progress{background:#f1f5f9;background:var(--gray-100);border-radius:3px;height:5px;margin-bottom:8px;overflow:hidden}.vote-fill{background:#10b981;background:var(--green);border-radius:3px;height:100%}.vote-empty{color:#94a3b8;color:var(--gray-400);font-size:12px;margin-bottom:10px}.survey-actions{grid-gap:8px;display:grid;gap:8px;grid-template-columns:1fr 1fr}.btn-vote-yes{align-items:center;background:#ecfdf5;background:var(--green-l);border:1px solid #a7f3d0;border-radius:8px;border-radius:var(--r);color:#065f46;cursor:pointer;display:flex;font-size:13px;font-weight:600;gap:5px;justify-content:center;padding:9px}.btn-vote-yes:hover{background:#d1fae5}.btn-vote-no{align-items:center;background:#f1f5f9;background:var(--gray-100);border:1px solid #e2e8f0;border:1px solid var(--gray-200);border-radius:8px;border-radius:var(--r);color:#334155;color:var(--gray-700);cursor:pointer;display:flex;font-size:13px;font-weight:600;gap:5px;justify-content:center;padding:9px}.btn-vote-no:hover{background:#e2e8f0;background:var(--gray-200)}.data-table{border-collapse:collapse;font-size:13px;width:100%}.data-table th{background:#f8fafc;background:var(--gray-50);border-bottom:2px solid #e2e8f0;border-bottom:2px solid var(--gray-200);color:#64748b;color:var(--gray-500);font-size:11px;font-weight:700;letter-spacing:.5px;padding:10px 12px;text-align:left;text-transform:uppercase}.data-table td{border-bottom:1px solid #f1f5f9;border-bottom:1px solid var(--gray-100);color:#334155;color:var(--gray-700);padding:10px 12px}.data-table tr:last-child td{border-bottom:none}.captcha-box,.data-table tr:hover td{background:#f8fafc;background:var(--gray-50)}.captcha-box{align-items:center;border:1.5px solid #e2e8f0;border:1.5px solid var(--gray-200);border-radius:8px;border-radius:var(--r);display:flex;gap:12px;margin-bottom:14px;padding:12px 16px}.captcha-math{color:#1557b0;color:var(--blue-d);font-family:monospace;font-size:18px;font-weight:700;letter-spacing:2px}.auth-wrap{align-items:center;background:linear-gradient(135deg,#0f1f3d,#1e3a6e);background:linear-gradient(135deg,var(--sidebar-bg) 0,#1e3a6e 100%);display:flex;justify-content:center;min-height:100vh;padding:20px}.auth-card{background:#fff;background:var(--white);border-radius:16px;border-radius:var(--rxl);box-shadow:0 20px 60px #0000004d;padding:36px;width:100%}.auth-logo{margin-bottom:24px;text-align:center}.auth-logo img{height:52px;margin-bottom:12px}.auth-title{font-size:22px;font-weight:800;margin-bottom:4px}.auth-sub{color:#64748b;color:var(--gray-500);font-size:13px}.page-header{margin-bottom:24px}.page-header h1{align-items:center;display:flex;font-size:22px;font-weight:800;gap:8px;margin-bottom:4px}.page-header h1 i{color:#1a73e8;color:var(--blue);font-size:22px}.page-header p{color:#64748b;color:var(--gray-500);font-size:13px}img{height:auto;max-width:100%}code,pre{overflow-x:auto;white-space:pre-wrap;word-break:break-all}.card{overflow:hidden}.news-card-excerpt,.news-list-title{overflow-wrap:break-word;word-break:break-word}.spinner{animation:spin .7s linear infinite;border:3px solid #e2e8f0;border-top-color:#1a73e8;border:3px solid var(--gray-200);border-radius:50%;border-top-color:var(--blue);height:32px;margin:40px auto;width:32px}@keyframes spin{to{transform:rotate(1turn)}}.ti-spin{animation:spin .7s linear infinite;display:inline-block}.loading-wrap{align-items:center;display:flex;justify-content:center;padding:60px}.empty-state{color:#94a3b8;color:var(--gray-400);padding:48px 20px;text-align:center}.empty-state i{display:block;font-size:48px;margin-bottom:12px;opacity:.4}.empty-state h3{color:#64748b;color:var(--gray-500);font-size:16px;font-weight:600;margin-bottom:6px}.empty-state p{font-size:13px}.progress-bar{background:#f1f5f9;background:var(--gray-100);border-radius:4px;height:8px;margin-top:4px;overflow:hidden}.progress-fill{background:#1a73e8;background:var(--blue);border-radius:4px;height:100%;transition:width .5s}.modal-overlay{align-items:center;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0f172a80;display:flex;inset:0;justify-content:center;padding:20px;position:fixed;z-index:200}.modal{animation:fadeUp .2s ease;background:#fff;background:var(--white);border-radius:16px;border-radius:var(--rxl);box-shadow:0 20px 60px #0003;max-width:440px;padding:28px;width:100%}@keyframes fadeUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.modal-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.modal-title{font-size:17px;font-weight:700}.modal-close{background:none;border:none;color:#94a3b8;color:var(--gray-400);cursor:pointer;font-size:20px;padding:4px}.modal-close:hover{color:#334155;color:var(--gray-700)}.feedback-layout{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 280px}.member-card{background:linear-gradient(135deg,#1565c0,#0288d1);border-radius:16px;border-radius:var(--rxl);color:#fff;overflow:hidden;padding:24px;position:relative}.member-card:before{background:#ffffff14;border-radius:50%;content:"";height:120px;position:absolute;right:-30px;top:-30px;width:120px}.member-card-name{font-size:20px;font-weight:800;margin-bottom:4px}.member-card-id{font-size:12px;margin-bottom:16px;opacity:.7}.member-card-row{display:flex;font-size:12px;justify-content:space-between;opacity:.8}@media (max-width:1024px){:root{--sidebar-w:220px}.stats-grid{grid-template-columns:repeat(2,1fr)}.home-grid,.survey-grid{grid-template-columns:1fr}}@media (max-width:768px){.sidebar{transform:translateX(-100%)}.sidebar.open{transform:translateX(0)}.quick-grid{grid-template-columns:repeat(2,1fr)}.feedback-layout,.form-row{grid-template-columns:1fr}}.hidden{display:none!important}
/*# sourceMappingURL=main.5a3dccd3.css.map*/