:root{--bg:#fff;--bg-secondary:#f5f5f5;--bg-card:#fff;--text:#1a1a1a;--text-secondary:#666;--accent:#4a90d9;--accent-hover:#357abd;--accent-light:#e8f0fe;--border:#e0e0e0;--danger:#d9534f;--danger-hover:#c9302c;--success:#5cb85c;--warning:#f0ad4e;--shadow:0 2px 8px #0000001a;--radius:12px;--radius-sm:8px;--font:-apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--transition:.2s ease}@media (prefers-color-scheme:dark){:root{--bg:#1a1a2e;--bg-secondary:#16213e;--bg-card:#1f2b47;--text:#e0e0e0;--text-secondary:#a0a0a0;--accent:#5dade2;--accent-hover:#4a9fd4;--accent-light:#1f2b47;--border:#2c3e5a;--shadow:0 2px 8px #0000004d}}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;font-family:var(--font);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow:hidden}.screen{height:100vh;flex-direction:column;height:100dvh;display:none;overflow:hidden}.screen.active{display:flex}.header{background:var(--bg-secondary);border-bottom:1px solid var(--border);z-index:10;flex-shrink:0;align-items:center;min-height:52px;padding:12px 16px;display:flex}.header-back{background:var(--bg-card,#f0f0f0);color:var(--accent);cursor:pointer;-webkit-tap-highlight-color:#0000001a;border:none;border-radius:50%;justify-content:center;align-items:center;width:44px;min-width:44px;height:44px;min-height:44px;margin-right:8px;font-size:24px;font-weight:700;display:inline-flex}.header-title{flex:1;font-size:18px;font-weight:600}.header-home{background:var(--bg-card,#f0f0f0);color:var(--accent);cursor:pointer;-webkit-tap-highlight-color:#0000001a;border:none;border-radius:50%;justify-content:center;align-items:center;width:44px;min-width:44px;height:44px;min-height:44px;margin-left:8px;font-size:22px;display:inline-flex}.content{flex:1;padding:16px;overflow-y:auto}.btn{border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition), transform var(--transition);-webkit-tap-highlight-color:transparent;border:none;justify-content:center;align-items:center;padding:12px 24px;font-size:16px;font-weight:500;display:inline-flex}.btn:active{transform:scale(.97)}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-hover)}.btn-secondary{background:var(--bg-secondary);color:var(--text);border:1px solid var(--border)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{background:var(--danger-hover)}.btn-block{width:100%;display:flex}.btn-large{border-radius:var(--radius);padding:16px 32px;font-size:18px}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:16px}.card+.card{margin-top:12px}.menu-btn{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);width:100%;color:var(--text);cursor:pointer;transition:background var(--transition), transform var(--transition);-webkit-tap-highlight-color:transparent;align-items:center;gap:12px;padding:18px 20px;font-size:17px;font-weight:500;display:flex}.menu-btn:active{background:var(--accent-light);transform:scale(.97)}.menu-btn+.menu-btn{margin-top:10px}.menu-btn .icon{text-align:center;width:32px;font-size:24px}input[type=text],input[type=date],input[type=number],textarea,select{width:100%;font-size:16px;font-family:var(--font);background:var(--bg-card);color:var(--text);border:1px solid var(--border);border-radius:var(--radius-sm);transition:border-color var(--transition);outline:none;padding:12px 16px}input:focus,textarea:focus,select:focus{border-color:var(--accent)}textarea{resize:vertical;min-height:100px}.chip-group{flex-wrap:wrap;gap:8px;display:flex}.chip{border:1px solid var(--border);cursor:pointer;transition:all var(--transition);background:var(--bg-card);color:var(--text);-webkit-tap-highlight-color:transparent;border-radius:20px;padding:8px 16px;font-size:14px}.chip.selected{background:var(--accent);color:#fff;border-color:var(--accent)}.chip:active{transform:scale(.95)}.modal-overlay{z-index:1000;background:#00000080;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;top:0;bottom:0;left:0;right:0}.modal-box{background:var(--bg-card);border-radius:var(--radius);flex-direction:column;width:100%;max-width:400px;max-height:80dvh;padding:24px;display:flex;overflow-y:auto;box-shadow:0 8px 32px #0003}.modal-box h2{flex-shrink:0;margin-bottom:12px;font-size:18px;font-weight:700}.modal-box h3{flex-shrink:0;margin-bottom:12px;font-size:18px}.modal-box p{color:var(--text-secondary);margin-bottom:16px;line-height:1.5}.modal-actions{flex-shrink:0;justify-content:flex-end;gap:8px;margin-top:8px;display:flex}.nav-btns{gap:8px;margin-top:16px;display:flex}.nav-btns .btn{flex:1}.modal-list{flex-direction:column;flex:1;gap:8px;margin-bottom:8px;display:flex;overflow-y:auto}.toast{background:var(--text);color:var(--bg);z-index:2000;opacity:0;pointer-events:none;border-radius:24px;padding:12px 24px;font-size:14px;transition:opacity .3s;position:fixed;bottom:80px;left:50%;transform:translate(-50%)}.toast.visible{opacity:1}.loader-overlay{z-index:3000;background:#0006;flex-direction:column;justify-content:center;align-items:center;gap:16px;display:flex;position:fixed;top:0;bottom:0;left:0;right:0}.spinner{border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:40px;height:40px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.loader-text{color:#fff;font-size:16px}.map-container{-webkit-overflow-scrolling:touch;flex:1;min-height:0;overflow-y:auto}.list-item{border-bottom:1px solid var(--border);cursor:pointer;transition:background var(--transition);align-items:center;padding:14px 16px;display:flex}.list-item:active{background:var(--accent-light)}.gap-8{gap:8px}.gap-12{gap:12px}.gap-16{gap:16px}.mt-8{margin-top:8px}.mt-12{margin-top:12px}.mt-16{margin-top:16px}.text-center{text-align:center}.text-secondary{color:var(--text-secondary)}.flex-col{flex-direction:column;display:flex}.flex-row{flex-direction:row;align-items:center;gap:8px;display:flex}.flex-1{flex:1}@supports (padding:env(safe-area-inset-top)){.header{padding-top:calc(12px + env(safe-area-inset-top))}.content{padding-bottom:calc(16px + env(safe-area-inset-bottom))}.screen{padding-bottom:env(safe-area-inset-bottom)}}.input{width:100%;font-size:16px;font-family:var(--font);background:var(--bg-card);color:var(--text);border:1.5px solid var(--border);border-radius:var(--radius-sm);transition:border-color var(--transition), box-shadow var(--transition);-webkit-appearance:none;outline:none;padding:14px 16px;display:block}.input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #4a90d91f}.input+.input{margin-top:10px}label{color:var(--text-secondary);margin-top:12px;margin-bottom:6px;font-size:14px;font-weight:500;display:block}.mb-4{margin-bottom:4px}.mb-8{margin-bottom:8px}.mb-12{margin-bottom:12px}.mb-16{margin-bottom:16px}.mt-4{margin-top:4px}.p-0{padding:0}.text-sm{font-size:13px}.text-lg{font-size:18px}.font-bold{font-weight:600}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.align-center{align-items:center}.w-full{width:100%}.badge{letter-spacing:.2px;border-radius:20px;align-items:center;padding:2px 10px;font-size:12px;font-weight:600;display:inline-flex}.badge-success{background:var(--success);color:#fff}.badge-warning{background:var(--warning);color:#fff}.badge-danger{background:var(--danger);color:#fff}.badge-accent{background:var(--accent);color:#fff}.btn-small{padding:6px 12px;font-size:13px}.settings-section h3,.section-heading{text-transform:uppercase;letter-spacing:.6px;color:var(--text-secondary);margin-bottom:10px;font-size:13px;font-weight:600}.home-content{flex-direction:column;flex:1;justify-content:center;gap:12px;padding:24px 16px;display:flex}.home-greeting{text-align:center;color:var(--text-secondary);margin-bottom:8px;font-size:15px}.step-progress{gap:6px;margin-bottom:20px;display:flex}.step-progress-dot{background:var(--border);border-radius:2px;flex:1;height:4px;transition:background .3s}.step-progress-dot.active{background:var(--accent)}.step-progress-dot.done{background:var(--success)}.install-hint{background:var(--accent-light);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-secondary);align-items:center;gap:10px;padding:12px 14px;font-size:13px;line-height:1.4;display:flex}.install-hint .icon{flex-shrink:0;font-size:22px}.map-card{position:relative}.map-card-title{margin-bottom:4px;padding-right:32px;font-size:16px;font-weight:600}.btn-icon{cursor:pointer;color:var(--text-secondary);border-radius:var(--radius-sm);transition:background var(--transition);-webkit-tap-highlight-color:transparent;background:0 0;border:none;padding:4px 8px;font-size:20px}.btn-icon:active{background:var(--accent-light)}.map-card-more{position:absolute;top:8px;right:8px}.map-tabs{background:var(--bg-card);border-bottom:2px solid var(--border);z-index:500;display:flex;position:sticky;top:52px}.map-tab{text-align:center;cursor:pointer;color:var(--text-secondary);-webkit-tap-highlight-color:transparent;background:0 0;border:none;border-bottom:3px solid #0000;flex:1;padding:12px;font-size:14px;font-weight:500;transition:all .2s}.map-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.map-filters{background:var(--bg-card);border-bottom:1px solid var(--border);-webkit-overflow-scrolling:touch;gap:8px;padding:10px 16px;display:flex;overflow-x:auto}.filter-chip{border:1.5px solid var(--border);background:var(--bg-card);color:var(--text);cursor:pointer;white-space:nowrap;-webkit-tap-highlight-color:transparent;border-radius:20px;align-items:center;gap:4px;padding:6px 12px;font-size:12px;transition:all .2s;display:inline-flex}.filter-chip.active{border-color:var(--accent);background:var(--accent);color:#fff}.filter-chip .dot{border-radius:50%;width:8px;height:8px;display:inline-block}.map-panel{flex:1;min-height:0;display:none}.map-panel.active{flex-direction:column;display:flex}.leaflet-map{flex:1;min-height:300px}.map-cards{flex:1;padding:12px;overflow-y:auto}.map-card{background:var(--bg-card);border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:12px;padding:16px;position:relative}.map-card-cat{color:#fff;border-radius:12px;padding:3px 8px;font-size:11px;position:absolute;top:12px;right:12px}.map-card h3{margin-bottom:6px;padding-right:80px;font-size:16px}.map-card .meta{color:var(--text-secondary);font-size:13px;line-height:1.6}.map-card .description{color:var(--text);margin:8px 0;font-size:13px}.map-card .actions{flex-wrap:wrap;gap:8px;margin-top:10px;display:flex}.btn-navigate{color:#fff;background:#4285f4;border-radius:8px;align-items:center;gap:4px;padding:8px 14px;font-size:13px;font-weight:500;text-decoration:none;display:inline-flex}.btn-info{background:var(--bg-secondary);color:var(--text);border-radius:8px;align-items:center;gap:4px;padding:8px 14px;font-size:13px;font-weight:500;text-decoration:none;display:inline-flex}.map-timeline{flex:1;padding:12px 16px;overflow-y:auto}.timeline-day{margin-bottom:20px}.timeline-day h2{color:var(--accent);border-bottom:2px solid var(--accent);margin-bottom:8px;padding-bottom:4px;font-size:15px}.timeline-slot{gap:12px;margin-bottom:8px;display:flex}.timeline-time{text-align:right;width:50px;color:var(--text);flex-shrink:0;padding-top:2px;font-size:13px;font-weight:600}.timeline-content{background:var(--bg-card);box-shadow:var(--shadow);border-left:3px solid var(--accent);border-radius:8px;flex:1;padding:10px 14px}.timeline-content h4{margin-bottom:2px;font-size:14px}.timeline-content .tl-meta{color:var(--text-secondary);font-size:12px}.share-bar{background:var(--bg-card);border-bottom:1px solid var(--border);justify-content:flex-end;gap:8px;padding:10px 16px;display:flex}.btn-share{cursor:pointer;color:#fff;-webkit-tap-highlight-color:transparent;border:none;border-radius:20px;align-items:center;gap:6px;padding:8px 16px;font-size:13px;font-weight:500;display:inline-flex}.btn-whatsapp{background:#25d366}.btn-share-native{background:var(--accent)}.start-info{color:#333;background:#fff3cd;border-bottom:1px solid #ffc107;align-items:center;gap:8px;padding:10px 16px;font-size:13px;display:flex}@media (prefers-color-scheme:dark){.start-info{color:var(--text);background:#3d3200;border-bottom-color:#665200}}.map-popup strong{font-size:14px}.map-popup p{color:var(--text-secondary);margin:4px 0;font-size:12px}.drawing-mode{cursor:crosshair!important}.corridor-waypoint{cursor:grab}.trip-map-pane{flex:1;min-height:200px}.trip-bottom-sheet{background:var(--bg);border-top:2px solid var(--border);flex:1;padding:12px 16px;overflow-y:auto}.trip-title-bar{align-items:center;margin-bottom:12px;display:flex}.trip-title{cursor:pointer;flex:1;font-size:18px;font-weight:600}.trip-stops-list{flex-direction:column;gap:4px;display:flex}.trip-stop-item{background:var(--bg-card);border-radius:var(--radius-sm);box-shadow:var(--shadow);align-items:center;gap:10px;padding:10px 12px;display:flex}.trip-stop-icon{flex-shrink:0;font-size:20px}.trip-stop-info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.trip-stop-name{text-overflow:ellipsis;white-space:nowrap;font-size:14px;font-weight:500;overflow:hidden}.trip-mode-btn{border:1.5px solid var(--border);background:var(--bg-secondary);cursor:pointer;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:16px;display:flex}.trip-del-btn{background:var(--danger,#ef4444);color:#fff;cursor:pointer;opacity:.7;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:16px;display:flex}.trip-del-btn:hover{opacity:1}.trip-add-between{border:2px dashed var(--accent);width:28px;height:28px;color:var(--accent);cursor:pointer;opacity:.5;background:0 0;border-radius:50%;justify-content:center;align-self:center;align-items:center;margin:2px 0;font-size:16px;transition:opacity .2s;display:flex}.trip-add-between:hover{opacity:1}.trip-actions{flex-wrap:wrap;gap:10px;margin-top:16px;display:flex}.trip-stop-num{color:#fff;background:#667eea;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:14px;font-weight:700;display:flex;box-shadow:0 2px 6px #0000004d}.corridor-confirm-control{pointer-events:auto}.btn-outline{border-radius:var(--radius-sm);border:2px solid var(--accent);color:var(--accent);cursor:pointer;background:0 0;padding:10px 20px;font-size:14px;font-weight:500}.trip-search-btn,.trip-split-btn{border:1.5px solid var(--border);background:var(--bg-secondary);cursor:pointer;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:14px;display:flex}.trip-travel-info{text-align:center;color:var(--text-secondary);opacity:.8;padding:4px 0;font-size:12px}.corridor-search-progress{text-align:center;color:var(--accent);padding:12px;font-size:14px;font-weight:500;animation:1.5s ease-in-out infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.trip-tab-bar{background:var(--bg-card);border-bottom:2px solid var(--border);flex-shrink:0;display:flex}.trip-tab{text-align:center;cursor:pointer;color:var(--text-secondary);-webkit-tap-highlight-color:transparent;background:0 0;border:none;border-bottom:3px solid #0000;flex:1;padding:10px;font-size:14px;font-weight:500;transition:all .2s}.trip-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.trip-timeline-pane{background:var(--bg);flex:1;padding:12px 16px;overflow-y:auto}.trip-timeline-day{margin-bottom:20px}.trip-timeline-day-header{color:var(--accent);border-bottom:2px solid var(--accent);align-items:center;gap:8px;margin-bottom:8px;padding-bottom:4px;font-size:15px;display:flex}.trip-timeline-day-header.anytime-header{color:#9b59b6;border-bottom-color:#9b59b6}.trip-time-budget{border-radius:10px;padding:2px 8px;font-size:11px;font-weight:600}.trip-time-budget.budget-warn{color:#856404;background:#fff3cd}.trip-time-budget.budget-over{color:#721c24;background:#f8d7da}@media (prefers-color-scheme:dark){.trip-time-budget.budget-warn{color:#ffc107;background:#3d3200}.trip-time-budget.budget-over{color:#f5a6ad;background:#3d1c20}}.trip-timeline-travel{background:var(--bg-secondary);border-radius:var(--radius-sm);color:var(--text-secondary);margin-bottom:8px;padding:8px 12px;font-size:13px;font-weight:500}.trip-timeline-empty{color:var(--text-secondary);padding:8px 0;font-size:13px;font-style:italic}.trip-timeline-slot{gap:12px;margin-bottom:8px;display:flex}.trip-timeline-time{text-align:right;width:50px;color:var(--text);flex-shrink:0;padding-top:2px;font-size:13px;font-weight:600}.trip-timeline-content{background:var(--bg-card);box-shadow:var(--shadow);border-left:3px solid var(--accent);border-radius:8px;flex:1;padding:10px 14px}.trip-timeline-content h4{margin:0 0 2px;font-size:14px}.trip-timeline-meta{color:var(--text-secondary);font-size:12px}.trip-timeline-desc{color:var(--text);opacity:.8;margin-top:4px;font-size:12px}.trip-layer-info{background:var(--bg-secondary);color:var(--text-secondary);border-radius:20px;align-items:center;padding:6px 12px;font-size:12px;font-weight:500;display:inline-flex}
