:root{--primary:#1264a3;--primary-light:#e8f5fe;--danger:#e74c3c;--danger-light:#ffeaea;--success:#2ecc71;--success-light:#e8faf0;--warning:#f39c12;--warning-light:#fff8e1;--gray-50:#f8f9fa;--gray-100:#f1f3f5;--gray-200:#e9ecef;--gray-300:#dee2e6;--gray-500:#868e96;--gray-700:#495057;--gray-900:#212529;--radius:8px;--shadow:0 1px 3px #0000001a;--shadow-md:0 4px 12px #0000001a;color:var(--gray-900);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Hiragino Sans,Noto Sans JP,sans-serif;font-size:14px;line-height:1.5}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--gray-50)}#root{max-width:1200px;margin:0 auto;padding:0 20px}.loading{height:100vh;color:var(--gray-500);justify-content:center;align-items:center;font-size:18px;display:flex}.unauthorized{flex-direction:column;justify-content:center;align-items:center;gap:16px;height:100vh;display:flex}.unauthorized h2{color:var(--gray-700)}.unauthorized code{background:var(--gray-100);border-radius:4px;padding:2px 8px;font-size:14px}.dashboard-header{border-bottom:1px solid var(--gray-200);justify-content:space-between;align-items:center;margin-bottom:24px;padding:24px 0 16px;display:flex}.dashboard-header h1{color:var(--gray-900);font-size:24px;font-weight:700}.user-info{color:var(--gray-500);background:var(--gray-100);border-radius:20px;padding:6px 14px;font-size:14px}section{margin-bottom:32px}section h2{color:var(--gray-700);margin-bottom:12px;font-size:16px;font-weight:600}.status-summary{flex-wrap:wrap;gap:12px;display:flex}.status-card{border:1px solid var(--gray-200);border-top:3px solid var(--gray-300);border-radius:var(--radius);cursor:pointer;background:#fff;min-width:120px;padding:16px 24px;transition:box-shadow .15s,transform .15s}.status-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.status-card.total{border-top-color:var(--primary);background:var(--primary-light)}.status-count{color:var(--gray-900);font-size:28px;font-weight:700}.status-label{color:var(--gray-500);margin-top:4px;font-size:13px}.member-list{flex-wrap:wrap;gap:10px;display:flex}.member-card{border:1px solid var(--gray-200);border-radius:var(--radius);cursor:pointer;background:#fff;min-width:160px;padding:12px 16px;transition:box-shadow .15s}.member-card:hover{box-shadow:var(--shadow-md)}.member-card.selected{border-color:var(--primary);background:var(--primary-light)}.member-name{margin-bottom:6px;font-size:14px;font-weight:600}.member-stats{gap:8px;font-size:13px;display:flex}.member-stats .overdue{color:var(--danger);font-weight:600}.projects-section{margin-bottom:24px}.project-cards{flex-wrap:wrap;gap:10px;display:flex}.project-card{border:1px solid var(--gray-200);border-radius:var(--radius);color:var(--gray-900);background:#fff;padding:12px 20px;font-size:14px;font-weight:600;text-decoration:none;transition:box-shadow .15s,border-color .15s}.project-card:hover{box-shadow:var(--shadow-md);border-color:var(--primary);color:var(--primary)}.tasks-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.tasks-header h2{margin-bottom:0}.filter-info{gap:8px;display:flex}.filter-tag{background:var(--primary-light);color:var(--primary);cursor:pointer;border-radius:12px;padding:4px 10px;font-size:12px}.filter-tag:hover{opacity:.7}.task-table-wrap{border:1px solid var(--gray-200);border-radius:var(--radius);background:#fff;overflow:hidden}.task-table{border-collapse:collapse;width:100%}.task-table th{background:var(--gray-100);color:var(--gray-500);text-transform:uppercase;text-align:left;border-bottom:1px solid var(--gray-200);padding:10px 16px;font-size:12px;font-weight:600}.task-table td{border-bottom:1px solid var(--gray-100);padding:12px 16px;font-size:13px}.task-table tbody tr:hover{background:var(--gray-50)}.task-title{max-width:400px;font-weight:500}.overdue-row{background:var(--danger-light)!important}.overdue-date{color:var(--danger);font-weight:600}.empty{text-align:center;color:var(--gray-500);padding:24px!important}.status-badge{border-radius:12px;padding:3px 10px;font-size:12px;font-weight:500}.status-badge.in_progress{color:#1565c0;background:#e3f2fd}.status-badge.done{background:var(--success-light);color:#27ae60}.status-badge.cancelled{background:var(--gray-100);color:var(--gray-500)}.status-badge.pending{background:var(--warning-light);color:#e67e22}.pagination{border-top:1px solid var(--gray-200);justify-content:center;align-items:center;gap:16px;padding:12px;display:flex}.pagination button{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:6px;padding:6px 16px;font-size:13px}.pagination button:disabled{background:var(--gray-300);cursor:default}.pagination span{color:var(--gray-500);font-size:13px}.header-right{align-items:center;gap:12px;display:flex}.admin-link{color:var(--primary);border:1px solid var(--primary);border-radius:6px;padding:6px 14px;font-size:13px;text-decoration:none;transition:background .15s}.admin-link:hover{background:var(--primary-light)}.role-badge{background:var(--primary);color:#fff;border-radius:4px;margin-left:6px;padding:2px 6px;font-size:11px}.filter-controls{align-items:center;gap:12px;display:flex}.project-filter{border:1px solid var(--gray-300);background:#fff;border-radius:6px;padding:6px 10px;font-size:13px}.admin-layout{gap:32px;min-height:100vh;padding-top:24px;display:flex}.admin-nav{flex-direction:column;flex-shrink:0;gap:4px;width:200px;display:flex}.admin-nav h2{color:var(--gray-900);margin-bottom:12px;font-size:16px}.admin-nav a{color:var(--gray-700);border-radius:6px;padding:8px 12px;font-size:14px;text-decoration:none;transition:background .1s;display:block}.admin-nav a:hover{background:var(--gray-100)}.admin-nav a.active{background:var(--primary-light);color:var(--primary);font-weight:600}.admin-nav .back-link{color:var(--gray-500);margin-top:16px;font-size:13px}.admin-content{flex:1;min-width:0}.admin-content h2{color:var(--gray-900);margin-bottom:16px;font-size:20px}.admin-form-row{align-items:center;gap:8px;margin-bottom:16px;display:flex}.admin-form-row input,.admin-form-row select{border:1px solid var(--gray-300);border-radius:6px;flex:1;min-width:0;padding:8px 12px;font-size:14px}.btn-primary{background:var(--primary);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:6px;padding:8px 16px;font-size:14px}.btn-primary:hover{opacity:.9}.btn-sm{border:1px solid var(--gray-300);cursor:pointer;background:#fff;border-radius:4px;padding:4px 10px;font-size:12px}.btn-sm:hover{background:var(--gray-100)}.btn-sm.btn-primary{background:var(--primary);color:#fff;border-color:var(--primary)}.btn-sm.btn-danger{color:var(--danger);border-color:var(--danger)}.btn-sm.btn-danger:hover{background:var(--danger-light)}.btn-sm.btn-ghost{color:var(--gray-500);border:none}.admin-list{flex-direction:column;gap:8px;display:flex}.admin-card{border:1px solid var(--gray-200);border-radius:var(--radius);background:#fff;overflow:hidden}.admin-card-header{justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.admin-card-title{cursor:pointer;align-items:center;gap:8px;font-size:14px;font-weight:600;display:flex}.admin-card-actions{gap:6px;display:flex}.admin-card-body{border-top:1px solid var(--gray-100);padding:0 16px 16px}.admin-card-body h4{color:var(--gray-500);margin:12px 0 8px;font-size:13px}.badge{background:var(--gray-100);color:var(--gray-500);border-radius:10px;padding:2px 8px;font-size:11px;font-weight:400}.user-id-hint{color:var(--gray-500);font-size:11px;font-weight:400}.hint-text{color:var(--gray-500);margin-bottom:16px;font-size:13px}.empty-text{color:var(--gray-500);padding:12px 0;font-size:13px}.member-ul{padding:0;list-style:none}.member-ul li{border-bottom:1px solid var(--gray-100);justify-content:space-between;align-items:center;padding:6px 0;font-size:13px;display:flex}.clickable-row{cursor:pointer}.clickable-row:hover{background:var(--primary-light)!important}.create-task-link{color:#fff;background:var(--primary);border-radius:6px;padding:6px 14px;font-size:13px;text-decoration:none}.create-task-link:hover{opacity:.9}.task-detail{padding:24px 0}.task-detail-nav{margin-bottom:20px}.back-btn{color:var(--primary);font-size:14px;text-decoration:none}.back-btn:hover{text-decoration:underline}.task-detail-main{gap:32px;display:flex}.task-detail-left{flex:1;min-width:0}.task-detail-sidebar{border:1px solid var(--gray-200);border-radius:var(--radius);background:#fff;flex-shrink:0;align-self:flex-start;width:280px;padding:20px;position:sticky;top:20px}.task-detail-title{color:var(--gray-900);margin:0 0 20px;font-size:22px;font-weight:700;line-height:1.4}.edit-title-input{border:1px solid var(--primary);border-radius:6px;width:100%;margin-bottom:16px;padding:8px 12px;font-size:20px;font-weight:700}.task-detail-section{margin-bottom:28px}.task-detail-section h3{color:var(--gray-700);border-bottom:1px solid var(--gray-200);margin-bottom:10px;padding-bottom:6px;font-size:14px;font-weight:600}.desc-pre{white-space:pre-wrap;word-break:break-word;color:var(--gray-900);margin:0;font-family:inherit;font-size:14px;line-height:1.6}.edit-desc-input{border:1px solid var(--primary);resize:vertical;border-radius:6px;width:100%;padding:10px 12px;font-family:inherit;font-size:14px}.sidebar-section{margin-bottom:16px}.sidebar-section label{color:var(--gray-500);text-transform:uppercase;margin-bottom:4px;font-size:11px;font-weight:600;display:block}.sidebar-value{color:var(--gray-900);font-size:14px}.sidebar-value.small{color:var(--gray-500);font-size:12px}.overdue-text{color:var(--danger);font-weight:600}.sidebar-input{border:1px solid var(--gray-300);border-radius:6px;width:100%;padding:6px 10px;font-size:13px}.status-select-group{flex-wrap:wrap;gap:4px;display:flex}.status-btn{border:1px solid var(--gray-300);cursor:pointer;background:#fff;border-radius:12px;padding:4px 10px;font-size:12px;transition:all .1s}.status-btn:hover{background:var(--gray-100)}.status-btn.active{font-weight:600}.slack-link{color:var(--primary);font-size:13px;text-decoration:none;display:inline-block}.slack-link:hover{text-decoration:underline}.sidebar-actions{border-top:1px solid var(--gray-200);gap:8px;margin-top:20px;padding-top:16px;display:flex}.btn-outline{border:1px solid var(--primary);color:var(--primary);cursor:pointer;background:#fff;border-radius:6px;width:100%;padding:6px 16px;font-size:13px}.btn-outline:hover{background:var(--primary-light)}.btn-ghost{color:var(--gray-500);cursor:pointer;background:0 0;border:none;padding:6px 16px;font-size:13px}.comments-list{margin-bottom:16px}.comment-item{border-bottom:1px solid var(--gray-100);padding:10px 0}.comment-header{justify-content:space-between;margin-bottom:4px;display:flex}.comment-author{color:var(--gray-900);font-size:13px;font-weight:600}.comment-time{color:var(--gray-500);font-size:11px}.comment-body{color:var(--gray-700);white-space:pre-wrap;font-size:14px;line-height:1.5}.comment-form{flex-direction:column;gap:8px;display:flex}.comment-form textarea{border:1px solid var(--gray-300);resize:vertical;border-radius:6px;width:100%;padding:10px 12px;font-family:inherit;font-size:14px}.comment-form .btn-primary{align-self:flex-end}.task-create{max-width:700px;margin:0 auto;padding:32px 0}.task-create h1{margin-bottom:24px;font-size:22px;font-weight:700}.task-create-form{flex-direction:column;gap:20px;display:flex}.form-group{flex-direction:column;gap:4px;display:flex}.form-group label{color:var(--gray-700);font-size:13px;font-weight:600}.form-group input,.form-group textarea,.form-group select{border:1px solid var(--gray-300);border-radius:6px;padding:10px 12px;font-family:inherit;font-size:14px}.form-group textarea{resize:vertical}.form-row{gap:16px;display:flex}.form-row .form-group{flex:1}.form-actions{gap:12px;padding-top:8px;display:flex}@media (width<=768px){.task-detail-main{flex-direction:column}.task-detail-sidebar{width:100%;position:static}.form-row{flex-direction:column}}.analytics-link{color:var(--primary);border:1px solid var(--primary);border-radius:var(--radius);padding:6px 14px;font-size:13px;font-weight:600;text-decoration:none;transition:background .15s}.analytics-link:hover{background:var(--primary-light)}.analytics-page{max-width:1100px;margin:0 auto;padding:24px}.analytics-page h1{margin-bottom:24px;font-size:22px}.analytics-section{border:1px solid var(--gray-200);border-radius:var(--radius);background:#fff;margin-bottom:24px;padding:20px 24px}.analytics-section h2{color:var(--gray-700);margin-bottom:16px;font-size:16px}.empty-text{color:var(--gray-500);text-align:center;padding:24px}.member-completion-grid{grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:16px;display:grid}.member-completion-card{border:1px solid var(--gray-200);border-radius:var(--radius);padding:16px}.mc-header{align-items:center;gap:16px;margin-bottom:12px;display:flex}.mc-info{flex-direction:column;display:flex}.mc-name{font-size:15px;font-weight:700}.mc-total{color:var(--gray-500);margin-top:2px;font-size:13px}.mc-bars{flex-direction:column;gap:6px;display:flex}.bar-row{align-items:center;gap:8px;display:flex}.bar-label{width:55px;color:var(--gray-500);text-align:right;flex-shrink:0;font-size:12px}.bar-track{background:var(--gray-100);border-radius:7px;flex:1;height:14px;overflow:hidden}.bar-fill{border-radius:7px;min-width:2px;height:100%;transition:width .4s}.bar-value{width:30px;color:var(--gray-700);flex-shrink:0;font-size:12px;font-weight:600}.progress-ring{flex-shrink:0}.compliance-chart{align-items:stretch;gap:8px;height:220px;padding-bottom:40px;display:flex}.chart-y-axis{color:var(--gray-500);text-align:right;flex-direction:column;justify-content:space-between;width:40px;padding-right:4px;font-size:11px;display:flex}.chart-bars{border-left:1px solid var(--gray-200);border-bottom:1px solid var(--gray-200);flex:1;align-items:flex-end;gap:4px;padding:0 4px;display:flex;position:relative}.chart-bar-col{flex-direction:column;flex:1;justify-content:flex-end;align-items:center;min-width:0;height:100%;display:flex}.chart-bar-wrap{flex:1;justify-content:center;align-items:flex-end;width:100%;display:flex}.chart-bar{border-radius:4px 4px 0 0;width:70%;max-width:40px;min-height:2px;transition:height .4s}.chart-bar-label{color:var(--gray-500);white-space:nowrap;margin-top:4px;font-size:10px}.chart-bar-rate{color:var(--gray-700);font-size:11px;font-weight:600}.compliance-legend,.project-legend{color:var(--gray-500);gap:16px;margin-top:12px;font-size:12px;display:flex}.legend-item{align-items:center;gap:4px;display:flex}.legend-dot{border-radius:50%;width:10px;height:10px;display:inline-block}.project-progress-list{flex-direction:column;gap:12px;display:flex}.project-progress-card{border:1px solid var(--gray-200);border-radius:var(--radius);color:inherit;padding:16px;text-decoration:none;transition:box-shadow .15s;display:block}.project-progress-card:hover{box-shadow:var(--shadow-md)}.pp-header{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.pp-name{font-size:15px;font-weight:700}.pp-rate{color:var(--primary);font-size:20px;font-weight:700}.pp-bar-track{background:var(--gray-100);border-radius:10px;height:20px;margin-bottom:8px;display:flex;overflow:hidden}.pp-bar-seg{height:100%;transition:width .4s}.pp-stats{color:var(--gray-500);gap:16px;font-size:13px;display:flex}@media (width<=768px){.member-completion-grid{grid-template-columns:1fr}.compliance-chart{height:180px}.chart-y-axis{display:none}}.integrations-admin{max-width:900px}.integration-create-form{background:var(--gray-50);border:1px solid var(--gray-200);border-radius:var(--radius);margin-bottom:20px;padding:20px}.integration-create-form h3{margin-bottom:12px;font-size:15px}.int-form-grid{grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px;display:grid}.int-form-grid .full-width{grid-column:1/-1}.int-form-grid .form-group label{color:var(--gray-500);margin-bottom:4px;font-size:12px;font-weight:600;display:block}.int-form-grid .form-group input,.int-form-grid .form-group select{border:1px solid var(--gray-300);border-radius:6px;width:100%;padding:8px 10px;font-size:13px}.integration-list{flex-direction:column;gap:8px;margin-bottom:20px;display:flex}.integration-card{border:1px solid var(--gray-200);border-radius:var(--radius);cursor:pointer;background:#fff;padding:12px 16px;transition:border-color .15s,box-shadow .15s}.integration-card:hover{box-shadow:var(--shadow)}.integration-card.selected{border-color:var(--primary);background:var(--primary-light)}.int-card-header{align-items:center;gap:10px;display:flex}.int-service-badge{background:var(--gray-100);color:var(--gray-700);text-transform:uppercase;border-radius:4px;padding:2px 8px;font-size:11px;font-weight:700}.int-name{flex:1;font-size:14px;font-weight:600}.int-status-dot{border-radius:50%;width:10px;height:10px}.int-status-dot.active{background:var(--success)}.int-status-dot.inactive{background:var(--gray-300)}.int-card-meta{color:var(--gray-500);gap:12px;margin-top:6px;font-size:12px;display:flex}.sync-status.success{color:var(--success);font-weight:600}.sync-status.error{color:var(--danger);font-weight:600}.integration-detail{border:1px solid var(--gray-200);border-radius:var(--radius);background:#fff;padding:20px}.int-detail-header{border-bottom:1px solid var(--gray-200);justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:12px;display:flex}.int-detail-header h3{font-size:17px}.int-detail-actions{gap:8px;display:flex}.int-section{border-bottom:1px solid var(--gray-100);margin-bottom:24px;padding-bottom:20px}.int-section:last-child{border-bottom:none;margin-bottom:0}.int-section h4{color:var(--gray-700);margin-bottom:10px;font-size:14px}.int-section-desc{color:var(--gray-500);margin-bottom:10px;font-size:12px}.int-btn-row{align-items:center;gap:8px;margin-bottom:12px;display:flex}.int-btn-row select{border:1px solid var(--gray-300);border-radius:6px;padding:6px 10px;font-size:13px}.int-warn{color:var(--warning);margin-top:6px;font-size:12px}.sync-message{color:var(--primary);background:var(--primary-light);border-radius:6px;margin-top:8px;padding:8px 12px;font-size:13px}.test-result{border-radius:6px;margin-top:10px;padding:10px 14px;font-size:13px}.test-result.success{background:var(--success-light);color:#1a7f37}.test-result.error{background:var(--danger-light);color:var(--danger)}.test-result.testing{background:var(--gray-100);color:var(--gray-500)}.remote-fields-preview{background:var(--gray-50);border-radius:6px;flex-wrap:wrap;align-items:center;gap:6px;margin-bottom:12px;padding:10px;display:flex}.rf-label{color:var(--gray-500);font-size:12px;font-weight:600}.rf-chip{border:1px solid var(--gray-200);background:#fff;border-radius:4px;padding:2px 8px;font-size:11px}.mapping-list{margin-bottom:12px}.mapping-header-row{color:var(--gray-500);grid-template-columns:1fr 120px 1fr 36px;gap:8px;margin-bottom:4px;padding:4px 0;font-size:11px;font-weight:600;display:grid}.mapping-row{grid-template-columns:1fr 120px 1fr 36px;align-items:center;gap:8px;margin-bottom:6px;display:grid}.mapping-row select,.mapping-row input{border:1px solid var(--gray-300);border-radius:6px;width:100%;padding:6px 8px;font-size:13px}.sync-logs{margin-top:16px}.sync-logs h5{color:var(--gray-500);margin-bottom:8px;font-size:13px}@media (width<=768px){.int-form-grid{grid-template-columns:1fr}.mapping-header-row,.mapping-row{grid-template-columns:1fr;gap:4px}.mapping-header-row{display:none}}
