:root{--bg: #f7fafc;--surface: #ffffff;--surface-strong: #f0fdfa;--ink: #102027;--muted: #5d6b78;--line: #d8e3e9;--primary: #087f8c;--primary-dark: #075d66;--green: #14805e;--amber: #b7791f;--red: #c53030;--blue: #2563eb;--violet: #6d28d9;--shadow: 0 18px 50px rgba(16, 32, 39, .08);--radius: 8px;color-scheme:light;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Noto Sans Thai,sans-serif}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;background:var(--bg);color:var(--ink);font-size:16px;line-height:1.5}button,input,select,textarea{font:inherit}button,select,summary{cursor:pointer}button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible,a:focus-visible{outline:3px solid rgba(8,127,140,.32);outline-offset:2px}.app-shell{display:grid;grid-template-columns:280px minmax(0,1fr);min-height:100dvh}.sidebar{position:sticky;top:0;height:100dvh;padding:24px;background:#102027;color:#f8fafc;display:flex;flex-direction:column;gap:28px}.brand{display:flex;align-items:center;gap:12px}.brand-mark{width:44px;height:44px;border-radius:var(--radius);display:grid;place-items:center;background:#20c997;color:#062a30;font-weight:800}.brand h1,.topbar h2,.section-header h3,.export-panel h3{margin:0;letter-spacing:0}.brand h1{font-size:20px}.eyebrow{margin:0 0 4px;font-size:12px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:0}.sidebar .eyebrow{color:#9fb5bf}.nav-list{display:grid;gap:8px}.nav-item{min-height:44px;padding:10px 12px;border-radius:var(--radius);color:#d7e7eb;text-decoration:none;display:flex;align-items:center;transition:background .16s ease,color .16s ease}.nav-item:hover,.nav-item.active{background:#ffffff1f;color:#fff}.side-note{margin-top:auto;padding:16px;border:1px solid rgba(255,255,255,.14);border-radius:var(--radius);background:#ffffff0f}.note-title{margin:0 0 8px;font-weight:700}.side-note p:last-child{margin:0;color:#d8e7eb;font-size:14px}.main-content{padding:28px;display:grid;gap:20px}.topbar,.section-header,.export-panel{display:flex;align-items:center;justify-content:space-between;gap:16px}.topbar h2{font-size:clamp(24px,3vw,34px)}.topbar-actions,.export-actions{display:flex;align-items:flex-end;gap:10px;flex-wrap:wrap}.field{display:grid;gap:6px}.field span{color:var(--muted);font-size:13px;font-weight:700}.field.compact{min-width:180px}input,select,textarea{width:100%;min-height:44px;border:1px solid var(--line);border-radius:var(--radius);background:#fff;color:var(--ink);padding:9px 11px}textarea{resize:vertical}.primary-button,.secondary-button,.ghost-button{min-height:44px;border:0;border-radius:var(--radius);padding:10px 15px;font-weight:800;transition:transform .16s ease,background .16s ease,border-color .16s ease}.icon-button{display:inline-flex;align-items:center;justify-content:center;gap:8px}.icon-button svg{flex:0 0 auto}.primary-button{background:var(--primary);color:#fff}.primary-button:hover{background:var(--primary-dark)}.secondary-button{border:1px solid var(--line);background:#fff;color:var(--ink)}.secondary-button:hover{border-color:#9bb4bd;background:#f8fbfc}.ghost-button{border:1px dashed #8db5be;background:#eefaf9;color:var(--primary-dark)}.status-strip{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}.metric-panel,.calendar-panel,.rules-panel,.people-panel,.summary-panel,.export-panel,.access-panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}.metric-panel{padding:16px;display:grid;gap:4px}.metric-label,.metric-panel small{color:var(--muted)}.metric-panel strong{font-size:28px;line-height:1.15}.metric-panel strong.good{color:var(--green)}.metric-panel strong.warn{color:var(--amber)}.workspace-grid{display:grid;grid-template-columns:minmax(0,1.75fr) minmax(320px,.8fr);gap:20px;align-items:start}.calendar-panel,.rules-panel,.people-panel,.summary-panel,.export-panel,.access-panel{padding:18px}.section-header{margin-bottom:14px}.section-header.stacked{align-items:flex-start;flex-direction:column;gap:0}.legend{display:flex;align-items:center;gap:10px;flex-wrap:wrap;color:var(--muted);font-size:13px}.dot{width:10px;height:10px;display:inline-block;border-radius:999px;margin-right:5px}.dot.duty{background:var(--primary)}.dot.off{background:var(--blue)}.dot.risk{background:var(--amber)}.weekday-row,.calendar-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr))}.weekday-row{gap:8px;margin-bottom:8px;color:var(--muted);font-size:13px;font-weight:800}.weekday-row span{text-align:center}.calendar-grid{gap:8px}.day-cell{min-height:146px;border:1px solid var(--line);border-radius:var(--radius);background:#fff;padding:10px;display:grid;align-content:start;gap:7px}.day-cell.muted{background:#f3f7f9;color:#90a0aa}.day-cell.weekend{border-color:#9ed3d9;background:#f5fffd}.day-cell.blocked{border-color:#f4bf75;background:#fffaf0}.day-top{display:flex;align-items:center;justify-content:space-between;gap:6px}.day-number{font-weight:800}.day-label{color:var(--muted);font-size:12px}.tag-stack{display:grid;gap:5px}.tag{width:fit-content;max-width:100%;border-radius:999px;padding:3px 8px;font-size:12px;font-weight:750;white-space:normal;overflow-wrap:anywhere}.tag.mkt{background:#dff8f2;color:#075d52}.tag.photo{background:#e8edff;color:#273e8f}.tag.off{background:#e6f0ff;color:#174ea6}.tag.wfh{background:#f0e7ff;color:var(--violet)}.tag.star{background:#ffe4e4;color:#a11b1b}.tag.doctor{background:#fff1ce;color:#8a5a00}.tag.outing{background:#e8f7d9;color:#315f12}.tag.custom{background:#eef2f7;color:#43515d}.rule-stack{display:grid;gap:10px}.rule-block{border:1px solid var(--line);border-radius:var(--radius);background:#fff}.rule-block summary{min-height:44px;padding:12px 14px;font-weight:800;list-style-position:inside}.rule-body{padding:0 14px 14px;display:grid;gap:12px}.two-cols{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.lower-grid{display:grid;grid-template-columns:minmax(0,1.35fr) minmax(300px,.65fr);gap:20px;align-items:start}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse;min-width:720px}table.memory-table{min-width:1120px}th,td{padding:12px 10px;border-bottom:1px solid var(--line);text-align:left;vertical-align:middle}th{color:var(--muted);font-size:13px}.pill{display:inline-flex;min-height:28px;align-items:center;border-radius:999px;padding:3px 9px;font-size:12px;font-weight:800}.pill.ok{background:#dff8f2;color:#075d52}.pill.probation{background:#fff1ce;color:#8a5a00}.date-list{display:block;max-width:210px;color:#40515d;font-size:13px;line-height:1.45;overflow-wrap:anywhere}.muted-text{color:var(--muted)}.memory-editor{margin-top:18px;padding:16px;border:1px solid var(--line);border-radius:var(--radius);background:#fbfdfe;display:grid;gap:14px}.memory-editor h4{margin:0;font-size:18px}.memory-editor p:last-child{margin:4px 0 0;color:var(--muted)}.memory-form{display:grid;grid-template-columns:minmax(160px,1fr) repeat(2,minmax(130px,.7fr));gap:12px}.memory-form .wide{grid-column:span 3}.summary-list{display:grid;gap:10px}.summary-row{display:grid;gap:3px;padding:12px;border:1px solid var(--line);border-radius:var(--radius);background:#fbfdfe}.summary-row span{color:var(--muted);font-weight:700}.summary-row strong{font-size:15px}.warning-box{margin-top:14px;padding:12px;border-radius:var(--radius);background:#fff8e8;color:#6f4d05;border:1px solid #f4d18c;font-weight:700}.export-panel{align-items:center}.export-panel p:last-child{margin:4px 0 0;color:var(--muted)}.access-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.access-card{min-height:154px;padding:16px;border:1px solid var(--line);border-radius:var(--radius);background:#fbfdfe}.access-card h4{margin:10px 0 6px;font-size:17px}.access-card p{margin:0;color:var(--muted)}.step-number{width:32px;height:32px;display:grid;place-items:center;border-radius:999px;background:#dff8f2;color:#075d52;font-weight:900}@media(max-width:1180px){.app-shell{grid-template-columns:1fr}.sidebar{position:static;height:auto;padding:18px}.nav-list{grid-template-columns:repeat(5,minmax(0,1fr))}.side-note{margin-top:0}.workspace-grid,.lower-grid,.access-grid{grid-template-columns:1fr}}@media(max-width:780px){.main-content{padding:16px}.topbar,.section-header,.export-panel{align-items:stretch;flex-direction:column}.topbar-actions,.export-actions{align-items:stretch}.topbar-actions>*,.export-actions>*{width:100%}.status-strip{grid-template-columns:repeat(2,minmax(0,1fr))}.memory-form{grid-template-columns:1fr}.memory-form .wide{grid-column:auto}.nav-list{grid-template-columns:1fr 1fr}.calendar-grid,.weekday-row{grid-template-columns:1fr}.weekday-row{display:none}.day-cell{min-height:128px}}@media(max-width:520px){.status-strip,.two-cols,.nav-list{grid-template-columns:1fr}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}
