@import "https://fonts.googleapis.com/css2?family=DM+Sans:wght@400;500;600;700;800&family=JetBrains+Mono:wght@500;700&display=swap";:root{--bg:#f0f2f5;--surface:#fff;--border:#e2e6ec;--text:#1a1d23;--text2:#5a6070;--text3:#8a90a0;--accent:#4f46e5;--accent2:#6366f1;--accent-light:#eef2ff;--rose:#e11d48;--rose-light:#fff1f2;--emerald:#059669;--emerald-light:#ecfdf5;--amber:#d97706;--amber-light:#fffbeb;--blue:#2563eb;--blue-light:#eff6ff;--orange:#ea580c;--orange-light:#fff7ed;--purple:#7c3aed;--purple-light:#f5f3ff;--teal:#0d9488;--teal-light:#f0fdfa;--sky:#0284c7;--radius:12px;--radius-lg:16px}[data-theme=dark]{--bg:#111318;--surface:#1a1d24;--border:#2a2e38;--text:#e2e5eb;--text2:#8b92a5;--text3:#5c6378;--accent:#6366f1;--accent2:#818cf8;--accent-light:#1e1b4b;--rose:#fb7185;--rose-light:#1c0c10;--emerald:#34d399;--emerald-light:#0c1f17;--amber:#fbbf24;--amber-light:#1c1508;--blue:#60a5fa;--blue-light:#0c1524;--orange:#fb923c;--orange-light:#1c1208;--purple:#a78bfa;--purple-light:#150f24;--teal:#2dd4bf;--teal-light:#0c1c1a;--sky:#38bdf8}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text);height:100vh;font-family:DM Sans,system-ui,sans-serif;overflow:hidden}button{cursor:pointer;background:0 0;border:none;font-family:inherit}input,textarea,select{font-family:inherit}.app{height:100vh;display:flex;overflow:hidden}.sidebar{background:var(--surface);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;width:290px;display:flex}.sidebar-header{border-bottom:1px solid var(--border);align-items:center;gap:12px;padding:20px;display:flex}.sidebar-logo{background:var(--accent);color:#fff;border-radius:10px;justify-content:center;align-items:center;width:40px;height:40px;font-size:20px;display:flex}.sidebar-title{letter-spacing:-.5px;font-size:20px;font-weight:800}.sidebar-content{flex:1;padding:16px;overflow-y:auto}.sidebar-section-title{color:var(--text3);text-transform:uppercase;letter-spacing:2px;margin-bottom:14px;padding:0 8px;font-size:10px;font-weight:700}.asv-card{margin-bottom:18px;padding:0 4px}.asv-card-header{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.asv-info{align-items:center;gap:10px;display:flex}.asv-avatar{color:#fff;border-radius:10px;justify-content:center;align-items:center;width:36px;height:36px;font-size:14px;font-weight:700;display:flex}.asv-avatar.rose{background:var(--rose)}.asv-avatar.sky{background:var(--sky)}.asv-avatar.emerald{background:var(--emerald)}.asv-name{font-size:14px;font-weight:700}.asv-contract{color:var(--text3);text-transform:uppercase;letter-spacing:.5px;font-size:10px;font-weight:700}.asv-edit-btn{width:28px;height:28px;color:var(--text3);border-radius:8px;justify-content:center;align-items:center;transition:all .2s;display:flex}.asv-edit-btn:hover{background:var(--accent-light);color:var(--accent)}.asv-stats{background:var(--bg);border-radius:var(--radius);border:1px solid var(--border);padding:12px}.stat-row{justify-content:space-between;align-items:center;margin-bottom:6px;font-size:11px;font-weight:700;display:flex}.stat-label{color:var(--text2);text-transform:uppercase;letter-spacing:.3px;font-size:10px}.stat-value{font-family:JetBrains Mono,monospace}.stat-value.over{color:var(--orange)}.stat-value.ok{color:var(--blue)}.progress-bar{background:#e2e6ec;border-radius:4px;height:4px;margin-bottom:10px;overflow:hidden}.progress-fill{border-radius:4px;height:100%;transition:width .5s}.progress-fill.ok{background:var(--blue)}.progress-fill.over{background:var(--orange)}.stat-divider{background:var(--border);height:1px;margin:8px 0}.cp-badge{border-radius:6px;padding:2px 8px;font-size:11px;font-weight:700}.cp-badge.low{background:var(--rose-light);color:var(--rose)}.cp-badge.ok{background:var(--emerald-light);color:var(--emerald)}.cp-row{justify-content:space-between;align-items:center;display:flex}.cp-icon{color:var(--emerald);text-transform:uppercase;letter-spacing:.3px;align-items:center;gap:4px;font-size:11px;font-weight:700;display:flex}.cp-detail{color:var(--text3);justify-content:space-between;margin-top:4px;font-size:10px;display:flex}.sidebar-footer{background:var(--bg);text-align:center;color:var(--text3);border-top:1px solid var(--border);padding:12px;font-size:10px;font-weight:500}.cp-table{border-collapse:collapse;width:100%;margin-top:6px}.cp-table td{padding:4px 0;font-size:11px}.cp-table td:first-child{color:var(--text2);font-weight:600}.cp-table td:last-child{text-align:right;font-family:JetBrains Mono,monospace;font-size:11px;font-weight:700}.cp-table tr.cp-total td{border-top:1px solid var(--border);padding-top:6px;font-size:12px;font-weight:800}.cp-table tr.cp-total td:first-child{color:var(--text)}.cp-section-header{color:var(--text3);text-transform:uppercase;letter-spacing:1px;align-items:center;gap:5px;margin-bottom:2px;font-size:10px;font-weight:700;display:flex}.hours-row{justify-content:space-between;align-items:center;display:flex}.hours-block{flex-direction:column;gap:2px;display:flex}.main{flex-direction:column;flex:1;min-width:0;display:flex}.header{background:var(--surface);border-bottom:1px solid var(--border);z-index:10;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding:12px 20px;display:flex;position:sticky;top:0}.header-left{align-items:center;gap:16px;display:flex}.header-title{font-size:15px;font-weight:700}.header-locked{color:var(--rose);text-transform:uppercase;align-items:center;gap:4px;margin-top:2px;font-size:10px;font-weight:700;display:flex}.nav-group{background:var(--bg);border-radius:8px;align-items:center;gap:2px;padding:2px;display:flex}.nav-btn{color:var(--text2);border-radius:6px;justify-content:center;align-items:center;padding:6px 8px;transition:all .15s;display:flex}.nav-btn:hover{background:var(--surface)}.nav-btn-text{padding:6px 10px;font-size:12px;font-weight:600}.header-right{align-items:center;gap:8px;display:flex}.btn{border:1px solid var(--border);border-radius:8px;align-items:center;gap:6px;padding:8px 14px;font-size:13px;font-weight:600;transition:all .2s;display:flex}.btn-lock{background:var(--surface);color:var(--text2)}.btn-lock:hover{background:var(--bg)}.btn-lock.locked{background:var(--rose-light);color:var(--rose);border-color:#e11d4833}.btn-lock.locked:hover{background:#ffe4e6}.btn-ai{background:var(--accent);color:#fff;border-color:var(--accent);box-shadow:0 2px 8px #4f46e540}.btn-ai:hover{background:var(--accent2)}.btn-ai:disabled{opacity:.4;cursor:not-allowed}.grid-wrap{flex:1;padding:14px;overflow:auto}.cal-grid{background:var(--surface);border-radius:var(--radius-lg);border:1px solid var(--border);position:relative;overflow:hidden}.cal-grid.locked{box-shadow:0 0 0 2px #e11d481f}.locked-badge{z-index:5;background:var(--rose);color:#fff;text-transform:uppercase;letter-spacing:1px;border-radius:20px;align-items:center;gap:6px;padding:4px 12px;font-size:10px;font-weight:700;display:flex;position:absolute;top:10px;right:10px}.grid-table{grid-template-columns:160px repeat(7,minmax(105px,1fr));display:grid}.grid-header-corner{background:var(--bg);border-bottom:1px solid var(--border);border-right:1px solid var(--border);z-index:4;height:52px;position:sticky;top:0;left:0}.grid-header-day{background:var(--bg);border-bottom:1px solid var(--border);z-index:3;flex-direction:column;justify-content:center;align-items:center;height:52px;display:flex;position:sticky;top:0}.grid-header-day-name{color:var(--text3);text-transform:uppercase;letter-spacing:2px;font-size:10px;font-weight:700}.grid-header-day-date{color:var(--text);font-size:14px;font-weight:700}.grid-name-cell{border-bottom:1px solid var(--border);border-right:1px solid var(--border);background:var(--surface);z-index:2;flex-direction:column;justify-content:center;height:120px;padding:12px;display:flex;position:sticky;left:0}.grid-name{font-size:14px;font-weight:700}.grid-role{color:var(--text3);text-transform:uppercase;letter-spacing:.5px;font-size:10px;font-weight:700}.grid-hours-tag{align-items:center;gap:4px;margin-top:6px;display:flex}.grid-hours-dot{border-radius:50%;width:7px;height:7px}.grid-hours-dot.rose{background:var(--rose)}.grid-hours-dot.sky{background:var(--sky)}.grid-hours-dot.emerald{background:var(--emerald)}.grid-hours-text{color:var(--text3);font-size:10px;font-weight:700}.grid-cell{border-bottom:1px solid var(--border);border-right:1px solid var(--border);height:120px;padding:3px;transition:background .15s;position:relative}.grid-cell:not(.locked-cell):hover{background:#00000004}.grid-cell:not(.locked-cell){cursor:pointer}.grid-cell.locked-cell{cursor:not-allowed;opacity:.92}.cell-empty{border:2px dashed #e8eaef;border-radius:10px;justify-content:center;align-items:center;width:100%;height:100%;transition:all .2s;display:flex}.grid-cell:not(.locked-cell):hover .cell-empty{background:var(--surface);border-color:#c8cdd6}.cell-empty svg{color:#d5d8e0;transition:color .2s}.grid-cell:not(.locked-cell):hover .cell-empty svg{color:#a0a6b4}.cell-shift{border:1px solid;border-radius:10px;flex-direction:column;justify-content:space-between;width:100%;height:100%;padding:8px;display:flex;position:relative;overflow:hidden}.cell-shift.t-journee{color:#1e40af;background:#eff6ff;border-color:#bfdbfe}.cell-shift.t-matin{color:#92400e;background:#fffbeb;border-color:#fde68a}.cell-shift.t-apresmidi{color:#9a3412;background:#fff7ed;border-color:#fed7aa}.cell-shift.t-garde{color:#5b21b6;background:#f5f3ff;border-color:#ddd6fe}.cell-shift.t-repos{color:#94a3b8;background:#f8fafc;border-color:#e2e8f0}.cell-shift.t-conges{color:#065f46;background:#ecfdf5;border-color:#a7f3d0}.cell-shift.t-recup{color:#115e59;background:#f0fdfa;border-color:#99f6e4}.shift-type-label{text-transform:uppercase;letter-spacing:.5px;text-overflow:ellipsis;white-space:nowrap;font-size:10px;font-weight:800;overflow:hidden}.shift-times{flex-direction:column;flex:1;justify-content:center;gap:0;display:flex}.shift-time{font-family:JetBrains Mono,monospace;font-size:12px;font-weight:700}.shift-dash{opacity:.4;font-size:10px}.shift-notes{opacity:.65;text-overflow:ellipsis;white-space:nowrap;border-top:1px solid #0000000f;padding-top:3px;font-size:9px;font-style:italic;overflow:hidden}.shift-duration{opacity:.35;font-family:JetBrains Mono,monospace;font-size:10px;font-weight:700;position:absolute;bottom:4px;right:6px}.view-toggle{background:var(--bg);border-radius:8px;gap:2px;padding:2px;display:flex}.view-toggle-btn{color:var(--text3);text-transform:uppercase;letter-spacing:.5px;border-radius:6px;padding:5px 12px;font-size:11px;font-weight:700;transition:all .15s}.view-toggle-btn:hover{color:var(--text2)}.view-toggle-btn.active{background:var(--surface);color:var(--accent);box-shadow:0 1px 3px #00000014}.asv-filter{-webkit-overflow-scrolling:touch;flex-wrap:nowrap;overflow-x:auto}.asv-filter .view-toggle-btn{flex:none;padding:4px 10px;font-size:10px}.month-grid{background:var(--surface);border-radius:var(--radius-lg);border:1px solid var(--border);overflow:hidden}.month-grid-header{grid-template-columns:repeat(7,1fr);display:grid}.month-grid-header-cell{text-align:center;color:var(--text3);text-transform:uppercase;letter-spacing:1.5px;background:var(--bg);border-bottom:1px solid var(--border);padding:10px 4px;font-size:10px;font-weight:700}.month-grid-body{grid-template-columns:repeat(7,1fr);display:grid}.month-day{border-bottom:1px solid var(--border);border-right:1px solid var(--border);min-height:100px;padding:4px;transition:background .15s;position:relative}.month-day:nth-child(7n){border-right:none}.month-day:hover{background:#00000003}.month-day.outside{background:var(--bg);opacity:.4}.month-day.today{background:#eef2ff}.month-day-number{color:var(--text);margin-bottom:4px;padding:2px 4px;font-size:12px;font-weight:700}.month-day.outside .month-day-number{color:var(--text3)}.month-day.today .month-day-number{background:var(--accent);color:#fff;border-radius:6px;padding:1px 6px;display:inline-block}.month-day-shifts{flex-direction:column;gap:2px;display:flex}.month-shift-chip:hover{transform:scale(1.03);box-shadow:0 1px 4px #0000001a}.month-chip-dot{border-radius:50%;flex-shrink:0;width:5px;height:5px}.month-chip-dot.rose{background:var(--rose)}.month-chip-dot.sky{background:var(--sky)}.month-chip-dot.emerald{background:var(--emerald)}.mchip-journee{color:#1e40af;background:#eff6ff;border-color:#bfdbfe}.mchip-matin{color:#92400e;background:#fffbeb;border-color:#fde68a}.mchip-apresmidi{color:#9a3412;background:#fff7ed;border-color:#fed7aa}.mchip-garde{color:#5b21b6;background:#f5f3ff;border-color:#ddd6fe}.mchip-repos{color:#94a3b8;background:#f8fafc;border-color:#e2e8f0}.mchip-conges{color:#065f46;background:#ecfdf5;border-color:#a7f3d0}.mchip-recup{color:#115e59;background:#f0fdfa;border-color:#99f6e4}.month-legend{border-top:1px solid var(--border);background:var(--bg);flex-wrap:wrap;gap:12px;padding:10px 14px;display:flex}.month-legend-item{color:var(--text2);align-items:center;gap:5px;font-size:10px;font-weight:600;display:flex}.btn-cp{background:var(--emerald);color:#fff;border:1px solid var(--emerald);border-radius:8px;align-items:center;gap:6px;padding:8px 14px;font-size:13px;font-weight:600;transition:all .2s;display:flex;box-shadow:0 2px 8px #05966940}.btn-cp:hover{background:#047857}.asv-selector{gap:6px;display:flex}.asv-select-btn{border:2px solid var(--border);border-radius:10px;flex-direction:column;flex:1;align-items:center;gap:6px;padding:10px 8px;transition:all .2s;display:flex}.asv-select-btn:hover{border-color:#c0c4cc}.asv-select-btn.selected{border-color:var(--accent);background:var(--accent-light);box-shadow:0 0 0 2px #4f46e526}.asv-select-avatar{color:#fff;border-radius:10px;justify-content:center;align-items:center;width:36px;height:36px;font-size:14px;font-weight:700;display:flex}.asv-select-name{color:var(--text);font-size:11px;font-weight:700}.date-range-row{grid-template-columns:1fr auto 1fr;align-items:end;gap:8px;display:grid}.date-range-arrow{color:var(--text3);text-align:center;padding-bottom:12px;font-size:18px;font-weight:700}.cp-preview{background:var(--bg);border:1px solid var(--border);border-radius:10px;padding:12px}.cp-preview-title{color:var(--text3);text-transform:uppercase;letter-spacing:1px;margin-bottom:8px;font-size:10px;font-weight:700}.cp-preview-grid{flex-wrap:wrap;gap:4px;display:flex}.cp-preview-day{border-radius:6px;padding:4px 8px;font-size:10px;font-weight:700}.cp-preview-day.cp{background:var(--emerald-light);color:var(--emerald);border:1px solid #a7f3d0}.cp-preview-day.rest{background:var(--bg);color:var(--text3);border:1px solid var(--border)}.cp-summary{justify-content:space-between;margin-top:8px;font-size:11px;font-weight:700;display:flex}.cp-summary-label{color:var(--text2)}.cp-summary-value{color:var(--emerald);font-family:JetBrains Mono,monospace}.synth-modal{max-width:700px}.synth-header{color:#fff;background:linear-gradient(135deg,#1e293b,#334155);padding:24px;position:relative}.synth-header-content{align-items:center;gap:14px;display:flex}.synth-icon{background:#ffffff26;border-radius:14px;justify-content:center;align-items:center;width:50px;height:50px;font-size:22px;display:flex}.synth-title{font-size:22px;font-weight:800}.synth-sub{opacity:.75;font-size:13px}.synth-body{max-height:65vh;padding:20px;overflow-y:auto}.synth-section{margin-bottom:20px}.synth-section-title{color:var(--text3);text-transform:uppercase;letter-spacing:1.5px;align-items:center;gap:6px;margin-bottom:8px;font-size:11px;font-weight:700;display:flex}.synth-table{border-collapse:collapse;width:100%;font-size:12px}.synth-table th{text-align:left;background:var(--bg);color:var(--text3);text-transform:uppercase;letter-spacing:.8px;border-bottom:2px solid var(--border);padding:8px 10px;font-size:10px;font-weight:700}.synth-table th:not(:first-child){text-align:right}.synth-table td{border-bottom:1px solid var(--border);padding:7px 10px;font-weight:500}.synth-table td:not(:first-child){text-align:right;font-family:JetBrains Mono,monospace;font-size:11px;font-weight:600}.synth-table tr.synth-total td{border-top:2px solid var(--text);background:var(--bg);font-size:12px;font-weight:800}.synth-table tr:hover td{background:#4f46e508}.synth-table .positive{color:var(--emerald)}.synth-table .negative{color:var(--rose)}.synth-table .neutral{color:var(--text3)}.synth-asv-header{align-items:center;gap:8px;padding:10px 0 6px;display:flex}.synth-asv-dot{border-radius:50%;width:10px;height:10px}.synth-asv-dot.rose{background:var(--rose)}.synth-asv-dot.sky{background:var(--sky)}.synth-asv-dot.emerald{background:var(--emerald)}.synth-asv-name{font-size:14px;font-weight:800}.synth-asv-contract{color:var(--text3);text-transform:uppercase;font-size:10px;font-weight:700}.synth-footer{border-top:1px solid var(--border);background:var(--bg);justify-content:flex-end;gap:8px;padding:16px 20px;display:flex}.btn-print{background:var(--surface);border:1px solid var(--border);color:var(--text);border-radius:var(--radius);align-items:center;gap:6px;padding:10px 20px;font-weight:600;transition:all .2s;display:flex}.btn-print:hover{background:var(--bg)}.btn-dark{color:#fff;border-radius:var(--radius);background:#1e293b;align-items:center;gap:6px;padding:10px 20px;font-weight:600;transition:all .2s;display:flex;box-shadow:0 2px 8px #00000026}.btn-dark:hover{background:#334155}.synth-info-grid{grid-template-columns:1fr 1fr;gap:10px;margin-bottom:16px;display:grid}.synth-info-card{background:var(--bg);border:1px solid var(--border);border-radius:10px;padding:12px}.synth-info-label{color:var(--text3);text-transform:uppercase;letter-spacing:1px;font-size:9px;font-weight:700}.synth-info-value{color:var(--text);margin-top:2px;font-family:JetBrains Mono,monospace;font-size:18px;font-weight:800}.synth-info-detail{color:var(--text3);font-size:10px}@media print{body{background:#fff!important;overflow:visible!important}body.print-synth .sidebar,body.print-synth .main,body.print-synth .print-only-header{display:none!important}body.print-synth .app{height:auto!important;display:block!important;overflow:visible!important}body.print-synth .modal-overlay{-webkit-backdrop-filter:none!important;backdrop-filter:none!important;background:0 0!important;padding:0!important;display:block!important;position:static!important;overflow:visible!important}body.print-synth .modal{box-shadow:none!important;border-radius:0!important;width:100%!important;max-width:100%!important;overflow:visible!important}body.print-synth .synth-modal{max-width:100%!important;box-shadow:none!important;border:none!important;border-radius:0!important}body.print-synth .synth-header{-webkit-print-color-adjust:exact;print-color-adjust:exact}body.print-synth .synth-footer{display:none!important}body.print-synth .synth-body{max-height:none!important;padding:16px!important;overflow:visible!important}body.print-synth .synth-section{page-break-inside:avoid}body.print-synth .synth-table td,body.print-synth .synth-table th,body.print-synth .synth-asv-dot,body.print-synth .synth-info-card,body.print-synth .synth-table tr.synth-total td{-webkit-print-color-adjust:exact;print-color-adjust:exact}body.print-grid .sidebar,body.print-grid .header,body.print-grid .modal-overlay{display:none!important}body.print-grid .app,body.print-grid .main{height:auto!important;display:block!important;overflow:visible!important}body.print-grid .grid-wrap{padding:0!important;overflow:visible!important}body.print-grid .cal-grid{box-shadow:none;border:2px solid #333;overflow:visible!important}body.print-grid .grid-table{overflow:visible!important}body.print-grid .cell-shift{-webkit-print-color-adjust:exact;print-color-adjust:exact}body.print-grid .grid-cell,body.print-grid .grid-name-cell{height:90px!important}body.print-grid .month-day,body.print-grid .month-shift-chip{-webkit-print-color-adjust:exact;print-color-adjust:exact}body.print-grid .print-only-header{display:block!important}@page{size:landscape;margin:8mm}}.modal-overlay{z-index:50;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#0006;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.modal{background:var(--surface);border-radius:var(--radius-lg);width:100%;animation:.2s modalIn;overflow:hidden;box-shadow:0 25px 60px #0003}.modal-sm{max-width:380px}.modal-md{max-width:440px}.modal-lg{max-width:500px}@keyframes modalIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:18px 20px;display:flex}.modal-title{font-size:18px;font-weight:700}.modal-subtitle{color:var(--text2);font-size:13px}.modal-close{width:32px;height:32px;color:var(--text3);border-radius:50%;justify-content:center;align-items:center;transition:all .2s;display:flex}.modal-close:hover{background:var(--bg);color:var(--text)}.modal-body{padding:20px}.form-label{color:var(--text);margin-bottom:6px;font-size:13px;font-weight:600;display:block}.form-input{background:var(--bg);border:1px solid var(--border);border-radius:10px;outline:none;width:100%;padding:10px 14px;font-size:14px;transition:all .2s}.form-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #4f46e51a}.form-textarea{resize:none;height:80px;font-size:13px}.type-grid{grid-template-columns:1fr 1fr;gap:6px;display:grid}.type-btn{border:1px solid var(--border);text-align:left;border-radius:8px;align-items:center;gap:6px;padding:8px 12px;font-size:11px;font-weight:700;transition:all .2s;display:flex}.type-btn:hover{border-color:#c0c4cc}.type-btn.active{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 2px 8px #4f46e540}.type-btn.absence{background:var(--bg);color:var(--text2)}.time-grid{grid-template-columns:1fr 1fr;gap:12px;display:grid}.recup-row{gap:6px;display:flex}.recup-btn{background:var(--surface);color:var(--teal);border:1px solid #0d948833;border-radius:8px;flex:1;justify-content:center;align-items:center;gap:4px;padding:8px;font-size:10px;font-weight:700;transition:all .2s;display:flex}.recup-btn:hover{background:var(--teal-light)}.modal-actions{flex-wrap:wrap;gap:8px;padding-top:14px;display:flex}.btn-cancel{background:var(--bg);color:var(--text2);border-radius:var(--radius);flex:0;padding:10px 18px;font-weight:600;transition:all .2s}.btn-cancel:hover{background:#e2e6ec}.btn-delete{background:var(--rose-light);min-width:120px;color:var(--rose);border-radius:var(--radius);border:1px solid #e11d481a;flex:1;justify-content:center;align-items:center;gap:6px;padding:10px;font-weight:600;transition:all .2s;display:flex}.btn-delete:hover{background:#fecdd3}.btn-submit{background:var(--accent);color:#fff;border-radius:var(--radius);flex:1;justify-content:center;align-items:center;gap:6px;min-width:120px;padding:10px;font-weight:600;transition:all .2s;display:flex;box-shadow:0 2px 8px #4f46e540}.btn-submit:hover{background:var(--accent2)}.btn-save-green{background:var(--emerald);color:#fff;border-radius:var(--radius);flex:1;justify-content:center;align-items:center;gap:6px;padding:12px;font-weight:600;display:flex;box-shadow:0 2px 8px #05966940}.btn-save-green:hover{background:#047857}.ai-header{background:linear-gradient(135deg, var(--accent), #3b82f6);color:#fff;padding:28px;position:relative}.ai-header-content{align-items:center;gap:14px;display:flex}.ai-icon{background:#fff3;border-radius:14px;justify-content:center;align-items:center;width:50px;height:50px;font-size:24px;display:flex}.ai-title{font-size:22px;font-weight:800}.ai-sub{opacity:.8;font-size:13px}.ai-close{color:#fff;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;transition:all .2s;display:flex;position:absolute;top:14px;right:14px}.ai-close:hover{background:#ffffff26}.rules-list{flex-direction:column;gap:6px;display:flex}.rule-item{border:1px solid;border-radius:10px;align-items:center;gap:10px;padding:10px 12px;font-size:12px;font-weight:500;display:flex}.rule-item.green{background:var(--emerald-light);color:#065f46;border-color:#a7f3d0}.rule-item.blue{background:var(--blue-light);color:#1e40af;border-color:#bfdbfe}.rule-item.amber{background:var(--amber-light);color:#92400e;border-color:#fde68a}.rule-dot{border-radius:50%;flex-shrink:0;width:7px;height:7px}.rule-dot.green{background:var(--emerald)}.rule-dot.blue{background:var(--blue)}.rule-dot.amber{background:var(--amber)}.btn-generate{background:var(--accent);color:#fff;border-radius:14px;justify-content:center;align-items:center;gap:10px;width:100%;padding:16px;font-size:16px;font-weight:700;transition:all .2s;display:flex;box-shadow:0 4px 16px #4f46e54d}.btn-generate:hover{background:var(--accent2)}.btn-generate:disabled{opacity:.5;cursor:not-allowed}.btn-generate .spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:22px;height:22px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.ai-info{color:var(--text3);align-items:center;gap:4px;margin-top:6px;font-size:11px;display:flex}.cp-modal-banner{background:var(--emerald-light);border-radius:var(--radius);border:1px solid #a7f3d0;align-items:center;gap:12px;padding:14px;display:flex}.cp-modal-icon{background:var(--emerald);color:#fff;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:20px;display:flex}.cp-modal-text{color:#065f46;text-transform:uppercase;font-size:11px;font-weight:700}.cp-modal-sub{color:#059669;font-size:11px}.input-suffix{position:relative}.input-suffix .form-input{padding-right:60px;font-size:18px;font-weight:700}.input-suffix .suffix{color:var(--text3);text-transform:uppercase;font-size:10px;font-weight:700;position:absolute;top:50%;right:14px;transform:translateY(-50%)}.form-note{color:var(--text3);margin-top:8px;font-size:11px;font-style:italic}.icon{justify-content:center;align-items:center;display:inline-flex}@media (width<=768px){body{height:auto;overflow:auto}.app{flex-direction:column;height:auto;min-height:100vh;overflow:auto}.sidebar:not(.drawer){display:none}.hamburger{display:flex}.main{min-height:0;overflow:auto}.header{flex-wrap:wrap;gap:6px;padding:8px 10px;position:relative}.header-left{flex-wrap:wrap;gap:6px;width:100%}.header-title{font-size:13px}.header-right{flex-wrap:wrap;justify-content:flex-start;gap:4px;width:100%}.nav-group,.view-toggle{order:-1}.view-toggle-btn{padding:4px 8px;font-size:9px}.btn{padding:5px 8px;font-size:10px}.btn-lock,.btn-ai{font-size:10px}.nav-btn{padding:4px 6px;font-size:12px}.grid-wrap{-webkit-overflow-scrolling:touch;padding:6px;overflow:auto}.cal-grid{-webkit-overflow-scrolling:touch;overflow-x:auto}.grid-table{grid-template-columns:100px repeat(7,minmax(90px,1fr));min-width:800px;font-size:11px}.grid-header-corner,.grid-header-day{height:40px}.grid-header-day-name{letter-spacing:1px;font-size:8px}.grid-header-day-date{font-size:11px}.grid-name-cell{height:90px;padding:6px}.grid-name{font-size:11px}.grid-cell{height:90px;padding:2px}.cell-shift{border-radius:6px;padding:4px}.shift-type-label{font-size:9px}.shift-times,.shift-duration{font-size:8px}.shift-notes{font-size:7px}.drag-handle{display:none}.cell-empty{border-width:1px;font-size:14px}.month-grid-container{-webkit-overflow-scrolling:touch;overflow-x:auto}.month-grid-container .grid-table{min-width:800px}.modal-inner{max-height:90vh;margin:10px;max-width:95vw!important}.modal-body{max-height:60vh}.team-modal{max-width:95vw}.team-form-row{grid-template-columns:1fr}}.toast-container{z-index:1000;pointer-events:none;flex-direction:column;gap:8px;display:flex;position:fixed;bottom:20px;right:20px}.toast{pointer-events:auto;border-radius:10px;align-items:center;gap:10px;min-width:280px;max-width:400px;padding:12px 18px;font-size:13px;font-weight:600;animation:.3s toastIn,.3s 2.7s forwards toastOut;display:flex;box-shadow:0 8px 24px #00000026}.toast-success{color:#fff;background:#059669}.toast-error{color:#fff;background:#e11d48}.toast-info{color:#fff;background:#2563eb}.toast-warning{color:#fff;background:#d97706}@keyframes toastIn{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}@keyframes toastOut{0%{opacity:1}to{opacity:0;transform:translate(50px)}}@keyframes fadeSlideIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.cell-shift{animation:.3s fadeSlideIn}.drawer-overlay{z-index:40;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0006;display:none;position:fixed;inset:0}.drawer-overlay.open{display:block}.sidebar.drawer{z-index:41;transition:transform .3s;position:fixed;top:0;bottom:0;left:0;transform:translate(-100%)}.sidebar.drawer.open{transform:translate(0)}.hamburger{width:36px;height:36px;color:var(--text2);border:1px solid var(--border);background:var(--surface);border-radius:8px;justify-content:center;align-items:center;display:none}.confirm-overlay{z-index:60;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.confirm-box{background:var(--surface);border-radius:var(--radius-lg);width:100%;max-width:380px;padding:24px;animation:.2s modalIn;box-shadow:0 20px 50px #0003}.confirm-title{margin-bottom:8px;font-size:16px;font-weight:700}.confirm-msg{color:var(--text2);margin-bottom:18px;font-size:13px;line-height:1.5}.confirm-actions{justify-content:flex-end;gap:8px;display:flex}.history-list{max-height:400px;overflow-y:auto}.history-item{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:10px 14px;display:flex}.history-action{font-size:13px;font-weight:600}.history-detail{color:var(--text3);font-size:11px}.history-time{color:var(--text3);white-space:nowrap;font-family:JetBrains Mono,monospace;font-size:10px}.search-box{position:relative}.search-input{border:1px solid var(--border);background:var(--bg);width:160px;color:var(--text);border-radius:8px;outline:none;padding:6px 12px 6px 32px;font-family:inherit;font-size:12px;font-weight:500;transition:all .2s}.search-input:focus{border-color:var(--accent);width:220px;box-shadow:0 0 0 3px #4f46e51a}.search-icon{color:var(--text3);pointer-events:none;position:absolute;top:50%;left:10px;transform:translateY(-50%)}.search-clear{width:18px;height:18px;color:var(--text3);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;display:flex;position:absolute;top:50%;right:6px;transform:translateY(-50%)}.search-clear:hover{background:var(--border)}.settings-btn{color:var(--text3);border-radius:8px;align-items:center;gap:6px;width:100%;padding:6px 10px;font-size:11px;font-weight:600;transition:all .2s;display:flex}.settings-btn:hover{background:var(--bg);color:var(--text2)}.settings-section{margin-bottom:16px}.settings-section-title{color:var(--text3);text-transform:uppercase;letter-spacing:1.5px;margin-bottom:8px;font-size:10px;font-weight:700}.grid-cell.drag-over .cell-empty{border-color:var(--accent);background:var(--accent-light);border-style:solid}.grid-cell.drag-over .cell-shift{outline:2px dashed var(--accent);outline-offset:2px}.grid-cell.dragging{opacity:.5}.grid-cell[draggable=true] .cell-shift{cursor:grab}.grid-cell[draggable=true]:active .cell-shift{cursor:grabbing}.drag-handle{color:var(--text3);opacity:0;cursor:grab;-webkit-user-select:none;user-select:none;font-size:10px;transition:opacity .15s;position:absolute;top:4px;right:4px}.grid-cell:hover .drag-handle{opacity:.6}.grid-cell:hover .drag-handle:hover{opacity:1}.grid-header-day.today{background:var(--accent-light)!important}.grid-header-day.today .grid-header-day-name{color:var(--accent)}.grid-header-day.today .grid-header-day-date{color:var(--accent);font-weight:800}.month-shift-chip{cursor:pointer;white-space:nowrap;text-overflow:ellipsis;border:1px solid #0000;border-radius:4px;align-items:center;gap:3px;padding:2px 5px;font-size:9px;font-weight:700;transition:all .15s;display:flex;overflow:hidden}.team-modal{max-width:560px}.team-header{background:linear-gradient(135deg, var(--accent), #3b82f6);color:#fff;padding:24px;position:relative}.team-list{max-height:300px;overflow-y:auto}.team-item{border-bottom:1px solid var(--border);align-items:center;gap:12px;padding:12px 16px;transition:background .15s;display:flex}.team-item:hover{background:var(--bg)}.team-item-info{flex:1;min-width:0}.team-item-name{font-size:14px;font-weight:700}.team-item-detail{color:var(--text3);flex-wrap:wrap;gap:8px;font-size:11px;display:flex}.team-item-actions{gap:4px;display:flex}.team-action-btn{width:30px;height:30px;color:var(--text3);border-radius:8px;justify-content:center;align-items:center;transition:all .2s;display:flex}.team-action-btn:hover{background:var(--accent-light);color:var(--accent)}.team-action-btn.delete:hover{background:var(--rose-light);color:var(--rose)}.team-add-btn{width:100%;color:var(--accent);border-top:1px solid var(--border);justify-content:center;align-items:center;gap:8px;padding:12px;font-size:13px;font-weight:600;transition:all .2s;display:flex}.team-add-btn:hover{background:var(--accent-light)}.team-form{flex-direction:column;gap:12px;padding:20px;display:flex}.team-form-row{grid-template-columns:1fr 1fr;gap:10px;display:grid}.color-picker{flex-wrap:wrap;gap:6px;display:flex}.color-dot{cursor:pointer;border:3px solid #0000;border-radius:10px;justify-content:center;align-items:center;width:32px;height:32px;transition:all .2s;display:flex}.color-dot:hover{transform:scale(1.1)}.color-dot.selected{border-color:var(--text);box-shadow:0 0 0 2px var(--surface), 0 0 0 4px var(--text)}.color-dot.c-rose{background:var(--rose)}.color-dot.c-sky{background:var(--sky)}.color-dot.c-emerald{background:var(--emerald)}.color-dot.c-amber{background:var(--amber)}.color-dot.c-purple{background:var(--purple)}.color-dot.c-teal{background:var(--teal)}.color-dot.c-blue{background:var(--blue)}.color-dot.c-orange{background:var(--orange)}.sidebar-team-btn{color:var(--accent);background:var(--accent-light);border:1px solid #4f46e526;border-radius:10px;align-items:center;gap:8px;width:calc(100% - 8px);margin:0 4px 12px;padding:10px 12px;font-size:12px;font-weight:700;transition:all .2s;display:flex}.sidebar-team-btn:hover{background:var(--accent);color:#fff}
