.integrations-page .page-header{margin-bottom:2rem}.integrations-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem}.integration-card{background:var(--bg-card, #ffffff);border:1px solid var(--border-color, #e2e8f0);border-radius:12px;padding:1.5rem;transition:all .3s ease;cursor:pointer;box-shadow:0 4px 6px -1px #0000000d;display:flex;flex-direction:column}.integration-card:hover{transform:translateY(-4px);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;border-color:var(--primary-color, #3b82f6)}.integration-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}.integration-icon-wrapper{width:64px;height:64px;border-radius:16px;display:flex;align-items:center;justify-content:center;background:var(--bg-soft, #f8fafc)}.integration-title{font-size:1.25rem;font-weight:600;color:var(--text-main, #1e293b);margin-bottom:.5rem}.integration-desc{font-size:.875rem;color:var(--text-muted, #64748b);line-height:1.5;flex-grow:1;margin-bottom:1.5rem}.integration-tags{margin-top:auto}.integration-tag{display:inline-block;padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:500;background:var(--bg-hover, #f1f5f9);color:var(--text-main, #334155)}.status-badge{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:600}.status-active{background:#dcfce7;color:#166534}.status-pending{background:#fef9c3;color:#854d0e}.status-inactive{background:#f1f5f9;color:#475569}.integration-detail-page{display:flex;flex-direction:column;gap:2rem}.detail-header-actions{margin-bottom:-1rem}.detail-hero{display:flex;align-items:center;gap:2rem;background:var(--bg-card, #ffffff);padding:2.5rem;border-radius:16px;box-shadow:0 4px 6px -1px #0000000d;border:1px solid var(--border-color, #e2e8f0);flex-wrap:wrap}.detail-hero-icon{width:96px;height:96px;border-radius:24px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.bg-gradient-ai{background:linear-gradient(135deg,#6366f1,#a855f7)}.detail-hero-info{flex-grow:1}.hero-title{font-size:2rem;font-weight:700;color:var(--text-main, #0f172a);margin:0}.hero-subtitle{margin-top:.5rem;color:var(--text-muted, #64748b);font-size:1rem}.detail-hero-actions{display:flex;gap:1rem}.detail-grid{display:grid;grid-template-columns:2fr 1fr;gap:2rem}.integration-detail-page .card{padding:1.5rem}.integration-detail-page .card p{margin:0}@media(max-width:1024px){.detail-grid{grid-template-columns:1fr}}.workflow-steps{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;padding:1rem 0}.workflow-step{display:flex;align-items:center;gap:1rem;background:var(--bg-soft, #f8fafc);padding:1rem 1.5rem;border-radius:12px;min-width:200px;flex:1}.workflow-step-icon{color:var(--primary-color, #3b82f6)}.workflow-arrow{flex-shrink:0}.metrics-card .metrics-list{display:flex;flex-direction:column;gap:1rem}.metric-item{display:flex;justify-content:space-between;align-items:center;padding-bottom:.5rem;border-bottom:1px solid var(--border-color, #f1f5f9)}.metric-label{color:var(--text-muted)}.metric-value{font-weight:600;font-size:1.125rem;color:var(--text-main)}.sys-logs{list-style:none;padding:0;margin:0;font-family:monospace;font-size:.875rem}.sys-logs li{padding:.5rem 0;color:var(--text-main)}.sys-logs li:not(:last-child){border-bottom:1px dashed var(--border-color)}.log-time{color:var(--text-muted);margin-right:.5rem}:root{--bg-primary: #f3f6fc;--bg-main: #f3f6fc;--bg-secondary: #ffffff;--bg-card: #ffffff;--bg-sidebar: #1e3a5f;--bg-muted: #eef3fb;--accent: #0078d4;--accent-hover: #106ebe;--primary: #0078d4;--primary-hover: #106ebe;--success: #107c10;--warning: #ffb900;--danger: #d13438;--text-primary: #323130;--text-secondary: #605e5c;--text-on-dark: #ffffff;--border: #dde5f2;--border-color: #dde5f2;--border-focus: #0078d4;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--spacing-2xl: 40px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--shadow-sm: 0 1px 2px rgba(15, 23, 42, .08);--shadow-md: 0 8px 22px rgba(15, 23, 42, .12);--shadow-lg: 0 18px 44px rgba(15, 23, 42, .16);--font-family: "Segoe UI", -apple-system, BlinkMacSystemFont, "Roboto", "Helvetica Neue", sans-serif;--font-size-xs: 12px;--font-size-sm: 13px;--font-size-md: 14px;--font-size-lg: 16px;--font-size-xl: 20px;--font-size-2xl: 24px;--content-max-width: 1420px}*,*:before,*:after{box-sizing:border-box}body{margin:0;padding:0;font-family:var(--font-family);background-color:var(--bg-primary);color:var(--text-primary);line-height:1.5;font-size:var(--font-size-md);-webkit-font-smoothing:antialiased}img,picture,video,canvas,svg{display:block;max-width:100%}input,button,textarea,select{font:inherit}h1,h2,h3,h4,h5,h6{margin-top:0;margin-bottom:var(--spacing-md);font-weight:600;line-height:1.3}h1{font-size:var(--font-size-2xl)}h2{font-size:var(--font-size-xl)}h3{font-size:var(--font-size-lg)}p{margin-top:0}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}@media(max-width:768px){body{font-size:var(--font-size-sm)}}.app{display:flex;min-height:100vh;flex-direction:column}.ribbon{background-color:var(--accent);color:var(--text-on-dark);height:48px}.ribbon-inner{max-width:var(--content-max-width);margin:0 auto;padding:0 var(--spacing-lg);height:100%;display:flex;align-items:center;justify-content:space-between}.ribbon-nav{display:flex;gap:4px;height:100%;align-items:flex-end}.ribbon-tab{background:none;border:none;color:#fffc;padding:10px 16px;height:auto;display:flex;align-items:center;cursor:pointer;font-size:.9rem;text-decoration:none;transition:background .2s;border-radius:4px 4px 0 0;margin-bottom:0}.ribbon-tab:hover{background-color:#ffffff1a;color:#fff;text-decoration:none}.ribbon-tab.active{background-color:var(--bg-primary);color:var(--accent);font-weight:600}.ribbon-actions{display:flex;align-items:center;gap:var(--spacing-sm)}.ribbon-action-btn{background:none;border:none;color:#fff;cursor:pointer;opacity:.8;padding:6px;display:flex;align-items:center}.ribbon-action-btn:hover{opacity:1}.ribbon-user{margin-left:var(--spacing-sm)}.user-avatar{width:32px;height:32px;background:#fff3;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:600}.content{flex:1;width:100%;max-width:var(--content-max-width);margin:0 auto;padding:var(--spacing-lg);background-color:var(--bg-primary);overflow-y:auto}.page-header{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-md);margin-bottom:var(--spacing-md)}.page-header h2{margin:0}.page-actions{display:flex;align-items:center;gap:var(--spacing-sm);flex-wrap:wrap}.page-actions .form-select{min-width:170px;width:auto}.section-stack{display:flex;flex-direction:column;gap:var(--spacing-md)}.detail-layout{display:grid;grid-template-columns:1fr 400px;gap:2rem;align-items:start}.detail-main{display:flex;flex-direction:column;gap:1.5rem}.detail-sidebar{background:var(--bg-primary);border:1px solid var(--border);border-radius:12px;padding:1.5rem;position:sticky;top:2rem}.project-info-card{background:radial-gradient(1200px 280px at 50% -220px,rgba(0,120,212,.15),transparent 62%),#fff}.project-info-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px;margin-bottom:14px}.project-info-header h4{margin:0;min-width:0;flex:1 1 auto;font-size:.85rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-secondary);font-weight:700}.project-info-header .badge{flex-shrink:0;white-space:nowrap}.project-info-kpi-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-bottom:10px}.project-info-kpi{border:1px solid var(--border);background:#fff;border-radius:10px;padding:10px 12px;display:flex;align-items:center;gap:10px;box-shadow:var(--shadow-sm)}.project-info-kpi-content{display:flex;flex-direction:column;gap:1px}.project-info-kpi-content span{font-size:.72rem;color:var(--text-secondary);line-height:1.15}.project-info-kpi-content strong{font-size:1.12rem;font-weight:800;color:var(--text-primary);line-height:1.2}.project-info-kpi-icon{width:32px;height:32px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.project-info-kpi-icon.is-blue{background:#e3f2fd;color:#1565c0}.project-info-kpi-icon.is-teal{background:#e0f2f1;color:#00695c}.project-info-kpi-icon.is-purple{background:#f3e5f5;color:#6a1b9a}.project-info-kpi-icon.is-gray{background:#eceff1;color:#455a64}.project-meta-row{display:flex;flex-direction:column;gap:.36rem;padding:.75rem 0;border-bottom:1px solid var(--border)}.project-meta-row.no-border{border-bottom:none}.project-meta-label{font-size:.78rem;color:var(--text-secondary);display:flex;align-items:center;gap:.4rem;text-transform:uppercase;letter-spacing:.04em}.project-meta-value{font-weight:500;padding-left:1.35rem;color:var(--text-primary)}.project-meta-value .muted-value{color:var(--text-secondary)}.project-meta-value .emphasis-value{font-weight:700}.project-progress-wrap{margin-top:.2rem;display:flex;flex-direction:column;gap:.5rem}.project-progress-meta{display:flex;justify-content:space-between;font-size:.82rem;font-weight:700}.project-progress-track{height:9px;background:linear-gradient(180deg,#d9dee7,#cfd6e1);border-radius:999px;overflow:hidden}.project-progress-fill{height:100%;border-radius:999px;background:linear-gradient(90deg,#0b69d4,#3aa0ff);transition:width .45s cubic-bezier(.4,0,.2,1)}.project-progress-fill.is-complete{background:linear-gradient(90deg,#0f9f5a,#3fc77f)}.project-info-actions{margin-top:1.2rem;display:flex;flex-direction:column;gap:.5rem;border-top:1px solid var(--border);padding-top:.9rem}@media(max-width:991px){.content{padding:var(--spacing-md)}.page-header{align-items:flex-start;flex-direction:column}.page-actions{width:100%}.page-actions .form-select{min-width:0;width:100%}.detail-layout{grid-template-columns:1fr}.detail-sidebar{position:static}.project-info-kpi-grid{grid-template-columns:1fr}}.card{background-color:var(--bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--border);margin-bottom:var(--spacing-md)}.card-header{padding:var(--spacing-md);border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}.card-title{margin:0;font-size:1.1rem;font-weight:600}.card-body{padding:var(--spacing-md)}.card:last-child{margin-bottom:0}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-xs);border-radius:var(--radius-sm);border:1px solid transparent;cursor:pointer;transition:all .2s ease;font-weight:500;font-family:inherit;line-height:1}.btn-icon{width:18px;height:18px}.btn-sm{padding:4px 8px;font-size:.85rem}.btn-md{min-height:38px;padding:8px 16px;font-size:.95rem}.btn-lg{padding:12px 24px;font-size:1.1rem}.btn-primary{background-color:var(--primary);color:#fff;border-color:var(--primary)}.btn-primary:hover{background-color:var(--primary-hover);border-color:var(--primary-hover)}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{background-color:#fff;color:var(--text-primary);border-color:var(--border)}.btn-secondary:hover{background-color:#f3f2f1}.btn-danger{background-color:var(--danger);color:#fff;border-color:var(--danger)}.btn-danger:hover{filter:brightness(.9)}.btn-ghost{background-color:transparent;color:var(--text-secondary)}.btn-ghost:hover{background-color:#0000000d;color:var(--text-primary)}.form-group{margin-bottom:var(--spacing-md)}.form-label{display:block;margin-bottom:var(--spacing-xs);font-weight:500;color:var(--text-secondary)}.form-input,.form-select,.form-textarea,.form-control{width:100%;min-height:40px;padding:9px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);background-color:#fff;color:var(--text-primary);transition:border-color .2s,box-shadow .2s}.form-input:focus,.form-select:focus,.form-textarea:focus,.form-control:focus{outline:none;border-color:var(--border-focus);box-shadow:0 0 0 2px #0078d433}.form-textarea{min-height:96px;resize:vertical}.form-select{appearance:none;-webkit-appearance:none;-moz-appearance:none;background-image:linear-gradient(180deg,#fff0,#0078d40a),url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23605e5c' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");background-repeat:no-repeat;background-position:0 0,right 12px center;background-size:16px;padding-right:40px;cursor:pointer}.form-select:hover{border-color:#bfd3f2}.form-select option{background-color:#fff;color:var(--text-primary)}.form-error{display:block;margin-top:4px;color:var(--danger);font-size:.85rem}.badge{display:inline-block;padding:2px 8px;border-radius:12px;font-size:.75rem;font-weight:600;line-height:1.2}.badge-default{background-color:#e1dfdd;color:var(--text-primary)}.badge-success{background-color:#dff6dd;color:var(--success)}.badge-warning{background-color:#fff4ce;color:#795709}.badge-danger{background-color:#fde7e9;color:var(--danger)}.badge-info{background-color:#c7e0f4;color:var(--accent)}.table-responsive{overflow-x:auto;background:#fff;border-radius:var(--radius-md);box-shadow:var(--shadow-sm)}.table{width:100%;border-collapse:collapse;font-size:.92rem}.table th,.table td{padding:12px 16px;text-align:left;border-bottom:1px solid var(--border)}.table th{background-color:#faf9f8;color:var(--text-secondary);font-weight:600;-webkit-user-select:none;user-select:none}.table tr:last-child td{border-bottom:none}.table tbody tr:hover{background-color:#f3f6fc}.table-empty{text-align:center;color:var(--text-secondary);padding:var(--spacing-xl) 0}.th-content{display:flex;align-items:center;gap:8px}.sortable{cursor:pointer}.modal-overlay{position:fixed;inset:0;background-color:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn .2s ease-out}.modal-container{background:#fff;border-radius:var(--radius-xl);width:100%;max-width:500px;box-shadow:0 25px 50px -12px #00000040,0 0 0 1px #0000000d;animation:modalSlideIn .3s cubic-bezier(.16,1,.3,1);display:flex;flex-direction:column;max-height:90vh;overflow:visible}.modal-lg{max-width:800px}.modal-xl{max-width:1100px}.modal-full{max-width:95vw;height:90vh}.modal-header{padding:20px 24px;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;align-items:center;background:linear-gradient(to bottom,#fafafa,#fff)}.modal-title{margin:0;font-size:1.25rem;font-weight:600;color:#111827;letter-spacing:-.025em}.modal-close{background:#f3f4f6;border:none;cursor:pointer;color:#6b7280;width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;transition:all .15s ease}.modal-close:hover{background:#e5e7eb;color:#111827}.modal-body{padding:24px;overflow-y:auto;overflow-x:visible;flex:1}.modal-footer{padding:16px 24px;border-top:1px solid #e5e7eb;display:flex;justify-content:flex-end;gap:12px;background:#fafafa}.finance-transaction-modal.modal-container{max-width:640px;border-radius:16px;box-shadow:0 22px 44px -16px #0c1c3761,0 0 0 1px #071d3b14}.finance-transaction-modal .modal-header{padding:18px 24px;border-top-left-radius:16px;border-top-right-radius:16px;background:linear-gradient(180deg,#0078d414,#0078d400),#fff}.finance-transaction-modal .modal-title{font-size:1.85rem;font-weight:800;letter-spacing:-.03em;color:#0f2a44}.finance-transaction-modal .modal-close{width:36px;height:36px;border-radius:10px}.finance-transaction-modal .modal-body{padding:20px 24px 22px}.finance-tx-form{display:flex;flex-direction:column;gap:4px}.finance-tx-note{margin-bottom:8px;padding:10px 12px;border:1px solid #d8e5f8;background:#f4f9ff;border-radius:10px;color:#355068;font-size:.88rem}.finance-transaction-modal .form-label{margin-bottom:6px;font-size:.83rem;letter-spacing:.01em}.finance-transaction-modal .form-input,.finance-transaction-modal .form-select,.finance-transaction-modal .form-textarea{min-height:42px;border-radius:8px;border-color:#c8d6e7;background-color:#fff}.finance-transaction-modal .form-input:focus,.finance-transaction-modal .form-select:focus,.finance-transaction-modal .form-textarea:focus{border-color:#2e82de;box-shadow:0 0 0 3px #2e82de2e}.finance-transaction-modal .custom-dropdown{width:100%}.finance-transaction-modal .custom-dropdown-trigger{width:100%;min-height:42px;border-radius:8px;border-color:#c8d6e7}.finance-transaction-modal .custom-dropdown-trigger.is-open{border-color:#2e82de;box-shadow:0 0 0 3px #2e82de2e}.finance-transaction-modal .custom-dropdown-menu{border-radius:10px 10px 0 0;border-color:#c8d6e7}.finance-tx-actions{margin-top:8px}.finance-tx-actions .btn{min-width:104px;min-height:40px;border-radius:8px;font-weight:700}@media(max-width:640px){.finance-transaction-modal.modal-container{width:calc(100% - 20px)}.finance-transaction-modal .modal-title{font-size:1.4rem}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalSlideIn{0%{opacity:0;transform:scale(.95) translateY(-10px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.custom-dropdown{position:relative;display:inline-block}.custom-dropdown-trigger{display:flex;align-items:center;gap:8px;min-height:38px;padding:0 12px;background:#fff;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:.92rem;cursor:pointer;transition:border-color .15s,box-shadow .15s;white-space:nowrap;min-width:160px}.custom-dropdown-trigger:hover{border-color:#bfd3f2}.custom-dropdown-trigger.is-open{border-color:var(--border-focus);box-shadow:0 0 0 2px #0078d426}.custom-dropdown-label{flex:1;text-align:left;overflow:hidden;text-overflow:ellipsis}.custom-dropdown-chevron{flex-shrink:0;color:var(--text-secondary);transition:transform .2s}.custom-dropdown-chevron.rotated{transform:rotate(180deg)}.custom-dropdown-menu{position:absolute;top:calc(100% + 4px);left:0;min-width:100%;background:#fff;border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-md);z-index:200;padding:4px;max-height:280px;overflow-y:auto;animation:dropdownIn .12s ease-out}.custom-dropdown.open-up .custom-dropdown-menu{top:auto;bottom:calc(100% + 4px)}@keyframes dropdownIn{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.custom-dropdown-item{display:flex;align-items:center;justify-content:space-between;gap:8px;width:100%;padding:8px 10px;border:none;border-radius:6px;background:none;color:var(--text-primary);font-size:.9rem;text-align:left;cursor:pointer;transition:background .12s;white-space:nowrap}.custom-dropdown-item:hover{background:var(--bg-muted)}.custom-dropdown-item.is-selected{color:var(--accent);font-weight:500}.custom-dropdown-item.is-selected:hover{background:#e8f2ff}.finance-transaction-modal.modal-container{max-height:none;overflow:hidden;border-radius:16px}.finance-transaction-modal .modal-body{overflow:visible}.finance-transaction-modal .custom-dropdown-menu{border-radius:10px 10px 0 0!important;z-index:1200}.finance-transaction-modal .custom-dropdown.open-up .custom-dropdown-menu{border-radius:0 0 10px 10px!important}.task-list-title{font-weight:500;color:var(--text-primary)}.task-list-tag{display:inline-block;margin-left:8px;padding:1px 6px;border-radius:4px;font-size:.72rem;font-weight:500;background:var(--bg-muted);color:var(--text-secondary);vertical-align:middle}.kanban-board{display:flex;gap:var(--spacing-md);overflow-x:auto;height:calc(100vh - 190px);padding-bottom:var(--spacing-md)}.kanban-column{flex:0 0 360px;background-color:#f3f2f1;border-radius:var(--radius-md);display:flex;flex-direction:column;max-height:100%}.kanban-header{padding:var(--spacing-md);font-weight:600;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid rgba(0,0,0,.05)}.kanban-count{background:#0000001a;padding:2px 8px;border-radius:12px;font-size:.8rem}.kanban-list{padding:var(--spacing-sm);overflow-y:auto;flex:1;display:flex;flex-direction:column;gap:var(--spacing-sm)}.kanban-card{background:#fff;padding:calc(var(--spacing-md) + 2px);border-radius:10px;box-shadow:0 1px 2px #0000001a;cursor:grab;border:1px solid #e6e6e6}.kanban-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px);transition:all .2s ease}.kanban-card h4{margin:0 0 var(--spacing-sm) 0;font-size:1rem;font-weight:600;line-height:1.35}.kanban-card-project{font-size:.8rem;color:var(--text-secondary);margin-bottom:var(--spacing-xs)}.kanban-card-meta{display:flex;align-items:center;gap:var(--spacing-xs);flex-wrap:wrap}.kanban-due-date{font-size:.75rem;color:var(--text-secondary)}.kanban-assignee{font-size:.8rem;color:var(--text-secondary);margin-top:var(--spacing-xs)}.kanban-column.drag-over{background-color:#e8f4fd;border:2px dashed var(--accent)}.kanban-wrapper{width:100%;min-width:0}.kanban-dropdown{position:absolute;right:0;top:calc(100% + 6px);background:#fff;border:1px solid var(--border);border-radius:10px;box-shadow:var(--shadow-md);min-width:180px;z-index:100;padding:6px}.kanban-dropdown button{display:flex;align-items:center;gap:8px;width:100%;padding:8px 10px;border:none;border-radius:8px;background:none;cursor:pointer;font-size:.86rem;text-align:left}.kanban-dropdown button:hover{background-color:#f3f2f1}.kanban-dropdown button.danger{color:var(--danger)}.kanban-dropdown button.danger:hover{background-color:#fde7e9}.kanban-add-column{flex:0 0 336px;min-height:200px;background:#00000008;border:2px dashed var(--border);border-radius:var(--radius-md);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;cursor:pointer;color:var(--text-secondary);transition:all .2s}.kanban-add-column:hover{background:#0000000d;border-color:var(--accent);color:var(--accent)}@media(min-width:992px){html.tasks-kanban-lock,body.tasks-kanban-lock{overflow:hidden;height:100dvh}body.tasks-kanban-lock #root,body.tasks-kanban-lock .app{height:100dvh;overflow:hidden}body.tasks-kanban-lock .content{height:calc(100dvh - 48px);overflow:hidden}.tasks-page.tasks-page-kanban{height:100%;min-height:0;display:flex;flex-direction:column;overflow:hidden}.tasks-page.tasks-page-kanban .page-header{flex:0 0 auto}.tasks-page.tasks-page-kanban .kanban-wrapper{flex:1 1 auto;min-height:0;overflow:hidden}.tasks-page.tasks-page-kanban .kanban-board{height:100%}}.kanban-title{margin:0;font-size:.95rem;font-weight:600}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-main);padding:var(--spacing-md)}.login-container{width:100%;max-width:400px}.login-header{text-align:center;margin-bottom:var(--spacing-lg);color:var(--text-primary)}.login-title{font-size:2.5rem;font-weight:700;margin:0 0 var(--spacing-xs) 0;letter-spacing:-1px}.login-subtitle{margin:0;opacity:.9;font-size:1.1rem}.login-form{padding:var(--spacing-md)}.login-form-title{margin:0 0 var(--spacing-lg) 0;font-size:1.25rem;text-align:center;color:var(--text-primary)}.login-error{background-color:#fde7e9;color:var(--danger);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-sm);margin-bottom:var(--spacing-md);font-size:.9rem;text-align:center}.login-button{width:100%;padding:12px;font-size:1rem;margin-top:var(--spacing-sm)}.login-hint{margin-top:var(--spacing-md);text-align:center;font-size:.85rem;color:var(--text-secondary)}.loading{display:flex;align-items:center;justify-content:center;min-height:200px;color:var(--text-secondary);font-size:1rem}.calendar-widget{background:var(--bg-card);padding:var(--spacing-md);border-radius:var(--radius-md);border:1px solid var(--border);box-shadow:var(--shadow-sm)}.calendar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md);font-weight:600;font-size:1.1rem}.calendar-nav-btn{background:none;border:none;cursor:pointer;padding:8px;border-radius:var(--radius-sm);color:var(--text-secondary);display:flex;align-items:center;justify-content:center;transition:all .2s}.calendar-nav-btn:hover{background-color:#f3f2f1;color:var(--text-primary)}.calendar-grid{display:grid;grid-template-columns:repeat(7,50px);gap:6px;text-align:center;justify-content:center}.calendar-day-header{font-size:.9rem;color:var(--text-secondary);padding:8px 0;font-weight:500}.calendar-day{width:40px;height:40px;margin:2px auto;display:flex;align-items:center;justify-content:center;border-radius:50%;cursor:pointer;font-size:1.1rem;transition:all .2s;-webkit-user-select:none;user-select:none}.calendar-day:hover:not(.empty){background-color:#f3f2f1}.calendar-day.empty{cursor:default}.calendar-day.today{border:2px solid var(--accent);font-weight:600}.calendar-day.selected{background-color:var(--accent);color:#fff}.dashboard-calendar-layout{display:grid;grid-template-columns:auto 1fr;gap:var(--spacing-md);margin-top:var(--spacing-md);align-items:stretch}.dashboard-calendar-layout .calendar-widget{height:100%}.dashboard-grid>.card{height:100%;margin-bottom:0;box-sizing:border-box}.dashboard-calendar-layout>.card{height:100%;margin-bottom:0;display:flex;flex-direction:column}.dashboard-calendar-layout>.card .card-body{flex:1}@media(max-width:768px){.dashboard-calendar-layout{grid-template-columns:1fr}}.gantt-container{width:100%;overflow-x:auto;font-size:.9rem}.gantt-header{display:flex;border-bottom:2px solid var(--border);background:#faf9f8;position:sticky;top:0;z-index:1}.gantt-label-cell{flex:0 0 200px;padding:12px;font-weight:600;border-right:1px solid var(--border);display:flex;flex-direction:column;justify-content:center}.gantt-timeline-header{flex:1;position:relative;height:40px;min-width:600px}.gantt-month-label{position:absolute;top:50%;transform:translateY(-50%);font-size:.8rem;color:var(--text-secondary);white-space:nowrap;padding-left:4px;border-left:1px solid var(--border);height:100%;display:flex;align-items:center}.gantt-body{min-width:800px}.gantt-row{display:flex;border-bottom:1px solid var(--border)}.gantt-row:hover{background-color:#f3f6fc}.gantt-project-name{font-weight:500;display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.gantt-project-client{font-size:.8rem;color:var(--text-secondary);display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.gantt-timeline-cell{flex:1;position:relative;height:50px;min-width:600px;background:repeating-linear-gradient(90deg,transparent,transparent 30px,rgba(0,0,0,.03) 30px,rgba(0,0,0,.03) 60px)}.gantt-bar{position:absolute;top:10px;height:30px;border-radius:4px;display:flex;align-items:center;padding:0 12px;cursor:pointer;transition:filter .2s;box-shadow:0 1px 3px #0003}.gantt-bar:hover{filter:brightness(1.1)}.gantt-bar-label{color:#fff;font-size:.8rem;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;text-align:center}.gantt-resize-handle{position:absolute;top:0;width:8px;height:100%;cursor:ew-resize;opacity:0;transition:opacity .2s}.gantt-bar:hover .gantt-resize-handle{opacity:1}.gantt-resize-start{left:0;border-radius:4px 0 0 4px;background:linear-gradient(90deg,rgba(255,255,255,.5),transparent)}.gantt-resize-end{right:0;border-radius:0 4px 4px 0;background:linear-gradient(270deg,rgba(255,255,255,.5),transparent)}.gantt-resize-handle:hover{background:#ffffff4d}.gantt-bar-resizing{opacity:.8;box-shadow:0 0 0 2px var(--accent),0 2px 8px #0000004d}.gantt-wrapper{width:100%}.gantt-controls{display:flex;align-items:center;justify-content:flex-end;padding:8px 12px;border-bottom:1px solid var(--border);background:#faf9f8}.gantt-zoom-btn{background:#fff;border:1px solid var(--border);border-radius:4px;padding:4px 8px;cursor:pointer;display:flex;align-items:center;justify-content:center;margin-left:4px;transition:all .2s}.gantt-zoom-btn:hover:not(:disabled){background:#f3f2f1;border-color:var(--accent)}.gantt-zoom-btn:disabled{opacity:.4;cursor:not-allowed}.gantt-day-row{display:flex;border-bottom:1px solid var(--border);background:#faf9f8}.gantt-day-label{position:absolute;font-size:.7rem;color:var(--text-secondary);padding-left:2px;border-left:1px solid rgba(0,0,0,.1);height:100%;display:flex;align-items:center}.project-payouts-section{margin-top:var(--spacing-lg)}.project-tabs{display:flex;gap:4px;border-bottom:1px solid var(--border);margin-bottom:var(--spacing-md);flex-wrap:wrap}.project-tab{padding:8px 16px;border:none;background:transparent;color:var(--text-secondary);border-radius:4px 4px 0 0;cursor:pointer;font-size:.9rem;font-weight:400;transition:all .2s}.project-tab:hover{background-color:#f3f2f1;color:var(--text-primary)}.project-tab.active{background-color:var(--primary);color:#fff;font-weight:500}.payout-table-container{overflow-x:auto}.payout-table{width:100%;border-collapse:collapse;font-size:.9rem}.payout-table th{padding:12px;text-align:left;font-weight:500;border-bottom:2px solid var(--border);background:var(--bg-secondary)}.payout-table th:last-child{text-align:right}.payout-table td{padding:10px 12px;border-bottom:1px solid var(--border)}.payout-table td:last-child{text-align:right;font-weight:500}.payout-table tbody tr:nth-child(2n){background:var(--bg-secondary)}.payout-table tbody tr:hover{background:#e8f4fd}.payout-table .stage-name{font-weight:500}.payout-table .separator-row td{height:8px;background:transparent!important;border:none;padding:0}.form-grid-2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.form-actions{margin-top:var(--spacing-md);display:flex;justify-content:flex-end;gap:var(--spacing-sm)}.view-toggle{display:inline-flex;align-items:center;background:#fff;border-radius:var(--radius-sm);border:1px solid var(--border);overflow:hidden}.view-toggle button{display:flex;align-items:center;justify-content:center;padding:7px 11px;border:none;background:transparent;color:var(--text-secondary);cursor:pointer;transition:background-color .2s,color .2s}.view-toggle button:hover:not(:disabled){background:var(--bg-muted);color:var(--text-primary)}.view-toggle button.is-active{background:#e8f2ff;color:var(--accent)}.filters-row{display:flex;gap:var(--spacing-sm);align-items:center;flex-wrap:wrap}.field-with-icon{position:relative;flex:1;min-width:220px}.field-with-icon .field-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--text-secondary);pointer-events:none}.field-with-icon .form-input{padding-left:36px}.panel{background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg)}.panel-header{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-sm);padding:var(--spacing-md);border-bottom:1px solid var(--border)}.panel-body{padding:var(--spacing-md)}.tabs{margin-bottom:var(--spacing-lg);display:flex;align-items:center;gap:var(--spacing-lg);border-bottom:1px solid var(--border);overflow-x:auto}.tab-button{display:flex;align-items:center;justify-content:center;min-height:44px;padding:0 var(--spacing-xs);border:none;border-bottom:2px solid transparent;background:none;color:var(--text-secondary);font-weight:500;cursor:pointer;white-space:nowrap}.tab-button.active{border-bottom-color:var(--accent);color:var(--accent)}@media(max-width:768px){.card-header{align-items:flex-start;flex-direction:column}.form-grid-2{grid-template-columns:1fr}.filters-row{align-items:stretch}.filters-row .form-select,.filters-row .btn,.filters-row .field-with-icon{width:100%}}
