:root{color:#10213f;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f6f9fd;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}body{margin:0}.app{color:#101d33;background:#f5f7fb;min-height:100vh}button{font:inherit}.workspace{width:min(1360px,100% - 32px);margin:0 auto;padding:18px 0 32px}.app-header,.brand,.header-actions,.room-tabs,.calendar-head,.month-actions,.agenda-head,.day-summary,.agenda-item,.section-title,.detail-head,.info-row,.form-actions,.checkline,.stepper{align-items:center;display:flex}.app-header{background:#fff;border:1px solid #d9e4f2;border-radius:8px;justify-content:space-between;gap:16px;padding:14px}.brand{gap:12px;min-width:250px}.brand-mark{color:#fff;background:#1e5ce6;border-radius:8px;place-items:center;width:40px;height:40px;display:grid}.brand strong,.brand span{display:block}.brand strong{font-size:18px}.brand span{color:#637895;margin-top:2px;font-size:13px}.search{color:#607693;background:#fff;border:1px solid #d9e4f2;border-radius:8px;flex:1;align-items:center;gap:10px;max-width:420px;height:42px;padding:0 13px;display:flex}.search input{color:#101d33;border:0;outline:0;width:100%}.header-actions{gap:10px}.primary-button,.ghost-button,.icon-button{cursor:pointer;white-space:nowrap;border-radius:8px;justify-content:center;align-items:center;gap:8px;min-height:40px;display:inline-flex}.primary-button{color:#fff;background:#1e5ce6;border:0;padding:0 16px;font-weight:700}.ghost-button{color:#101d33;background:#fff;border:1px solid #d9e4f2;padding:0 14px}.icon-button{color:#101d33;background:#fff;border:1px solid #d9e4f2;width:38px}.icon-button:disabled{opacity:.45;cursor:not-allowed}.icon-button.danger{color:#e54855}.notice{color:#164aa5;background:#eef4ff;border:1px solid #cbdaf8;border-radius:8px;justify-content:space-between;align-items:center;gap:12px;margin-top:12px;padding:11px 13px;display:flex}.modal-notice{color:#b4232f;background:#fff0f1;border-color:#f4c8cc;margin:0 0 12px}.notice button,.month-actions button{color:inherit;cursor:pointer;background:0 0;border:0}.room-tabs{flex-wrap:wrap;gap:8px;margin:14px 0}.room-tabs button{color:#344761;cursor:pointer;background:#fff;border:1px solid #d9e4f2;border-radius:8px;align-items:center;gap:8px;min-height:38px;padding:0 13px;display:inline-flex}.room-tabs button.active{color:#1e5ce6;background:#eef4ff;border-color:#1e5ce6}.room-tabs span{background:var(--room,#1e5ce6);border-radius:50%;width:9px;height:9px}.room-tabs small{color:#72849d}.layout{grid-template-columns:minmax(0,1fr) 360px;align-items:start;gap:14px;display:grid}.calendar-card,.agenda-card,.form-card,.detail-card{background:#fff;border:1px solid #d9e4f2;border-radius:8px}.calendar-card{overflow:hidden}.calendar-head{border-bottom:1px solid #e6edf7;justify-content:space-between;gap:14px;padding:16px}h1,h2,p{margin:0}h1{font-size:25px;line-height:1.15}h2{font-size:18px}.calendar-head p,.agenda-head p,.empty-state p,.detail-card.empty p{color:#637895;margin-top:4px;font-size:13px}.month-actions{gap:8px}.month-actions button{background:#fff;border:1px solid #d9e4f2;border-radius:8px;min-width:40px;height:38px}.calendar-grid{grid-template-columns:repeat(7,minmax(0,1fr));display:grid}.weekday{color:#637895;border-right:1px solid #e6edf7;place-items:center;height:36px;font-size:13px;display:grid}.day-cell{text-align:left;cursor:pointer;background:#fff;border-top:1px solid #e6edf7;border-bottom:0;border-left:0;border-right:1px solid #e6edf7;min-height:105px;padding:8px;position:relative;overflow:hidden}.day-cell.full-booked:after{content:"";background:#e54855;border-radius:999px;width:8px;height:calc(100% - 16px);position:absolute;top:8px;right:8px}.day-cell:hover,.day-cell.picked{background:#f3f7ff}.day-cell.muted{color:#9aacbf;background:#fafcff}.day-number{border-radius:50%;place-items:center;min-width:24px;height:24px;font-size:13px;font-weight:800;display:inline-grid}.day-number.today,.day-cell.picked .day-number{color:#fff;background:#1e5ce6}.events-stack{gap:5px;margin-top:6px;display:grid}.event-pill{border-left:3px solid var(--event);background:color-mix(in srgb, var(--event) 12%, white);border-radius:6px;gap:2px;padding:6px 7px;display:grid}.event-pill b{color:var(--event);text-overflow:ellipsis;white-space:nowrap;font-size:11px;overflow:hidden}.event-pill small,.more{color:#526784;font-size:11px}.agenda-card{padding:16px}.agenda-head{justify-content:space-between;gap:12px}.agenda-head span{color:#1e5ce6;background:#eef4ff;border-radius:8px;padding:7px 10px;font-size:13px;font-weight:800}.day-summary{flex-wrap:wrap;gap:8px;margin:13px 0}.day-summary span{color:#536982;background:#f4f7fb;border-radius:8px;align-items:center;gap:7px;min-height:32px;padding:0 10px;font-size:13px;display:inline-flex}.agenda-list{gap:8px;max-height:360px;padding-right:2px;display:grid;overflow-y:auto}.agenda-item{border:1px solid #d9e4f2;border-left:4px solid var(--event);text-align:left;cursor:pointer;background:#fff;border-radius:8px;gap:12px;width:100%;padding:10px}.agenda-item.selected{background:#f3f7ff;border-color:#1e5ce6}.agenda-time{color:#536982;flex:none;width:46px;font-size:13px;font-weight:800}.agenda-item strong,.agenda-item small{display:block}.agenda-item small{color:#637895;margin-top:3px}.empty-state{text-align:center;background:#fbfdff;border:1px dashed #bfd0e7;border-radius:8px;place-items:center;gap:8px;padding:26px 16px;display:grid}.empty-state svg{color:#1e5ce6}.detail-card{margin-top:12px;padding:14px}.detail-card.empty{color:#637895;gap:4px;display:grid}.detail-head{justify-content:space-between;gap:12px;margin-bottom:10px}.detail-head div{gap:8px;display:flex}.info-row{border-bottom:1px solid #edf2f8;grid-template-columns:22px 76px minmax(0,1fr);gap:10px;padding:10px 0;display:grid}.info-row span{color:#536982}.info-row small{color:#637895}.info-row strong{font-size:14px}.modal-backdrop{z-index:40;background:#0f1d336b;place-items:center;padding:22px;display:grid;position:fixed;inset:0;overflow-y:auto}.booking-modal{width:min(1100px,100%);position:relative}.login-modal,.form-card{gap:14px;width:100%;padding:22px;display:grid;position:relative;box-shadow:0 30px 90px #0a16283d}.login-modal{background:#fff;border-radius:10px;width:min(420px,100%)}.login-modal p{color:#637895}.close{z-index:2;cursor:pointer;background:#fff;border:1px solid #d9e4f2;border-radius:8px;width:34px;height:34px;position:absolute;top:14px;right:14px}.section-title{justify-content:space-between;gap:12px}.section-title h2{align-items:center;gap:8px;display:flex}.form-close{color:#101d33;cursor:pointer;background:#fff;border:1px solid #d9e4f2;border-radius:8px;flex:none;place-items:center;width:36px;height:36px;display:inline-grid}label{color:#344761;gap:7px;font-size:12px;font-weight:800;display:grid}input,textarea,select{box-sizing:border-box;color:#101d33;width:100%;min-height:39px;font:inherit;background:#fff;border:1px solid #d9e4f2;border-radius:7px;outline:none;padding:0 12px;font-size:14px}.date-field{position:relative}.date-input{color:#101d33;cursor:pointer;background:#fff;border:1px solid #d9e4f2;border-radius:7px;justify-content:space-between;align-items:center;gap:10px;width:100%;min-height:39px;padding:0 12px;font-weight:700;display:flex}.date-popover{z-index:60;background:#fff;border:1px solid #d9e4f2;border-radius:10px;width:292px;padding:12px;position:absolute;top:calc(100% + 8px);left:0;box-shadow:0 18px 48px #0a16282e}.date-popover-head{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.date-popover-head button{cursor:pointer;background:#fff;border:1px solid #d9e4f2;border-radius:7px;width:32px;height:32px}.date-popover-grid{grid-template-columns:repeat(7,1fr);gap:4px;display:grid}.date-popover-grid small{color:#637895;place-items:center;height:26px;font-size:11px;display:grid}.date-popover-grid button{color:#101d33;cursor:pointer;background:#fff;border:0;border-radius:7px;height:34px}.date-popover-grid button:hover{background:#eef4ff}.date-popover-grid button.muted{color:#a1afc1}.date-popover-grid button.selected{color:#fff;background:#1e5ce6}textarea{resize:vertical;min-height:78px;padding-top:10px}.form-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;display:grid}.form-grid.times{grid-template-columns:repeat(2,minmax(0,1fr))}.room-picker{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.room-picker button{color:#101d33;cursor:pointer;background:#fff;border:1px solid #d9e4f2;border-radius:8px;min-height:42px}.room-picker button.selected{background:#eef4ff;border-color:#1e5ce6}.form-two{grid-template-columns:minmax(0,1fr) 280px;gap:14px;display:grid}.checkline{grid-template-columns:auto 1fr;justify-content:start;gap:8px;margin-top:12px;font-weight:700}.checkline input{accent-color:#1e5ce6;width:17px;min-height:17px}.checkline.compact{margin:9px 0}.resource-box{background:#fbfdff;border:1px solid #d9e4f2;border-radius:8px;padding:12px}.resource-box>strong{margin-bottom:10px;display:block}.stepper{color:#344761;justify-content:space-between;gap:10px;margin:8px 0;font-size:13px}.stepper div{background:#fff;border:1px solid #d9e4f2;border-radius:7px;align-items:center;display:inline-flex;overflow:hidden}.stepper button{cursor:pointer;background:#f4f7fb;border:0;width:30px;height:28px}.stepper input{text-align:center;appearance:textfield;border:0;border-left:1px solid #d9e4f2;border-right:1px solid #d9e4f2;border-radius:0;width:42px;height:28px;min-height:28px;padding:0 4px;font-weight:800}.stepper input::-webkit-outer-spin-button{appearance:none;margin:0}.stepper input::-webkit-inner-spin-button{appearance:none;margin:0}.form-actions{justify-content:flex-end;gap:10px}@media (width<=980px){.app-header,.layout,.form-two,.form-grid,.form-grid.times{grid-template-columns:1fr}.app-header{display:grid}.brand{min-width:0}.search{max-width:none}.header-actions{grid-template-columns:1fr;display:grid}.primary-button,.ghost-button{width:100%}}@media (width<=640px){.workspace{width:min(100% - 20px,1360px);padding-top:10px}.calendar-card{overflow-x:auto}.calendar-grid{min-width:720px}.calendar-head,.month-actions,.room-tabs,.room-picker{flex-direction:column;align-items:stretch}.month-actions button,.room-tabs button{width:100%}}
