*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;color:#1a1a2e;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#fff;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,sans-serif;font-size:16px;line-height:1.5}body{margin:0}#root{flex-direction:column;width:100%;max-width:100%;min-height:100svh;display:flex}input,textarea,select,button{font-family:inherit;font-size:inherit;color:inherit;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light}*{box-sizing:border-box;margin:0;padding:0}body{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif}.App{max-width:1400px;margin:0 auto;padding:20px}.app-header{color:#fff;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffffff1f;border-radius:20px;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;margin-bottom:24px;padding:20px 28px;display:flex;box-shadow:0 8px 32px #00000026}.header-left h1{margin-bottom:4px;font-size:1.85rem;font-weight:800}.header-left p{opacity:.85;font-size:.9rem}.header-right{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.user-badge{align-items:center;gap:8px;display:flex}.user-name{font-size:.9rem;font-weight:600}.role-pill{text-transform:uppercase;letter-spacing:.5px;border-radius:20px;padding:4px 12px;font-size:.75rem;font-weight:700}.role-pill.admin{color:#fff;background:#dc3545}.role-pill.user{color:#fff;background:#ffffff40;border:1px solid #fff6}.logout-btn{color:#fff;cursor:pointer;white-space:nowrap;background:#ffffff26;border:1px solid #fff6;border-radius:8px;min-height:38px;padding:8px 16px;font-size:.88rem;font-weight:600;transition:all .2s}.logout-btn:hover{background:#ffffff47;transform:translateY(-1px)}.api-docs-btn{color:#fff;cursor:pointer;white-space:nowrap;background:#ffffff1f;border:1px solid #ffffff59;border-radius:8px;align-items:center;gap:5px;min-height:38px;padding:8px 14px;font-size:.88rem;font-weight:600;text-decoration:none;transition:all .2s;display:inline-flex}.api-docs-btn:hover{color:#fff;background:#ffffff40;transform:translateY(-1px)}.tabs{scrollbar-width:none;justify-content:center;gap:10px;margin-bottom:24px;padding-bottom:2px;display:flex;overflow-x:auto}.tabs::-webkit-scrollbar{display:none}.tab{color:#fff;cursor:pointer;white-space:nowrap;background:#fff3;border:none;border-radius:12px;min-height:46px;padding:12px 28px;font-size:1rem;font-weight:600;transition:all .3s}.tab:hover{background:#ffffff52;transform:translateY(-2px)}.tab.active{color:#667eea;background:#fff}.content{background:#fff;border-radius:20px;min-height:500px;padding:28px;box-shadow:0 20px 60px #0003}.loading{color:#fff;justify-content:center;align-items:center;height:100vh;font-size:1.8rem;font-weight:700;display:flex}.error-toast{color:#fff;text-align:center;background:#dc3545;border-radius:12px;margin-bottom:16px;padding:12px 20px;font-weight:600;animation:.3s slideDown}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@media (width<=1024px){.App{padding:16px}.app-header{padding:18px 22px}.header-left h1{font-size:1.55rem}.content{padding:22px}}@media (width<=768px){.App{padding:12px}.app-header{border-radius:16px;gap:12px;margin-bottom:16px;padding:16px 18px}.header-left h1{margin-bottom:2px;font-size:1.25rem}.header-left p{font-size:.8rem}.header-right{justify-content:space-between;gap:8px;width:100%}.user-badge{gap:6px}.user-name{font-size:.82rem}.role-pill{padding:3px 9px;font-size:.68rem}.logout-btn{padding:8px 12px;font-size:.82rem}.tabs{justify-content:flex-start;gap:8px;margin-bottom:16px}.tab{border-radius:10px;min-height:42px;padding:10px 18px;font-size:.9rem}.content{border-radius:16px;min-height:auto;padding:14px}}@media (width<=480px){.App{padding:10px}.app-header{border-radius:14px;padding:14px}.header-left h1{font-size:1.1rem}.header-left p{display:none}.content{border-radius:14px;padding:12px}.tab{padding:9px 14px;font-size:.85rem}}.user-list h2{color:#1a1a2e;margin-bottom:20px;font-size:1.1rem;font-weight:700}.users-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px;display:grid}.user-card{background:#fff;border:2px solid #e9ecef;border-radius:12px;padding:18px;transition:transform .25s,box-shadow .25s}.user-card:hover{transform:translateY(-4px);box-shadow:0 8px 20px #0000001a}.user-card.admin{border-left:4px solid #dc3545}.user-card.user{border-left:4px solid #0d6efd}.user-header{justify-content:space-between;align-items:center;gap:8px;margin-bottom:12px;display:flex}.user-header h3{color:#1a1a2e;margin:0;font-size:1rem;font-weight:700}.role-badge{text-transform:uppercase;letter-spacing:.4px;border-radius:20px;flex-shrink:0;padding:4px 12px;font-size:.75rem;font-weight:700}.role-badge.admin{color:#fff;background:#dc3545}.role-badge.user{color:#fff;background:#0d6efd}.email{color:#666;margin:8px 0;font-size:.875rem}.task-count{color:#667eea;margin:8px 0;font-size:.875rem;font-weight:700}.delete-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#dc3545,#c82333);border:none;border-radius:8px;width:100%;min-height:42px;margin-top:12px;padding:10px;font-size:.88rem;font-weight:700;transition:all .2s}.delete-btn:hover{opacity:.9;transform:translateY(-1px)}@media (width<=768px){.users-grid{grid-template-columns:1fr;gap:12px}.user-card{padding:14px}.delete-btn{min-height:46px;font-size:.92rem}}@media (width<=480px){.users-grid{grid-template-columns:1fr}}.task-card{cursor:grab;-webkit-user-select:none;user-select:none;background:#fff;border-left:4px solid #667eea;border-radius:10px;padding:14px;transition:transform .2s,box-shadow .2s;position:relative;box-shadow:0 2px 8px #00000014}.task-card:hover{transform:translateY(-2px);box-shadow:0 6px 16px #0000001f}.task-card:active{cursor:grabbing}.task-card.overdue{background:#fff8f8;border-left-color:#dc3545}.task-card:not(:active){cursor:pointer}.task-card[draggable]:active{cursor:grabbing}.task-card.dragging{opacity:.35;cursor:grabbing;transform:scale(.97)rotate(1deg);box-shadow:0 12px 32px #667eea59}.drag-handle{color:#ccc;cursor:grab;letter-spacing:-2px;flex-shrink:0;padding-right:8px;font-size:1rem;transition:color .15s}.task-card:hover .drag-handle{color:#667eea}.task-header{align-items:flex-start;gap:6px;margin-bottom:10px;display:flex}.task-title{color:#1a1a2e;word-break:break-word;flex:1;margin:0;font-size:1rem;font-weight:700;line-height:1.35}.delete-btn-small{cursor:pointer;background:0 0;border:none;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;min-width:32px;min-height:32px;padding:2px 6px;font-size:1rem;transition:background .15s;display:flex}.delete-btn-small:hover{background:#fef2f2}.description{color:#555;margin-bottom:12px;font-size:.875rem;line-height:1.5}.task-meta{flex-direction:column;gap:8px;display:flex}.assign-row{flex-direction:column;gap:4px;display:flex}.assign-row label{color:#888;text-transform:uppercase;letter-spacing:.4px;font-size:.78rem;font-weight:600}.assign-row select{cursor:pointer;color:#1a1a2e;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;background:#fff;border:1.5px solid #e5e7eb;border-radius:8px;outline:none;width:100%;padding:7px 10px;font-size:.875rem;transition:border-color .2s}.assign-row select:focus{border-color:#667eea;outline:none}.assigned-user{color:#0d6efd;background:linear-gradient(135deg,#e7f3ff,#f0f7ff);border:1px solid #cce5ff;border-radius:8px;padding:6px 10px;font-size:.82rem;font-weight:700}.move-btn-wrapper{margin-top:10px;display:none;position:relative}.priority-badge{color:#fff;white-space:nowrap;letter-spacing:.3px;border-radius:20px;flex-shrink:0;align-items:center;padding:3px 8px;font-size:.68rem;font-weight:800;display:inline-flex}.due-date-row{color:#555;background:#f0f7ff;border-radius:6px;margin-bottom:8px;padding:4px 8px;font-size:.8rem;font-weight:600;display:inline-block}.due-date-row.overdue-text{color:#dc3545;background:#fef2f2;font-weight:700;animation:2s ease-in-out infinite pulse-overdue}@keyframes pulse-overdue{0%,to{opacity:1}50%{opacity:.75}}@media (width<=768px){.task-card{cursor:default;padding:14px 12px}.drag-handle{display:none}.move-btn-wrapper{display:block}.move-btn{color:#fff;cursor:pointer;letter-spacing:.3px;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:10px;width:100%;min-height:42px;padding:10px;font-size:.88rem;font-weight:700;transition:opacity .2s}.move-btn:active{opacity:.85}.move-menu{z-index:200;background:#fff;border-radius:12px;animation:.15s menuPop;position:absolute;bottom:calc(100% + 6px);left:0;right:0;overflow:hidden;box-shadow:0 8px 32px #0000002e}@keyframes menuPop{0%{opacity:0;transform:translateY(6px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}.move-option{text-align:left;cursor:pointer;color:#333;background:0 0;border:none;border-bottom:1px solid #f0f0f0;width:100%;min-height:48px;padding:14px 16px;font-size:.92rem;font-weight:600;transition:background .15s;display:block}.move-option:last-child{border-bottom:none}.move-option:active{background:#f5f5ff}.delete-btn-small{min-width:40px;min-height:40px;font-size:1.1rem}.assign-row select{min-height:42px;padding:9px 10px;font-size:.9rem}.task-title{font-size:.95rem}.description{font-size:.85rem}}@media (width<=480px){.task-card{padding:12px 10px}}.task-board{grid-template-columns:repeat(4,1fr);gap:16px;margin-top:16px;display:grid}.column{background:#f8f9fa;border:2px solid #0000;border-radius:12px;min-height:400px;padding:14px;transition:background .2s,border-color .2s}.column.drag-over{background:#eef2ff;border-color:#667eea;box-shadow:inset 0 0 0 2px #667eea}.drop-hint{text-align:center;color:#667eea;pointer-events:none;border:2px dashed #667eea;border-radius:8px;padding:20px;font-size:.9rem;font-weight:600;animation:.8s ease-in-out infinite alternate pulse}.drop-hint-bottom{margin-top:12px}@keyframes pulse{0%{opacity:.5}to{opacity:1}}.column-header{color:#fff;border-radius:10px;justify-content:space-between;align-items:center;margin-bottom:14px;padding:12px 14px;display:flex}.column-header h3{margin:0;font-size:1rem;font-weight:700}.count{background:#ffffff4d;border-radius:20px;padding:3px 10px;font-size:.85rem;font-weight:700}.tasks{flex-direction:column;gap:12px;display:flex}.mobile-col-tabs,.swipe-hint{display:none}@media (width<=1200px){.task-board{grid-template-columns:repeat(2,1fr)}}@media (width<=768px){.mobile-col-tabs{scrollbar-width:none;gap:6px;margin-bottom:12px;padding:2px 0;display:flex;overflow-x:auto}.mobile-col-tabs::-webkit-scrollbar{display:none}.mobile-col-tab{cursor:pointer;text-align:center;color:#666;background:#f8f9fa;border:2px solid #e9ecef;border-radius:10px;flex-direction:column;flex:1;align-items:center;gap:2px;min-width:0;padding:8px 6px;font-size:.72rem;font-weight:600;line-height:1.2;transition:all .2s;display:flex}.mobile-col-tab .col-tab-emoji{font-size:1.1rem}.mobile-col-tab .col-tab-label{text-transform:uppercase;letter-spacing:.3px}.mobile-col-tab .col-tab-count{background:#e9ecef;border-radius:20px;padding:1px 7px;font-size:.7rem;font-weight:700}.mobile-col-tab.active{color:#fff;border-color:#0000}.mobile-col-tab.active .col-tab-count{background:#ffffff4d}.swipe-hint{color:#999;justify-content:center;align-items:center;gap:6px;margin-bottom:10px;font-size:.78rem;display:flex}.swipe-hint span{font-size:.9rem}.task-board{scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;grid-template-columns:unset;scrollbar-width:none;-ms-overflow-style:none;flex-direction:row;gap:12px;margin-top:0;padding-bottom:12px;display:flex;overflow-x:auto}.task-board::-webkit-scrollbar{display:none}.column{scroll-snap-align:start;border-radius:14px;flex:0 0 88vw;max-width:88vw;min-height:300px}.column-header{padding:10px 12px}.column-header h3{font-size:.95rem}}@media (width<=480px){.column{flex:0 0 92vw;max-width:92vw}.mobile-col-tab{padding:7px 4px;font-size:.68rem}}.create-user-form{background:#f8f9fa;border:1px solid #e9ecef;border-radius:14px;margin-bottom:24px;padding:20px}.create-user-form h2{color:#1a1a2e;margin-bottom:16px;font-size:1.1rem;font-weight:700}.create-user-form form{flex-wrap:wrap;align-items:flex-end;gap:10px;display:flex}.create-user-form input,.create-user-form select{color:#1a1a2e;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;box-sizing:border-box;background:#fff;border:1.5px solid #dee2e6;border-radius:10px;outline:none;flex:1;min-width:140px;padding:11px 14px;font-size:.95rem;transition:border-color .2s,box-shadow .2s}.create-user-form input:focus,.create-user-form select:focus{border-color:#667eea;outline:none;box-shadow:0 0 0 3px #667eea1f}.create-user-form button{color:#fff;cursor:pointer;white-space:nowrap;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:10px;min-height:46px;padding:11px 22px;font-size:.95rem;font-weight:700;transition:all .25s}.create-user-form button:hover{opacity:.9;transform:translateY(-1px);box-shadow:0 4px 14px #667eea59}@media (width<=768px){.create-user-form{border-radius:12px;padding:16px}.create-user-form h2{font-size:1rem}.create-user-form form{flex-direction:column;gap:10px}.create-user-form input,.create-user-form select{min-width:unset;width:100%;min-height:46px;font-size:1rem}.create-user-form button{width:100%}}.create-task-form{background:linear-gradient(135deg,#f8f9ff 0%,#f0f4ff 100%);border:1.5px solid #e0e7ff;border-radius:16px;margin-bottom:24px;padding:22px 24px;box-shadow:0 2px 12px #667eea14}.create-task-form h2{color:#1a1a2e;align-items:center;gap:8px;margin-bottom:18px;font-size:1.05rem;font-weight:700;display:flex}.create-task-form form{flex-direction:column;gap:12px;display:flex}.create-task-form input,.create-task-form textarea{color:#1a1a2e;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;resize:vertical;background:#fff;border:1.5px solid #d1d5db;border-radius:10px;outline:none;width:100%;padding:12px 14px;font-family:inherit;font-size:.95rem;transition:border-color .2s,box-shadow .2s}.create-task-form input::placeholder,.create-task-form textarea::placeholder{color:#9ca3af}.create-task-form input:focus,.create-task-form textarea:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea26}.create-task-form textarea{min-height:80px}.status-select-label{color:#6b7280;text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;font-size:.78rem;font-weight:700;display:block}.status-pills{flex-wrap:wrap;gap:8px;display:flex}.status-pill{cursor:pointer;color:#6b7280;text-align:center;-webkit-user-select:none;user-select:none;background:#fff;border:2px solid #e5e7eb;border-radius:10px;flex-direction:column;flex:1;align-items:center;gap:3px;min-width:0;padding:9px 6px;font-size:.78rem;font-weight:700;line-height:1.2;transition:all .18s;display:flex}.status-pill .pill-emoji{font-size:1.1rem}.status-pill .pill-label{text-transform:uppercase;letter-spacing:.3px}.status-pill.active-TODO{color:#fff;background:#6c757d;border-color:#6c757d}.status-pill.active-IN_PROGRESS{color:#fff;background:#0d6efd;border-color:#0d6efd}.status-pill.active-REVIEW{color:#fff;background:#e67e00;border-color:#e67e00}.status-pill.active-DONE{color:#fff;background:#198754;border-color:#198754}.status-pill:hover:not(.active-TODO):not(.active-IN_PROGRESS):not(.active-REVIEW):not(.active-DONE){color:#667eea;background:#f0f4ff;border-color:#667eea}.form-row-inline{gap:12px;display:flex}.form-field{flex-direction:column;flex:1;gap:5px;display:flex}.form-select,.form-date{color:#1a1a2e;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;cursor:pointer;background:#fff;border:1.5px solid #d1d5db;border-radius:10px;outline:none;width:100%;padding:10px 12px;font-family:inherit;font-size:.9rem;transition:border-color .2s,box-shadow .2s}.form-select:focus,.form-date:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea26}.optional-hint{color:#9ca3af;text-transform:none;letter-spacing:0;font-size:.72rem;font-weight:400}.create-task-form button[type=submit]{color:#fff;cursor:pointer;letter-spacing:.3px;background:linear-gradient(135deg,#28a745 0%,#20883a 100%);border:none;border-radius:10px;min-height:46px;padding:13px 24px;font-size:.95rem;font-weight:700;transition:all .22s;box-shadow:0 2px 8px #28a74540}.create-task-form button[type=submit]:hover{opacity:.92;transform:translateY(-1px);box-shadow:0 6px 16px #28a74559}.create-task-form button[type=submit]:active{transform:translateY(0)}@media (width<=768px){.create-task-form{border-radius:14px;padding:16px}.create-task-form h2{font-size:.98rem}.create-task-form input,.create-task-form textarea{min-height:46px;font-size:1rem}.status-pill{padding:8px 4px;font-size:.72rem}.status-pill .pill-emoji{font-size:1rem}.form-select,.form-date{min-height:44px;font-size:.95rem}}@media (width<=480px){.form-row-inline{flex-direction:column;gap:8px}.status-pills{gap:5px}.status-pill{padding:7px 3px;font-size:.68rem}}.login-page{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.login-card{background:#fff;border-radius:20px;width:100%;max-width:420px;padding:48px 40px;animation:.4s ease-out slideUp;box-shadow:0 20px 60px #00000040}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.login-header{text-align:center;margin-bottom:36px}.login-logo{margin-bottom:12px;font-size:3rem}.login-header h1{color:#1a1a2e;margin:0 0 8px;font-size:1.6rem;font-weight:700}.login-header p{color:#6b7280;margin:0;font-size:.95rem}.login-form{flex-direction:column;gap:20px;display:flex}.form-group{flex-direction:column;gap:6px;display:flex}.form-group label{color:#374151;font-size:.875rem;font-weight:600}.form-group input{color:#1a1a2e;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;box-sizing:border-box;background:#fff;border:2px solid #e5e7eb;border-radius:10px;outline:none;width:100%;padding:12px 16px;font-size:1rem;transition:border-color .2s,box-shadow .2s}.form-group input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea26}.login-error{color:#dc2626;text-align:center;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;padding:12px 16px;font-size:.9rem}.login-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:10px;margin-top:4px;padding:14px;font-size:1rem;font-weight:600;transition:opacity .2s,transform .1s}.login-btn:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.login-btn:disabled{opacity:.7;cursor:not-allowed}.login-hint{text-align:center;background:#f9fafb;border:1px dashed #d1d5db;border-radius:10px;margin-top:24px;padding:16px}.login-hint p{color:#6b7280;margin:0 0 6px;font-size:.85rem}.login-hint code{color:#374151;background:#e5e7eb;border-radius:6px;padding:4px 10px;font-size:.9rem;font-weight:600}@media (width<=480px){.login-card{border-radius:16px;padding:32px 20px}.login-header h1{font-size:1.35rem}.login-logo{font-size:2.5rem}.login-btn{padding:13px;font-size:.95rem}.form-group input{min-height:46px;font-size:1rem}}@media (width<=360px){.login-card{padding:24px 16px}}.ai-fab{color:#fff;cursor:pointer;z-index:1000;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:50%;justify-content:center;align-items:center;width:60px;height:60px;transition:transform .2s,box-shadow .2s,background .3s;animation:3s ease-in-out infinite fabPulse;display:flex;position:fixed;bottom:28px;right:28px;box-shadow:0 4px 20px #667eea80}@keyframes fabPulse{0%,to{box-shadow:0 4px 20px #667eea80}50%{box-shadow:0 4px 32px #667eead9,0 0 0 6px #667eea1f}}.ai-fab:hover{animation:none;transform:scale(1.1);box-shadow:0 8px 32px #667eeab3}.ai-fab--open{background:linear-gradient(135deg,#4a4a6a,#2d2d4e);animation:none;box-shadow:0 4px 20px #00000059}.ai-fab--open:hover{background:linear-gradient(135deg,#5a5a7a,#3d3d5e)}.ai-panel{z-index:999;background:#fff;border-radius:20px;flex-direction:column;width:390px;max-height:570px;animation:.22s cubic-bezier(.34,1.56,.64,1) popIn;display:flex;position:fixed;bottom:100px;right:28px;overflow:hidden;box-shadow:0 16px 56px #00000038,0 2px 8px #667eea26}@keyframes popIn{0%{opacity:0;transform:scale(.85)translateY(20px)}to{opacity:1;transform:scale(1)translateY(0)}}.ai-header{color:#fff;background:linear-gradient(135deg,#667eea,#764ba2);justify-content:space-between;align-items:center;gap:8px;padding:14px 18px;font-size:1rem;font-weight:700;display:flex}.ai-header-title{align-items:center;gap:8px;font-weight:700;display:flex}.ai-badge{letter-spacing:.02em;white-space:nowrap;background:#ffffff2e;border-radius:20px;padding:3px 10px;font-size:.72rem;font-weight:600}.ai-messages{background:#f9fafb;flex-direction:column;flex:1;gap:12px;padding:16px;display:flex;overflow-y:auto}.ai-msg{align-items:flex-start;gap:8px;max-width:92%;display:flex}.ai-msg--user{flex-direction:row-reverse;align-self:flex-end}.ai-msg-avatar{flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;margin-top:3px;font-size:1.1rem;display:flex}.ai-msg-text{white-space:pre-wrap;word-break:break-word;border-radius:14px;padding:10px 14px;font-size:.9rem;line-height:1.5}.ai-msg--ai .ai-msg-text{color:#1f2937;background:#fff;border:1px solid #e5e7eb;border-radius:4px 14px 14px}.ai-msg--user .ai-msg-text{color:#fff;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:14px 4px 14px 14px}.ai-msg--error .ai-msg-text{color:#dc2626;background:#fef2f2;border-color:#fecaca}.ai-thinking{align-items:center;gap:5px;display:flex;padding:14px 18px!important}.ai-thinking span{background:#9ca3af;border-radius:50%;width:8px;height:8px;animation:1.2s infinite bounce}.ai-thinking span:nth-child(2){animation-delay:.2s}.ai-thinking span:nth-child(3){animation-delay:.4s}@keyframes bounce{0%,80%,to{opacity:.4;transform:translateY(0)}40%{opacity:1;transform:translateY(-6px)}}.ai-suggestions{background:#f9fafb;border-top:1px solid #e5e7eb;flex-wrap:wrap;gap:6px;padding:8px 12px;display:flex}.ai-suggestion{cursor:pointer;color:#374151;white-space:nowrap;background:#fff;border:1px solid #d1d5db;border-radius:20px;padding:5px 12px;font-size:.78rem;transition:all .15s}.ai-suggestion:hover{color:#fff;background:#667eea;border-color:#667eea}.ai-input-row{background:#fff;border-top:1px solid #e5e7eb;align-items:flex-end;gap:8px;padding:12px;display:flex}.ai-input{resize:none;border:1.5px solid #e5e7eb;border-radius:12px;outline:none;flex:1;padding:10px 14px;font-family:inherit;font-size:.9rem;line-height:1.4;transition:border-color .2s}.ai-input:focus{border-color:#667eea}.ai-send{color:#fff;cursor:pointer;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;transition:opacity .2s,transform .1s;display:flex}.ai-send:disabled{opacity:.35;cursor:not-allowed}.ai-send:not(:disabled):hover{opacity:.88;transform:scale(1.05)}@media (width<=600px){.ai-panel{border-radius:16px;width:calc(100vw - 24px);max-height:70vh;bottom:86px;right:12px}.ai-fab{width:54px;height:54px;bottom:16px;right:16px}.ai-suggestion{padding:6px 10px;font-size:.75rem}.ai-input{font-size:.9rem}}@media (width<=380px){.ai-panel{width:calc(100vw - 16px);left:8px;right:8px}}.import-export-wrapper{position:relative}.ie-toggle-btn{color:#fff;cursor:pointer;white-space:nowrap;background:#ffffff26;border:1px solid #fff6;border-radius:8px;padding:8px 16px;font-size:.9rem;font-weight:600;transition:all .2s}.ie-toggle-btn:hover{background:#ffffff47;transform:translateY(-1px)}.ie-panel{z-index:1000;background:#fff;border-radius:16px;width:380px;padding:20px;animation:.2s ieFadeIn;position:absolute;top:calc(100% + 10px);right:0;box-shadow:0 20px 60px #00000040}@keyframes ieFadeIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.ie-panel-header{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.ie-panel-header h3{color:#333;margin:0;font-size:1.1rem}.ie-close-btn{cursor:pointer;color:#888;background:0 0;border:none;border-radius:6px;padding:4px 8px;font-size:1.1rem;transition:background .15s}.ie-close-btn:hover{color:#333;background:#f0f0f0}.ie-description{color:#666;margin-bottom:14px;font-size:.85rem;line-height:1.5}.ie-tabs{background:#f4f4f4;border-radius:10px;gap:6px;margin-bottom:12px;padding:4px;display:flex}.ie-tab{cursor:pointer;color:#666;background:0 0;border:none;border-radius:8px;flex:1;padding:7px 12px;font-size:.85rem;font-weight:600;transition:all .18s}.ie-tab:hover{color:#667eea;background:#667eea1a}.ie-tab--active{color:#667eea;background:#fff;box-shadow:0 2px 8px #0000001a}.ie-status{border-radius:8px;margin-bottom:12px;padding:10px 14px;font-size:.875rem;font-weight:600;animation:.2s ieFadeIn}.ie-status--success{color:#155724;background:#d4edda;border:1px solid #c3e6cb}.ie-status--error{color:#721c24;background:#f8d7da;border:1px solid #f5c6cb}.ie-status--info{color:#0c5460;background:#d1ecf1;border:1px solid #bee5eb}.ie-actions{flex-direction:column;gap:12px;margin-bottom:14px;display:flex}.ie-card{background:#fafafa;border:1.5px solid #eee;border-radius:12px;align-items:center;gap:14px;padding:14px;transition:border-color .2s;display:flex}.ie-card--export:hover{border-color:#667eea}.ie-card--import:hover{border-color:#28a745}.ie-card-icon{flex-shrink:0;font-size:1.8rem}.ie-card-body{flex:1;min-width:0}.ie-card-body h4{color:#333;margin:0 0 3px;font-size:.95rem}.ie-card-body p{color:#777;margin:0;font-size:.78rem;line-height:1.4}.ie-btn{cursor:pointer;white-space:nowrap;border:none;border-radius:8px;flex-shrink:0;padding:8px 14px;font-size:.82rem;font-weight:700;transition:all .2s}.ie-btn:disabled{opacity:.6;cursor:not-allowed}.ie-btn--export{color:#fff;background:linear-gradient(135deg,#667eea,#764ba2)}.ie-btn--export:hover:not(:disabled){background:linear-gradient(135deg,#5a6fd8,#6a409e);transform:translateY(-1px)}.ie-btn--import{color:#fff;background:linear-gradient(135deg,#28a745,#20883a)}.ie-btn--import:hover:not(:disabled){background:linear-gradient(135deg,#218838,#1a7230);transform:translateY(-1px)}.ie-warning{color:#856404;background:#fff3cd;border:1px solid #ffc107;border-radius:8px;margin:0;padding:8px 12px;font-size:.78rem;line-height:1.4}@media (width<=480px){.ie-panel{width:calc(100vw - 32px);right:-8px}}.filter-bar{background:linear-gradient(135deg,#f8f9ff 0%,#f0f4ff 100%);border:1.5px solid #e0e7ff;border-radius:14px;flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:18px;padding:14px 18px;display:flex;box-shadow:0 2px 10px #667eea12}.filter-search-wrapper{flex:1;align-items:center;min-width:180px;display:flex;position:relative}.filter-search-icon{pointer-events:none;font-size:.95rem;position:absolute;left:11px}.filter-search{color:#1a1a2e;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;background:#fff;border:1.5px solid #d1d5db;border-radius:10px;outline:none;width:100%;padding:9px 34px;font-family:inherit;font-size:.9rem;transition:border-color .2s,box-shadow .2s}.filter-search:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea26}.filter-search::placeholder{color:#9ca3af}.filter-clear-x{cursor:pointer;color:#9ca3af;background:0 0;border:none;border-radius:4px;padding:2px 4px;font-size:.85rem;line-height:1;transition:color .15s,background .15s;position:absolute;right:8px}.filter-clear-x:hover{color:#dc3545;background:#fef2f2}.filter-select{color:#1a1a2e;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;cursor:pointer;appearance:auto;background:#fff;border:1.5px solid #d1d5db;border-radius:10px;outline:none;min-width:140px;padding:9px 12px;font-family:inherit;font-size:.88rem;transition:border-color .2s,box-shadow .2s}.filter-select:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea26}.filter-clear-btn{color:#dc3545;cursor:pointer;white-space:nowrap;background:#fef2f2;border:1.5px solid #fecaca;border-radius:10px;padding:9px 14px;font-family:inherit;font-size:.85rem;font-weight:700;transition:background .2s,border-color .2s}.filter-clear-btn:hover{background:#fee2e2;border-color:#dc3545}@media (width<=768px){.filter-bar{border-radius:12px;gap:8px;padding:12px}.filter-search-wrapper{min-width:100%}.filter-select{flex:1;min-width:120px;font-size:.85rem}.filter-search{min-height:42px;font-size:.95rem}}@media (width<=480px){.filter-select{min-width:0;font-size:.82rem}}.modal-backdrop{z-index:900;background:#00000073;animation:.2s fadeIn;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.task-detail-modal{z-index:901;background:#fff;flex-direction:column;width:420px;max-width:95vw;animation:.25s cubic-bezier(.16,1,.3,1) slideIn;display:flex;position:fixed;top:0;bottom:0;right:0;overflow:hidden;box-shadow:-8px 0 32px #0000002e}@keyframes slideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.modal-header{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);flex-shrink:0;justify-content:space-between;align-items:center;padding:18px 20px 14px;display:flex}.modal-title{color:#fff;letter-spacing:.2px;margin:0;font-size:1rem;font-weight:700}.modal-close-btn{color:#fff;cursor:pointer;background:#fff3;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:1rem;font-weight:700;transition:background .15s;display:flex}.modal-close-btn:hover{background:#ffffff59}.modal-body{flex-direction:column;flex:1;gap:0;padding:20px;display:flex;overflow-y:auto}.modal-body::-webkit-scrollbar{width:5px}.modal-body::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:10px}.detail-task-title{color:#1a1a2e;word-break:break-word;margin:0 0 14px;font-size:1.2rem;font-weight:800;line-height:1.4}.detail-badges{flex-wrap:wrap;gap:8px;margin-bottom:18px;display:flex}.detail-badge{color:#fff;letter-spacing:.3px;border-radius:20px;align-items:center;padding:5px 12px;font-size:.78rem;font-weight:700;display:inline-flex}.detail-section{border-bottom:1px solid #f0f0f0;padding:14px 0}.detail-section:last-child{border-bottom:none}.detail-label{text-transform:uppercase;letter-spacing:.6px;color:#888;margin:0 0 6px;font-size:.75rem;font-weight:700}.detail-text{color:#333;white-space:pre-wrap;word-break:break-word;margin:0;font-size:.92rem;line-height:1.6}.detail-empty{color:#aaa;font-style:italic}.detail-overdue{color:#dc3545;font-weight:700}.detail-assignee-chip{align-items:center;gap:10px;display:flex}.assignee-avatar{color:#fff;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:1rem;font-weight:800;display:flex}.assignee-role{color:#888;font-size:.78rem;font-weight:600}.detail-timestamps{background:#f8f9ff;border-radius:10px;margin-top:4px;padding:12px 14px}.timestamp-row{justify-content:space-between;align-items:center;gap:8px;padding:4px 0;display:flex}.timestamp-label{color:#888;white-space:nowrap;font-size:.78rem;font-weight:600}.timestamp-value{color:#555;text-align:right;font-size:.82rem;font-weight:500}.modal-footer{background:#fafafa;border-top:1px solid #f0f0f0;flex-shrink:0;padding:14px 20px}.modal-close-footer-btn{color:#fff;cursor:pointer;letter-spacing:.3px;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border:none;border-radius:10px;width:100%;padding:12px;font-size:.95rem;font-weight:700;transition:opacity .2s,transform .15s}.modal-close-footer-btn:hover{opacity:.9;transform:translateY(-1px)}.modal-close-footer-btn:active{transform:translateY(0)}@media (width<=480px){.task-detail-modal{width:100vw;max-width:100vw}.modal-body{padding:16px}.modal-header{padding:14px 16px}.modal-footer{padding:12px 16px}}
