:root{font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;color:#1f2937;background:#f3f4f6;line-height:1.4}*{box-sizing:border-box}body,html,#root{margin:0;min-height:100vh}a{color:inherit;text-decoration:none}input{border:1px solid #d1d5db;border-radius:8px;padding:.55rem .7rem;font:inherit}.btn{border:0;border-radius:8px;background:#2563eb;color:#fff;font:inherit;font-weight:600;padding:.55rem .9rem;cursor:pointer}.btn:disabled{opacity:.65;cursor:not-allowed}.btn-secondary{background:#e5e7eb;color:#111827}.btn-secondary:hover:not(:disabled){background:#d1d5db}.fullscreen{min-height:100vh;width:100%}.centered{display:flex;align-items:center;justify-content:center;flex-direction:column;text-align:center;gap:.8rem;padding:1.2rem}.login-screen{background:linear-gradient(140deg,#111827,#1f2937 45%,#f3f4f6)}.card{background:#fff;border-radius:12px;padding:1rem;box-shadow:0 8px 24px #0f172a0f}.login-card{width:min(450px,100%);display:flex;flex-direction:column;gap:.85rem;text-align:left;padding:1.35rem;border:1px solid #e5e7eb;box-shadow:0 20px 40px #0f172a33}.login-logo-wrap{background:#111827;border-radius:10px;padding:1rem;display:flex;justify-content:center;align-items:center;margin-bottom:.4rem}.login-logo{display:block;width:min(290px,100%);height:auto}.login-subtitle{margin:0;font-size:1.2rem;font-weight:700;color:#111827;text-align:center;margin-bottom:.1rem}.login-helper{margin:0;text-align:center;color:#4b5563;font-size:.95rem}.login-field{display:flex;flex-direction:column;gap:.35rem}.login-label{color:#374151;font-weight:600;font-size:.94rem}.login-input{min-height:44px;border-radius:10px;border-color:#cbd5e1;transition:border-color .2s ease,box-shadow .2s ease}.login-input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb26}.login-btn{min-height:44px;margin-top:.25rem;font-size:1rem}.error-text{margin:0;color:#b91c1c;font-weight:600}.app-shell{min-height:100vh;display:grid;grid-template-columns:250px 1fr}.sidebar{background:#111827;color:#f9fafb;padding:1.2rem;position:sticky;top:0;height:100vh}.sidebar-title{margin:0}.sidebar-brand{margin-bottom:.9rem;padding-bottom:.8rem;border-bottom:1px solid #1f2937}.sidebar-subtitle{margin:.2rem 0 0;color:#9ca3af;font-size:.85rem}.sidebar-nav{display:flex;flex-direction:column;gap:.45rem}.nav-link{border-radius:8px;padding:.65rem .78rem;color:#d1d5db;background:#172033;border:1px solid #263244;font-weight:600;transition:background-color .15s ease,color .15s ease}.nav-link.active,.nav-link:hover{background:#1f2937;border-color:#364153;color:#fff}.sidebar-backdrop{display:none}.content-shell{display:flex;flex-direction:column;min-width:0}.topbar{background:#fff;border-bottom:1px solid #e5e7eb;padding:.9rem 1.1rem;display:flex;justify-content:space-between;align-items:center;gap:.8rem}.topbar-user{font-size:.9rem;color:#4b5563}.topbar-left{display:flex;align-items:center;gap:.75rem}.topbar-menu-btn{display:none;border:1px solid #d1d5db;border-radius:8px;background:#fff;color:#111827;font:inherit;font-weight:700;padding:.3rem .55rem;cursor:pointer}.topbar-section{font-weight:600;color:#111827;border-right:1px solid #e5e7eb;padding-right:.75rem}.page-content{padding:1.1rem}.stack{display:flex;flex-direction:column;gap:1rem}.stack h1,.stack h2{margin:0}.inline-form{display:flex;flex-wrap:wrap;gap:.7rem;align-items:center}.table-wrap{overflow-x:auto}.table{width:100%;border-collapse:collapse;min-width:520px}.data-table-card{border:1px solid #e5e7eb}.data-table-head{display:flex;align-items:center;justify-content:space-between;gap:.7rem;margin-bottom:.55rem}.data-table-count{background:#f3f4f6;color:#374151;font-size:.8rem;font-weight:600;border-radius:999px;padding:.2rem .6rem}.data-table-empty{color:#6b7280;font-weight:600}.table th,.table td{border-bottom:1px solid #e5e7eb;padding:.7rem;text-align:left}.table thead{background:#f9fafb}.table th{font-size:.82rem;color:#374151;text-transform:uppercase;letter-spacing:.02em}.table td{color:#111827;font-size:.92rem}.table-row-clickable{cursor:pointer}.table-row-clickable:hover{background:#f9fafb}.modal-overlay{position:fixed;inset:0;z-index:1500;background:#11182773;display:flex;align-items:center;justify-content:center;padding:1rem}.modal-card{width:min(900px,100%);max-height:85vh;overflow:auto}.planning-modal-card{width:min(1200px,100%)}.modal-header{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.modal-close{border:0;border-radius:8px;background:#e5e7eb;color:#111827;font:inherit;font-weight:600;padding:.35rem .6rem;cursor:pointer}.spinner{width:34px;height:34px;border:4px solid #bfdbfe;border-top-color:#2563eb;border-radius:50%;animation:spin .85s linear infinite}.spinner-small{width:22px;height:22px;border-width:3px}.global-loader{position:fixed;top:.8rem;right:.8rem;z-index:1200;background:#fffffff2;border-radius:999px;padding:.35rem;box-shadow:0 8px 24px #0f172a1f}.toast-container{position:fixed;top:1rem;left:50%;transform:translate(-50%);z-index:1300;display:flex;flex-direction:column;gap:.5rem}.toast{padding:.7rem .95rem;border-radius:10px;color:#fff;font-weight:600;min-width:260px;text-align:center}.toast-error{background:#b91c1c}.planning-list-card h2{margin-top:0}.planning-page-header h1{margin:0}.planning-page-subtitle{margin:.2rem 0 0;color:#4b5563}.planning-search-form{margin-bottom:.65rem}.planning-search-form input{min-width:min(380px,100%)}.planning-search-meta{margin:0 0 .55rem;color:#6b7280;font-size:.84rem;font-weight:600}.planning-compact-list{display:flex;flex-direction:column;gap:.4rem;max-height:62vh;overflow:auto;padding-right:.25rem}.planning-list-item{border:1px solid #d1d5db;border-radius:8px;background:#f9fafb;color:#111827;font:inherit;text-align:left;padding:.48rem .6rem;cursor:pointer}.planning-list-item:hover{background:#e5e7eb}.planning-filters{display:flex;flex-wrap:wrap;gap:.45rem;align-items:center;margin-bottom:.6rem}.planning-filters-label{font-weight:600;color:#374151}.planning-filter-btn{border:1px solid #cbd5e1;border-radius:999px;background:#fff;color:#1f2937;font:inherit;font-size:.9rem;padding:.3rem .65rem;cursor:pointer}.planning-filter-btn-active{background:#1f2937;color:#fff;border-color:#1f2937}.planning-count{margin:.2rem 0 .7rem;color:#4b5563;font-size:.83rem;font-weight:600}.planning-actions{display:flex;justify-content:flex-end;margin:0 0 .7rem}.planning-calendar-wrap{border:1px solid #e5e7eb;border-radius:10px;overflow:hidden}.planning-calendar-toolbar{display:flex;flex-wrap:wrap;gap:.6rem;justify-content:space-between;align-items:center;background:#f9fafb;border-bottom:1px solid #e5e7eb;padding:.55rem}.planning-toolbar-right{display:flex;gap:.5rem}.planning-month-label{text-transform:capitalize}.planning-weekdays,.planning-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr))}.planning-weekday{background:#f3f4f6;border-bottom:1px solid #e5e7eb;border-right:1px solid #e5e7eb;font-weight:600;text-align:center;padding:.35rem}.planning-weekday:last-child{border-right:0}.planning-day{min-height:120px;border-right:1px solid #e5e7eb;border-bottom:1px solid #e5e7eb;padding:.35rem;background:#fff;display:flex;flex-direction:column;gap:.28rem}.planning-day:nth-child(7n){border-right:0}.planning-day-number{font-size:.82rem;font-weight:700;color:#374151}.planning-day-outside{background:#f9fafb}.planning-day-today{background:#eef2ff}.planning-day-events{display:flex;flex-direction:column;gap:.25rem}.planning-event{border:1px solid #dbeafe;border-radius:7px;background:#eff6ff;color:#1e3a8a;font:inherit;font-size:.75rem;text-align:left;padding:.22rem .3rem;display:flex;flex-direction:column;cursor:pointer}.planning-event:disabled{cursor:default;opacity:.65}.planning-event-id{font-size:.66rem}.planning-empty-state{color:#4b5563;text-align:center;font-weight:600}.planning-calendar-empty{border-top:1px solid #e5e7eb;padding:.65rem;color:#6b7280;text-align:center;font-size:.88rem}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:900px){.app-shell{grid-template-columns:1fr}.sidebar{position:fixed;left:0;top:0;bottom:0;width:min(300px,82vw);height:100vh;z-index:1600;transform:translate(-102%);transition:transform .2s ease;box-shadow:0 14px 40px #0f172a47}.sidebar-open{transform:translate(0)}.sidebar-backdrop-open{display:block;position:fixed;inset:0;z-index:1500;border:0;background:#0f172a73;padding:0;margin:0}.topbar{position:sticky;top:0;z-index:1200}.topbar-menu-btn{display:inline-flex;align-items:center;justify-content:center}.login-screen{padding:1rem;background:linear-gradient(170deg,#111827,#1f2937 42%,#f3f4f6)}.login-card{width:min(500px,100%)}}@media(max-width:640px){.topbar{padding:.72rem .85rem;align-items:flex-start}.topbar-left{flex-wrap:wrap;gap:.5rem}.topbar-section{border-right:0;padding-right:0;width:100%}.topbar-user{width:100%}.page-content,.card{padding:.85rem}.table{min-width:440px}.login-screen{align-items:stretch;justify-content:center;padding:.85rem}.login-card{width:100%;padding:1rem;border-radius:10px}.login-logo-wrap{padding:.8rem}.login-logo{width:min(250px,100%)}.login-subtitle{font-size:1.1rem}.planning-calendar-toolbar{flex-direction:column;align-items:stretch}.planning-toolbar-right{width:100%;justify-content:space-between}.planning-day{min-height:92px;padding:.28rem}.planning-actions{justify-content:stretch}.planning-actions .btn{width:100%}}
