*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--primary: #2563eb;--primary-dark: #1d4ed8;--primary-light: #3b82f6;--success: #16a34a;--danger: #dc2626;--warning: #f59e0b;--gray-50: #f9fafb;--gray-100: #f3f4f6;--gray-200: #e5e7eb;--gray-300: #d1d5db;--gray-400: #9ca3af;--gray-500: #6b7280;--gray-600: #4b5563;--gray-700: #374151;--gray-800: #1f2937;--gray-900: #111827;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--radius: 8px;--radius-lg: 12px}html{font-size:16px;-webkit-text-size-adjust:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;background:var(--gray-100);color:var(--gray-900);line-height:1.5;min-height:100vh;-webkit-font-smoothing:antialiased}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:1rem}.spinner{width:40px;height:40px;border:3px solid var(--gray-200);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}.spinner.small{width:20px;height:20px;border-width:2px}.spinner.white{border-color:#ffffff4d;border-top-color:#fff}@keyframes spin{to{transform:rotate(360deg)}}.app-layout{display:flex;flex-direction:column;min-height:100vh;max-width:100vw;overflow-x:hidden}.app-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background:#fff;border-bottom:1px solid var(--gray-200);position:sticky;top:0;z-index:100}.app-title{font-size:1.125rem;font-weight:600;color:var(--gray-900)}.app-logo{height:36px;width:auto;object-fit:contain}.user-info{display:flex;align-items:center;gap:.75rem}.user-name{font-size:.875rem;color:var(--gray-600);max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.btn-logout{padding:.375rem .75rem;font-size:.875rem;color:var(--gray-600);background:var(--gray-100);border:1px solid var(--gray-200);border-radius:var(--radius);cursor:pointer;transition:all .15s ease}.btn-logout:active{background:var(--gray-200)}.app-main{flex:1;padding-bottom:70px}.bottom-nav{display:flex;position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:1px solid var(--gray-200);padding:.5rem 0;padding-bottom:max(.5rem,env(safe-area-inset-bottom));z-index:100}.nav-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:.5rem;color:var(--gray-500);text-decoration:none;font-size:.75rem;transition:color .15s ease}.nav-item.active{color:var(--primary)}.nav-icon{width:24px;height:24px}.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:2rem 1rem;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%)}.login-container{width:100%;max-width:360px;padding:2rem;background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);text-align:center}.login-logo{margin-bottom:1rem}.logo-icon{width:64px;height:64px;color:var(--primary)}.login-logo-img{max-width:200px;height:auto}.login-title{font-size:1.5rem;font-weight:700;color:var(--gray-900);margin-bottom:.5rem}.login-subtitle{color:var(--gray-500);margin-bottom:1.5rem}.btn-login{display:inline-flex;align-items:center;justify-content:center;gap:.75rem;width:100%;padding:.875rem 1.5rem;font-size:1rem;font-weight:600;color:#fff;background:var(--primary);border:none;border-radius:var(--radius);cursor:pointer;transition:background .15s ease}.btn-login:active{background:var(--primary-dark)}.zoho-icon{width:20px;height:20px}.login-info{margin-top:1rem;font-size:.875rem;color:var(--gray-500)}.error-message{padding:.75rem;margin-bottom:1rem;background:#fef2f2;color:var(--danger);border-radius:var(--radius);font-size:.875rem}.dashboard-page{padding:1rem}.search-bar{position:relative;margin-bottom:1rem}.search-icon{position:absolute;left:.75rem;top:50%;transform:translateY(-50%);width:20px;height:20px;color:var(--gray-400);pointer-events:none}.search-input{width:100%;padding:.75rem 2.5rem;font-size:1rem;background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius);outline:none;transition:border-color .15s ease,box-shadow .15s ease}.search-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a}.search-clear{position:absolute;right:.5rem;top:50%;transform:translateY(-50%);width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:none;border:none;color:var(--gray-400);cursor:pointer}.search-clear svg{width:18px;height:18px}.selection-toolbar{display:flex;align-items:center;justify-content:space-between;padding:.5rem 0;margin-bottom:.5rem}.selection-count{font-size:.875rem;font-weight:500;color:var(--gray-600)}.selection-actions{display:flex;gap:1rem}.btn-text{padding:.25rem .5rem;font-size:.875rem;font-weight:500;color:var(--primary);background:none;border:none;cursor:pointer}.company-list{display:flex;flex-direction:column;gap:.75rem}.company-card{display:flex;gap:.75rem;padding:1rem;background:#fff;border-radius:var(--radius);border:2px solid transparent;box-shadow:var(--shadow-sm);cursor:pointer;transition:border-color .15s ease,box-shadow .15s ease}.company-card.selected{border-color:var(--primary);box-shadow:var(--shadow-md)}.company-checkbox{flex-shrink:0}.checkbox{width:24px;height:24px;display:flex;align-items:center;justify-content:center;border:2px solid var(--gray-300);border-radius:6px;transition:all .15s ease}.checkbox.checked{background:var(--primary);border-color:var(--primary)}.checkbox svg{width:14px;height:14px;color:#fff}.company-info{flex:1;min-width:0}.company-name{font-size:1rem;font-weight:600;color:var(--gray-900);margin-bottom:.25rem}.company-address{font-size:.875rem;color:var(--gray-500);margin-bottom:.25rem}.company-phone{display:flex;align-items:center;gap:.375rem;font-size:.875rem;color:var(--gray-600)}.icon-small{width:14px;height:14px}.company-notes{font-size:.75rem;color:var(--gray-400);margin-top:.5rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.loading-indicator{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:2rem;color:var(--gray-500)}.empty-state{text-align:center;padding:3rem 1rem;color:var(--gray-500)}.empty-state .hint{font-size:.875rem;color:var(--gray-400);margin-top:.5rem}.error-banner{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;margin-bottom:1rem;background:#fef2f2;color:var(--danger);border-radius:var(--radius);font-size:.875rem}.btn-load-more{width:100%;padding:.75rem;font-size:.875rem;font-weight:500;color:var(--primary);background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius);cursor:pointer}.floating-action{position:fixed;bottom:80px;left:1rem;right:1rem;z-index:50}.btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;font-size:1rem;font-weight:600;color:#fff;background:var(--primary);border:none;border-radius:var(--radius);cursor:pointer;transition:background .15s ease}.btn-primary:active{background:var(--primary-dark)}.btn-large{width:100%;padding:1rem;font-size:1.125rem;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg)}.btn-icon{width:20px;height:20px}.map-page{position:relative;height:calc(100vh - 120px)}.map-container{width:100%;height:100%}.map-loading,.map-error{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;gap:1rem;padding:2rem;background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);text-align:center}.optimize-button-container{position:absolute;bottom:1rem;left:1rem;right:1rem}.btn-optimize{display:flex;align-items:center;justify-content:center;gap:.75rem;width:100%;padding:1rem;font-size:1.125rem;font-weight:600;color:#fff;background:var(--success);border:none;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);cursor:pointer;transition:background .15s ease}.btn-optimize:active{background:#15803d}.btn-optimize:disabled{background:var(--gray-400);cursor:not-allowed}.route-panel{position:absolute;bottom:0;left:0;right:0;max-height:60vh;background:#fff;border-radius:var(--radius-lg) var(--radius-lg) 0 0;box-shadow:0 -4px 20px #00000026;display:flex;flex-direction:column;animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.route-panel-header{display:flex;align-items:flex-start;justify-content:space-between;padding:1rem;border-bottom:1px solid var(--gray-200)}.route-summary h2{font-size:1.125rem;font-weight:600;margin-bottom:.5rem}.route-stats{display:flex;gap:1rem}.stat{display:flex;align-items:center;gap:.375rem;font-size:.875rem;color:var(--gray-600)}.stat-icon{width:16px;height:16px}.btn-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--gray-100);border:none;border-radius:var(--radius);cursor:pointer}.btn-close svg{width:18px;height:18px;color:var(--gray-500)}.route-stops{flex:1;overflow-y:auto;padding:.5rem 1rem}.stop-item{display:flex;align-items:flex-start;gap:.75rem;padding:.75rem 0;position:relative}.stop-connector{position:absolute;left:15px;top:-.75rem;width:2px;height:.75rem;background:var(--gray-300)}.stop-item:first-child .stop-connector{display:none}.stop-marker{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--success);color:#fff;border-radius:50%;font-size:.875rem;font-weight:600;flex-shrink:0}.start-marker{background:var(--primary)}.start-marker svg{width:16px;height:16px}.stop-info{flex:1;min-width:0}.stop-name{display:block;font-weight:500;color:var(--gray-900)}.stop-label{font-size:.75rem;color:var(--gray-500)}.stop-address{display:block;font-size:.875rem;color:var(--gray-500);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.stop-distance{display:block;font-size:.75rem;color:var(--primary);margin-top:.25rem}.route-panel-footer{padding:1rem;border-top:1px solid var(--gray-200);padding-bottom:max(1rem,env(safe-area-inset-bottom))}.btn-navigate{display:flex;align-items:center;justify-content:center;gap:.75rem;width:100%;padding:1rem;font-size:1rem;font-weight:600;color:#fff;background:var(--primary);border:none;border-radius:var(--radius);cursor:pointer;transition:background .15s ease}.btn-navigate:active{background:var(--primary-dark)}.api-key-modal{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;padding:1rem;background:#00000080;z-index:200}.modal-content{width:100%;max-width:400px;padding:1.5rem;background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg)}.modal-content h2{font-size:1.25rem;margin-bottom:.5rem}.modal-content p{color:var(--gray-600);margin-bottom:1rem}.input-api-key{width:100%;padding:.75rem;font-size:1rem;border:1px solid var(--gray-300);border-radius:var(--radius);margin-bottom:1rem;outline:none}.input-api-key:focus{border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a}.modal-content .btn-primary{width:100%}.modal-content .hint{font-size:.75rem;color:var(--gray-400);margin-top:1rem;text-align:center}.hint{font-size:.875rem;color:var(--gray-400)}.map-search-container{position:absolute;top:1rem;left:1rem;right:1rem;z-index:10}.places-search{width:100%}.btn-add-place{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;font-size:.875rem;font-weight:500;color:var(--gray-700);background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius);box-shadow:var(--shadow-md);cursor:pointer;transition:all .15s ease}.btn-add-place:hover{background:var(--gray-50)}.btn-add-place .btn-icon{width:18px;height:18px}.places-search-container{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-lg);overflow:hidden}.places-search-header{display:flex;align-items:center;gap:.5rem;padding:.5rem;border-bottom:1px solid var(--gray-200)}.places-search-input{flex:1;padding:.5rem;font-size:1rem;border:none;outline:none}.btn-close-search{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--gray-100);border:none;border-radius:var(--radius);cursor:pointer}.btn-close-search svg{width:16px;height:16px;color:var(--gray-500)}.btn-search{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--primary);border:none;border-radius:var(--radius);cursor:pointer;transition:background .15s ease}.btn-search:hover{background:var(--primary-dark)}.btn-search svg{width:16px;height:16px;color:#fff}.search-hint{padding:.5rem 1rem;font-size:.75rem;color:var(--gray-500);background:var(--gray-50);border-bottom:1px solid var(--gray-200)}.search-results-header{padding:.5rem 1rem;font-size:.875rem;font-weight:500;color:var(--success);background:#f0fdf4;border-bottom:1px solid var(--gray-200)}.add-badge{font-size:.75rem;color:var(--primary);background:#eff6ff;padding:.25rem .5rem;border-radius:4px;font-weight:500}.places-loading{display:flex;align-items:center;gap:.5rem;padding:1rem;color:var(--gray-500);font-size:.875rem}.places-predictions{list-style:none;max-height:300px;overflow-y:auto}.prediction-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;cursor:pointer;transition:background .15s ease}.prediction-item:hover{background:var(--gray-50)}.prediction-item.already-added{opacity:.5}.place-icon{width:20px;height:20px;color:var(--gray-400);flex-shrink:0}.prediction-text{flex:1;min-width:0}.prediction-main{display:block;font-weight:500;color:var(--gray-900)}.prediction-secondary{display:block;font-size:.75rem;color:var(--gray-500);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.already-added-badge{font-size:.75rem;color:var(--gray-400);background:var(--gray-100);padding:.25rem .5rem;border-radius:4px}.no-results{padding:1rem;text-align:center;color:var(--gray-500);font-size:.875rem}.searched-places-list{position:absolute;top:4rem;left:1rem;right:1rem;max-height:200px;overflow-y:auto;background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-md);z-index:10}.searched-places-header{padding:.5rem 1rem;font-size:.75rem;font-weight:600;color:var(--gray-500);text-transform:uppercase;background:var(--gray-50);border-bottom:1px solid var(--gray-200)}.searched-place-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;border-bottom:1px solid var(--gray-100)}.searched-place-item:last-child{border-bottom:none}.searched-place-info{flex:1;min-width:0}.searched-place-name{display:block;font-weight:500;color:var(--gray-900);font-size:.875rem}.searched-place-address{display:block;font-size:.75rem;color:var(--gray-500);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.btn-remove-place{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:var(--gray-100);border:none;border-radius:var(--radius);cursor:pointer;transition:background .15s ease}.btn-remove-place:hover{background:#fee2e2}.btn-remove-place svg{width:14px;height:14px;color:var(--gray-500)}.btn-remove-place:hover svg{color:var(--danger)}.btn-load-more-places{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:.75rem;font-size:.875rem;font-weight:500;color:var(--primary);background:var(--gray-50);border:none;border-top:1px solid var(--gray-200);cursor:pointer;transition:background .15s ease}.btn-load-more-places:hover:not(:disabled){background:var(--gray-100)}.btn-load-more-places:disabled{color:var(--gray-400);cursor:not-allowed}
