:root{--sans:Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", "Noto Sans Thai", "Helvetica Neue", Arial, sans-serif;font-family:var(--sans);color:#242628;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#fbfaf7}*{box-sizing:border-box}html{background:#fbfaf7;min-width:320px;min-height:100%}body{background:linear-gradient(#3f876f1f,#0000 280px),radial-gradient(circle at 100% 0,#c94d3f1a,#0000 260px),#fbfaf7;min-width:320px;min-height:100svh;margin:0}button,input,select{font:inherit}button:focus-visible,input:focus-visible,select:focus-visible{outline-offset:2px;outline:3px solid #3f79a76b}#root{min-height:100svh}.app-shell{width:min(100%,1040px);margin:0 auto;padding:18px 14px 44px}.topbar,.date-panel,.actions,.shift-heading,.role-row,.calendar-heading,.calendar-legend,.selected-day,.export-panel,.history-heading,.history-day,.panel-heading,.toggle-chip,.staff-row,.backup-action,.mini-action,.undo-panel,.undo-panel button,.pdf-title,.pdf-shift p{align-items:center;display:flex}.topbar{justify-content:space-between;gap:16px;padding:8px 2px 16px}.eyebrow,.topbar h1,.shift-heading p,.shift-heading h2,.pdf-title p,.pdf-title h2{margin:0}.eyebrow{color:#7b6f63;font-size:13px;font-weight:700}.topbar h1{color:#1f2428;font-size:34px;line-height:1}.icon-button,.pdf-main-button,.primary-action,.ghost-action{cursor:pointer;border:0;min-height:44px;transition:transform .16s,box-shadow .16s,background .16s}.icon-button:active,.pdf-main-button:active,.primary-action:active,.ghost-action:active{transform:scale(.98)}.primary-action:disabled{cursor:not-allowed;color:#fff;box-shadow:none;background:#bdb5aa}.icon-button{color:#24292d;background:#fff;border-radius:8px;width:46px;height:46px;box-shadow:0 1px #ded8cf,0 8px 20px #2d261e14}.pdf-main-button{color:#fff;background:#25342f;border-radius:8px;justify-content:center;align-items:center;gap:7px;min-width:76px;height:46px;font-weight:900;display:inline-flex;box-shadow:0 10px 22px #25342f2e}.export-panel{background:#ffffffd1;border:1px solid #ded6cb;border-radius:8px;justify-content:space-between;gap:12px;margin-bottom:12px;padding:10px;box-shadow:0 10px 24px #362b1e12}.settings-panel{background:#ffffffd1;border:1px solid #ded6cb;border-radius:8px;margin-top:14px;overflow:hidden;box-shadow:0 10px 24px #362b1e12}.settings-panel summary{cursor:pointer;color:#202326;justify-content:space-between;align-items:center;min-height:52px;padding:0 14px;font-weight:900;list-style:none;display:flex}.settings-panel summary::-webkit-details-marker{display:none}.settings-panel summary:after{content:"+";color:#34322e;background:#ece6dc;border-radius:999px;place-items:center;width:28px;height:28px;display:grid}.settings-panel[open] summary:after{content:"-"}.settings-panel>section{margin:0 10px 10px}.export-copy{text-align:left;min-width:0}.export-copy strong,.export-copy span{display:block}.export-copy strong{color:#202326;font-size:14px;line-height:1.2}.export-copy span{color:#7b6f63;margin-top:2px;font-size:12px;font-weight:900}.range-tabs{background:#ece6dc;border-radius:8px;flex:0 430px;grid-template-columns:repeat(3,minmax(0,1fr));gap:4px;min-width:0;padding:4px;display:grid}.range-tab{color:#5f574f;cursor:pointer;background:0 0;border:0;border-radius:6px;min-width:0;min-height:38px;padding:0 8px;font-size:13px;font-weight:900}.range-tab.active{color:#fff;background:#25342f;box-shadow:0 8px 18px #25342f2e}.history-panel{background:#ffffffd1;border:1px solid #ded6cb;border-radius:8px;margin-bottom:12px;padding:12px;box-shadow:0 10px 24px #362b1e12}.history-heading{text-align:left;gap:10px}.history-icon{color:#315144;background:#edf4f1;border-radius:8px;flex:0 0 38px;place-items:center;width:38px;height:38px;display:grid}.history-heading h2,.history-heading p,.history-empty{margin:0}.history-heading h2{color:#202326;font-size:17px;line-height:1.2}.history-heading p,.history-empty{color:#756b60;font-size:12px;font-weight:900}.history-heading p{margin-top:3px}.history-empty{text-align:left;padding:12px 0 2px}.month-tabs{scrollbar-width:none;grid-auto-columns:minmax(128px,1fr);grid-auto-flow:column;gap:8px;padding:12px 0 10px;display:grid;overflow-x:auto}.month-tabs::-webkit-scrollbar{display:none}.history-days::-webkit-scrollbar{display:none}.month-tab{color:#34322e;cursor:pointer;text-align:left;background:#fff;border:1px solid #ddd5ca;border-radius:8px;min-height:48px;padding:7px 9px}.month-tab strong,.month-tab span{display:block}.month-tab strong{font-size:13px;line-height:1.2}.month-tab span{color:#7b6f63;margin-top:3px;font-size:11px;font-weight:900}.month-tab.active{color:#fff;background:#25342f;border-color:#25342f}.month-tab.active span{color:#dcebdd}.history-days{scrollbar-width:none;gap:8px;display:flex;overflow-x:auto}.history-day{color:#34322e;cursor:pointer;background:#fff;border:1px solid #ddd5ca;border-radius:999px;flex:none;gap:6px;min-height:36px;padding:0 9px;font-size:12px;font-weight:900}.history-day b{color:#fff;border-radius:999px;padding:4px 6px;font-size:10px;line-height:1}.history-day.ready b{background:#3f876f}.history-day.partial b{background:#c94d3f}.history-day.closed b,.history-day.empty b{background:#8d6a35}.availability-panel,.staff-manager{background:#ffffffd1;border:1px solid #ded6cb;border-radius:8px;margin-bottom:12px;padding:12px;box-shadow:0 10px 24px #362b1e12}.panel-heading{text-align:left;justify-content:space-between;gap:12px}.panel-heading h2,.panel-heading p{margin:0}.panel-heading h2{color:#202326;font-size:17px;line-height:1.2}.panel-heading p{color:#756b60;font-size:12px;font-weight:900}.toggle-grid,.skill-picker{scrollbar-width:none;gap:8px;padding-top:10px;display:flex;overflow-x:auto}.toggle-grid::-webkit-scrollbar{display:none}.skill-picker::-webkit-scrollbar{display:none}.toggle-chip,.skill-chip{color:#34322e;cursor:pointer;background:#fff;border:1px solid #d8d0c4;border-radius:999px;flex:none;min-height:38px;padding:0 10px;font-weight:900}.toggle-chip{gap:6px}.toggle-chip.active,.skill-chip.active{color:#fff;background:#25342f;border-color:#25342f}.toggle-chip b{color:#25342f;background:#fff;border-radius:999px;padding:4px 6px;font-size:10px;line-height:1}.undo-panel{color:#34322e;background:#fff;border:1px solid #d8d0c4;border-radius:8px;justify-content:space-between;gap:10px;margin-bottom:12px;padding:10px 12px;font-size:13px;font-weight:900}.undo-panel button,.mini-action,.backup-action{cursor:pointer;border:0;border-radius:8px;font-weight:900}.undo-panel button{color:#fff;background:#25342f;gap:6px;min-height:36px;padding:0 10px}.staff-form{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-top:12px;display:grid}.staff-form input[type=text],.staff-form input:not([type]){color:#202326;min-width:0;min-height:44px;font:inherit;background:#fff;border:1px solid #d8d0c4;border-radius:8px;padding:0 10px;font-weight:800}.skill-picker{grid-column:1/-1}.check-row{color:#34322e;align-items:center;gap:8px;min-height:40px;font-size:13px;font-weight:900;display:inline-flex}.check-row input{width:18px;height:18px}.staff-submit{grid-column:1/-1}.staff-list{gap:8px;margin-top:12px;display:grid}.staff-row{text-align:left;background:#fff;border:1px solid #e2dbd0;border-radius:8px;justify-content:space-between;gap:10px;padding:10px}.staff-row.inactive{opacity:.62}.staff-row strong,.staff-row span{display:block}.staff-row strong{color:#202326;line-height:1.2}.staff-row span{color:#756b60;margin-top:4px;font-size:12px;font-weight:900}.mini-action{color:#34322e;background:#ece6dc;flex:none;min-height:36px;padding:0 10px}.backup-action{color:#fff;background:#25342f;justify-content:center;align-items:center;gap:8px;width:100%;min-height:42px;margin-top:10px;display:inline-flex}.restore-action{color:#34322e;cursor:pointer;background:#fff;border:1px solid #d8d0c4;border-radius:8px;place-items:center;width:100%;min-height:42px;margin-top:8px;font-weight:900;display:grid}.restore-action input{display:none}.date-panel{gap:10px}.date-picker{background:#fff;border:1px solid #ddd5ca;border-radius:8px;flex:1;align-items:center;gap:10px;min-width:0;min-height:52px;padding:0 14px;display:flex}.date-picker input{color:#1f2428;width:100%;min-width:0;font:inherit;background:0 0;border:0;font-weight:800}.calendar-card{background:#ffffffd1;border:1px solid #ded6cb;border-radius:8px;margin:14px 0;overflow:hidden;box-shadow:0 16px 34px #362b1e14}.calendar-heading{background:#fff;border-bottom:1px solid #e6ded3;justify-content:space-between;gap:12px;padding:14px}.calendar-heading p,.calendar-heading h2{margin:0}.calendar-heading p{color:#85796c;font-size:12px;font-weight:900}.calendar-heading h2{color:#202326;font-size:22px;line-height:1.2}.calendar-legend{color:#6f685f;white-space:nowrap;gap:6px;font-size:12px;font-weight:900}.legend-dot,.shift-dots i{border-radius:999px;display:inline-block}.legend-dot{width:9px;height:9px}.legend-dot.ready,.shift-dots i.ready{background:#3f876f}.legend-dot.partial,.shift-dots i.partial{background:#c94d3f}.calendar-day.closed{color:#7f756a;background:#ece6dc;border-color:#d8d0c4}.shift-dots i.empty{background:#d6cec2}.calendar-weekdays,.calendar-grid{grid-template-columns:repeat(7,minmax(0,1fr));display:grid}.calendar-weekdays{color:#82776a;text-align:center;padding:10px 10px 0;font-size:12px;font-weight:900}.calendar-grid{gap:6px;padding:10px}.calendar-day{color:#202326;cursor:pointer;background:#fff;border:1px solid #e2dbd0;border-radius:8px;align-content:space-between;justify-items:center;min-width:0;min-height:58px;padding:8px 4px 7px;display:grid;position:relative}.calendar-day strong{font-size:17px;line-height:1}.calendar-day em{color:inherit;font-size:10px;font-style:normal;font-weight:900;line-height:1}.calendar-day.muted{color:#968c80;background:#f2eee7}.calendar-day.selected{color:#fff;background:#25342f;border-color:#25342f;box-shadow:0 12px 24px #25342f2e}.calendar-day.partial:not(.selected){border-color:#c94d3f6b}.calendar-day.ready:not(.selected){border-color:#3f876f7a}.shift-dots{gap:4px;min-height:7px;display:inline-flex}.shift-dots i{width:7px;height:7px}.calendar-day.selected .shift-dots i.empty{background:#ffffff61}.selected-day{color:#302d29;background:#ece6dc;border-radius:8px;justify-content:space-between;gap:10px;margin:0 0 14px;padding:12px 14px}.selected-day strong,.selected-day span{min-width:0}.selected-day strong{font-size:15px;line-height:1.25}.selected-day span{color:#70675d;flex:none;font-size:12px;font-weight:900}.actions{gap:10px;padding:4px 0 14px}.primary-action,.ghost-action{font:inherit;white-space:nowrap;border-radius:8px;justify-content:center;align-items:center;gap:8px;padding:0 14px;font-weight:800;display:inline-flex}.primary-action{color:#fff;background:#c94d3f;flex:1;box-shadow:0 12px 26px #c94d3f38}.ghost-action{color:#32302c;background:#ece6dc}.staff-strip{scrollbar-width:none;gap:8px;padding:2px 0 16px;display:flex;overflow-x:auto}.staff-strip::-webkit-scrollbar{display:none}.staff-chip{color:#3c3a35;background:#ffffffb8;border:1px solid #d9d1c6;border-radius:999px;flex:none;align-items:center;gap:6px;min-height:34px;padding:0 10px;font-size:13px;font-weight:800;display:inline-flex}.staff-chip b{color:#fff;background:#25342f;border-radius:999px;padding:4px 6px;font-size:10px;line-height:1}.staff-chip.flexible{border-color:#c94d3f}.closed-panel{color:#34322e;background:#ffffffd1;border:1px solid #ded6cb;border-radius:8px;align-items:center;gap:12px;padding:18px;display:flex;box-shadow:0 16px 34px #362b1e14}.closed-panel svg{color:#8d6a35;flex:none}.closed-panel h2,.closed-panel p{text-align:left;margin:0}.closed-panel h2{color:#202326;font-size:20px;line-height:1.2}.closed-panel p{color:#756b60;margin-top:4px;font-size:14px;font-weight:800}.schedule-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;display:grid}.shift-card{background:#ffffffd1;border:1px solid #ded6cb;border-radius:8px;overflow:hidden;box-shadow:0 16px 34px #362b1e14}.shift-heading{background:#fff;border-bottom:1px solid #e6ded3;justify-content:space-between;gap:12px;padding:16px}.shift-heading p{color:#85796c;font-size:13px;font-weight:800}.shift-heading h2{color:#202326;font-size:22px}.status{color:#8b362e;background:#f1ddd8;border-radius:999px;align-items:center;gap:6px;min-height:34px;padding:0 10px;font-size:13px;font-weight:900;display:inline-flex}.status.ready{color:#244c30;background:#dcebdd}.warning,.hint{text-align:left;border-radius:8px;margin:12px 16px 0;padding:10px 12px;font-size:13px;font-weight:800}.warning{color:#953529;background:#fff1ed}.hint{color:#315144;background:#edf4f1}.role-list{gap:10px;padding:14px;display:grid}.role-row{background:#fff;border:1px solid #e2dbd0;border-left-width:5px;border-radius:8px;gap:10px;min-height:70px;padding:10px}.role-row.heat{border-left-color:#c94d3f}.role-row.fresh{border-left-color:#3f876f}.role-row.water{border-left-color:#3f79a7}.role-row.service{border-left-color:#8d6a35}.role-row.part{border-left-color:#68717a}.role-row.duplicate{outline:2px solid #c94d3f}.role-icon{color:#34322e;background:#f3efe8;border-radius:8px;flex:0 0 38px;place-items:center;width:38px;height:38px;display:grid}.role-copy{text-align:left;flex:1;min-width:0}.role-copy strong,.role-copy small{display:block}.role-copy strong{color:#202326;line-height:1.15}.role-copy small{color:#82776a;margin-top:3px;font-size:12px}.role-row select{color:#202326;max-width:42%;min-height:44px;font:inherit;background:#fbfaf7;border:1px solid #d8d0c4;border-radius:8px;flex:0 0 132px;padding:0 8px;font-weight:900}.pdf-preview{background:#fff;width:1123px;position:fixed;top:0;left:-10000px}.pdf-sheet{box-sizing:border-box;color:#111;width:1123px;height:794px;font-family:var(--sans);background:#fff;padding:24px}.pdf-title{border-bottom:2px solid #111;justify-content:space-between;gap:16px;padding-bottom:10px}.pdf-title p{color:#333;font-size:12px;font-weight:900}.pdf-title h2{color:#111;font-size:24px;line-height:1.15}.pdf-title span{color:#111;text-align:right;font-size:13px;font-weight:900;line-height:1.35}.pdf-table{table-layout:fixed;border-collapse:collapse;width:100%;margin-top:10px}.pdf-table th,.pdf-table td{color:#111;vertical-align:top;text-align:left;border:1px solid #222}.pdf-table th{background:#fff;padding:4px 5px;font-size:12px;font-weight:900}.pdf-table td{padding:3px 5px;font-size:9.4px;line-height:1.28}.pdf-table th:first-child,.pdf-table td:first-child{width:90px}.pdf-table th:nth-child(2),.pdf-table td:nth-child(2),.pdf-table th:nth-child(3),.pdf-table td:nth-child(3){width:430px}.pdf-table th:nth-child(4),.pdf-table td:nth-child(4){text-align:center;width:62px}.pdf-table strong{font-weight:900}.pdf-row-closed td{color:#333}.pdf-row-closed td:nth-child(2),.pdf-row-closed td:nth-child(3){text-align:center;font-weight:900}.export-toast{inset-inline:14px;z-index:10;color:#fff;background:#25342f;border-radius:8px;place-items:center;min-height:48px;font-weight:900;display:grid;position:fixed;bottom:16px;box-shadow:0 12px 30px #1d22203d}@media (width<=820px){.app-shell{padding-inline:12px}.topbar h1{font-size:30px}.export-panel{flex-direction:column;align-items:stretch}.range-tabs{flex-basis:auto;width:100%}.schedule-grid{grid-template-columns:1fr}}@media (width<=420px){.primary-action,.ghost-action{padding-inline:10px;font-size:14px}.range-tab{padding-inline:4px;font-size:12px}.staff-form{grid-template-columns:1fr}.role-row{flex-wrap:wrap;grid-template-columns:38px 1fr}.role-row select{flex:0 0 calc(100% - 48px);width:calc(100% - 48px);max-width:none;margin-left:48px}}
