*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--color-bg:#0f172a;--color-surface:#1e293b;--color-surface-elevated:#334155;--color-border:#475569;--color-text:#f1f5f9;--color-text-muted:#94a3b8;--color-text-subtle:#64748b;--color-user-a:#0ea5e9;--color-user-a-bg:#0ea5e940;--color-user-b:#f97316;--color-user-b-bg:#f9731640;--color-available:#16a34a;--color-available-bg:#052e16;--color-partial:#ca8a04;--color-partial-bg:#1c1200;--color-past:#1e293b;--color-past-text:#475569;--color-blocked:#dc2626;--color-blocked-bg:#450a0a;--color-focus:#38bdf8;--radius-sm:4px;--radius-md:8px;--radius-lg:12px;--font-family:system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;--font-size-xs:.7rem;--font-size-sm:.8rem;--font-size-base:1rem;--font-size-lg:1.125rem;--font-size-xl:1.25rem;--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark}html{font-family:var(--font-family);background:var(--color-bg);color:var(--color-text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100dvh;font-size:16px}body{min-height:100dvh}:focus-visible{outline:2px solid var(--color-focus);outline-offset:2px;border-radius:var(--radius-sm)}#app{flex-direction:column;min-height:100dvh;display:flex}.page{flex:1;justify-content:center;align-items:center;padding:2rem 1rem;display:flex}.auth-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);width:100%;max-width:380px;padding:2rem}.auth-card h1{font-size:var(--font-size-xl);text-align:center;margin-bottom:.25rem;font-weight:600}.auth-card .subtitle{color:var(--color-text-muted);font-size:var(--font-size-sm);text-align:center;margin-bottom:1.5rem}.form-group{margin-bottom:1rem}.form-group label{font-size:var(--font-size-sm);color:var(--color-text-muted);margin-bottom:.4rem;font-weight:500;display:block}.form-group input{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm);width:100%;color:var(--color-text);font-size:var(--font-size-base);padding:.6rem .75rem;transition:border-color .15s}.form-group input:focus{border-color:var(--color-focus);outline:none;box-shadow:0 0 0 2px #38bdf833}.form-group input::placeholder{color:var(--color-text-subtle)}.error-msg{color:#f87171;font-size:var(--font-size-sm);text-align:center;min-height:1.2em;margin-top:.75rem}.btn{cursor:pointer;font-family:var(--font-family);font-size:var(--font-size-base);border-radius:var(--radius-sm);border:none;padding:.625rem 1rem;font-weight:500;transition:background .15s,opacity .15s}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--color-focus);color:#0f172a;width:100%}.btn-primary:hover:not(:disabled){background:#7dd3fc}.btn-sm{font-size:var(--font-size-xs);padding:.25rem .5rem}.btn-ghost{color:var(--color-text-muted);border:1px solid var(--color-border);background:0 0}.btn-ghost:hover:not(:disabled){background:var(--color-surface-elevated);color:var(--color-text)}.cal-page{flex-direction:column;flex:1;width:100%;max-width:1200px;margin:0 auto;padding:1.5rem 1rem;display:flex}.cal-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem;margin-bottom:1rem;display:flex}.cal-header h1{font-size:var(--font-size-xl);font-weight:600}.cal-header-right{flex-wrap:wrap;align-items:center;gap:.75rem;display:flex}.user-badge{font-size:var(--font-size-sm);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);align-items:center;gap:.4rem;padding:.3rem .6rem;font-weight:500;display:inline-flex}.user-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.cal-legend{font-size:var(--font-size-xs);color:var(--color-text-muted);flex-wrap:wrap;align-items:center;gap:1rem;margin-bottom:1rem;display:flex}.legend-item{align-items:center;gap:.35rem;display:flex}.legend-swatch{border-radius:3px;flex-shrink:0;width:14px;height:14px}.tz-notice{font-size:var(--font-size-xs);color:var(--color-text-subtle);margin-bottom:1.5rem}.months-container{flex-direction:column;gap:2rem;display:flex}.month-block{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1.25rem}.month-title{font-size:var(--font-size-lg);margin-bottom:1rem;font-weight:600}.weekday-headers{grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:4px;display:grid}.weekday-header{text-align:center;font-size:var(--font-size-xs);color:var(--color-text-muted);padding:.2rem 0;font-weight:500}.days-grid{grid-template-columns:repeat(7,1fr);gap:4px;display:grid}.day-cell{border-radius:var(--radius-sm);background:var(--color-surface-elevated);border:1px solid var(--color-border);min-height:56px;position:relative;overflow:hidden}.day-cell:not(.is-placeholder):not(.is-past){cursor:pointer}.day-cell:not(.is-placeholder):not(.is-past):hover{border-color:var(--color-text-subtle)}.day-cell:not(.is-placeholder):not(.is-past):focus-visible{outline:2px solid var(--color-focus);outline-offset:0}.day-cell.is-placeholder{background:0 0;border-color:#0000}.day-cell.is-past{background:var(--color-past);opacity:.4;border-color:#0000}.day-cell.is-today{border-color:var(--color-focus)!important}.day-cell.both-available{background:var(--color-available-bg);border-color:var(--color-available)}.day-cell.one-unavailable{background:var(--color-partial-bg);border-color:var(--color-partial)}.day-number{font-size:var(--font-size-xs);color:var(--color-text-muted);font-weight:600;line-height:1;position:absolute;top:5px;left:6px}.day-cell.both-available .day-number{color:#4ade80}.day-cell.one-unavailable .day-number{color:#fde047}.day-cell.is-past .day-number{color:var(--color-past-text)}.day-bars{flex-direction:column;gap:2px;display:flex;position:absolute;bottom:4px;left:4px;right:4px}.day-bar{border-radius:2px;width:100%;height:4px}.detail-overlay{z-index:100;background:#000000a6;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.detail-panel{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);width:100%;max-width:500px;max-height:90dvh;padding:1.5rem;overflow-y:auto}.detail-header{justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1.25rem;display:flex}.detail-header h2{font-size:var(--font-size-lg);font-weight:600;line-height:1.3}.detail-header .detail-meta{font-size:var(--font-size-sm);color:var(--color-text-muted);margin-top:.15rem}.detail-section-title{font-size:var(--font-size-sm);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:.6rem;font-size:.65rem;font-weight:600}.chunk-buttons{flex-wrap:wrap;gap:.5rem;margin-bottom:1rem;display:flex}.hours-grid{grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:6px;margin-bottom:1.25rem;display:grid}.hour-slot{border-radius:var(--radius-sm);border:1px solid var(--color-border);background:var(--color-surface-elevated);font-size:var(--font-size-xs);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:6px;padding:.4rem .5rem;transition:background .1s,border-color .1s;display:flex}.hour-slot:focus-visible{outline:2px solid var(--color-focus);outline-offset:0}.hour-slot.blocked-mine{background:var(--color-blocked-bg);border-color:var(--color-blocked)}.hour-slot-label{color:var(--color-text);white-space:nowrap;flex:1;font-weight:500}.hour-slot.blocked-mine .hour-slot-label{color:#fca5a5}.hour-slot-indicators{flex-shrink:0;gap:2px;display:flex}.hour-indicator{border-radius:50%;flex-shrink:0;width:8px;height:8px}.hour-indicator.available{opacity:1}.hour-indicator.blocked{opacity:.2;background:var(--color-border)!important}.other-user-section{border-top:1px solid var(--color-border);margin-top:1rem;padding-top:1rem}.site-lock-control{font-size:var(--font-size-xs);color:var(--color-text-muted);align-items:center;gap:.4rem;display:inline-flex}.site-lock-label{white-space:nowrap}.event-name-group{margin-bottom:1rem}.event-name-group label{font-size:var(--font-size-xs);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:.4rem;font-weight:600;display:block}.event-name-input{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm);width:100%;color:var(--color-text);font-size:var(--font-size-sm);padding:.5rem .6rem;transition:border-color .15s}.event-name-input:focus{border-color:var(--color-focus);outline:none;box-shadow:0 0 0 2px #38bdf833}.event-name-input::placeholder{color:var(--color-text-subtle)}.other-event-name{font-size:var(--font-size-xs);color:var(--color-text-muted);margin-bottom:.6rem;font-style:italic}.spinner{border:2px solid #ffffff26;border-top-color:var(--color-focus);vertical-align:middle;border-radius:50%;width:16px;height:16px;margin-right:.4rem;animation:.6s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}@media (width<=600px){.day-cell{min-height:44px}.month-block{padding:.75rem}.detail-panel{padding:1rem}.cal-page{padding:1rem .75rem}}
