:root{--bg: #f3f6fb;--panel: #ffffff;--line: #dbe3ef;--text: #1f2937;--muted: #6b7280;--red: #ef4444;--shadow: 0 10px 30px rgba(15, 23, 42, .08)}*{box-sizing:border-box}body{margin:0;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--bg);color:var(--text)}button,input,textarea,select{font:inherit}button,input,textarea,select{border:1px solid var(--line);border-radius:10px;padding:.75rem .9rem;background:#fff}button{cursor:pointer}button.primary{background:#111827;border-color:#111827;color:#fff}button.danger{color:var(--red)}.app-shell{display:grid;grid-template-columns:280px 1fr 320px;grid-template-rows:auto 1fr;gap:1rem;height:100vh;overflow:hidden;padding:1rem}.sidebar,.main-content,.details-panel{overflow-y:auto;min-height:0}.panel{background:var(--panel);border:1px solid var(--line);border-radius:18px;padding:1rem;box-shadow:var(--shadow);margin-bottom:1rem}.brand{display:flex;align-items:center;gap:.8rem;margin-bottom:1rem}.brand-mark{width:48px;height:48px;display:grid;place-items:center;border-radius:14px;background:linear-gradient(135deg,#111827,#2563eb);color:#fff;font-weight:700}.brand h1,.topbar h2,.panel h2,.panel h3,.manager-header h2{margin:0}.brand p,.topbar p,.panel p,.staff span,.staff small,.day span,.manager-header p,.role-card p,.staff-card p{color:var(--muted)}.period-nav,.topbar,.top-actions,.form-actions,.split-fields,.role-title,.colour-field,.manager-header{display:flex;gap:.75rem}.period-nav,.topbar,.manager-header{justify-content:space-between;align-items:center}.legend,.warnings,.next-steps-list{list-style:none;padding:0;margin:0;display:grid;gap:.7rem}.swatch{width:14px;height:14px;border-radius:999px;display:inline-block;margin-right:.6rem;vertical-align:middle}.swatch.large{width:24px;height:24px;margin-right:0}.warning{background:#facc152e;color:#854d0e;padding:.75rem;border-radius:12px}.nav-panel{display:grid;gap:.75rem}.roster-wrapper{background:var(--panel);border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow);overflow-x:hidden;overflow-y:visible}.roster-grid{display:grid;grid-template-columns:180px repeat(7,minmax(0,1fr))}.roster-grid>div{border-right:1px solid var(--line);border-bottom:1px solid var(--line);min-height:94px}.corner,.day,.staff{background:#f8fbff}.corner,.day{position:sticky;top:0;z-index:3;min-height:74px!important;display:flex;align-items:center;justify-content:center;text-align:center;font-weight:700}.corner{left:0;z-index:5}.staff{position:sticky;left:0;z-index:2;padding:.9rem;display:flex;flex-direction:column;gap:.3rem}.cell{padding:.5rem;background:#fff}.weekend{background:#fbfdff}.shift{border-radius:14px;padding:.65rem .75rem;box-shadow:0 4px 14px #0f172a14;cursor:grab;display:flex;flex-direction:column;gap:.25rem}.shift span{font-size:.85rem;color:var(--muted)}.shift.selected{outline:2px solid #111827}.shift.warning{outline:2px dashed rgba(239,68,68,.5)}label{display:grid;gap:.4rem;margin-bottom:.9rem;font-size:.92rem}.actions,.manager-grid,.staff-list,.role-list{display:grid;gap:1rem}.manager-grid{grid-template-columns:1.1fr 1fr}.manager-grid.two-col{grid-template-columns:1fr 1fr}.staff-card,.role-card{border:1px solid var(--line);border-radius:14px;padding:.9rem;display:flex;justify-content:space-between;gap:1rem;align-items:center;cursor:pointer}.selected-card{border-color:#111827;box-shadow:inset 0 0 0 1px #111827}.staff-meta{display:grid;gap:.35rem;text-align:right;color:var(--muted);font-size:.9rem}.role-colour-code{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;color:var(--muted)}.chip-row{display:flex;gap:.5rem;flex-wrap:wrap}.chip{border:1px solid var(--line);border-radius:999px;padding:.35rem .75rem;background:#f8fbff}.chip.active{background:#111827;color:#fff;border-color:#111827}@media (max-width: 1400px){.app-shell{grid-template-columns:260px 1fr}.details-panel{grid-column:1 / -1}}@media (max-width: 1100px){.manager-grid,.manager-grid.two-col{grid-template-columns:1fr}}@media (max-width: 900px){.app-shell{grid-template-columns:1fr}.topbar,.manager-header{flex-direction:column;align-items:flex-start}.top-actions,.period-nav,.form-actions,.split-fields,.colour-field{flex-wrap:wrap}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:grid;place-items:center;z-index:100}.modal-content{width:420px;max-width:90vw;max-height:90vh;overflow:auto}.supabase-banner{grid-column:1 / -1;background:#fef3c7;color:#92400e;padding:.75rem 1rem;border-radius:12px;text-align:center;font-size:.9rem}.error-banner{grid-column:1 / -1;background:#fee2e2;color:#991b1b;padding:.75rem 1rem;border-radius:12px;text-align:center;font-size:.9rem}@media print{body{background:#fff}.sidebar,.details-panel,.top-actions,.nav-panel,button{display:none!important}.app-shell{display:block;padding:0}.roster-wrapper{max-height:none;overflow:visible;border:none;box-shadow:none}}.warnings-panel{margin-bottom:1rem;border:1.5px solid #f59e0b;border-radius:12px;overflow:hidden;background:#fbbf2414}.warnings-toggle{width:100%;text-align:left;padding:.65rem 1rem;background:#fbbf2426;border:none;cursor:pointer;font-weight:600;color:#92400e;font-size:.9rem}.warnings-toggle:hover{background:#fbbf2447}.warnings-list{list-style:none;margin:0;padding:.5rem 1rem .75rem;display:grid;gap:.4rem}.warning-item{font-size:.82rem;color:#78350f;padding:.35rem .5rem;border-radius:6px;background:#fbbf241f}.warn-icon{font-size:.7rem;margin-right:.2rem;vertical-align:middle}.cell-warn{background:#fbbf2414;outline:1.5px dashed #f59e0b;outline-offset:-2px}.day.public-holiday{background:#fde8e8;color:#991b1b}.ph-badge{display:inline-block;font-size:.65rem;font-weight:700;background:#ef4444;color:#fff;border-radius:4px;padding:0 4px;margin-left:4px;vertical-align:middle}.ph-cell{background:#fecaca59;cursor:not-allowed}.ph-cell .shift{opacity:.5;cursor:default}.fortnight-summary{margin-top:1.5rem}.summary-table{width:100%;border-collapse:collapse;font-size:.85rem}.summary-table th,.summary-table td{text-align:left;padding:.4rem .6rem;border-bottom:1px solid var(--line)}.summary-table th{font-weight:600;color:var(--muted)}
