:root{--cardinal: #8C1515;--cardinal-dark: #650F0F;--cardinal-light: #B83A4B;--sandstone: #F4F4F4;--black: #2E2D29;--gray: #6B6864;--gray-light: #D4D2CD;--white: #FFFFFF;--green: #175E54}*{box-sizing:border-box}html,body{margin:0;padding:0;font-family:"Source Sans 3",-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;color:var(--black);background:var(--sandstone);-webkit-font-smoothing:antialiased;font-size:16px}button,input,textarea,select{font:inherit;color:inherit}.app{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column}.header{background:var(--cardinal);color:#fff;padding:14px 20px;display:flex;align-items:center;gap:12px;box-shadow:0 2px 4px #00000014}.header .crest{font-family:"Source Serif 4",Georgia,serif;font-weight:700;font-size:20px;letter-spacing:.5px}.header .sub{font-size:13px;opacity:.85;font-weight:400}.header .divider{width:1px;background:#ffffff4d;align-self:stretch;margin:0 4px}.header .role-badge{margin-left:auto;background:#ffffff26;border:1px solid rgba(255,255,255,.35);color:#fff;font-size:12px;font-weight:600;letter-spacing:.5px;padding:3px 10px;border-radius:999px;text-transform:uppercase}.main{flex:1;width:100%;max-width:880px;margin:0 auto;padding:20px}.card{background:#fff;border-radius:8px;padding:20px;box-shadow:0 1px 3px #0000000f;margin-bottom:16px}h1{font-family:"Source Serif 4",Georgia,serif;font-weight:700;margin:0 0 6px;color:var(--cardinal)}h2{font-family:"Source Serif 4",Georgia,serif;font-weight:600;margin:0 0 12px;font-size:20px}.muted{color:var(--gray);font-size:14px}label{display:block;font-weight:600;font-size:14px;margin-bottom:6px}input,textarea,select{width:100%;padding:10px 12px;border:1px solid var(--gray-light);border-radius:6px;background:#fff;outline:none}input:focus,textarea:focus,select:focus{border-color:var(--cardinal);box-shadow:0 0 0 3px #8c15151f}.field{margin-bottom:14px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 18px;background:var(--cardinal);color:#fff;border:none;border-radius:6px;font-weight:600;cursor:pointer;text-decoration:none;min-height:44px}.btn:hover{background:var(--cardinal-dark)}.btn:disabled{background:var(--gray-light);color:var(--gray);cursor:not-allowed}.btn.secondary{background:#fff;color:var(--cardinal);border:1px solid var(--cardinal)}.btn.secondary:hover{background:#fbeeee}.btn.ghost{background:transparent;color:var(--gray)}.btn.ghost:hover{color:var(--black);background:var(--sandstone)}.header .btn.ghost{color:#ffffffd9}.header .btn.ghost:hover{color:#fff;background:#ffffff26}.header .btn.secondary{background:#ffffff26;color:#fff;border-color:#fff6}.header .btn.secondary:hover{background:#ffffff40}.header-nav{display:flex;align-items:center;gap:12px}.header-nav span{color:#ffffffbf;font-size:13px}.help-btn{display:none;width:32px;height:32px;min-height:32px;padding:0;border-radius:999px;background:#ffffff26;border:1px solid rgba(255,255,255,.35);color:#fff;font-weight:700;font-size:16px;margin-left:auto}.help-btn:hover{background:#ffffff40;color:#fff}.row{display:flex;gap:10px;flex-wrap:wrap}.row>*{flex:1;min-width:0}.pill{display:inline-block;padding:4px 10px;background:var(--sandstone);border-radius:999px;font-size:13px;color:var(--gray)}.grid-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}.grid{display:grid;user-select:none;-webkit-user-select:none;touch-action:none;min-width:max-content}.grid .corner,.grid .day-head,.grid .time-label,.grid .cell{border-right:1px solid var(--gray-light);border-bottom:1px solid var(--gray-light)}.grid .day-head{background:var(--sandstone);text-align:center;font-weight:600;font-size:13px;padding:8px 6px;position:sticky;top:0;z-index:2}.grid .day-head .dow{display:block;color:var(--gray);font-size:11px;font-weight:400}.grid .corner{background:var(--sandstone);position:sticky;top:0;left:0;z-index:3}.grid .time-label{font-size:11px;color:var(--gray);padding:2px 6px;text-align:right;background:#fff;position:sticky;left:0;z-index:1;display:flex;align-items:flex-start;justify-content:flex-end}.grid .time-label.hour{font-weight:600;color:var(--black)}.grid .cell{background:#fff;min-height:22px;cursor:default;position:relative}.grid[data-mode=admin] .cell.available{cursor:crosshair}.grid[data-mode=admin] .cell.taken,.grid[data-mode=student] .cell.available{cursor:pointer}.grid[data-mode=student] .cell.taken{cursor:not-allowed}.grid[data-mode=student] .cell.mine{background:var(--cardinal);cursor:default}.grid[data-mode=student] .cell.past{background:repeating-linear-gradient(45deg,#f4f4f4,#f4f4f4 4px,#ededed 4px,#ededed 8px);cursor:not-allowed;opacity:.6}.grid[data-mode=student] .cell.past.available{background:repeating-linear-gradient(45deg,#e8f1ee,#e8f1ee 4px,#dce7e3 4px,#dce7e3 8px)}.grid .cell.available{background:#e8f1ee}.grid .cell.taken{background:#2e2d29;color:#fff;overflow:hidden}.grid .cell .booking-label{position:absolute;top:0;right:0;bottom:0;left:0;padding:2px 4px;font-size:11px;font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;pointer-events:none}.grid .cell.selecting{background:#8c151559}.grid .cell.preview{box-shadow:inset 0 0 0 2px var(--cardinal)}.grid .cell.bookable:hover{background:#c9ddd5}.legend{display:flex;gap:16px;flex-wrap:wrap;margin:10px 0;font-size:13px;color:var(--gray)}.legend .swatch{display:inline-block;width:14px;height:14px;border-radius:3px;vertical-align:middle;margin-right:6px;border:1px solid var(--gray-light)}.swatch.avail{background:#e8f1ee}.swatch.taken{background:var(--black)}.swatch.select{background:#8c151559}.guide-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;z-index:80;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.guide-drawer{position:fixed;top:0;right:0;bottom:0;width:min(420px,100vw);background:#fff;box-shadow:-4px 0 24px #00000026;overflow-y:auto;z-index:81;animation:slideInRight .25s ease-out}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:none}}.guide-drawer-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;background:var(--cardinal);color:#fff;position:sticky;top:0;z-index:1}.guide-drawer-header h2{margin:0;color:#fff;font-size:18px}.guide-drawer-close{background:none;border:none;color:#fff;font-size:24px;cursor:pointer;line-height:1;padding:0}.guide-drawer-body{padding:20px}.guide-drawer-body h2{margin-top:20px;font-size:17px}.guide-drawer-body h2:first-child{margin-top:0}.guide-drawer-body p,.guide-drawer-body li{font-size:14px;line-height:1.6}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:flex-end;justify-content:center;z-index:50}@media (min-width: 600px){.modal-backdrop{align-items:center}}.modal{background:#fff;width:100%;max-width:480px;border-radius:12px 12px 0 0;padding:22px;animation:slideUp .2s ease-out}@media (min-width: 600px){.modal{border-radius:12px}}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:none;opacity:1}}.toast{position:fixed;bottom:20px;left:50%;transform:translate(-50%);background:var(--black);color:#fff;padding:10px 18px;border-radius:6px;z-index:100;font-size:14px}.toast.error{background:var(--cardinal)}.error-text{color:var(--cardinal);font-size:14px;margin-top:6px}.booking-list{list-style:none;padding:0;margin:0}.booking-list li{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border-bottom:1px solid var(--gray-light);gap:10px}.booking-list li:last-child{border-bottom:none}.booking-list .b-time{font-weight:600}.booking-list .b-topic{color:var(--gray);font-size:13px}.link-box{background:var(--sandstone);padding:12px;border-radius:6px;font-family:Menlo,Consolas,monospace;font-size:13px;word-break:break-all;margin-bottom:8px}.nav-toolbar{display:flex;justify-content:space-between;align-items:center;gap:8px;margin-bottom:10px;flex-wrap:wrap}.tab-row{display:flex;gap:6px;margin-bottom:14px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-bottom:2px}.tab-row::-webkit-scrollbar{display:none}.tab-row .tab{flex-shrink:0;white-space:nowrap;padding:8px 14px;border:1px solid var(--gray-light);background:#fff;border-radius:999px;cursor:pointer;font-weight:600;font-size:14px}.tab-row .tab.active{background:var(--cardinal);color:#fff;border-color:var(--cardinal)}.nav-bottom{display:none}@media (max-width: 640px){.header-nav,.header .role-badge{display:none}.help-btn{display:inline-flex;align-items:center;justify-content:center}h1{font-size:20px}.card{padding:14px}.main{padding-bottom:76px}.toast{bottom:80px}.modal-backdrop{z-index:60}.nav-bottom{display:flex;position:fixed;bottom:0;left:0;right:0;width:100%;background:#fff;border-top:1px solid var(--gray-light);z-index:50;padding-bottom:env(safe-area-inset-bottom,6px);box-shadow:0 -2px 8px #00000014}.nav-bottom button{flex:1;min-width:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:none;border:none;padding:8px 4px 6px;font-size:10px;font-weight:600;color:var(--gray);cursor:pointer;gap:3px;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.nav-bottom button.active{color:var(--cardinal)}.nav-bottom .nav-icon{font-size:18px;line-height:1}}
