:root{color-scheme:light dark;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:#f4f6fb;color:#152033}*{box-sizing:border-box}body{margin:0;min-height:100vh}button,input,select,textarea{font:inherit}button{border:0;border-radius:12px;padding:.75rem 1rem;background:#213547;color:#fff;cursor:pointer}button:hover{filter:brightness(1.08)}button.ghost{background:transparent;color:inherit;border:1px solid #cfd7e6}button.danger{background:#b91c1c}input,select,textarea{width:100%;border:1px solid #cfd7e6;border-radius:12px;padding:.75rem;background:#fff;color:#152033}textarea{min-height:96px;resize:vertical}label{display:grid;gap:.35rem;font-weight:700}.login-card{width:min(92vw,460px);margin:8vh auto;background:#fff;padding:2rem;border-radius:24px;box-shadow:0 18px 50px #15203322}.login-card form,.appointment-form{display:grid;gap:1rem}.error{color:#b91c1c;font-weight:700}.muted{color:#657086}.app-shell{width:min(1500px,100%);margin:0 auto;padding:1rem}.topbar{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1rem;background:#fff;border-radius:22px;padding:1rem;box-shadow:0 8px 30px #15203312}.topbar h1{margin:0}.topbar p{margin:.25rem 0 0;color:#657086}.topbar nav{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.topbar select{width:auto;min-width:120px}.calendar{background:#fff;border-radius:22px;padding:1rem;box-shadow:0 8px 30px #15203312}.week-view{display:grid;grid-template-columns:repeat(7,minmax(150px,1fr));gap:.75rem;overflow-x:auto}.day-column{min-height:65vh;border:1px solid #e4e8f0;border-radius:18px;padding:.75rem;background:#fbfcff}.day-column h3{margin:0 0 .75rem}.calendar-title{display:flex;justify-content:space-between;align-items:baseline;gap:1rem;margin-bottom:1rem}.calendar-title h2{margin:0;font-size:clamp(1.35rem,2vw,2rem)}.calendar-title p{margin:0;color:#657086;font-weight:700}.month-calendar{display:block}.month-weekday{color:#657086;font-weight:800;padding:.25rem .5rem;text-align:center}.month-view{display:grid;grid-template-columns:repeat(7,minmax(120px,1fr));gap:.5rem;overflow-x:auto}.month-cell{min-height:130px;border:1px solid #e4e8f0;border-radius:16px;padding:.5rem;background:#fbfcff}.month-cell.outside{opacity:.45}.appointment-list{display:grid;gap:.75rem}.appointment-chip{display:grid;gap:.15rem;width:100%;margin-bottom:.5rem;text-align:left;color:#152033;background:#f4f7ff;border-left:6px solid #4f7cff;padding:.65rem;border-radius:12px}.appointment-chip span,.appointment-chip small{color:#657086}.appointment-chip.private{background:#fff7ed}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;padding:1rem;background:#0f172a99;z-index:10}.dialog-card{width:min(94vw,700px);max-height:92vh;overflow:auto;background:#fff;color:#152033;border-radius:24px;padding:1.25rem;box-shadow:0 18px 80px #0005}.dialog-card header,.dialog-card footer{display:flex;justify-content:space-between;align-items:center;gap:1rem}.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.checkbox-row{align-items:end}@media (max-width: 760px){.topbar{align-items:stretch;flex-direction:column}.topbar nav{display:grid;grid-template-columns:repeat(2,1fr)}.grid-2,.week-view,.month-view{grid-template-columns:1fr}.month-weekday{display:none}.day-column{min-height:auto}}@media (prefers-color-scheme: dark){:root{background:#0f172a;color:#e5e7eb}.login-card,.topbar,.calendar,.dialog-card{background:#111827;color:#e5e7eb}input,select,textarea{background:#0f172a;color:#e5e7eb;border-color:#334155}.day-column,.month-cell{background:#0f172a;border-color:#334155}.appointment-chip{background:#172033;color:#e5e7eb}}.hint{color:#64748b;font-size:.9rem;line-height:1.35}.import-result{background:#f8fafc;border:1px solid #e2e8f0;border-radius:.75rem;margin-top:.75rem;padding:.75rem}.special-day-chip{display:grid;gap:.15rem;margin-bottom:.5rem;text-align:left;color:#713f12;background:#fef3c7;border-left:6px solid #f59e0b;padding:.65rem;border-radius:12px}.special-day-chip span{color:#92400e;font-size:.8rem;font-weight:700}.special-day-chip strong{font-size:.95rem}.special-day-chip.vacation{color:#064e3b;background:#d1fae5;border-left-color:#10b981}.special-day-chip.vacation span{color:#047857}@media (prefers-color-scheme: dark){.special-day-chip{background:#422006;color:#fde68a}.special-day-chip span{color:#fbbf24}.special-day-chip.vacation{background:#052e2b;color:#a7f3d0}.special-day-chip.vacation span{color:#34d399}}
