@import"https://fonts.googleapis.com/css2?family=M+PLUS+Rounded+1c:wght@400;600;700;800&display=swap";:root{font-family:"M PLUS Rounded 1c",Noto Sans JP,Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.6;font-weight:400;color:#2f3a4f;background-color:#fdf9f4;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;color-scheme:light;--kb-bg-gradient: radial-gradient(circle at 15% 20%, #fff6e8 0%, #f4f8ff 45%, #fdf1ff 100%);--kb-surface: #ffffff;--kb-surface-soft: #f4f7ff;--kb-surface-strong: #eaf1ff;--kb-border: rgba(111, 140, 255, .22);--kb-border-strong: rgba(111, 140, 255, .42);--kb-muted: #6d7c96;--kb-muted-strong: #2f3a4f;--kb-primary: #6b8dfd;--kb-primary-strong: #4f6bde;--kb-primary-soft: rgba(107, 141, 253, .16);--kb-accent: #ff97a7;--kb-success: #22c55e;--kb-warning: #f6b447;--kb-danger: #ff6b6b;--kb-radius-lg: 1.1rem;--kb-shadow-soft: 0 32px 60px rgba(107, 141, 253, .18);--kb-shadow-card: 0 16px 38px rgba(57, 84, 146, .18)}*,*:before,*:after{box-sizing:border-box}body{margin:0;min-height:100vh;background:var(--kb-bg-gradient);background-attachment:fixed;color:#2f3a4f}img{max-width:100%;display:block}button,input,select,textarea{font:inherit}#root{min-height:100vh}:focus-visible{outline:2px solid var(--kb-primary);outline-offset:2px}.workspace-shell{min-height:100vh;padding:clamp(1.25rem,3vw,2.5rem);display:flex;flex-direction:column;gap:.9rem}.workspace-header{display:flex;justify-content:space-between;align-items:stretch;gap:1rem;padding:1.05rem 1.5rem;background:linear-gradient(120deg,#fdf7ed,#f1f6ff 60%,#fff2fb);border-radius:1.1rem;border:1px solid var(--kb-border);box-shadow:var(--kb-shadow-soft);position:relative;overflow:hidden}.workspace-header:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 15% 30%,rgba(255,151,167,.15),transparent 35%),radial-gradient(circle at 85% 20%,rgba(107,141,253,.12),transparent 30%);pointer-events:none}.app-title{margin:0;font-size:clamp(1rem,3.2vw,2.3rem);font-weight:800;letter-spacing:clamp(.035em,calc(.02em + .2vw),.08em);line-height:1.15;white-space:nowrap;text-transform:uppercase;color:transparent;background-image:linear-gradient(90deg,var(--kb-primary),var(--kb-accent));background-clip:text;-webkit-background-clip:text;text-shadow:0 10px 25px rgba(107,141,253,.28)}.auth-promo .app-title{margin-bottom:.75rem}.header-meta{display:flex;align-items:center;gap:.75rem;position:relative;z-index:1}.user-chip{display:flex;flex-direction:column;gap:.1rem;text-align:left}.user-chip.compact strong{font-size:1rem;color:var(--kb-muted-strong)}.role-pill{display:inline-flex;align-items:center;justify-content:center;padding:.1rem .7rem;border-radius:999px;background:var(--kb-surface-strong);color:var(--kb-primary-strong);border:1px solid var(--kb-border);font-size:.75rem;font-weight:600}.header-notify{display:inline-flex;align-items:center;gap:.35rem;font-size:.85rem;color:var(--kb-muted);padding:.35rem .55rem;border-radius:999px;background:#6b8dfd14;border:1px solid var(--kb-border)}.header-notify input{margin:0}.workspace-nav{display:flex;flex-wrap:wrap;gap:.5rem}.nav-chip{display:flex;flex-direction:column;align-items:flex-start;gap:.1rem;min-width:150px;padding:.7rem 1rem;border-radius:1rem;background:linear-gradient(145deg,#fff,#f4f7ff);border:1px solid var(--kb-border);color:var(--kb-muted-strong);cursor:pointer;transition:border-color .2s ease,background .2s ease,box-shadow .2s ease,transform .2s ease;box-shadow:0 14px 28px #6b8dfd1f}.nav-chip span{font-size:clamp(1rem,2.2vw,1.1rem);font-weight:600;white-space:nowrap}.nav-chip small{color:var(--kb-muted);font-size:clamp(.78rem,1.8vw,.85rem);white-space:nowrap}.nav-chip.active{background:linear-gradient(120deg,var(--kb-primary),var(--kb-accent));color:#fff;border-color:transparent;box-shadow:0 16px 40px #6b8dfd52;transform:translateY(-2px)}.metrics-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:.65rem}.metric-card{background:linear-gradient(150deg,#fff,#eef3ff 70%,#ffeef6);border-radius:1rem;border:1px solid var(--kb-border);padding:.85rem 1rem;display:flex;flex-direction:column;gap:.15rem;box-shadow:0 16px 36px #6b8dfd24}.summary-label{margin:0;font-size:.85rem;color:var(--kb-muted)}.summary-value{font-size:1.7rem;margin:0;color:var(--kb-primary-strong)}.summary-caption{margin:0;color:var(--kb-muted);font-size:.85rem}.workspace-main{display:flex;flex-direction:column;gap:.75rem}.dashboard-grid{display:grid;grid-template-columns:minmax(320px,.9fr) minmax(0,1.2fr);gap:.75rem;align-items:start}@media(max-width:1100px){.workspace-header{flex-direction:column}.dashboard-grid{grid-template-columns:1fr}}.card{background:linear-gradient(180deg,#fff,#f7f9ff 70%,#fff);border-radius:var(--kb-radius-lg);border:1px solid var(--kb-border);padding:1.05rem;box-shadow:var(--kb-shadow-card);position:relative;overflow:hidden}.card:after{content:"";position:absolute;inset:0;background:radial-gradient(circle at top right,rgba(255,151,167,.16),transparent 52%),radial-gradient(circle at 15% 10%,rgba(107,141,253,.14),transparent 45%);pointer-events:none}.card.tight{padding:.85rem}.data-card{display:flex;flex-direction:column;gap:.75rem}.section-heading{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.section-title{margin:0}.badge{display:inline-flex;align-items:center;justify-content:center;padding:.1rem .75rem;border-radius:999px;background:var(--kb-primary-soft);color:var(--kb-primary-strong);font-size:.8rem;font-weight:600}.auth-layout{min-height:100vh;display:grid;grid-template-columns:1fr minmax(auto,480px);gap:1rem;padding:clamp(1.5rem,5vw,2.5rem);align-items:start;max-width:1280px;margin:0 auto}.auth-panel{grid-column:2;width:100%}@media(max-width:820px){.auth-layout{grid-template-columns:1fr}.auth-panel{grid-column:1}}.auth-promo{background:linear-gradient(145deg,#fdf7ed,#eef4ff 65%,#fff0f8);border-radius:1.05rem;border:1px solid var(--kb-border);padding:1.25rem;box-shadow:var(--kb-shadow-card)}.auth-promo h1{margin:.4rem 0}.auth-panel-card{background:var(--kb-surface);border-radius:1rem;border:1px solid var(--kb-border);padding:1.15rem;display:flex;flex-direction:column;gap:.75rem;box-shadow:var(--kb-shadow-card)}.collapsible-card{gap:.25rem}.collapse-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem}.collapse-header-content{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:.5rem 1rem;width:100%}.collapse-header h2{margin:.2rem 0}.collapse-body{border-top:1px solid var(--kb-border);padding-top:.75rem}.collapsible-card:not(.expanded) .collapse-body{display:none}.auth-calendar{grid-column:1 / -1;width:100%}.search-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.65rem;margin-bottom:.35rem}.search-grid label{display:flex;flex-direction:column;gap:.35rem;color:var(--kb-muted-strong)}.compact-list{margin:0;padding-left:1.1rem;display:flex;flex-direction:column;gap:.2rem;color:var(--kb-muted-strong)}.auth-calendar .section-heading .eyebrow{font-size:.85rem}.results-header{display:flex;align-items:center;justify-content:space-between;gap:.5rem;flex-wrap:wrap}.results-header__titles{display:flex;align-items:baseline;gap:.45rem}.results-header__count{color:var(--kb-primary-strong);font-size:1rem}.auth-calendar .section-heading h2{font-size:clamp(1.2rem,2.6vw,1.55rem);white-space:nowrap}.auth-form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:.75rem}.login-form,.registration-form{background:linear-gradient(180deg,#fff,#f4f7ff);border-radius:1rem;border:1px solid var(--kb-border);padding:1rem;display:flex;flex-direction:column;gap:.75rem;box-shadow:inset 0 0 0 1px #6b8dfd14}.auth-toggle{display:flex;align-items:center;justify-content:space-between;gap:.5rem}button.link-button{background:transparent;border:none;color:var(--kb-primary-strong);padding:0;text-decoration:underline;box-shadow:none;min-height:auto}.auth-side{display:flex;flex-direction:column;gap:.75rem}.form-error{color:var(--kb-danger);font-size:.85rem;margin:0}.success{color:var(--kb-success);font-size:.85rem;margin:0}.muted{color:var(--kb-muted);margin:0}.muted.small{font-size:.78rem}.eyebrow{text-transform:uppercase;letter-spacing:.08em;margin:0;font-size:.72rem;color:var(--kb-muted)}input,select,textarea{width:100%;border-radius:.8rem;border:1px solid var(--kb-border);padding:.65rem .85rem;background:#fff;color:var(--kb-muted-strong);transition:border-color .15s ease,box-shadow .15s ease,transform .15s ease;box-shadow:inset 0 1px #fff9}input:focus,select:focus,textarea:focus{border-color:var(--kb-primary);box-shadow:0 0 0 3px #6b8dfd33;outline:none;transform:translateY(-1px)}textarea{resize:vertical;min-height:72px}button{border:none;border-radius:999px;padding:.65rem 1.4rem;background:linear-gradient(135deg,var(--kb-primary),var(--kb-accent));color:#fff;font-weight:600;cursor:pointer;transition:transform .15s ease,box-shadow .2s ease,opacity .2s ease;box-shadow:0 14px 26px #6b8dfd4d}button:hover{transform:translateY(-2px)}button:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}button.ghost{background:#fff;color:var(--kb-primary-strong);border:1px solid var(--kb-border);box-shadow:0 8px 18px #6b8dfd24}button.ghost:hover{transform:translateY(-1px)}button.danger{color:var(--kb-danger);background:linear-gradient(135deg,#ff8c8c,#ff6b6b);border-color:transparent}button.danger.ghost{color:var(--kb-danger);border-color:#ff6b6b66;background:#fff6f6}.form-grid{display:grid;gap:.75rem}.form-grid label{display:flex;flex-direction:column;gap:.3rem;font-size:.9rem}.form-card{display:flex;flex-direction:column;gap:.75rem}.form-card h2{margin:0}.bed-number-hint{margin:-.35rem 0 .2rem;font-size:.8rem;color:var(--kb-muted)}.form-actions{display:flex;justify-content:flex-end;gap:.5rem;margin-top:.25rem}.range-availability{grid-column:1 / -1;background:var(--kb-surface-soft);border:1px dashed var(--kb-border);border-radius:.95rem;padding:.9rem;display:flex;flex-direction:column;gap:.5rem}.range-availability-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(80px,1fr));gap:.4rem}.range-day{border:1px solid var(--kb-border);border-radius:.9rem;padding:.4rem .35rem;display:flex;flex-direction:column;align-items:center;gap:.1rem;font-size:.75rem;background:var(--kb-surface-soft);color:var(--kb-muted-strong);cursor:pointer}.range-day.open{border-color:#22c55e59;background:#22c55e1a;color:#1b7a45}.range-day.blocked{border-color:#ff6b6b73;background:#ff6b6b24;color:var(--kb-danger)}.table-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch}.table-wrapper--compact{max-height:420px;overflow-y:auto}.table-wrapper--compact table{min-width:720px}table{width:100%;min-width:1000px;border-collapse:collapse;font-size:.9rem}th,td{padding:.6rem .35rem;text-align:left;border-bottom:1px solid rgba(148,163,184,.3);white-space:nowrap}.compact-table th,.compact-table td{white-space:normal}th{font-size:.8rem;color:var(--kb-muted);font-weight:600}thead th{background:var(--kb-surface-strong);border-bottom:1px solid var(--kb-border)}tbody tr:nth-child(2n){background:var(--kb-surface-soft)}tbody tr:hover{background:#6b8dfd1f}.row-actions{display:flex;gap:.35rem;justify-content:flex-end;flex-wrap:wrap}.table-row-clickable{cursor:pointer}.note-row td{background:var(--kb-surface-soft);border-bottom:1px solid rgba(148,163,184,.25);padding:.75rem;white-space:normal}.note-row strong{display:block;margin-bottom:.2rem;color:var(--kb-muted-strong)}.calendar-page{display:flex;flex-direction:column;gap:.85rem}.calendar-page.compact{gap:.65rem}.calendar-page-header{display:flex;justify-content:space-between;align-items:flex-start;gap:.75rem}.calendar-card{padding:.85rem}.calendar-view{display:flex;flex-direction:column;gap:.9rem}.calendar-body{display:grid;grid-template-columns:minmax(0,1fr) minmax(280px,340px);gap:.85rem;align-items:start}.calendar-main{min-width:0}.calendar-toolbar{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.75rem}.calendar-legend{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.calendar-scroller{overflow-x:auto;padding-bottom:.25rem}.calendar-header{display:flex;align-items:center;gap:.5rem}.calendar-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:.4rem}.calendar-cell{border:1px solid var(--kb-border);border-radius:1rem;padding:.75rem;min-height:clamp(90px,12vw,140px);display:flex;flex-direction:column;justify-content:space-between;gap:.65rem;background:linear-gradient(180deg,#fff,#f3f6ff 45%,#fff);position:relative;overflow:hidden;transition:transform .2s ease,box-shadow .2s ease}.calendar-heading{border:none;text-align:center;color:var(--kb-muted);font-size:.8rem}.calendar-cell.cell-available{background:linear-gradient(180deg,#4ade801f,#fffffff0);border-color:#22c55e59}.calendar-cell.cell-full{background:linear-gradient(180deg,#ff8b8b1f,#fffffff2);border-color:#ff6b6b59}.calendar-cell.cell-disabled{background:linear-gradient(180deg,#94a3b82e,#ffffffe6);border-color:#94a3b873;color:var(--kb-muted);cursor:not-allowed;pointer-events:none}.calendar-cell.empty{border:none;background:transparent}.calendar-cell-clickable{cursor:pointer}.calendar-cell.cell-selected{box-shadow:0 0 0 2px #6b8dfd47}.calendar-cell:not(.empty):hover{transform:translateY(-2px);box-shadow:0 8px 20px #0f172a14}.calendar-cell.cell-disabled:hover{transform:none;box-shadow:none}.legend-item{display:inline-flex;align-items:center;gap:.35rem;color:var(--kb-muted)}.legend-dot{width:.6rem;height:.6rem;border-radius:50%}.legend-空床あり{background:#4ade80}.legend-満床{background:#f87171}.calendar-detail{background:linear-gradient(180deg,#fff,#f4f7ff);border-radius:1rem;border:1px solid var(--kb-border);padding:.95rem;display:flex;flex-direction:column;gap:.75rem;max-height:calc(100vh - .8rem);overflow-y:auto}.calendar-detail-panel{position:sticky;top:.4rem;align-self:start;max-height:calc(100vh - .8rem)}.calendar-detail-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.25rem;gap:.5rem}.calendar-detail-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.6rem}.calendar-detail-item{border-bottom:1px solid rgba(148,163,184,.3);padding-bottom:.5rem;display:flex;justify-content:space-between;gap:.75rem}.calendar-detail-item:last-child{border-bottom:none;padding-bottom:0}.calendar-detail-item.is-clickable{cursor:pointer;border:1px solid var(--kb-border);border-radius:.65rem;padding:.7rem .75rem;box-shadow:inset 0 0 0 1px #6b8dfd14;transition:box-shadow .12s ease,transform .12s ease;background:#fff}.calendar-detail-item.is-clickable:last-child{border-bottom:1px solid var(--kb-border)}.calendar-detail-item.is-clickable:hover{box-shadow:0 6px 18px #0f172a14;transform:translateY(-1px)}.calendar-detail-item.is-clickable:focus-visible{outline:2px solid var(--kb-primary-strong);outline-offset:2px}.calendar-detail-notes p{margin:0;font-size:.85rem;color:var(--kb-muted)}.calendar-detail-notes{display:flex;flex-direction:column;gap:.2rem}@media(max-width:900px){.calendar-body{grid-template-columns:1fr}.calendar-detail-panel{position:fixed;bottom:1rem;left:1rem;right:1rem;max-height:70vh;transform:translateY(115%);transition:transform .2s ease,opacity .2s ease;pointer-events:none;z-index:8}.calendar-detail-panel.open{transform:translateY(0);pointer-events:auto}.calendar-detail-panel .calendar-detail{box-shadow:0 10px 28px #0f172a2e;max-height:70vh;overflow-y:auto}.overlay{position:fixed;inset:0;background-color:#0f172a80;opacity:0;transition:opacity .2s ease;pointer-events:none;z-index:7}body.overlay-visible .overlay{opacity:1;pointer-events:auto}}.settings-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:.85rem}.settings-grid.compact{gap:.65rem}.settings-card h2{margin-top:0}.settings-header{display:flex;align-items:center;justify-content:space-between;gap:.5rem;margin-bottom:.5rem}.user-section{margin-top:1rem;display:flex;flex-direction:column;gap:.35rem}.scroll-section{max-height:320px;overflow-y:auto;padding-right:.35rem;margin-top:.25rem}.facility-list,.user-list{list-style:none;padding:0;margin:.75rem 0 0;display:flex;flex-direction:column;gap:.65rem}.facility-list li,.user-list li{display:flex;justify-content:space-between;gap:.5rem;border-bottom:1px solid rgba(148,163,184,.3);padding-bottom:.5rem}.user-row{flex-direction:column;gap:.5rem}.danger-zone{margin-top:1rem;padding:.85rem;border-radius:.9rem;border:1px dashed rgba(255,107,107,.6);background:#ff6b6b14;display:flex;flex-direction:column;gap:.5rem}.danger-text{margin:0;color:var(--kb-danger);font-size:.85rem}.danger-zone button.danger{background:var(--kb-danger);color:#fff;border-color:transparent;box-shadow:0 12px 25px #ff6b6b59}.danger-zone button.danger:disabled{background:#ff6b6ba6}.user-actions{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;justify-content:flex-end}.notify-toggle{display:inline-flex;align-items:center;gap:.5rem;font-size:.85rem;color:var(--kb-muted);white-space:nowrap}.notify-toggle input{margin:0}.notify-toggle span{white-space:nowrap}.calendar-day-row{display:flex;justify-content:flex-start;align-items:center;gap:.5rem;flex-wrap:nowrap}.calendar-day{font-size:clamp(1rem,1.3vw + .6rem,1.5rem);font-weight:700;color:var(--kb-muted-strong)}.calendar-cell.cell-disabled .calendar-day,.calendar-cell.cell-disabled .calendar-day-status{color:#94a3b8}.calendar-cell.cell-disabled .calendar-capacity-indicator{background:#cbd5e1;box-shadow:none}.calendar-day-meta{display:flex;justify-content:space-between;align-items:center;gap:.4rem}.calendar-day-status{font-size:.8rem;color:var(--kb-muted)}.calendar-capacity-indicator{width:.6rem;height:.6rem;border-radius:50%;display:inline-flex}.indicator-available{background:#22c55e;box-shadow:0 0 0 3px #22c55e33}.indicator-full{background:#f87171;box-shadow:0 0 0 3px #f8717133}@media(max-width:820px){.calendar-grid{gap:.3rem}}@media(max-width:640px){.calendar-grid{gap:.2rem}.calendar-cell{padding:.5rem;min-height:80px;gap:.4rem}.calendar-day-row{flex-direction:column;align-items:flex-start;gap:.1rem}.calendar-day{font-size:1.2rem}.calendar-day-status{display:none}.calendar-day-meta{justify-content:flex-start;gap:.25rem}.calendar-capacity-indicator{width:.45rem;height:.45rem;box-shadow:none}}.auth-overlay{position:fixed;inset:0;background:#ffffffe6;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:100;padding:1rem}.auth-overlay .login-form{width:100%;max-width:400px;box-shadow:0 25px 50px -12px #00000040}
