:root{--bg:#f7f8fb;--text:#111827;--muted:#6b7280;--border:#e5e7eb;--line:#e5e7eb;--brand:#6d5efb;--on-brand:#ffffff;--danger:#b91c1c;--link: #6e56cf;--link-hover: #5b44c0;--link-visited:#5639b8;--link-focus: #9e8cff;--card:#ffffff;--card-bg:#ffffff;--card-shadow:0 8px 26px rgba(17,24,39,.06);--ring:#7c3aed;--ring-soft:#ede9fe;--accent:#111827;--accent-contrast:#ffffff;--primary:#0ea5e9;--primary-contrast:#ffffff;--success:#16a34a;--input-bg:#fff;--input-border:var(--border);--chip-bg:#fff;--chip-border:#e2e8f0;--chip-hover:#f8fafc;--radius:14px;--radius-lg:12px;--radius-md:10px;--radius-pill:999px;--space-xs:8px;--space-sm:12px;--space-md:14px;--space-lg:16px;--gap-xs:8px;--gap-md:12px;--gap-lg:24px;--text-md:16px;--text-lg:18px;--cal-radius:12px;--cal-ava-bg:#f1f7ff;--cal-ava-br:#cfe7ff;--cal-ava-fg:#0b4a7a;--cal-sel-bg:#f2eaff;--cal-sel-br:#d7c9ff;--cal-sel-ring:rgba(124,58,237,.18);--cal-sel-fg:#4b2ca5;--cal-full-bg:#ffe9ea;--cal-full-br:#ffd4d6;--cal-full-fg:#9f1d1d;--cal-closed-bg:#f4f6f8;--cal-closed-br:#e6e9ee;--cal-closed-fg:#98a2b3}body{background:var(--bg);color:var(--text)}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font:14px/1.45 system-ui,-apple-system,Segoe UI,Roboto,Inter,Helvetica Neue,Arial}.container{max-width:1100px;margin:24px auto;padding:0 16px;display:grid;gap:16px}.header-bar{display:grid;align-items:center;gap:12px;padding:14px 16px;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--card-shadow)}.header-title h1{margin:0;font-size:18px;letter-spacing:.2px}.header-sub{color:var(--muted);font-size:12.5px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:9px 12px;border:1px solid var(--line);background:#fff;color:#0f172a;border-radius:12px;cursor:pointer;font-weight:600;transition:.18s ease box-shadow,.18s ease transform,.18s ease background,.18s ease border-color}.btn:hover{transform:translateY(-1px);box-shadow:0 6px 18px #0206170f}.btn:focus-visible{outline:none;box-shadow:0 0 0 3px var(--ring-soft),0 0 0 5px #7c3aed40}.btn.primary{background:var(--primary);color:var(--primary-contrast);border-color:transparent}.btn.primary:hover{filter:saturate(1.05) brightness(.98)}.btn.danger{background:var(--danger);color:#fff;border-color:transparent}.btn.ghost{background:#fff}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:16px;box-shadow:var(--card-shadow)}.card--tight{padding:12px}.ok{color:var(--success);font-weight:600}.error{color:var(--danger);font-weight:600}.muted{color:var(--muted)}.row{display:grid;grid-template-columns:180px 1fr;align-items:center;gap:10px;margin:8px 0}.row>label{color:var(--muted);font-weight:600}input,select{width:100%;padding:10px 12px;border:1px solid var(--line);border-radius:10px;background:#fff;transition:.18s ease box-shadow,.18s ease border-color}input:focus,select:focus{outline:none;border-color:#cbd5e1;box-shadow:0 0 0 3px var(--ring-soft)}.table-wrap{overflow:auto;border:1px solid var(--line);border-radius:12px}.table{width:100%;border-collapse:separate;border-spacing:0}.table thead th{text-align:left;font-size:12px;color:#475569;background:#f8fafc;padding:10px;border-bottom:1px solid var(--line);position:sticky;top:0}.table tbody td{padding:10px;border-bottom:1px solid #f1f5f9}.table tbody tr:hover{background:#fafafa}.table tfoot td{padding:10px;background:#fafafa;border-top:1px solid var(--line)}.seg{display:inline-flex;background:#fff;border:1px solid var(--line);border-radius:12px;overflow:hidden}.seg__btn{padding:8px 12px;border:0;background:transparent;font-weight:700;cursor:pointer}.seg__btn:hover{background:#f3f4f6}.seg__btn.is-active{background:var(--accent);color:var(--accent-contrast)}.admin-date{padding:9px 10px;border:1px solid var(--line);border-radius:10px;background:#fff}.header-bar .btn+.btn{margin-left:6px}.legend{display:inline-block;width:12px;height:12px;border-radius:3px;border:1px solid var(--line);vertical-align:middle;margin-right:6px}.legend--available{background:var(--cal-ava-bg);border-color:var(--cal-ava-br)}.legend--full{background:var(--cal-full-bg);border-color:var(--cal-full-br)}.legend--closed{background:#f3f4f6;border-style:dashed}.legend--selected{background:var(--cal-sel-bg);border-color:var(--cal-sel-br)}.badge{display:inline-flex;align-items:center;padding:3px 8px;border-radius:999px;font-weight:600;font-size:11px;background:#f1f5f9;color:#334155;border:1px solid #e2e8f0}.badge.success{background:#ecfdf5;color:#166534;border-color:#a7f3d0}.badge.warn{background:#fff7ed;color:#9a3412;border-color:#fed7aa}@media (max-width: 820px){.row,.header-bar{grid-template-columns:1fr}}.week-cal__header,.week-cal__dayhead{background:var(--card)}.week-cal__corner,.week-cal__dayhead{border-bottom:1px solid var(--line)}.week-cal__time{color:var(--muted)}.week-cal .slot{border:1px solid var(--line);border-radius:var(--cal-radius);background:#fff;min-height:40px;display:flex;align-items:center;justify-content:center;padding:4px 6px;transition:transform .12s ease,box-shadow .18s ease,background .18s ease,border-color .18s ease,color .18s ease;font-weight:600}.week-cal .slot--available{background:var(--cal-ava-bg);border-color:var(--cal-ava-br);color:var(--cal-ava-fg)}.week-cal .slot--available:hover{transform:translateY(-1px);box-shadow:0 6px 18px #0206170f}.week-cal .slot--selected{background:var(--cal-sel-bg);border-color:var(--cal-sel-br);color:var(--cal-sel-fg);box-shadow:inset 0 0 0 2px var(--cal-sel-ring)}.week-cal .slot--full{background:var(--cal-full-bg);border-color:var(--cal-full-br);color:var(--cal-full-fg);cursor:not-allowed}.week-cal .slot--closed{background:linear-gradient(180deg,var(--cal-closed-bg),#eef2f6);border-color:var(--cal-closed-br);color:var(--cal-closed-fg);border-style:dashed;cursor:not-allowed}.week-cal .slot:focus-visible{outline:none;box-shadow:0 0 0 3px var(--ring-soft),0 0 0 5px #7c3aed38}.week-cal .slot:disabled{transform:none;box-shadow:none;opacity:.9;cursor:not-allowed}@media (max-width: 960px){.week-cal .slot{min-height:36px;border-radius:10px}}.btn-delete{background-color:#dc2626;color:#fff;border:none;padding:6px 12px;border-radius:8px;font-weight:600;cursor:pointer;transition:background-color .2s ease}.btn-delete:hover{background-color:#b91c1c}.nav{top:0;z-index:40;-webkit-backdrop-filter:saturate(180%) blur(10px);backdrop-filter:saturate(180%) blur(10px);background:color-mix(in oklab,white 80%,transparent);border-bottom:1px solid var(--line,#e5e7eb)}.nav__inner{max-width:1100px;margin:0 auto;padding:10px 16px;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:8px}.nav__left,.nav__right{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.nav__left{justify-content:flex-start}.nav__right{justify-content:flex-end}.nav__brand{display:grid;justify-items:center;line-height:1.1}.nav__logo{font-weight:800;letter-spacing:-.02em;text-decoration:none;color:#111827}.nav__logo:hover{text-decoration:underline}.nav__sub{font-size:12px;color:#6b7280}.nav__link{display:inline-flex;align-items:center;height:34px;padding:0 10px;border-radius:9px;font-weight:600;color:#111827;text-decoration:none;border:1px solid transparent;transition:background-color .15s ease,border-color .15s ease}.nav__link:hover{background:#f3f4f6;border-color:#e5e7eb}.nav__link.is-active{background:#eef2ff;border-color:#c7d2fe;color:#1f2937}.btn.btn--ghost{background:transparent;border:1px solid #e5e7eb;color:#111827;border-radius:9px;padding:6px 10px;font-weight:600}.btn.btn--ghost:hover{background:#f8fafc}.btn.btn--danger-ghost{background:transparent;border:1px solid #fecaca;color:#b91c1c;border-radius:9px;padding:6px 10px;font-weight:700}.btn.btn--danger-ghost:hover{background:#fff1f2;border-color:#fca5a5}@media (max-width: 720px){.nav__inner{grid-template-columns:1fr auto;grid-template-areas:"brand right" "left left";row-gap:8px}.nav__brand{grid-area:brand;justify-items:start}.nav__right{grid-area:right}.nav__left{grid-area:left}}.modal__backdrop{position:fixed;inset:0;z-index:50;background:#11182773;display:grid;place-items:center;padding:16px}.modal__panel{width:100%;max-width:560px;background:#fff;border-radius:14px;box-shadow:0 10px 35px #00000026;display:grid;grid-template-rows:auto 1fr auto;max-height:90vh;overflow:hidden}.modal__header,.modal__footer{padding:14px 16px;border-bottom:1px solid var(--line,#e5e7eb)}.modal__footer{border-top:1px solid var(--line,#e5e7eb);border-bottom:0;display:flex;gap:8px;justify-content:flex-end}.modal__body{padding:14px 16px;display:grid;gap:12px;overflow:auto}.modal__header{display:flex;align-items:center;justify-content:space-between}.toaster{position:fixed;right:16px;top:16px;z-index:60;display:grid;gap:8px}.toast{background:#111827;color:#fff;padding:10px 12px;border-radius:10px;box-shadow:0 6px 18px #0000002e;font-weight:600;font-size:14px;opacity:0;transform:translateY(-6px);animation:toast-in .18s ease-out forwards,toast-out .25s ease-in forwards;animation-delay:0s,var(--toast-hide, 3s)}.toast--success{background:#065f46}.toast--error{background:#991b1b}@keyframes toast-in{to{opacity:1;transform:translateY(0)}}@keyframes toast-out{to{opacity:0;transform:translateY(-6px)}}.actions{display:inline-flex;gap:8px;align-items:center;position:relative}.btn-icon{padding:6px 10px;line-height:1;font-weight:700;border-radius:10px;background:#fff;border:1px solid var(--line,#e5e7eb);cursor:pointer}.btn-icon:hover{background:#f8fafc}.menu{position:absolute;right:0;top:110%;min-width:180px;background:#fff;border:1px solid var(--line,#e5e7eb);border-radius:12px;box-shadow:0 8px 24px #10182814;padding:6px;z-index:50}.menu__item{display:block;width:100%;text-align:left;background:transparent;border:0;padding:8px 10px;border-radius:8px;font-weight:500;cursor:pointer}.menu__item:hover{background:#f3f4f6}.menu__item--danger{color:#b91c1c}.menu__item--danger:hover{background:#fee2e2}.menu__sep{height:1px;background:var(--line,#e5e7eb);margin:6px 4px}:root[data-theme=dark]{--bg:#0b1220;--card:#0f172a;--card-bg:#0f172a;--text:#e5e7eb;--muted:#94a3b8;--border:#1f2937;--line:#1f2937;--brand:#8b7bff;--on-brand:#0b1220;--link: #b388ff;--link-hover: #d1aaff;--link-visited:#c09cff;--link-focus: #e2d7ff;--primary:#38bdf8;--primary-contrast:#06131d;--danger:#ef4444;--success:#22c55e;--input-bg:#0b1220;--input-border:#263244;--chip-bg:#0b1220;--chip-border:#263244;--chip-hover:#0e1a2b;--card-shadow:0 10px 30px rgba(0,0,0,.35);--cal-ava-bg:#0f243d;--cal-ava-br:#1f3c63;--cal-ava-fg:#cce2ff;--cal-sel-bg:#1a1440;--cal-sel-br:#342a7a;--cal-sel-ring:rgba(124,58,237,.35);--cal-sel-fg:#d9d2ff;--cal-full-bg:#3a0e10;--cal-full-br:#5a1b1e;--cal-full-fg:#fecaca;--cal-closed-bg:#0f172a;--cal-closed-br:#233045;--cal-closed-fg:#9aa7b7;--ring:#7c3aed;--ring-soft:rgba(124,58,237,.28)}@media (prefers-color-scheme: dark){:root:not([data-theme=light]){--bg:#0b1220;--card:#0f172a;--card-bg:#0f172a;--text:#e5e7eb;--muted:#94a3b8;--border:#1f2937;--line:#1f2937;--brand:#8b7bff;--on-brand:#0b1220;--primary:#38bdf8;--primary-contrast:#06131d;--danger:#ef4444;--success:#22c55e;--input-bg:#0b1220;--input-border:#263244;--chip-bg:#0b1220;--chip-border:#263244;--chip-hover:#0e1a2b;--card-shadow:0 10px 30px rgba(0,0,0,.35);--cal-ava-bg:#0f243d;--cal-ava-br:#1f3c63;--cal-ava-fg:#cce2ff;--cal-sel-bg:#1a1440;--cal-sel-br:#342a7a;--cal-sel-ring:rgba(124,58,237,.35);--cal-sel-fg:#d9d2ff;--cal-full-bg:#3a0e10;--cal-full-br:#5a1b1e;--cal-full-fg:#fecaca;--cal-closed-bg:#0f172a;--cal-closed-br:#233045;--cal-closed-fg:#9aa7b7;--ring:#7c3aed;--ring-soft:rgba(124,58,237,.28);--link: #b388ff;--link-hover: #d1aaff;--link-visited:#c09cff;--link-focus: #e2d7ff}}:root[data-theme=dark] body{background:var(--bg);color:var(--text)}@media (prefers-color-scheme: dark){:root:not([data-theme=light]) body{background:var(--bg);color:var(--text)}}:root[data-theme=dark] .card,:root[data-theme=dark] .header-bar{background:var(--card-bg);border-color:var(--line);box-shadow:var(--card-shadow)}@media (prefers-color-scheme: dark){:root:not([data-theme=light]) .card,:root:not([data-theme=light]) .header-bar{background:var(--card-bg);border-color:var(--line);box-shadow:var(--card-shadow)}}:root[data-theme=dark] .btn{background:var(--card-bg);color:var(--text);border-color:var(--line)}:root[data-theme=dark] .btn.primary{background:var(--primary);color:var(--primary-contrast);border-color:transparent}:root[data-theme=dark] .btn.danger{background:var(--danger);color:#fff}:root[data-theme=dark] .btn-icon{background:var(--card-bg);border-color:var(--line);color:var(--text)}:root[data-theme=dark] input,:root[data-theme=dark] select,:root[data-theme=dark] textarea{background:var(--input-bg);border:1px solid var(--input-border);color:var(--text)}:root[data-theme=dark] input::placeholder,:root[data-theme=dark] textarea::placeholder{color:#94a3b8}:root[data-theme=dark] .table-wrap{border-color:var(--line)}:root[data-theme=dark] .table thead th{background:#0e1626;color:var(--muted);border-bottom-color:var(--line)}:root[data-theme=dark] .table tbody td{border-bottom-color:#1e293b}:root[data-theme=dark] .table tbody tr:hover{background:#0f1a2b}:root[data-theme=dark] .table tfoot td{background:#0e1626;border-top-color:var(--line)}:root[data-theme=dark] .chip{background:var(--chip-bg);color:var(--text);border-color:var(--chip-border)}:root[data-theme=dark] .chip:hover{background:var(--chip-hover)}:root[data-theme=dark] .chip.is-active{background:var(--brand);color:var(--on-brand);border-color:var(--brand)}:root[data-theme=dark] .menu{background:var(--card-bg);border-color:var(--line);box-shadow:0 12px 28px #00000073}:root[data-theme=dark] .menu__item{color:var(--text)}:root[data-theme=dark] .menu__item:hover{background:#0e1a2b}:root[data-theme=dark] .nav{-webkit-backdrop-filter:saturate(160%) blur(10px);backdrop-filter:saturate(160%) blur(10px);background:color-mix(in oklab,var(--card-bg) 80%,transparent);border-bottom-color:var(--line)}:root[data-theme=dark] .nav__logo{color:var(--text)}:root[data-theme=dark] .nav__sub{color:var(--muted)}:root[data-theme=dark] .nav__link{color:var(--text)}:root[data-theme=dark] .nav__link:hover{background:#0e1a2b;border-color:var(--line)}:root[data-theme=dark] .nav__link.is-active{background:#161b2c;border-color:#2b3560;color:var(--text)}:root[data-theme=dark] .btn.btn--ghost{background:transparent;border-color:var(--line);color:var(--text)}:root[data-theme=dark] .btn.btn--ghost:hover{background:#0e1a2b}:root[data-theme=dark] .btn.btn--danger-ghost{background:transparent;border-color:#5b1c1c;color:#fca5a5}:root[data-theme=dark] .btn.btn--danger-ghost:hover{background:#2a0f10;border-color:#7f1d1d}:root[data-theme=dark] .modal__panel{background:var(--card-bg);color:var(--text);box-shadow:0 18px 50px #00000073}:root[data-theme=dark] .modal__header,:root[data-theme=dark] .modal__footer{border-color:var(--line)}:root[data-theme=dark] .badge{background:#0e1a2b;color:var(--text);border-color:#223049}:root[data-theme=dark] .badge.success{background:#052e22;color:#86efac;border-color:#145a41}:root[data-theme=dark] .badge.warn{background:#2b1c08;color:#fdba74;border-color:#7c3a0a}.btn-reserve{background-color:var(--primary);color:var(--primary-contrast);font-weight:600;padding:8px 14px;border:none;border-radius:8px;cursor:pointer;transition:background-color .2s ease,opacity .2s ease}.btn-reserve:hover:not(:disabled){background-color:#0284c7}.btn-reserve:disabled{background-color:#9ca3af;color:#e5e7eb;cursor:not-allowed;opacity:.7;box-shadow:none}.daily-wrap{display:grid;grid-template-columns:1fr 360px;gap:var(--gap-lg,24px)}@media (max-width:980px){.daily-wrap{grid-template-columns:1fr}}.daily-main .section-title{font-size:var(--text-lg,18px);margin:0 0 var(--space-sm,12px)}.exp-card{display:grid;grid-template-columns:1fr auto;align-items:center;margin-bottom:var(--space-sm,12px);gap:var(--gap-md,12px)}.exp-title{font-weight:700;font-size:var(--text-md,16px)}.exp-sub{margin-top:2px}.exp-desc{margin-top:var(--space-xs,8px)}.exp-cta{display:grid;gap:var(--space-xs,6px);justify-items:end}.daily-aside .sticky{position:sticky;top:var(--space-md,16px)}.aside-title{margin:0 0 var(--space-sm,10px)}.daily-aside .row{display:grid;gap:var(--space-xs,6px);margin-bottom:var(--space-sm,12px)}.daily-aside .row input,.daily-aside .row select{height:36px;padding:6px 10px;border:1px solid var(--input-border, var(--border,#e5e7eb));border-radius:var(--radius-md,10px);background:var(--input-bg,#fff);color:var(--text,#111827)}.hour-groups{display:grid;gap:var(--space-sm,12px)}.hour-group{padding-top:var(--space-xs,8px);border-top:1px solid var(--border,#e5e7eb)}.hour-group:first-child{border-top:0;padding-top:0}.hour-head{font-weight:700;color:var(--muted,#6b7280);margin-bottom:var(--space-xs,6px);letter-spacing:.2px}.hour-chips{display:grid;grid-template-columns:1fr;gap:var(--gap-xs,8px)}.chip{width:100%;justify-content:center;padding:10px 14px;border:1px solid var(--chip-border,#e2e8f0);background:var(--chip-bg,#fff);color:var(--chip-fg, var(--text,#111827));border-radius:var(--radius-pill,999px);font-weight:600;font-size:12px;transition:background .12s ease,border-color .12s ease,color .12s ease}.chip:hover{background:var(--chip-hover,#f8fafc)}.chip.is-active{background:var(--brand,#6366f1);color:var(--on-brand,#fff);border-color:var(--brand,#6366f1)}.chip:disabled{opacity:.45;cursor:not-allowed}.notes{margin:0 0 var(--space-sm,12px);padding-left:18px;color:var(--muted,#6b7280)}.reserve-btn{min-width:220px}.reserve-btn:disabled{background:var(--btn-disabled-bg, #e5e7eb)!important;border-color:var(--btn-disabled-br, #e5e7eb)!important;color:var(--btn-disabled-fg, #6b7280)!important;cursor:not-allowed;box-shadow:none;opacity:1}[data-theme=dark] .hour-group{border-top-color:var(--line)}[data-theme=dark] .chip:hover{background:var(--chip-hover)}[data-theme=dark] .reserve-btn:disabled{background:var(--btn-disabled-bg,#1f2937)!important;border-color:var(--btn-disabled-br,#273449)!important;color:var(--btn-disabled-fg,#94a3b8)!important}[data-theme=dark] input,[data-theme=dark] select,[data-theme=dark] textarea{background-color:#1e293b;color:#fff;border:1px solid #334155}[data-theme=dark] input[type=date]::-webkit-calendar-picker-indicator,[data-theme=dark] input[type=time]::-webkit-calendar-picker-indicator,[data-theme=dark] select::-ms-expand,[data-theme=dark] input[type=datetime-local]::-webkit-calendar-picker-indicator{filter:invert(1)}[data-theme=dark] input[type=date],[data-theme=dark] input[type=time],[data-theme=dark] input[type=datetime-local]{color-scheme:dark}[data-theme=dark] select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='white' viewBox='0 0 16 16'%3E%3Cpath fill-rule='evenodd' d='M1.5 5.5l6 6 6-6H1.5z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .7rem center;background-size:1rem;padding-right:2rem}:where(a):not(.btn){color:var(--link);text-decoration:underline;text-underline-offset:2px;transition:color .2s ease}:where(a):not(.btn):hover{color:var(--link-hover)}:where(a):not(.btn):visited{color:var(--link-visited)}:where(a):not(.btn):focus-visible{outline:2px solid var(--link-focus);outline-offset:2px;border-radius:4px}:root{--table-head-bg: #f8fafc;--table-head-fg: #475569;--table-section-bg: #f8fafc}:root[data-theme=dark]{--table-head-bg: #0e1626;--table-head-fg: var(--muted);--table-section-bg: #0f1a2b}@media (prefers-color-scheme: dark){:root:not([data-theme=light]){--table-head-bg: #0e1626;--table-head-fg: var(--muted);--table-section-bg: #0f1a2b}}.table thead th{background:var(--table-head-bg);color:var(--table-head-fg);border-bottom:1px solid var(--line)}.group-header td{font-weight:700;background:var(--table-section-bg);color:var(--muted);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
