@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";:root{--bg-primary:#f8fafc;--bg-secondary:#fff;--bg-tertiary:#f1f5f9;--text-primary:#0f172a;--text-secondary:#475569;--text-muted:#94a3b8;--brand-primary:#2563eb;--brand-primary-hover:#1d4ed8;--brand-secondary:#3b82f6;--accent-success:#10b981;--accent-warning:#f59e0b;--accent-danger:#ef4444;--border-light:#e2e8f0;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -1px #0000000f;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -2px #0000000d;--shadow-glow:0 0 15px #2563eb4d;--radius-sm:.375rem;--radius-md:.5rem;--radius-lg:1rem;--radius-full:9999px;--transition-fast:.15s cubic-bezier(.4, 0, .2, 1);--transition-normal:.3s cubic-bezier(.4, 0, .2, 1)}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;font-family:Inter,sans-serif;line-height:1.5}a{color:inherit;text-decoration:none}button{cursor:pointer;background:0 0;border:none;font-family:inherit}input,select,textarea{font-family:inherit;font-size:1rem}.app-container{flex-direction:column;min-height:100vh;display:flex}.main-content{flex:1;width:100%;max-width:1200px;margin:0 auto;padding:2rem 1rem}@media (width<=768px){.main-content{padding:1rem .5rem}}.navbar{background-color:var(--bg-secondary);border-bottom:1px solid var(--border-light);z-index:10;box-shadow:var(--shadow-sm);justify-content:space-between;align-items:center;padding:1rem 2rem;display:flex;position:sticky;top:0}.nav-brand{color:var(--brand-primary);letter-spacing:-.025em;align-items:center;gap:.5rem;font-size:1.5rem;font-weight:700;display:flex}h1{letter-spacing:-.025em;margin-bottom:1rem;font-size:2.25rem;font-weight:700}h2{margin-bottom:.75rem;font-size:1.5rem;font-weight:600}h3{font-size:1.25rem;font-weight:600}.text-muted{color:var(--text-muted)}.btn{border-radius:var(--radius-md);transition:all var(--transition-fast);justify-content:center;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-size:.875rem;font-weight:600;display:inline-flex}.btn-primary{background-color:var(--brand-primary);color:#fff;box-shadow:0 4px 6px -1px #2563eb4d}.btn-primary:hover{background-color:var(--brand-primary-hover);box-shadow:var(--shadow-glow);transform:translateY(-1px)}.btn-secondary{background-color:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-light)}.btn-secondary:hover{background-color:var(--bg-tertiary)}.btn-danger{background-color:var(--accent-danger);color:#fff}.form-group{margin-bottom:1.5rem}.form-label{color:var(--text-secondary);margin-bottom:.5rem;font-size:.875rem;font-weight:500;display:block}.form-control{border:1px solid var(--border-light);border-radius:var(--radius-md);background-color:var(--bg-secondary);width:100%;color:var(--text-primary);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);padding:.75rem 1rem}.form-control:focus{border-color:var(--brand-primary);outline:none;box-shadow:0 0 0 3px #2563eb1a}.radio-group{gap:1.5rem;display:flex}.radio-label{cursor:pointer;align-items:center;gap:.5rem;font-weight:500;display:flex}.card{background-color:var(--bg-secondary);border-radius:var(--radius-lg);border:1px solid var(--border-light);box-shadow:var(--shadow-sm);transition:box-shadow var(--transition-normal);padding:1.5rem}.card:hover{box-shadow:var(--shadow-md)}.login-container{background:linear-gradient(135deg, var(--bg-primary) 0%, var(--bg-tertiary) 100%);justify-content:center;align-items:center;min-height:100vh;display:flex}.login-card{background:var(--bg-secondary);border-radius:var(--radius-lg);width:100%;max-width:400px;box-shadow:var(--shadow-lg);text-align:center;padding:2.5rem}.login-logo{color:var(--brand-primary);margin-bottom:1rem}.list-header{justify-content:space-between;align-items:center;margin-bottom:2rem;display:flex}.filters-bar{gap:1rem;margin-bottom:1.5rem;display:flex}.doctor-list{gap:1rem;display:grid}.doctor-item{background:var(--bg-secondary);border-radius:var(--radius-md);border:1px solid var(--border-light);transition:transform var(--transition-fast), box-shadow var(--transition-fast);justify-content:space-between;align-items:center;padding:1.25rem;display:flex}.doctor-item:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.doctor-info{flex-direction:column;gap:.25rem;display:flex}.doctor-name{font-size:1.125rem;font-weight:600}.doctor-meta{color:var(--text-secondary);gap:1rem;font-size:.875rem;display:flex}.badge{border-radius:var(--radius-full);background:var(--bg-tertiary);color:var(--text-secondary);align-items:center;padding:.25rem .5rem;font-size:.75rem;font-weight:600;display:inline-flex}.badge-cat-a{color:#1e40af;background:#dbeafe}.badge-cat-b{color:#b45309;background:#fef3c7}.badge-cat-c{color:#b91c1c;background:#fee2e2}.item-actions{gap:.5rem;display:flex}.action-btn{border-radius:var(--radius-md);color:var(--text-secondary);transition:background var(--transition-fast), color var(--transition-fast);padding:.5rem}.action-btn:hover{background:var(--bg-tertiary);color:var(--brand-primary)}.action-btn.delete:hover{color:var(--accent-danger)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.animate-fade-in{animation:.4s ease-out forwards fadeIn}.map-placeholder{background:var(--bg-tertiary);border-radius:var(--radius-md);width:100%;height:200px;color:var(--text-muted);border:1px dashed var(--border-light);justify-content:center;align-items:center;margin-top:1rem;display:flex}.nav-links{align-items:center;gap:.25rem;display:flex}.nav-link{border-radius:var(--radius-md);color:var(--text-secondary);transition:background var(--transition-fast), color var(--transition-fast);align-items:center;gap:.4rem;padding:.5rem .875rem;font-size:.875rem;font-weight:500;display:inline-flex}.nav-link:hover{background:var(--bg-tertiary);color:var(--text-primary)}.nav-link.active{color:var(--brand-primary);background:#dbeafe;font-weight:600}.schedule-page{flex-direction:column;gap:1.5rem;display:flex}.schedule-toolbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;display:flex}.toolbar-left{align-items:center;gap:.75rem;display:flex}.toolbar-center{flex:1;justify-content:center;display:flex}.toolbar-right{align-items:center;gap:.75rem;display:flex}.quarter-selector{border-radius:var(--radius-md);background:var(--bg-secondary);border:1px solid var(--border-light);cursor:pointer;width:auto;padding:.5rem 1rem;font-size:1rem;font-weight:600}.view-toggle{background:var(--bg-tertiary);border-radius:var(--radius-md);gap:.25rem;padding:.25rem;display:flex}.view-toggle-btn{border-radius:calc(var(--radius-md) - 2px);color:var(--text-muted);transition:background var(--transition-fast), color var(--transition-fast);align-items:center;padding:.375rem .625rem;display:flex}.view-toggle-btn.active{background:var(--bg-secondary);color:var(--brand-primary);box-shadow:var(--shadow-sm)}.schedule-stats{flex-wrap:wrap;gap:.75rem;display:flex}.stat-chip{background:var(--bg-secondary);border:1px solid var(--border-light);border-radius:var(--radius-full);color:var(--text-secondary);box-shadow:var(--shadow-sm);align-items:center;gap:.4rem;padding:.375rem .875rem;font-size:.8rem;font-weight:500;display:inline-flex}.schedule-body{transition:grid-template-columns var(--transition-normal);grid-template-columns:1fr;gap:1.5rem;display:grid}.schedule-body.with-panel{grid-template-columns:1fr 320px}.schedule-main{min-width:0}.calendar-container{background:var(--bg-secondary);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden}.calendar-nav{border-bottom:1px solid var(--border-light);justify-content:space-between;align-items:center;padding:1rem 1.25rem;display:flex}.calendar-month-label{color:var(--text-primary);font-size:1.1rem;font-weight:700}.calendar-grid{grid-template-columns:repeat(7,1fr);display:grid}.calendar-day-header{text-align:center;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border-light);background:var(--bg-tertiary);padding:.5rem;font-size:.75rem;font-weight:600}.calendar-cell{border-right:1px solid var(--border-light);border-bottom:1px solid var(--border-light);cursor:pointer;min-height:96px;transition:background var(--transition-fast);flex-direction:column;gap:.25rem;padding:.375rem;display:flex;position:relative}.calendar-cell:nth-child(7n){border-right:none}.calendar-cell:hover{background:var(--bg-tertiary)}.calendar-cell.empty{background:var(--bg-tertiary);opacity:.4;cursor:default}.calendar-cell.weekend{background:#fafafa}.calendar-cell.today .cell-date{background:var(--brand-primary);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;font-weight:700;display:flex}.calendar-cell.selected{outline:2px solid var(--brand-primary);outline-offset:-2px;background:#eff6ff}.cell-date{color:var(--text-secondary);justify-content:center;align-items:center;width:24px;height:24px;font-size:.75rem;font-weight:600;display:flex}.cell-chips{flex-direction:column;flex:1;gap:2px;display:flex;overflow:hidden}.chip-overflow{color:var(--text-muted);padding:1px 4px;font-size:.65rem;font-weight:600}.visit-chip{text-align:left;cursor:pointer;width:100%;transition:opacity var(--transition-fast);border:none;border-radius:3px;align-items:center;gap:3px;padding:2px 5px;font-size:.65rem;font-weight:600;display:flex;overflow:hidden}.visit-chip:hover{opacity:.8}.visit-chip-name{text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.day-panel{background:var(--bg-secondary);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);flex-direction:column;max-height:calc(100vh - 100px);display:flex;position:sticky;top:80px;overflow:hidden}.day-panel-header{border-bottom:1px solid var(--border-light);background:var(--bg-tertiary);justify-content:space-between;align-items:flex-start;padding:1.25rem;display:flex}.day-panel-date{color:var(--text-primary);font-size:.95rem;font-weight:700}.day-panel-count{color:var(--text-muted);margin-top:2px;font-size:.8rem}.day-panel-empty{text-align:center;color:var(--text-muted);padding:2rem;font-size:.875rem}.day-panel-list{flex-direction:column;flex:1;gap:.5rem;padding:.75rem;display:flex;overflow-y:auto}.day-visit-card{background:var(--bg-tertiary);border-radius:var(--radius-md);border:1px solid var(--border-light);align-items:flex-start;gap:.75rem;padding:.75rem;display:flex}.day-visit-order{background:var(--brand-primary);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;margin-top:2px;font-size:.7rem;font-weight:700;display:flex}.day-visit-body{flex-direction:column;flex:1;gap:.3rem;min-width:0;display:flex}.day-visit-name{color:var(--text-primary);font-size:.875rem;font-weight:600}.day-visit-meta{flex-wrap:wrap;align-items:center;gap:.4rem;display:flex}.day-visit-address{color:var(--text-muted);text-overflow:ellipsis;white-space:nowrap;font-size:.75rem;overflow:hidden}.region-dot{color:#fff;border-radius:var(--radius-full);align-items:center;gap:3px;padding:2px 6px;font-size:.72rem;font-weight:600;display:inline-flex}.appt-time{color:#92400e;border-radius:var(--radius-full);background:#fef3c7;align-items:center;gap:3px;padding:2px 6px;font-size:.72rem;font-weight:600;display:inline-flex}.list-view{flex-direction:column;gap:1rem;display:flex}.empty-schedule{background:var(--bg-secondary);border:1px solid var(--border-light);border-radius:var(--radius-lg);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:1rem;padding:5rem 2rem;display:flex}.list-day-group{background:var(--bg-secondary);border:1px solid var(--border-light);border-radius:var(--radius-md);overflow:hidden}.list-day-group.today-group{border-color:var(--brand-primary);box-shadow:0 0 0 2px #2563eb26}.list-day-header{background:var(--bg-tertiary);cursor:pointer;border-bottom:1px solid var(--border-light);justify-content:space-between;align-items:center;padding:.875rem 1.25rem;display:flex}.list-day-date{font-size:.9rem;font-weight:600}.list-day-count{color:var(--brand-primary);border-radius:var(--radius-full);background:#dbeafe;padding:2px 8px;font-size:.8rem;font-weight:600}.list-day-chips{flex-direction:column;display:flex}.list-visit-row{border-bottom:1px solid var(--border-light);cursor:pointer;transition:background var(--transition-fast);align-items:center;gap:.75rem;padding:.625rem 1.25rem;font-size:.875rem;display:flex}.list-visit-row:last-child{border-bottom:none}.list-visit-row:hover{background:var(--bg-tertiary)}.list-order{background:var(--brand-primary);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;font-size:.65rem;font-weight:700;display:flex}.list-name{text-overflow:ellipsis;white-space:nowrap;flex:1;font-weight:500;overflow:hidden}.modal-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#0f172a80;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.modal-card{background:var(--bg-secondary);border-radius:var(--radius-lg);width:100%;max-width:440px;box-shadow:var(--shadow-lg);text-align:center;flex-direction:column;align-items:center;gap:.75rem;padding:2.5rem;display:flex}.modal-icon{background:#dbeafe;border-radius:50%;justify-content:center;align-items:center;width:64px;height:64px;margin-bottom:.5rem;display:flex}.modal-warning{border-radius:var(--radius-md);color:#92400e;text-align:left;background:#fff8e6;border:1px solid #fbbf24;align-items:center;gap:.5rem;width:100%;padding:.75rem 1rem;font-size:.875rem;display:flex}.modal-actions{justify-content:center;gap:1rem;width:100%;margin-top:.75rem;display:flex}.toast{border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:2000;align-items:center;gap:.6rem;max-width:420px;padding:1rem 1.5rem;font-size:.875rem;font-weight:500;animation:.3s ease-out slideUp;display:flex;position:fixed;bottom:2rem;right:2rem}.toast-success{color:#065f46;background:#ecfdf5;border:1px solid #6ee7b7}.toast-error{color:#991b1b;background:#fef2f2;border:1px solid #fca5a5}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.animate-slide-in{animation:.3s ease-out forwards slideIn}.spin{animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.schedule-loading{color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;gap:1rem;padding:5rem 2rem;display:flex}.spinner{border:3px solid var(--border-light);border-top-color:var(--brand-primary);border-radius:50%;width:36px;height:36px;animation:.8s linear infinite spin}@media (width<=900px){.schedule-body.with-panel{grid-template-columns:1fr}.day-panel{border-radius:var(--radius-lg) var(--radius-lg) 0 0;z-index:100;max-height:60vh;position:fixed;bottom:0;left:0;right:0}.schedule-toolbar{flex-direction:column;align-items:stretch}.toolbar-center,.toolbar-right{justify-content:center}}@media (width<=600px){.calendar-cell{min-height:60px;padding:.25rem}.visit-chip{font-size:.6rem}.calendar-day-header{padding:.25rem;font-size:.65rem}}.rep-shell{background-color:var(--bg-primary);flex-direction:column;min-height:100vh;font-family:Inter,sans-serif;display:flex;position:relative;overflow:hidden}.rep-main{-webkit-overflow-scrolling:touch;flex-direction:column;flex:1;padding-bottom:74px;display:flex;overflow-y:auto}.bottom-nav{background-color:var(--bg-secondary);border-top:1px solid var(--border-light);z-index:1000;height:64px;padding-bottom:env(safe-area-inset-bottom,0);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);justify-content:space-around;align-items:center;display:flex;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -4px 10px #0000000a}.bottom-nav-item{color:var(--text-muted);width:20%;height:100%;transition:all var(--transition-fast);cursor:pointer;border-top:3px solid #0000;flex-direction:column;justify-content:center;align-items:center;gap:3px;font-size:.72rem;font-weight:500;text-decoration:none;display:flex}.bottom-nav-item:hover{color:var(--text-secondary)}.bottom-nav-item.active{color:var(--brand-primary);border-top:3px solid var(--brand-primary);font-weight:600}.rep-page{flex-direction:column;flex:1;min-height:0;padding:1.5rem 1rem;display:flex}.rep-page-content{flex-direction:column;flex:1;min-height:0;display:flex}.rep-header{border-bottom:1px solid var(--border-light);justify-content:space-between;align-items:center;margin-bottom:1.25rem;padding-bottom:.75rem;display:flex}.rep-header-left{flex-direction:column;display:flex}.rep-header-label{color:var(--brand-primary);letter-spacing:.075em;text-transform:uppercase;font-size:.7rem;font-weight:700}.rep-header-date{color:var(--text-primary);margin-top:2px;font-size:1.2rem;font-weight:700}.rep-header-icon-btn{border-radius:var(--radius-md);background-color:var(--bg-secondary);border:1px solid var(--border-light);width:38px;height:38px;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);justify-content:center;align-items:center;display:flex}.rep-header-icon-btn:hover{background-color:var(--bg-tertiary);color:var(--brand-primary);transform:scale(1.05)}.visit-card-list{flex-direction:column;gap:1rem;display:flex}.visit-card{background-color:var(--bg-secondary);border-radius:var(--radius-lg);border:1px solid var(--border-light);box-shadow:var(--shadow-sm);transition:all var(--transition-normal);position:relative;overflow:hidden}.visit-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.visit-card.completed{background-color:#f6fdfa;border-color:#a7f3d0}.visit-card-done-overlay{z-index:2;color:#065f46;-webkit-backdrop-filter:blur(1px);backdrop-filter:blur(1px);background-color:#f6fdfaeb;justify-content:center;align-items:center;gap:.5rem;font-size:1.1rem;font-weight:700;display:flex;position:absolute;inset:0}.visit-card-inner{align-items:flex-start;gap:1rem;padding:1.25rem;display:flex}.visit-order-badge{background-color:var(--brand-primary);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:26px;height:26px;margin-top:2px;font-size:.8rem;font-weight:700;display:flex}.visit-card-body{flex-direction:column;flex:1;gap:.5rem;min-width:0;display:flex}.visit-card-name{color:var(--text-primary);align-items:center;gap:.4rem;font-size:1.05rem;font-weight:600;display:flex}.visit-card-meta{color:var(--text-secondary);flex-wrap:wrap;align-items:center;gap:.5rem;font-size:.78rem;display:flex}.visit-card-address{color:var(--text-secondary);gap:.4rem;font-size:.85rem;line-height:1.4;display:flex}.visit-card-actions{gap:.75rem;margin-top:.5rem;display:flex}.visit-action-btn{border-radius:var(--radius-md);transition:all var(--transition-fast);flex:1;justify-content:center;align-items:center;gap:.4rem;padding:.55rem .875rem;font-size:.8rem;font-weight:600;display:inline-flex}.navigate-btn{background-color:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-light)}.navigate-btn:hover{background-color:var(--border-light)}.complete-btn{background-color:var(--brand-primary);color:#fff}.complete-btn:hover{background-color:var(--brand-primary-hover)}.day-summary-bar{background-color:var(--bg-secondary);border-top:1px solid var(--border-light);border-bottom:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);justify-content:space-between;align-items:center;margin-top:1.5rem;padding:1rem 1.25rem;display:flex}.summary-stat{color:var(--text-secondary);align-items:center;gap:.5rem;font-size:.85rem;font-weight:500;display:flex}.profile-avatar-block{border-bottom:1px solid var(--border-light);flex-direction:column;align-items:center;gap:.5rem;margin-bottom:1.5rem;padding:2.25rem 0;display:flex}.profile-avatar{background-color:var(--brand-primary);border-radius:50%;justify-content:center;align-items:center;width:76px;height:76px;display:flex;box-shadow:0 4px 12px #2563eb33}.profile-name{color:var(--text-primary);font-size:1.2rem;font-weight:700}.profile-email{color:var(--text-muted);font-size:.85rem}.profile-info-cards{flex-direction:column;gap:1rem;display:flex}.profile-info-card{background-color:var(--bg-secondary);border:1px solid var(--border-light);border-radius:var(--radius-md);transition:all var(--transition-fast);align-items:center;gap:1rem;padding:1rem;display:flex}.profile-info-card:hover{box-shadow:var(--shadow-sm);transform:translate(2px)}.profile-info-icon{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;display:flex}.profile-info-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.025em;font-size:.7rem;font-weight:600}.profile-info-value{color:var(--text-primary);font-size:.9rem;font-weight:600}.map-legend{border-radius:var(--radius-md);border:1px solid var(--border-light);box-shadow:var(--shadow-md);z-index:100;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background-color:#fffffff2;gap:1rem;padding:.5rem .75rem;font-size:.75rem;font-weight:600;display:flex;position:absolute;bottom:80px;left:1rem}.legend-item{align-items:center;gap:.4rem;display:flex}.legend-dot{border-radius:50%;width:10px;height:10px}
