:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;line-height:1.5;font-weight:400;color:#333;background-color:#f5f5f5;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh}#root{width:100%}*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background:#f5f5f5;color:#333;line-height:1.5}.app{min-height:100vh;display:flex;flex-direction:column}.app-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:20px;text-align:center}.app-header h1{font-size:24px;margin-bottom:5px}.app-header p{font-size:14px;opacity:.8}.app-main{flex:1;display:flex;padding:20px;gap:20px}.app-footer{background:#333;color:#999;text-align:center;padding:15px;font-size:12px}.sidebar{width:380px;flex-shrink:0}.config-panel{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;overflow:hidden}.tabs{display:flex;flex-wrap:wrap;background:#f0f0f0;border-bottom:1px solid #ddd}.tab{padding:10px 12px;border:none;background:transparent;cursor:pointer;font-size:13px;color:#666;transition:all .2s}.tab:hover{background:#e0e0e0}.tab.active{background:#fff;color:#667eea;font-weight:600}.tab-content{padding:15px;max-height:500px;overflow-y:auto}.config-section h3{font-size:16px;margin-bottom:15px;color:#333}.form-group{margin-bottom:15px}.form-group label{display:block;margin-bottom:5px;font-size:13px;color:#555;font-weight:500}.form-group input[type=text],.form-group input[type=number],.form-group select{width:100%;padding:8px 10px;border:1px solid #ddd;border-radius:4px;font-size:14px}.form-group input[type=range]{width:100%}.form-group input:focus,.form-group select:focus{outline:none;border-color:#667eea}.form-row{display:flex;gap:10px}.form-row .form-group{flex:1}.checkbox-group{display:flex;flex-wrap:wrap;gap:10px}.checkbox-group label{display:flex;align-items:center;gap:5px;font-weight:400}.hint{display:block;font-size:11px;color:#999;margin-top:3px}.group-list{max-height:200px;overflow-y:auto;border:1px solid #ddd;border-radius:4px;margin-bottom:10px}.group-item{display:flex;align-items:center;padding:5px 10px;border-bottom:1px solid #eee;gap:5px}.group-item:last-child{border-bottom:none}.group-index{width:20px;font-size:12px;color:#999}.group-item input{flex:1;padding:4px 8px;border:1px solid #ddd;border-radius:3px;font-size:13px}.group-item button{padding:3px 8px;border:none;background:#f0f0f0;border-radius:3px;cursor:pointer;font-size:12px}.group-item button:hover{background:#e0e0e0}.remove-btn{color:#f44!important;font-weight:700}.add-group{display:flex;gap:5px}.add-group input{flex:1}.add-group button,.add-button{padding:8px 15px;background:#667eea;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:13px}.add-button{width:100%;margin-top:10px}.add-group button:hover,.add-button:hover{background:#5a6fd6}.batches-list,.triggers-list{display:flex;flex-direction:column;gap:15px}.batch-item,.trigger-item{background:#f9f9f9;border:1px solid #eee;border-radius:6px;padding:12px}.batch-header,.trigger-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;font-weight:600;color:#555}.action-buttons{padding:15px;border-top:1px solid #eee;display:flex;gap:10px}.run-button{flex:1;padding:12px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:15px;font-weight:600}.run-button:hover:not(:disabled){opacity:.9}.run-button:disabled{opacity:.6;cursor:not-allowed}.reset-button{padding:12px 20px;background:#f0f0f0;color:#666;border:none;border-radius:6px;cursor:pointer;font-size:14px}.reset-button:hover{background:#e0e0e0}.content{flex:1;display:flex;flex-direction:column;gap:20px}.view-tabs{display:flex;gap:5px}.view-tab{padding:10px 20px;border:none;background:#fff;border-radius:6px 6px 0 0;cursor:pointer;font-size:14px;color:#666}.view-tab.active{background:#fff;color:#667eea;font-weight:600;box-shadow:0 -2px 4px #0000000d}.view-content{background:#fff;border-radius:0 8px 8px;box-shadow:0 2px 8px #0000001a;padding:20px;min-height:450px}.ring-visualization{text-align:center}.ring-visualization h3{margin-bottom:10px}.ring-info{display:flex;justify-content:center;gap:20px;margin-bottom:15px;font-size:14px;color:#666}.ring-legend{display:flex;justify-content:center;gap:20px;margin-top:15px}.legend-item{display:flex;align-items:center;gap:5px;font-size:12px}.legend-item .dot{width:16px;height:16px;border-radius:50%}.timeline-container{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;padding:20px}.timeline h3{margin-bottom:15px}.timeline-controls{display:flex;align-items:center;justify-content:center;gap:15px;margin-bottom:15px}.timeline-controls button{padding:8px 15px;border:1px solid #ddd;background:#fff;border-radius:4px;cursor:pointer}.timeline-controls button:hover:not(:disabled){background:#f0f0f0}.timeline-controls button:disabled{opacity:.5;cursor:not-allowed}.timeline-weeks{display:flex;flex-wrap:wrap;gap:15px;margin-bottom:20px}.week-block{background:#f9f9f9;border-radius:6px;padding:10px}.week-header{font-size:12px;font-weight:600;color:#666;margin-bottom:8px}.week-days{display:flex;gap:5px}.day-cell{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:#fff;border:1px solid #ddd;border-radius:4px;cursor:pointer;position:relative;font-size:12px}.day-cell:hover{border-color:#667eea}.day-cell.selected{background:#667eea;color:#fff;border-color:#667eea}.day-cell.has-event{background:#e6f7ff}.day-cell.has-conflict{background:#fff1f0;border-color:#ff4d4f}.day-cell.selected.has-event,.day-cell.selected.has-conflict{background:#667eea}.event-dot{position:absolute;top:2px;right:2px;font-size:6px;color:#1890ff}.conflict-dot{position:absolute;bottom:2px;right:2px;font-size:8px;color:#ff4d4f;font-weight:700}.day-details{border-top:1px solid #eee;padding-top:15px}.day-details h4{margin-bottom:10px;font-size:14px}.empty-events{color:#999;font-size:13px}.event-item,.conflict-item{display:flex;align-items:flex-start;gap:8px;padding:8px 10px;background:#f9f9f9;border-radius:4px;margin-bottom:5px;font-size:13px}.conflict-item{background:#fff1f0}.conflict-item.severity-high{background:#ffccc7}.event-icon,.conflict-icon{font-size:14px}.stats-display h3{margin-bottom:20px}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:15px;margin-bottom:25px}.stat-card{background:#f9f9f9;border-radius:8px;padding:15px;text-align:center}.stat-value{font-size:28px;font-weight:700;color:#667eea}.stat-label{font-size:12px;color:#666;margin-top:5px}.stats-section{margin-bottom:20px}.stats-section h4{font-size:14px;margin-bottom:10px;color:#555}.stats-table{width:100%;border-collapse:collapse;font-size:13px}.stats-table th,.stats-table td{padding:8px 12px;text-align:center;border-bottom:1px solid #eee}.stats-table th{background:#f5f5f5;font-weight:600;color:#555}.stats-table td.total{font-weight:600;color:#667eea}.stats-table td.debt{color:#f93}.conflict-stats,.follow-stats{display:flex;flex-wrap:wrap;gap:10px}.conflict-stat-item,.follow-stat-item{background:#f5f5f5;padding:8px 12px;border-radius:4px;font-size:13px}.conflict-count{font-weight:600;margin-left:5px;color:#ff4d4f}.drama-list h3,.drama-section{margin-bottom:20px}.drama-section h4{font-size:14px;color:#555;margin-bottom:10px}.drama-card{background:#f9f9f9;border-radius:6px;padding:12px;margin-bottom:8px;border-left:4px solid #999}.drama-card.active{border-left-color:#52c41a}.drama-card.pending{border-left-color:#faad14}.drama-header{display:flex;justify-content:space-between;margin-bottom:8px}.drama-name{font-weight:600}.drama-status{font-size:12px}.drama-details{font-size:12px;color:#666;display:grid;grid-template-columns:1fr 1fr;gap:4px}.ended-summary{color:#999;font-size:13px}.empty-state{text-align:center;color:#999;padding:40px}@media(max-width:1200px){.app-main{flex-direction:column}.sidebar{width:100%}.stats-grid{grid-template-columns:repeat(2,1fr)}}
