*{box-sizing:border-box}body{margin:0;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:#f5f7fb;color:#1f2933}.app-root{display:flex;min-height:100vh}.sidebar{width:220px;background:#fff;border-right:1px solid #e1e5ee;padding:.75rem .75rem 1rem;margin-top:20px;margin-bottom:20px;margin-left:24px;display:flex;flex-direction:column;gap:.75rem;transition:.2s ease-out;border-radius:12px}.sidebar-collapsed{width:100px}.sidebar-top{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.sidebar-title{font-size:.95rem;font-weight:600;color:#243b53}.sidebar-nav{display:flex;flex-direction:column;gap:.5rem;margin-top:.5rem}.nav-btn{border-radius:999px;border:1px solid transparent;padding:12px;text-align:left;background:transparent;cursor:pointer;font-size:.85rem;color:#52606d;transition:background .15s ease-out,border-color .15s ease-out,color .15s ease-out}.nav-btn:hover{background:#eef2ff;color:#364152}.nav-btn-active{background:#e0ebff;border-color:#b3c5ff;color:#1f3b8e;font-weight:600}.main-area{flex:1;padding:1.25rem 1.5rem;display:flex}.view-container{display:grid;grid-template-columns:minmax(0,.9fr) minmax(0,1.1fr);gap:1rem;width:100%}.panel{background:#fff;border-radius:12px;border:1px solid #e1e5ee;padding:.9rem 1rem;display:flex;flex-direction:column}.panel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.7rem}.panel-header h2{margin:0;font-size:1rem;color:#243b53}button{font-family:inherit}.btn-primary{border-radius:999px;border:none;padding:.4rem .85rem;background:#2563eb;color:#fff;font-size:.85rem;cursor:pointer;transition:background .15s ease-out,box-shadow .15s ease-out,transform .1s ease-out}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-primary:hover{background:#1d4ed8;box-shadow:0 6px 15px #2563eb40;transform:translateY(-1px)}.btn-secondary{border-radius:999px;border:1px solid #cbd2e1;padding:.35rem .75rem;background:#fff;color:#364152;font-size:.8rem;cursor:pointer;transition:background .15s ease-out,border-color .15s ease-out}.btn-secondary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary:hover{background:#f3f4ff;border-color:#9fb3ff}.btn-ghost{border-radius:999px;border:none;background:transparent;font-size:.8rem;color:#7b8794;cursor:pointer;padding:.2rem .45rem}.btn-ghost.small{font-size:28px;color:red}.list-scroll{flex:1;overflow-y:auto}.contact-list{list-style:none;padding:0;margin:0}.contact-list-item{padding:.5rem .55rem;border-radius:8px;border:1px solid transparent;display:flex;flex-direction:column;gap:.15rem;cursor:pointer;margin-bottom:.35rem;transition:background .12s ease-out,border-color .12s ease-out}.contact-list-item:hover{background:#f1f5fb}.contact-list-item.active{background:#e0ebff;border-color:#b3c5ff}.contact-main{display:flex;flex-direction:column}.contact-name{font-size:.9rem;font-weight:500;color:#243b53}.contact-email{font-size:.8rem;color:#7b8794}.contact-meta{font-size:.7rem;color:#9fb3c8}.detail-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:.6rem 1rem;margin-top:.4rem}.detail-label{font-size:.7rem;color:#7b8794;text-transform:uppercase;letter-spacing:.04em}.detail-value{font-size:.9rem;color:#243b53;text-overflow:ellipsis;overflow:hidden;white-space:nowrap}.note-value{white-space:wrap}.detail-full{grid-column:1 / -1}.muted{font-size:.85rem;color:#9fb3c8}.modal-backdrop{position:fixed;inset:0;background:#0f172a40;display:flex;align-items:center;justify-content:center;z-index:20}.modal{background:#fff;border-radius:12px;border:1px solid #e1e5ee;width:380px;max-width:90vw;box-shadow:0 18px 40px #0f172a40;padding:.85rem 1rem 1rem}.modal-header{display:flex;align-items:center;justify-content:space-between}.modal-header h3{margin:0;font-size:.95rem;color:#243b53}.modal-body{margin-top:.7rem}.form-vertical{display:flex;flex-direction:column;gap:20px}.form-vertical label{display:flex;flex-direction:column;gap:.25rem;font-size:.8rem;color:#52606d;text-align:left;position:relative}.form-vertical input,.form-vertical textarea,.form-vertical select{border-radius:8px;border:1px solid #cbd2e1;padding:.4rem .5rem;font-size:.85rem;font-family:inherit}.form-vertical textarea{resize:vertical;min-height:80px;max-height:200px}.modal-actions{margin-top:.8rem;display:flex;justify-content:flex-end;gap:.5rem}.inline-contact-row{display:flex;gap:.5rem}.inline-contact-row select{flex:1}.calendar-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.4rem}.calendar-month{font-size:.9rem;font-weight:500;color:#243b53}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:.25rem}.calendar-weekday{font-size:.7rem;text-align:center;color:#9fb3c8}.calendar-day{height:32px;border-radius:6px;border:1px solid transparent;background:#f9fbff;font-size:.8rem;cursor:pointer;color:#52606d;display:flex;align-items:center;justify-content:center;padding:0}.calendar-day:hover{background:#e5edff}.calendar-day-faded{background:#f0f4fa;color:#9fb3c8}.calendar-day-today{border-color:#2563eb}.calendar-day-has{background:#dde7ff}.calendar-day-selected{background:#2563eb;color:#fff}.calendar-day-past{opacity:.4;color:#9fb3ff}.hover-card{margin-top:.6rem;padding:.5rem .6rem;border-radius:8px;background:#f9fbff;border:1px solid #e1e5ee;font-size:.8rem}.hover-card-title{font-weight:500;margin-bottom:.2rem}.appointment-list{list-style:none;padding:0;margin:.4rem 0 0}.appointment-item{padding:.5rem .55rem;border-radius:8px;border:1px solid #e1e5ee;margin-bottom:.4rem;font-size:.82rem;cursor:pointer}.appointment-time{font-weight:500;color:#243b53}.appointment-contact{color:#364152}.appointment-type{color:#7b8794;font-size:.75rem}.appointment-note{margin-top:.2rem;color:#52606d}.radio-row{display:flex;gap:1.5rem;margin-top:.25rem}.radio-option{display:flex;align-items:center;gap:.4rem;font-size:.9rem;cursor:pointer}.radio-option input[type=radio]{cursor:pointer}.field-error{position:absolute;top:100%;font-size:.8rem;color:#c0392b}.form-field{text-align:left}.form-field span{font-size:.8rem;color:#52606d;text-align:left}@media(max-width:900px){.view-container{grid-template-columns:minmax(0,1fr)}.app-root{flex-direction:column}.sidebar{width:100%;margin:0;max-width:100vw;border-radius:0}.sidebar-nav{flex-direction:row}.btn-ghost{display:none}.main-area{padding:.75rem}}@media(max-width:700px){.detail-grid{grid-template-columns:1fr}}@media(max-width:450px){.panel-header{flex-direction:column;align-items:flex-start;gap:.5rem}}
