*{margin:0;padding:0;box-sizing:border-box}:root{--sidebar-width: 220px;--color-bg: #f5f6fa;--color-sidebar: #1a1a2e;--color-sidebar-hover: #16213e;--color-sidebar-active: #0f3460;--color-primary: #007aff;--color-danger: #ff3b30;--color-success: #34c759;--color-warning: #ff9500;--color-text: #1c1c1e;--color-text-secondary: #8e8e93;--color-border: #e5e5ea;--color-card: #ffffff;--radius: 10px}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background:var(--color-bg);color:var(--color-text);line-height:1.5}.app-layout{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-width);background:var(--color-sidebar);color:#fff;padding:20px 0;position:fixed;top:0;left:0;bottom:0;display:flex;flex-direction:column}.sidebar-title{font-size:18px;font-weight:700;padding:0 20px 20px;border-bottom:1px solid rgba(255,255,255,.1);margin-bottom:8px}.sidebar nav{flex:1}.sidebar a{display:flex;align-items:center;gap:10px;padding:12px 20px;color:#ffffffb3;text-decoration:none;font-size:14px;font-weight:500;transition:background .15s,color .15s}.sidebar a:hover{background:var(--color-sidebar-hover);color:#fff}.sidebar a.active{background:var(--color-sidebar-active);color:#fff}.sidebar-footer{padding:12px 20px;border-top:1px solid rgba(255,255,255,.1)}.sidebar-footer button{background:none;border:none;color:#ffffff80;cursor:pointer;font-size:13px;padding:4px 0}.sidebar-footer button:hover{color:#fff}.main-content{margin-left:var(--sidebar-width);padding:28px 32px;flex:1;min-width:0}.page-title{font-size:24px;font-weight:700;margin-bottom:24px}.card{background:var(--color-card);border-radius:var(--radius);padding:20px;box-shadow:0 1px 3px #0000000f}.collapsible-header:hover{background:#00000008;border-radius:6px;margin:-4px -4px 0;padding:4px}.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px}.stat-card{background:var(--color-card);border-radius:var(--radius);padding:20px;box-shadow:0 1px 3px #0000000f}.stat-card .label{font-size:13px;color:var(--color-text-secondary);font-weight:500;text-transform:uppercase;letter-spacing:.5px}.stat-card .value{font-size:32px;font-weight:700;margin-top:4px}.table-container{background:var(--color-card);border-radius:var(--radius);box-shadow:0 1px 3px #0000000f;overflow:hidden}table{width:100%;border-collapse:collapse}th{text-align:left;padding:12px 16px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-secondary);background:#fafafa;border-bottom:1px solid var(--color-border)}td{padding:12px 16px;font-size:14px;border-bottom:1px solid var(--color-border);vertical-align:middle}tr:last-child td{border-bottom:none}tr:hover td{background:#f9f9fb}.badge{display:inline-block;padding:2px 8px;border-radius:12px;font-size:12px;font-weight:600}.badge-green{background:#e8f8eb;color:#1b7a2d}.badge-red{background:#fde8e8;color:#c62828}.badge-blue{background:#e8f0fe;color:#1a56db}.badge-orange{background:#fff3e0;color:#e65100}.badge-yellow{background:#fff9e6;color:#92700c}.badge-gray{background:#f2f2f7;color:#666}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:8px;font-size:14px;font-weight:500;border:none;cursor:pointer;transition:opacity .15s}.btn:hover{opacity:.85}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--color-primary);color:#fff}.btn-danger{background:var(--color-danger);color:#fff}.btn-success{background:var(--color-success);color:#fff}.btn-secondary{background:#e5e5ea;color:var(--color-text)}.btn-sm{padding:4px 10px;font-size:13px}.form-group{margin-bottom:16px}.form-group label{display:block;font-size:13px;font-weight:600;color:var(--color-text-secondary);margin-bottom:4px}.form-group input,.form-group select,.form-group textarea{width:100%;padding:10px 12px;border:1px solid var(--color-border);border-radius:8px;font-size:14px;font-family:inherit;background:#fff;transition:border-color .15s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #007aff1a}.form-group textarea{resize:vertical;min-height:80px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.pagination{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;font-size:14px;color:var(--color-text-secondary)}.search-bar{display:flex;gap:8px;align-items:center;margin-bottom:16px}.search-bar input{flex:1;max-width:400px;padding:10px 14px;border:1px solid var(--color-border);border-radius:8px;font-size:14px}.search-bar input:focus{outline:none;border-color:var(--color-primary)}.login-container{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--color-bg)}.login-card{background:var(--color-card);border-radius:16px;padding:40px;width:100%;max-width:400px;box-shadow:0 4px 20px #00000014;text-align:center}.login-card h1{font-size:22px;margin-bottom:8px}.login-card p{color:var(--color-text-secondary);margin-bottom:24px;font-size:14px}.login-card input{width:100%;padding:12px 14px;border:1px solid var(--color-border);border-radius:8px;font-size:15px;margin-bottom:16px;text-align:center;letter-spacing:1px}.login-card input:focus{outline:none;border-color:var(--color-primary)}.login-card .btn{width:100%;justify-content:center;padding:12px;font-size:15px}.error-text{color:var(--color-danger);font-size:13px;margin-bottom:12px}.support-layout{display:grid;grid-template-columns:320px 1fr;gap:16px;height:calc(100vh - 120px)}.thread-list{background:var(--color-card);border-radius:var(--radius);box-shadow:0 1px 3px #0000000f;overflow-y:auto}.thread-item{padding:14px 16px;border-bottom:1px solid var(--color-border);cursor:pointer;transition:background .1s}.thread-item:hover{background:#f9f9fb}.thread-item.active{background:#e8f0fe}.thread-item .name{font-weight:600;font-size:14px}.thread-item .preview{font-size:13px;color:var(--color-text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:2px}.thread-item .meta{display:flex;align-items:center;justify-content:space-between;margin-top:4px}.thread-item .time{font-size:11px;color:var(--color-text-secondary)}.unread-badge{background:var(--color-primary);color:#fff;border-radius:10px;padding:1px 7px;font-size:11px;font-weight:700}.message-panel{background:var(--color-card);border-radius:var(--radius);box-shadow:0 1px 3px #0000000f;display:flex;flex-direction:column}.message-panel-header{padding:16px;border-bottom:1px solid var(--color-border);font-weight:600}.message-list{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:10px}.message-bubble{max-width:70%;padding:10px 14px;border-radius:12px;font-size:14px;line-height:1.4}.message-bubble.user{align-self:flex-start;background:#f2f2f7}.message-bubble.admin{align-self:flex-end;background:var(--color-primary);color:#fff}.message-bubble .time{font-size:11px;opacity:.6;margin-top:4px}.message-order-tag{font-size:11px;font-weight:600;font-family:monospace;padding:3px 8px;border-radius:6px;background:#00000014;margin-bottom:6px;display:inline-block}.reply-bar{display:flex;gap:8px;padding:12px 16px;border-top:1px solid var(--color-border)}.reply-bar input{flex:1;padding:10px 14px;border:1px solid var(--color-border);border-radius:8px;font-size:14px}.reply-bar input:focus{outline:none;border-color:var(--color-primary)}.banner-preview{width:120px;height:60px;object-fit:cover;border-radius:6px;background:#f2f2f7}.toggle{position:relative;display:inline-block;width:44px;height:24px;cursor:pointer}.toggle input{opacity:0;width:0;height:0;position:absolute}.toggle .slider{position:absolute;inset:0;background:#e5e5ea;border-radius:12px;transition:background .2s}.toggle .slider:after{content:"";position:absolute;width:20px;height:20px;background:#fff;border-radius:50%;top:2px;left:2px;transition:transform .2s;box-shadow:0 1px 3px #00000026}.toggle.active .slider{background:var(--color-success)}.toggle.active .slider:after{transform:translate(20px)}.spinner{display:flex;align-items:center;justify-content:center;padding:60px;color:var(--color-text-secondary);font-size:14px}.empty-state{text-align:center;padding:60px 20px;color:var(--color-text-secondary)}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal{background:var(--color-card);border-radius:var(--radius);padding:24px;width:100%;max-width:400px;box-shadow:0 8px 32px #0003}.modal h3{font-size:18px;margin-bottom:4px}.modal-subtitle{font-size:13px;color:var(--color-text-secondary);margin-bottom:20px}.modal .form-group{margin-bottom:16px}.form-error{color:var(--color-danger);font-size:13px;margin-bottom:12px}.modal-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:20px}.day-picker{display:flex;gap:6px;flex-wrap:wrap}.day-pill{display:inline-flex;align-items:center;justify-content:center;width:44px;height:36px;border-radius:8px;border:1px solid var(--color-border);background:#fff;font-size:13px;font-weight:500;color:var(--color-text);cursor:pointer;transition:background .15s,border-color .15s,color .15s}.day-pill:hover{border-color:var(--color-primary)}.day-pill.active{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.day-badges{display:flex;gap:3px}.day-badge{display:inline-flex;align-items:center;justify-content:center;width:28px;height:22px;border-radius:4px;font-size:10px;font-weight:600;background:#f2f2f7;color:#bbb}.day-badge.active{background:#e8f0fe;color:#1a56db}.run-detail{background:#fafafa;border-top:1px solid var(--color-border)}.cal-grid{border:1px solid var(--color-border);border-radius:8px;overflow:hidden;background:#fff}.cal-header{display:grid;grid-template-columns:repeat(7,1fr);background:#f0f0f4;border-bottom:1px solid var(--color-border)}.cal-header-cell{padding:8px 4px;text-align:center;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-secondary)}.cal-row{display:grid;grid-template-columns:repeat(7,1fr)}.cal-row:not(:last-child){border-bottom:1px solid var(--color-border)}.cal-cell{min-height:100px;padding:6px;border-right:1px solid var(--color-border)}.cal-cell:last-child{border-right:none}.cal-cell-outside{background:#f9f9fb;opacity:.4}.cal-cell-weekend{background:#fafbff}.cal-date{font-size:11px;font-weight:600;color:var(--color-text-secondary);margin-bottom:4px}.cal-shifts{display:flex;flex-direction:column;gap:3px}.cal-shift-chip{display:flex;align-items:center;justify-content:space-between;gap:4px;padding:3px 6px;border-radius:4px;font-size:11px;font-weight:500;border:1px solid;line-height:1.3}.cal-shift-name{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cal-shift-time{font-size:10px;opacity:.75;white-space:nowrap}.cal-chip-unassigned{border-style:dashed;border-width:2px;font-style:italic}.cal-summary{margin-top:16px}.cal-summary-title{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-secondary);margin-bottom:8px}.cal-summary-list{border:1px solid var(--color-border);border-radius:8px;overflow:hidden}.cal-summary-list-header{display:flex;align-items:center;padding:8px 14px;background:var(--color-bg-secondary);border-bottom:1px solid var(--color-border);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:var(--color-text-secondary)}.cal-summary-row{display:flex;align-items:center;padding:8px 14px;border-bottom:1px solid var(--color-border);font-size:13px}.cal-summary-row:last-child{border-bottom:none}.cal-summary-row:hover{background:var(--color-bg-secondary)}.cal-summary-col-name{flex:1;font-weight:600;font-size:13px}.cal-summary-col{width:60px;text-align:center;font-weight:600;font-size:13px}.cal-summary-open{color:#1a56db;font-weight:600}.cal-summary-close{color:#92700c;font-weight:600}.cal-summary-weekend{color:var(--color-warning);font-weight:600}.cal-legend{display:flex;gap:20px;margin-top:12px;padding:0 4px}.cal-legend-item{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--color-text-secondary)}.cal-legend-swatch{display:inline-block;width:14px;height:14px;border-radius:3px;border:1px solid}.config-section-label{font-size:14px;font-weight:600;color:#8e8e93;text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px}.to-form{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.to-form select,.to-form input{padding:6px 10px;border:1px solid var(--color-border);border-radius:6px;font-size:13px}.to-form select{min-width:160px}.to-cal-grid{display:grid;gap:0;border:1px solid var(--color-border);border-radius:8px;overflow-x:auto}.to-cal-header-cell{background:var(--color-bg-secondary);padding:6px 4px;font-size:11px;font-weight:600;color:var(--color-text-secondary);text-align:center;border-bottom:1px solid var(--color-border);display:flex;flex-direction:column;align-items:center;gap:1px;min-width:44px}.to-cal-header-cell.to-cal-wknd{background:#f5f3ff}.to-cal-day-label{font-size:10px;text-transform:uppercase;letter-spacing:.5px}.to-cal-date-label{font-size:11px;font-weight:700;color:var(--color-text-primary)}.to-cal-row{display:contents}.to-cal-name{padding:8px 10px;font-size:12px;font-weight:600;border-bottom:1px solid var(--color-border);display:flex;flex-direction:column;justify-content:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.to-cal-job{font-size:10px;font-weight:400;color:var(--color-text-secondary)}.to-cal-cell{display:flex;justify-content:center;align-items:center;padding:4px;border-bottom:1px solid var(--color-border);min-height:32px;min-width:44px}.to-cal-cell.to-cal-wknd{background:#faf9ff}.to-cal-cell.to-cal-off{background:#fde8e8}.to-cal-off-label{font-size:10px;font-weight:700;color:#c62828;letter-spacing:.5px}.to-list{border-top:1px solid var(--color-border);padding-top:12px}.to-entry{display:flex;align-items:center;gap:12px;padding:8px 0;border-bottom:1px solid var(--color-border);font-size:13px}.to-entry-name{font-weight:600;min-width:120px}.to-entry-dates{color:var(--color-text-secondary)}.to-entry-reason{color:var(--color-text-secondary);font-style:italic}.wknd-list{display:flex;flex-direction:column;gap:6px}.wknd-row{display:flex;align-items:center;gap:12px;padding:8px 12px;border-radius:8px;background:var(--color-bg-secondary)}.wknd-name{font-size:13px;font-weight:600;min-width:140px}.dc-grid{display:grid;grid-template-columns:60px repeat(7,1fr);gap:0;border:1px solid var(--color-border);border-radius:8px;overflow:hidden}.dc-header-cell{background:var(--color-bg-secondary);padding:8px 4px;font-size:12px;font-weight:600;color:var(--color-text-secondary);text-align:center;border-bottom:1px solid var(--color-border)}.dc-header-cell.dc-wknd{background:#f5f3ff}.dc-label{padding:8px 10px;font-size:12px;font-weight:600;border-bottom:1px solid var(--color-border);display:flex;align-items:center}.dc-cell{display:flex;justify-content:center;align-items:center;padding:4px;border-bottom:1px solid var(--color-border)}.dc-cell.dc-wknd{background:#faf9ff}.dc-input{width:44px;padding:4px 6px;border:2px solid #ddd;border-radius:6px;font-size:14px;font-weight:700;text-align:center;transition:border-color .15s}.dc-input:focus{outline:none}.dc-input-open:focus{border-color:#1a56db}.dc-input-close:focus{border-color:#92700c}.ov-entry{display:flex;align-items:center;gap:12px;padding:8px 0;border-bottom:1px solid var(--color-border);font-size:13px}.ov-label{font-weight:600;min-width:100px}.ov-dates{color:var(--color-text-secondary)}.ov-counts{font-weight:500;color:var(--color-text-primary)}.sc-grid{display:grid;grid-template-columns:50px repeat(7,1fr);gap:0;border:1px solid var(--color-border);border-radius:8px;overflow:hidden}.sc-header-cell{background:var(--color-bg-secondary);padding:6px 4px;font-size:11px;font-weight:600;color:var(--color-text-secondary);text-align:center;border-bottom:1px solid var(--color-border)}.sc-header-cell.sc-wknd{background:#f5f3ff}.sc-label{padding:6px 8px;font-size:11px;font-weight:600;border-bottom:1px solid var(--color-border);display:flex;align-items:center}.sc-label-open{color:#1a56db}.sc-label-close{color:#92700c}.sc-cell{display:flex;justify-content:center;align-items:center;padding:4px;border-bottom:1px solid var(--color-border)}.sc-cell.sc-wknd{background:#faf9ff}.sc-toggle{width:28px;height:28px;border-radius:6px;border:2px solid #ddd;cursor:pointer;transition:all .15s}.sc-toggle.sc-on{background:#34c759;border-color:#2da44e}.sc-toggle.sc-off{background:#f5f5f5;border-color:#ddd}.sc-toggle.sc-off:hover{border-color:#999}.sc-toggle.sc-on:hover{background:#2da44e}
