:root{font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.5;font-weight:400;color:#0f172a;background-color:#f8fafc;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-size-adjust:100%}body{margin:0;min-height:100vh;background:radial-gradient(circle at top,rgba(148,163,184,.25),transparent 55%),#f8fafc;color:inherit}#root{width:min(1200px,100%);margin:0 auto;padding:2rem 1.5rem 3rem}button,input,select,textarea{font:inherit;color:inherit}*{box-sizing:border-box}.app-shell{min-height:100vh;display:flex;flex-direction:column;gap:1.5rem;color:#0f172a}.toolbar{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}.toolbar__navigation{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.toolbar__title{font-size:1.75rem;font-weight:600;margin:0}.toolbar__month{display:flex;align-items:center;gap:.5rem;font-size:1.5rem;font-weight:600}.toolbar__month-label{font-size:inherit}.toolbar__month .toolbar__button{border:1px solid #cbd5f5;background:#fff;color:#0b3d91;width:2.5rem;height:2.5rem;padding:0;border-radius:.75rem;box-shadow:0 6px 16px #0f172a1f;transition:background .2s ease,border-color .2s ease,box-shadow .2s ease}.toolbar__month .toolbar__button:hover{background:#eef2ff;border-color:#94a3f7;box-shadow:0 8px 20px #0f172a2e}.toolbar__button{border:1px solid transparent;background:transparent;color:inherit;padding:.4rem .75rem;border-radius:.5rem;cursor:pointer}.toolbar__button:hover{background:#0f172a14}.toolbar__actions{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.toolbar__profile{display:flex;align-items:center;gap:.5rem;font-size:.9rem}.primary{background:#2563eb;color:#fff;border:none;border-radius:.75rem;padding:.6rem 1rem;font-weight:600;cursor:pointer}.primary:disabled{opacity:.6;cursor:not-allowed}.content{display:grid;grid-template-columns:minmax(0,2fr) minmax(280px,1fr);gap:1.5rem}.content__primary,.content__secondary{background:#fff;border-radius:1rem;padding:1rem;border:1px solid #e2e8f0;box-shadow:0 15px 35px #0f172a14}.calendar{display:flex;flex-direction:column;gap:.5rem}.calendar__row{display:grid;grid-template-columns:repeat(7,minmax(0,1fr))}.calendar__row--labels{font-size:.85rem;text-transform:uppercase;letter-spacing:.08em;opacity:.7}.calendar__weeks{display:flex;flex-direction:column;gap:.6rem}.calendar__week{position:relative;--reservation-row-count: 0;--reservation-extra-rows: 0}.calendar__week-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:.4rem}.calendar__week-overlay{position:absolute;inset:0;display:grid;grid-template-columns:repeat(7,minmax(0,1fr));grid-auto-rows:32px;gap:.4rem;padding:2.3rem .35rem .5rem;pointer-events:none;z-index:2}.calendar__cell{min-height:calc(110px + var(--reservation-extra-rows, 0) * 36px);background:#f8fafc;border:1px solid #e2e8f0;border-radius:.9rem;padding:.5rem;padding-bottom:calc(.5rem + var(--reservation-extra-rows, 0) * 36px);text-align:left;cursor:pointer;display:flex;flex-direction:column;gap:.3rem;position:relative}.calendar__cell--muted{color:#94a3b8;background:#f1f5f9}.calendar__cell--today{border-color:#2563eb;box-shadow:0 0 0 1px #2563eb4d}.calendar__date{font-weight:600;font-size:.95rem;color:inherit;position:relative;z-index:3}.reservation-bar{border:none;border-radius:.65rem;color:inherit;font-size:.78rem;display:flex;align-items:center;justify-content:center;text-align:center;padding:.35rem .5rem;cursor:pointer;min-width:0;box-shadow:0 4px 12px #0f172a2e;pointer-events:auto;height:32px}.reservation-bar__label{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;opacity:.95}.reservation-list{display:flex;flex-direction:column;gap:.5rem}.reservation-list__body{flex:1;max-height:60vh;overflow-y:auto;padding-right:.25rem}.reservation-list__section{margin-bottom:1.25rem}.reservation-list__section+.reservation-list__section{border-top:1px solid #e2e8f0;padding-top:1.25rem}.reservation-list__section h3{margin:0 0 .5rem;font-size:1rem;font-weight:600;color:#0f172a}.reservation-list__status,.reservation-list__empty{font-size:.85rem;color:#475569;padding:.75rem .25rem}.reservation-list__meta-details{display:inline-flex;align-items:center;gap:.4rem}.reservation-list__badge{display:inline-flex;align-items:center;justify-content:center;width:1.5rem;height:1.5rem;border-radius:999px;font-size:.8rem;font-weight:700}.reservation-list__badge--private{background:#bbf7d0;color:#047857}.reservation-list__badge--business{background:#bfdbfe;color:#1e3a8a}.reservation-list ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.5rem}.reservation-list li button{width:100%;border:1px solid #e2e8f0;background:#f8fafc;padding:.75rem;border-radius:.75rem;text-align:left;cursor:pointer;transition:box-shadow .2s ease}.reservation-list li button:hover{box-shadow:0 6px 20px #0f172a14}.reservation-list__row{display:flex;justify-content:space-between;font-size:.9rem}.reservation-list__row--meta{font-size:.8rem;opacity:.8}.reservation-list__row--people{font-size:.78rem;color:#475569;margin-top:.2rem;flex-wrap:wrap;gap:.35rem}.reservation-list__past{color:#0f172a}.modal{position:fixed;inset:0;background:#000000bf;display:flex;align-items:center;justify-content:center;padding:1.5rem;z-index:1000}.modal__content{background:#fff;border-radius:1rem;padding:1.5rem;width:min(480px,100%);border:1px solid #e2e8f0;display:flex;flex-direction:column;gap:1rem}.modal__header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem}.modal__close{border:none;background:transparent;color:inherit;font-size:1.5rem;line-height:1;cursor:pointer;padding:.2rem}.modal__close:hover{opacity:.8}.reservation-form{display:flex;flex-direction:column;gap:.85rem}.reservation-form label{display:flex;flex-direction:column;gap:.35rem;font-size:.9rem}.reservation-form input,.reservation-form select,.reservation-form textarea{border-radius:.6rem;border:1px solid #cbd5f5;background:#fff;color:inherit;padding:.5rem .75rem}.reservation-form__purpose{border:1px solid #e2e8f0;border-radius:.9rem;padding:.75rem 1rem}.reservation-form__purpose legend{font-weight:600;margin-bottom:.4rem;font-size:.9rem}.reservation-form__purpose-options{display:flex;gap:1rem;flex-wrap:wrap}.reservation-form__radio{display:inline-flex;align-items:center;gap:.35rem;font-size:.9rem}.form-error{color:#f87171}.form-meta{display:flex;flex-direction:column;gap:.2rem;font-size:.8rem;opacity:.8}.form-actions{display:flex;justify-content:space-between;align-items:center}.form-actions__primary{display:flex;gap:.5rem}.danger{background:transparent;border:1px solid rgba(220,38,38,.4);color:#dc2626;border-radius:.75rem;padding:.45rem .9rem;cursor:pointer}.error-banner{background:#fee2e2;border:1px solid #fecaca;color:#991b1b;padding:.75rem;border-radius:.8rem}.auth-gate{margin:4rem auto;padding:2rem;max-width:420px;text-align:center;background:#fff;border-radius:1rem;border:1px solid #e2e8f0;box-shadow:0 12px 30px #0f172a14;display:flex;flex-direction:column;gap:1rem}@media(max-width:960px){.content{grid-template-columns:1fr}}
