*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--primary: #667eea;--primary-dark: #5a6fd6;--danger: #ef4444;--text: #1e1e2e;--text-primary: #1e1e2e;--text-muted: #6b7280;--bg: #f8f9fc;--surface: #ffffff;--border: #e5e7eb;--radius: 12px;--radius-sm: 8px;--shadow: 0 2px 12px rgba(0,0,0,.08);--shadow-lg: 0 8px 30px rgba(0,0,0,.12)}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);font-size:14px;line-height:1.6;height:100vh;overflow:hidden}#root{height:100vh;display:flex;flex-direction:column}.app{display:flex;flex-direction:column;height:100vh}.app-main{flex:1;overflow:hidden;display:flex;flex-direction:column}.app-header{display:flex;align-items:center;justify-content:space-between;padding:0 24px;height:56px;background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0}.app-logo{display:flex;align-items:center;gap:8px;font-weight:700;font-size:16px;color:var(--primary)}.app-user{display:flex;align-items:center;gap:10px;color:var(--text-muted);font-size:13px}.auth-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2)}.auth-card{background:var(--surface);border-radius:20px;padding:40px;width:100%;max-width:400px;box-shadow:var(--shadow-lg)}.auth-logo{display:flex;align-items:center;gap:10px;margin-bottom:24px;color:var(--primary)}.auth-logo h1{font-size:20px;font-weight:700}.auth-card h2{font-size:18px;margin-bottom:20px}.auth-toggle{margin-top:16px;text-align:center;color:var(--text-muted)}.auth-toggle button{background:none;border:none;color:var(--primary);cursor:pointer;font-weight:600}.form-group{margin-bottom:16px}.form-group label{display:block;font-weight:600;font-size:13px;margin-bottom:6px}.form-group input,.form-group textarea,.form-group select{width:100%;padding:10px 12px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:14px;outline:none;transition:border-color .15s;background:var(--surface)}.form-group input:focus,.form-group textarea:focus{border-color:var(--primary)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.btn-primary{display:inline-flex;align-items:center;gap:6px;padding:10px 18px;background:var(--primary);color:#fff;border:none;border-radius:var(--radius-sm);font-size:14px;font-weight:600;cursor:pointer;transition:background .15s}.btn-primary:hover:not(:disabled){background:var(--primary-dark)}.btn-primary:disabled{opacity:.55;cursor:not-allowed}.btn-secondary{display:inline-flex;align-items:center;gap:6px;padding:10px 18px;background:var(--bg);color:var(--text);border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:14px;font-weight:600;cursor:pointer}.btn-secondary:hover{background:var(--border)}.btn-outline{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;background:transparent;color:var(--primary);border:1.5px solid var(--primary);border-radius:var(--radius-sm);font-size:13px;font-weight:600;cursor:pointer}.btn-outline:hover{background:#667eea14}.btn-outline-white{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;background:#ffffff26;color:#fff;border:1.5px solid rgba(255,255,255,.6);border-radius:var(--radius-sm);font-size:13px;font-weight:600;cursor:pointer}.btn-outline-white:hover{background:#ffffff40}.btn-sm{padding:6px 12px;font-size:12px;border-radius:6px}.icon-btn{background:none;border:none;cursor:pointer;color:var(--text-muted);padding:4px;border-radius:4px;display:inline-flex;align-items:center;transition:color .15s,background .15s}.icon-btn:hover{background:var(--bg);color:var(--text)}.icon-btn.danger:hover{color:var(--danger)}.icon-only{padding:10px}.avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--primary),#764ba2);color:#fff;font-weight:700;font-size:14px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.avatar.small{width:26px;height:26px;font-size:12px}.error-msg{color:var(--danger);background:#fef2f2;border:1px solid #fecaca;border-radius:8px;padding:10px 12px;margin-bottom:12px;font-size:13px}.success-msg{color:#16a34a;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:8px;padding:10px 12px;margin-bottom:12px;font-size:13px}.empty-text{color:var(--text-muted);font-size:13px;text-align:center;padding:16px 0}.empty-text.small{font-size:12px;padding:8px 0}.center{text-align:center}.plan-list{padding:28px;max-width:1100px;margin:0 auto;width:100%;overflow-y:auto;height:100%}.plan-list-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.plan-list-header h2{font-size:22px;font-weight:700}.plan-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:18px}.plan-card{background:var(--surface);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);cursor:pointer;transition:transform .15s,box-shadow .15s}.plan-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}.plan-card-banner{height:80px;position:relative}.plan-card-body{padding:16px}.plan-card-body h3{font-size:16px;font-weight:700;margin-bottom:4px}.plan-destination{color:var(--text-muted);font-size:13px;display:flex;align-items:center;gap:4px;margin-bottom:10px}.plan-meta{display:flex;flex-direction:column;gap:4px;color:var(--text-muted);font-size:12px}.plan-meta span{display:flex;align-items:center;gap:4px}.plan-card-author{font-size:11px;color:var(--primary);margin-top:6px;font-weight:600}.date-auto-display{display:flex;align-items:center;gap:6px;padding:10px 12px;background:#f3f4f6;border-radius:8px;border:1px solid var(--border);font-size:13px;color:var(--text);min-height:40px}.empty-state{text-align:center;padding:80px 20px;color:var(--text-muted)}.empty-state svg{margin-bottom:12px;opacity:.3}.plan-detail{display:flex;flex-direction:column;height:100%}.plan-detail-header{display:flex;align-items:center;position:relative;z-index:100;padding:14px 20px;color:#fff;flex-shrink:0}.back-btn{display:flex;align-items:center;gap:6px;background:#ffffff26;border:none;color:#fff;padding:8px 14px;border-radius:var(--radius-sm);cursor:pointer;font-size:13px;font-weight:600;white-space:nowrap;flex-shrink:0;z-index:1}.back-btn:hover{background:#ffffff40}.plan-detail-title{position:absolute;left:50%;transform:translate(-50%);text-align:center;pointer-events:none;max-width:calc(100% - 280px)}.plan-detail-title h2{font-size:20px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.plan-detail-meta{display:flex;justify-content:center;gap:12px;font-size:11px;opacity:.85;margin-top:3px;flex-wrap:wrap}.plan-detail-meta span{display:flex;align-items:center;gap:4px}.plan-detail-actions{display:flex;align-items:center;gap:8px;position:relative;margin-left:auto}.trip-settings-btn{width:36px;height:36px;border-radius:50%;justify-content:center;padding:0;background:#ffffff2e;border:1.5px solid rgba(255,255,255,.4);color:#fff;transition:background .15s}.trip-settings-btn:hover{background:#ffffff52!important}.trip-settings-menu{position:absolute;top:calc(100% + 8px);right:0;z-index:200;width:210px;padding:6px;border-radius:10px;background:#fff;color:#1e1e2e;box-shadow:0 12px 34px #00000038;border:1px solid rgba(0,0,0,.08)}.trip-settings-menu button,.trip-settings-menu .export-btn{width:100%;display:flex;align-items:center;justify-content:flex-start;gap:8px;padding:9px 10px;border:none;border-radius:7px;background:transparent;color:#1e1e2e!important;font-size:13px;font-weight:600;cursor:pointer}.trip-settings-menu button:hover,.trip-settings-menu .export-btn:hover{background:var(--bg-light)}.trip-settings-menu .export-btn{border-color:transparent}.trip-settings-menu .danger{color:#dc2626}.tab-nav{display:flex;border-bottom:1px solid var(--border);background:var(--surface);flex-shrink:0;padding:0 24px}.tab{display:inline-flex;align-items:center;gap:6px;padding:12px 16px;border:none;background:none;cursor:pointer;color:var(--text-muted);font-size:13px;font-weight:600;border-bottom:2px solid transparent;transition:color .15s}.tab:hover{color:var(--text)}.tab.active{color:var(--primary);border-bottom-color:var(--primary)}.plan-detail-body{flex:1;overflow:hidden;display:flex;flex-direction:row}.map-pane{flex:1;min-width:0;position:relative;display:flex;flex-direction:column}.itinerary-pane{width:420px;flex-shrink:0;display:flex;flex-direction:column;border-left:1px solid var(--border);background:var(--surface)}.chat-popup{position:absolute;top:60px;left:12px;z-index:20;width:260px;background:var(--surface);border-radius:12px;box-shadow:0 8px 32px #0000002e;display:flex;flex-direction:column;overflow:hidden;border:1px solid var(--border)}.chat-popup-header{display:flex;align-items:center;gap:7px;padding:10px 12px;background:var(--primary);color:#fff;cursor:pointer;font-size:13px;font-weight:600;flex-shrink:0}.chat-popup-header span{flex:1}.chat-popup-controls{display:flex;gap:4px}.chat-popup-controls button{background:#fff3;border:none;color:#fff;width:20px;height:20px;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s}.chat-popup-controls button:hover{background:#ffffff59}.chat-count{background:#ffffff40;color:#fff;font-size:10px;font-weight:700;padding:1px 6px;border-radius:10px}.chat-popup-messages{height:200px;overflow-y:auto;padding:10px 12px;display:flex;flex-direction:column;gap:8px}.chat-popup-input{display:flex;gap:6px;padding:8px 10px;border-top:1px solid var(--border);flex-shrink:0}.chat-popup-input input{flex:1;padding:7px 10px;border:1.5px solid var(--border);border-radius:16px;font-size:13px;outline:none}.chat-popup-input input:focus{border-color:var(--primary)}.chat-popup-input .btn-primary{padding:7px 10px}.confirm-iw{min-width:240px;max-width:280px;padding:4px 2px}.confirm-iw-name{font-weight:700;font-size:13px;color:#1e1e2e;margin-bottom:10px;line-height:1.4;border-bottom:1px solid #e5e7eb;padding-bottom:8px}.confirm-iw-fields{display:flex;flex-direction:column;gap:6px;margin-bottom:10px}.confirm-iw-row{display:flex;align-items:center;gap:8px;font-size:12px}.confirm-iw-row label{width:44px;font-weight:600;color:#6b7280;flex-shrink:0}.confirm-iw-row select,.confirm-iw-row input[type=time],.confirm-iw-row input[type=number]{border:1.5px solid #e5e7eb;border-radius:6px;padding:4px 8px;font-size:12px;outline:none;flex:1}.confirm-iw-row select:focus,.confirm-iw-row input:focus{border-color:#667eea}.confirm-iw-expense-toggle{margin-bottom:8px;font-size:12px}.confirm-iw-expense-toggle label{display:flex;align-items:center;gap:5px;cursor:pointer;color:#6b7280}.confirm-iw-expense-fields{display:flex;flex-direction:column;gap:4px;margin-bottom:8px}.confirm-iw-input{width:100%;border:1.5px solid #e5e7eb;border-radius:6px;padding:5px 8px;font-size:12px;outline:none}.confirm-iw-input:focus{border-color:#667eea}.confirm-iw-select{border:1.5px solid #e5e7eb;border-radius:6px;padding:5px 6px;font-size:12px;outline:none;flex-shrink:0}.confirm-iw-actions{display:flex;gap:6px;justify-content:flex-end;align-items:center;flex-wrap:wrap;width:100%;margin-top:8px}.confirm-iw-btn-cancel{padding:6px 12px;border:1.5px solid #e5e7eb;border-radius:6px;background:#fff;cursor:pointer;font-size:12px;color:#6b7280}.confirm-iw-btn-add{display:flex;align-items:center;gap:4px;padding:6px 12px;background:#667eea;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:12px;font-weight:600}.confirm-iw-btn-add:hover{background:#5a6fd6}.confirm-iw-btn-delete{display:flex;align-items:center;gap:4px;padding:6px 10px;border:1.5px solid #fecaca;border-radius:6px;background:#fff5f5;color:#dc2626;cursor:pointer;font-size:12px;font-weight:600;margin-right:auto}.confirm-iw-btn-delete:hover{background:#fee2e2}.map-wrapper{position:relative;flex:1;width:100%;height:100%}.map-loading{display:flex;align-items:center;justify-content:center;height:100%;color:var(--text-muted)}.map-info-panel{position:absolute;top:64px;right:16px;z-index:30;width:min(360px,calc(100% - 32px));max-height:calc(100% - 92px);overflow-y:auto;background:#fff;border:1px solid var(--border);border-radius:10px;box-shadow:0 10px 32px #00000038;padding:14px 12px 12px}.map-info-panel:after{content:"";position:absolute;left:50%;bottom:-9px;width:18px;height:18px;transform:translate(-50%) rotate(45deg);background:#fff;border-right:1px solid var(--border);border-bottom:1px solid var(--border)}.map-info-close{position:absolute;top:8px;right:8px;display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;border-radius:50%;background:transparent;color:var(--text-muted);cursor:pointer}.map-info-close:hover{background:var(--bg);color:var(--text)}.map-info-panel .confirm-iw{min-width:0;max-width:none;padding:0}.map-info-panel .confirm-iw-name{padding-right:34px}.map-search-bar{position:absolute;top:12px;left:50%;transform:translate(-50%);z-index:10;display:flex;align-items:center;background:#fff;border-radius:24px;box-shadow:0 2px 12px #0003;padding:0 12px;width:min(520px,calc(100% - 32px))}.map-search-icon{color:var(--text-muted);flex-shrink:0}.map-search-input{flex:1;border:none;outline:none;padding:11px 10px;font-size:14px;background:transparent;width:100%;min-width:0}.map-search-clear{background:none;border:none;cursor:pointer;color:var(--text-muted);padding:4px;display:flex;align-items:center}.map-search-clear:hover{color:var(--text)}.map-hint{position:absolute;top:58px;left:50%;transform:translate(-50%);z-index:10;background:#000000a6;color:#fff;padding:6px 14px;border-radius:20px;font-size:11px;display:flex;align-items:center;gap:6px;pointer-events:none;white-space:nowrap}.info-window{min-width:200px;max-width:260px}.info-window-header{display:flex;justify-content:space-between;align-items:flex-start;gap:8px;margin-bottom:8px}.info-window-header strong{font-size:13px;line-height:1.4}.info-window-meta{font-size:11px;color:var(--text-muted);margin-bottom:8px}.location-notes{margin-bottom:8px}.note-item{font-size:12px;color:#444;margin-bottom:2px}.add-note-form textarea{width:100%;padding:8px;border:1px solid var(--border);border-radius:6px;font-size:12px;resize:none;margin-bottom:6px}.add-note-actions{display:flex;justify-content:flex-end;gap:6px}.confirm-panel{position:absolute;bottom:0;left:0;right:0;z-index:10;background:#fff;border-top:1px solid var(--border);padding:14px 18px;box-shadow:0 -4px 20px #0000001f}.confirm-panel-name{display:flex;align-items:flex-start;gap:8px;margin-bottom:12px;color:var(--primary)}.confirm-panel-name span{flex:1;font-weight:600;font-size:14px;color:var(--text);line-height:1.4}.confirm-panel-fields{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:12px}.confirm-field{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--text-muted)}.confirm-field label{font-weight:600;color:var(--text)}.confirm-field select,.confirm-field input[type=time],.confirm-field input[type=number]{border:1.5px solid var(--border);border-radius:6px;padding:5px 8px;font-size:13px;outline:none}.confirm-field select:focus,.confirm-field input:focus{border-color:var(--primary)}.confirm-panel-actions{display:flex;gap:8px;justify-content:flex-end}.itinerary{display:flex;flex-direction:column;height:100%;overflow:hidden}.itinerary-day-nav{display:flex;align-items:center;border-bottom:1px solid var(--border);flex-shrink:0;background:var(--surface);padding:0 4px;gap:2px}.day-nav-btn{flex-shrink:0;width:26px;height:26px;border-radius:50%;border:1.5px solid var(--border);background:#fff;cursor:pointer;color:var(--text-muted);display:flex;align-items:center;justify-content:center;transition:all .15s;margin:8px 0}.day-nav-btn:hover:not(:disabled){border-color:var(--primary);color:var(--primary)}.day-nav-btn:disabled{opacity:.25;cursor:default}.itinerary-day-tabs{display:flex;flex:1;overflow-x:auto;gap:5px;padding:8px 4px;scrollbar-width:none}.itinerary-day-tabs::-webkit-scrollbar{display:none}.day-tab{flex-shrink:0;display:flex;flex-direction:column;align-items:center;padding:5px 14px;border-radius:20px;border:1.5px solid var(--border);background:#fff;cursor:pointer;transition:all .15s;gap:1px;color:var(--text-muted);line-height:1.3;white-space:nowrap}.day-tab:hover{border-color:var(--primary);color:var(--primary);background:#667eea0a}.day-tab.active{background:var(--primary);color:#fff;border-color:var(--primary);box-shadow:0 2px 8px #667eea4d}.day-tab-num{font-size:11px;font-weight:700}.day-tab-date{font-size:9px;opacity:.85}.itinerary-day-subheader{display:flex;align-items:center;gap:6px;padding:8px 10px 4px;flex-shrink:0}.itinerary-day-subheader-label{font-size:12px;font-weight:700;color:var(--text)}.itinerary-day-subheader-date{font-size:11px;color:var(--text-muted)}.itinerary-day-subheader-count{margin-left:auto;font-size:10px;color:var(--text-muted);background:var(--bg);border:1px solid var(--border);border-radius:10px;padding:1px 8px}.itinerary-cards{flex:1;overflow-y:auto;padding:6px 10px 16px;display:flex;flex-direction:column;gap:0}.itinerary-card{display:flex;align-items:center;gap:8px;background:var(--surface);border:1.5px solid var(--border);border-left:4px solid var(--primary);border-radius:10px;padding:10px 10px 10px 8px;cursor:pointer;transition:box-shadow .15s,border-color .15s;-webkit-user-select:none;user-select:none;margin-bottom:5px}.itinerary-card:hover{border-color:var(--primary);box-shadow:0 3px 12px #667eea1f}.itinerary-card.selected{border-color:var(--primary);background:#667eea08;box-shadow:0 0 0 3px #667eea26}.itinerary-card[draggable=true]:active{opacity:.6}.itinerary-card.touch-dragging{opacity:.45}.itinerary-card.drag-over{border-color:var(--primary);box-shadow:0 0 0 2px #667eea59;background:#667eea0a}.itinerary-cards.is-touch-dragging{touch-action:none}.itinerary-card-drag{color:#d1d5db;cursor:grab;flex-shrink:0;display:flex;align-items:center;touch-action:none;margin-left:-2px}.itinerary-card-drag:hover{color:var(--text-muted)}.itinerary-card-drag:active{cursor:grabbing;color:var(--primary)}.itinerary-card-num{width:22px;height:22px;border-radius:50%;background:var(--primary);color:#fff;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 1px 4px #667eea66}.itinerary-card-time{flex-shrink:0}.time-input{border:none;outline:none;font-size:13px;font-weight:700;color:var(--primary);background:transparent;cursor:pointer;width:70px;font-family:inherit}.time-input:focus{background:#667eea14;border-radius:5px;padding:2px 4px}.itinerary-card-body{flex:1;min-width:0}.itinerary-card-name{font-size:13px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.3}.itinerary-card-meta{display:flex;align-items:center;gap:4px;flex-wrap:wrap;color:var(--text-muted);font-size:11px;margin-top:3px}.duration-input{border:none;outline:none;font-size:11px;color:var(--text-muted);background:transparent;width:36px;text-align:right;font-family:inherit}.duration-input:focus{background:var(--bg);border-radius:4px;padding:1px 3px}.loc-type-badge{font-size:10px;color:var(--text-muted);background:var(--bg);border:1px solid var(--border);border-radius:4px;padding:1px 5px;white-space:nowrap;flex-shrink:0;line-height:1.4}.note-btn{color:var(--text-muted)}.note-btn.has-note{color:var(--primary)}.itinerary-top-tabs{display:flex;border-bottom:1px solid var(--border);flex-shrink:0;background:var(--surface)}.travel-connector{display:flex;align-items:stretch;padding:0 10px 5px 26px;gap:0}.travel-connector-spine{width:2px;flex-shrink:0;margin-right:10px;align-self:stretch;min-height:24px;background:linear-gradient(to bottom,#667eea80,#667eea26);border-radius:1px}.travel-connector-card{flex:1;background:var(--bg);border:1px solid var(--border);border-radius:8px;overflow:hidden}.travel-connector-row{display:flex;align-items:center;gap:6px;padding:4px 8px}.travel-mode-btn{display:flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;border:1.5px solid var(--border);background:#fff;cursor:pointer;color:var(--text-muted);transition:all .15s;flex-shrink:0}.travel-mode-btn.active{border-color:var(--primary);color:var(--primary);background:#667eea1a}.travel-mode-btn:hover{border-color:var(--primary);color:var(--primary)}.travel-time{font-size:11px;color:var(--text-muted);flex:1}.travel-expand-btn{background:none;border:none;cursor:pointer;color:var(--text-muted);padding:2px;display:flex;align-items:center}.travel-expand-btn:hover{color:var(--primary)}.travel-steps{border-top:1px solid var(--border);padding:6px 8px;display:flex;flex-direction:column;gap:5px;max-height:160px;overflow-y:auto}.travel-step-empty{font-size:11px;color:var(--text-muted)}.travel-step{display:flex;align-items:flex-start;gap:6px;font-size:11px}.travel-step-icon{display:flex;align-items:center;gap:3px;flex-shrink:0;color:var(--primary);padding-top:1px}.transit-line{background:var(--primary);color:#fff;font-size:9px;font-weight:700;padding:1px 4px;border-radius:3px}.travel-step-text{flex:1;color:#444;line-height:1.4}.travel-step-meta{flex-shrink:0;color:var(--text-muted)}.note-panel{flex-shrink:0;border-top:2px solid var(--primary);background:var(--surface);display:flex;flex-direction:column;height:220px}.note-panel-header{display:flex;align-items:center;gap:7px;padding:8px 12px;background:#667eea0f;border-bottom:1px solid var(--border);flex-shrink:0;color:var(--primary)}.note-panel-title{flex:1;font-size:12px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.note-panel-close{background:none;border:none;cursor:pointer;font-size:18px;color:var(--text-muted);line-height:1;padding:0}.note-panel-messages{flex:1;overflow-y:auto;padding:10px 12px;display:flex;flex-direction:column;gap:8px}.note-panel-msg{background:var(--bg);border-radius:8px;padding:8px 10px}.note-panel-msg-text{font-size:13px;color:var(--text);line-height:1.5}.note-panel-msg-footer{display:flex;align-items:center;justify-content:space-between;margin-top:4px}.note-panel-msg-meta{font-size:10px;color:var(--text-muted)}.delete-confirm-inline,.note-delete-confirm{display:flex;align-items:center;gap:6px;font-size:12px;color:#ef4444;padding:4px 0}.delete-confirm-inline span,.note-delete-confirm span{flex:1}.dcb-yes{padding:3px 10px;background:#ef4444;color:#fff;border:none;border-radius:4px;font-size:11px;cursor:pointer;font-weight:600}.dcb-yes:hover{background:#dc2626}.dcb-no{padding:3px 10px;background:var(--bg);color:var(--text);border:1px solid var(--border);border-radius:4px;font-size:11px;cursor:pointer}.dcb-no:hover{background:var(--border)}.note-panel-input{display:flex;gap:6px;padding:8px 10px;border-top:1px solid var(--border);flex-shrink:0}.note-panel-input input{flex:1;padding:7px 12px;border:1.5px solid var(--border);border-radius:16px;font-size:13px;outline:none}.note-panel-input input:focus{border-color:var(--primary)}.note-panel-input .btn-primary{padding:7px 10px}.note-count{font-size:9px;background:var(--primary);color:#fff;border-radius:8px;padding:1px 4px;margin-left:2px}.note-modal{max-width:480px}.note-modal-sub{font-size:12px;color:var(--text-muted);margin-top:2px}.note-modal-existing{background:var(--bg);border-radius:var(--radius-sm);padding:10px 12px;margin-bottom:14px;max-height:160px;overflow-y:auto}.note-modal-input textarea{width:100%;border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:10px 12px;font-size:14px;resize:none;outline:none;margin-bottom:12px}.note-modal-input textarea:focus{border-color:var(--primary)}.expenses-panel{display:flex;flex-direction:column;height:100%;overflow:hidden}.expenses-summary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:16px;flex-shrink:0}.expenses-total{margin-bottom:10px}.expenses-total-label{font-size:11px;opacity:.85;display:block}.expenses-total-amount{font-size:26px;font-weight:700}.expenses-breakdown{display:flex;flex-direction:column;gap:4px}.expenses-cat-row{display:flex;align-items:center;gap:6px;font-size:12px;opacity:.9}.expenses-cat-amount{margin-left:auto;font-weight:600}.expenses-add-btn{margin:12px;flex-shrink:0}.expenses-form{padding:0 12px 12px;border-bottom:1px solid var(--border);flex-shrink:0}.category-picker{display:flex;flex-wrap:wrap;gap:6px}.category-btn{display:flex;align-items:center;gap:4px;padding:5px 10px;border:1.5px solid var(--border);border-radius:20px;background:#fff;cursor:pointer;font-size:12px;transition:all .15s}.category-btn:hover{border-color:#aaa}.expenses-list{flex:1;overflow-y:auto;padding:8px 12px;display:flex;flex-direction:column;gap:6px}.expense-item{display:flex;align-items:center;gap:10px;padding:10px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm)}.expense-icon{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.expense-body{flex:1;min-width:0}.expense-desc{font-size:13px;font-weight:600}.expense-meta{font-size:11px;color:var(--text-muted)}.expense-right{display:flex;align-items:center;gap:6px;flex-shrink:0}.expense-amount{font-size:13px;font-weight:700;color:var(--primary)}.note-drawer{flex-shrink:0;border-top:2px solid var(--primary);background:var(--surface);max-height:220px;display:flex;flex-direction:column}.note-drawer-header{padding:10px 14px 0;flex-shrink:0}.note-drawer-title{font-size:12px;font-weight:700;color:var(--primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.note-drawer-notes{flex:1;overflow-y:auto;padding:8px 14px}.note-drawer-item{padding:6px 0;border-bottom:1px solid var(--border)}.note-drawer-item p{font-size:13px}.note-drawer-item span{font-size:10px;color:var(--text-muted)}.note-drawer-input{padding:8px 14px;flex-shrink:0}.note-drawer-input textarea{width:100%;border:1.5px solid var(--border);border-radius:6px;padding:8px;font-size:13px;resize:none;outline:none;margin-bottom:6px}.note-drawer-input textarea:focus{border-color:var(--primary)}.note-drawer-actions{display:flex;gap:6px;justify-content:flex-end}.note-drawer-add{margin:0 14px 10px;align-self:flex-start}.notes-panel{display:flex;flex-direction:column;height:100%;overflow:hidden}.notes-tabs{display:flex;gap:4px;padding:12px 20px;border-bottom:1px solid var(--border);flex-shrink:0}.notes-content{flex:1;overflow-y:auto;padding:20px}.add-note{margin-bottom:20px}.add-note textarea{width:100%;padding:10px 12px;border:1.5px solid var(--border);border-radius:var(--radius-sm);resize:none;font-size:14px;margin-bottom:8px}.add-note textarea:focus{outline:none;border-color:var(--primary)}.note-list{display:flex;flex-direction:column;gap:10px}.note-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:14px}.note-card.sublevel{background:var(--bg)}.note-text{font-size:14px;margin-bottom:8px;white-space:pre-wrap}.note-meta{display:flex;align-items:center;gap:10px;font-size:11px;color:var(--text-muted)}.note-actions{display:flex;gap:4px;margin-left:auto}.note-date{font-size:11px;color:var(--text-muted)}.location-note-group{margin-bottom:20px}.location-note-header{display:flex;align-items:center;gap:8px;margin-bottom:8px}.pin-badge{width:22px;height:22px;border-radius:50%;background:var(--primary);color:#fff;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center}.chat-panel{display:flex;flex-direction:column;height:100%}.chat-messages{flex:1;overflow-y:auto;padding:16px 20px;display:flex;flex-direction:column;gap:10px}.chat-bubble-row{display:flex;align-items:flex-end;gap:8px}.chat-bubble-row.me{flex-direction:row-reverse}.chat-bubble-group{display:flex;flex-direction:column;max-width:65%}.chat-bubble-row.me .chat-bubble-group{align-items:flex-end}.chat-author{font-size:11px;color:var(--text-muted);margin-bottom:2px;margin-left:2px}.chat-bubble{padding:10px 14px;border-radius:16px;font-size:14px;line-height:1.5}.bubble-me{background:var(--primary);color:#fff;border-bottom-right-radius:4px}.bubble-them{background:var(--surface);border:1px solid var(--border);border-bottom-left-radius:4px}.chat-time{font-size:10px;color:var(--text-muted);margin-top:2px;margin-left:2px}.chat-input-row{display:flex;gap:8px;padding:12px 20px;border-top:1px solid var(--border);background:var(--surface);flex-shrink:0}.chat-input-row input{flex:1;padding:10px 14px;border:1.5px solid var(--border);border-radius:24px;font-size:14px;outline:none}.chat-input-row input:focus{border-color:var(--primary)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal{background:var(--surface);border-radius:16px;padding:28px;width:100%;max-width:460px;box-shadow:var(--shadow-lg);max-height:90vh;overflow-y:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.modal-header h3{font-size:18px;font-weight:700;display:flex;align-items:center;gap:8px}.modal-header button{background:none;border:none;cursor:pointer;color:var(--text-muted)}.modal-sub{color:var(--text-muted);font-size:13px;margin-bottom:16px}.modal-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:20px}.color-picker{display:flex;gap:8px;flex-wrap:wrap}.color-swatch{width:36px;height:36px;border-radius:8px;border:3px solid transparent;cursor:pointer;transition:transform .1s}.color-swatch:hover{transform:scale(1.1)}.color-swatch.selected{border-color:#333;transform:scale(1.1)}.public-link-section{margin-top:20px;padding:14px;background:#f8f9fc;border-radius:10px;border:1px solid var(--border)}.public-link-header{display:flex;align-items:center;gap:10px}.public-link-title-col{flex:1;min-width:0}.public-link-label{font-size:13px;font-weight:700;color:var(--text);display:block}.public-link-sub{font-size:11px;color:var(--text-muted);display:block;margin-top:1px}.public-link-url-row{display:flex;gap:8px;margin-top:10px}.public-link-input{flex:1;min-width:0;font-size:12px;padding:7px 10px;border:1px solid var(--border);border-radius:7px;background:#fff;color:var(--text);cursor:text}.toggle-switch{width:40px;height:22px;border-radius:11px;flex-shrink:0;background:#d1d5db;border:none;cursor:pointer;position:relative;transition:background .2s}.toggle-switch:after{content:"";position:absolute;top:3px;left:3px;width:16px;height:16px;border-radius:50%;background:#fff;box-shadow:0 1px 3px #0003;transition:transform .2s}.toggle-switch.on{background:var(--primary)}.toggle-switch.on:after{transform:translate(18px)}.collaborators-list{margin-top:20px}.collaborators-list h4{font-size:13px;font-weight:700;margin-bottom:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.collaborator-item{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid var(--border)}.collaborator-text{min-width:0;display:flex;flex-direction:column;gap:1px}.collaborator-text span{font-size:13px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.collaborator-text small{font-size:11px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.export-btn{white-space:nowrap;border-color:#fff9;color:#fff}.export-btn:hover{background:#ffffff26}.trip-settings-menu button,.trip-settings-menu .export-btn{color:#1e1e2e!important;background:transparent!important;border:none!important;font-size:13px!important}.trip-settings-menu button:hover,.trip-settings-menu .export-btn:hover{background:#f3f4f6!important}.trip-settings-menu .danger{color:#dc2626!important}.btn-danger-white{border-color:#fff9!important;color:#fff!important}.btn-danger-white:hover{background:#ef44444d!important}.btn-danger{display:inline-flex;align-items:center;gap:6px;padding:10px 18px;background:#ef4444;color:#fff;border:none;border-radius:var(--radius-sm);font-size:14px;font-weight:600;cursor:pointer}.btn-danger:hover:not(:disabled){background:#dc2626}.btn-danger:disabled{opacity:.55;cursor:not-allowed}.delete-plan-modal{max-width:420px}.delete-plan-message{color:var(--text-muted);font-size:14px;line-height:1.6;margin-bottom:4px}.days-auto{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--bg);border-radius:var(--radius-sm)}.days-auto-count{font-size:18px;font-weight:700;color:var(--primary)}.days-auto-label{font-size:12px;color:var(--text-muted)}.loading{display:flex;align-items:center;justify-content:center;height:100%;color:var(--text-muted)}.plan-card-delete-btn{position:absolute;top:8px;right:8px;width:28px;height:28px;border-radius:50%;background:#00000040;border:none;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:0;transition:opacity .15s,background .15s}.plan-card:hover .plan-card-delete-btn{opacity:1}.plan-card-delete-btn:hover{background:#ef4444}.plan-card-public-badge{position:absolute;top:8px;left:8px;display:inline-flex;align-items:center;gap:4px;background:#ffffff40;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);color:#fff;font-size:10px;font-weight:700;padding:3px 8px;border-radius:20px}.plan-card-clone-btn{position:absolute;bottom:8px;right:8px;display:inline-flex;align-items:center;gap:4px;background:#ffffffe6;color:var(--primary);font-size:11px;font-weight:700;padding:4px 10px;border:none;border-radius:20px;cursor:pointer;opacity:0;transition:opacity .15s}.plan-card:hover .plan-card-clone-btn{opacity:1}.community-trips-section{margin-top:36px}.community-trips-header{display:flex;align-items:center;gap:8px;margin-bottom:16px}.community-trips-header h2{font-size:18px;font-weight:700;color:var(--text);margin:0}.community-trips-sub{font-size:13px;color:var(--text-muted);margin-left:4px}.note-count-badge{display:inline-flex;align-items:center;gap:2px;font-size:10px;background:#667eea1f;color:var(--primary);border-radius:6px;padding:1px 5px}.confirm-iw-note{width:100%;border:1.5px solid var(--border);border-radius:6px;padding:6px 8px;font-size:12px;resize:none;outline:none;font-family:inherit}.confirm-iw-note:focus{border-color:var(--primary)}.confirm-iw-address{font-size:11px;color:var(--text-muted);margin:-2px 0 6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.confirm-iw-place-info{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:8px}.place-info-chip{display:inline-flex;align-items:center;gap:4px;font-size:11px;padding:3px 8px;border-radius:20px;background:var(--bg);border:1px solid var(--border);color:var(--text-muted);white-space:nowrap}.place-info-chip.open{color:#16a34a;border-color:#bbf7d0;background:#f0fdf4}.place-info-chip.closed{color:#dc2626;border-color:#fecaca;background:#fef2f2}.place-info-chip.type{text-transform:capitalize}.place-info-sub{opacity:.7}.selected-pin-bar{position:absolute;top:52px;left:50%;transform:translate(-50%);z-index:10;background:#fff;border-radius:10px;box-shadow:0 4px 16px #0000002e;padding:8px 12px;display:flex;align-items:center;gap:8px;min-width:300px;max-width:500px;pointer-events:all}.selected-pin-bar-info{flex:1;min-width:0}.selected-pin-bar-name{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.selected-pin-bar-fields{display:flex;align-items:center;gap:6px;flex-shrink:0}.pin-bar-select,.pin-bar-input{border:1.5px solid var(--border);border-radius:6px;padding:3px 6px;font-size:12px;outline:none;background:var(--bg)}.pin-bar-select:focus,.pin-bar-input:focus{border-color:var(--primary)}.pin-bar-duration{width:52px}.pin-bar-label{font-size:11px;color:var(--text-muted)}.pin-bar-save{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;background:var(--primary);color:#fff;border:none;border-radius:6px;font-size:11px;font-weight:600;cursor:pointer}.pin-bar-save:hover{background:var(--primary-dark)}.selected-pin-bar-confirm{display:flex;align-items:center;gap:5px;font-size:11px;color:#ef4444}.selected-pin-bar-delete{background:none;border:none;cursor:pointer;color:var(--text-muted);display:flex;align-items:center;padding:2px}.selected-pin-bar-delete:hover{color:#ef4444}.selected-pin-bar-close{background:none;border:none;cursor:pointer;color:var(--text-muted);display:flex;align-items:center;padding:2px}.selected-pin-bar-close:hover{color:var(--text)}.loc-detail-panel{flex-shrink:0;border-top:2px solid var(--primary);background:var(--surface);display:flex;flex-direction:column;max-height:360px}.loc-detail-body{flex:1;overflow-y:auto;padding:0 10px 10px;display:flex;flex-direction:column;gap:0}.loc-section-label{display:flex;align-items:center;gap:5px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--primary);padding:8px 0 4px;border-top:1px solid var(--border);margin-top:2px}.loc-section-label:first-child{border-top:none;margin-top:0;padding-top:8px}.loc-section-divider{height:1px;background:var(--border);margin:6px 0}.loc-detail-header{display:flex;align-items:center;gap:8px;padding:6px 10px;background:#667eea0f;border-bottom:1px solid var(--border);flex-shrink:0}.loc-detail-title{font-size:12px;font-weight:700;color:var(--primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:120px}.loc-detail-tabs{display:flex;gap:4px;flex:1}.loc-detail-tab{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border:1.5px solid var(--border);border-radius:20px;font-size:11px;font-weight:600;background:#fff;color:var(--text-muted);cursor:pointer;transition:all .15s}.loc-detail-tab.active{border-color:var(--primary);color:var(--primary);background:#667eea14}.loc-detail-tab:hover:not(.active){border-color:#aaa;color:var(--text)}.loc-expense-panel{flex:1;display:flex;flex-direction:column;overflow:hidden;padding:8px 10px;gap:6px}.loc-expense-total{font-size:12px;color:var(--text-muted);padding:2px 0}.loc-expense-list{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:5px}.loc-expense-item{display:flex;align-items:center;gap:7px;padding:6px 8px;background:var(--bg);border-radius:7px}.loc-expense-form{display:flex;flex-direction:column;gap:5px;padding:4px 0}.loc-exp-input{flex:1;padding:5px 8px;border:1.5px solid var(--border);border-radius:6px;font-size:12px;outline:none;background:var(--surface)}.loc-exp-input:focus{border-color:var(--primary)}.loc-exp-select{padding:5px 4px;border:1.5px solid var(--border);border-radius:6px;font-size:12px;outline:none;background:var(--surface)}.loc-exp-cats{display:flex;gap:4px;flex-wrap:wrap}.loc-exp-cat-btn{display:flex;align-items:center;gap:3px;padding:3px 7px;border-radius:6px;border:1.5px solid var(--border);background:#fff;cursor:pointer;font-size:10px;transition:all .15s}.loc-exp-cat-btn:hover{border-color:#aaa}.loc-exp-cat-btn.add-cat-btn{padding:3px 6px}.loc-expense-add-btn{padding:5px 10px;font-size:12px;align-self:flex-start;display:inline-flex;align-items:center;gap:4px}.custom-cat-input-row{display:flex;gap:5px;align-items:center;margin-top:4px}.loc-notes-popup{position:fixed;bottom:80px;right:16px;background:var(--surface);border:1px solid var(--border);border-radius:14px;box-shadow:0 8px 32px #00000029;display:flex;flex-direction:column;overflow:hidden;z-index:500;min-width:240px;min-height:160px}.loc-notes-popup-resize-handle{position:absolute;top:0;left:0;right:0;height:6px;cursor:ns-resize;background:transparent;z-index:1}.loc-notes-popup-resize-handle:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:28px;height:3px;background:var(--border);border-radius:2px}.loc-notes-popup-resize-handle:hover:after{background:var(--primary)}.loc-notes-popup-header{display:flex;align-items:center;gap:8px;padding:10px 12px 8px;border-bottom:1px solid var(--border);flex-shrink:0;margin-top:4px}.loc-notes-popup-title-row{display:flex;align-items:center;gap:6px;flex:1;min-width:0}.loc-notes-popup-title{font-size:12px;font-weight:700;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.loc-notes-popup-body{flex:1;overflow:hidden;display:flex;flex-direction:column}.popup-section-label{display:flex;align-items:center;gap:5px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--primary);padding:6px 12px 4px;flex-shrink:0}.popup-notes-area{overflow-y:auto;flex-shrink:0}.popup-section-divider{height:5px;background:var(--bg);cursor:ns-resize;flex-shrink:0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:center}.popup-section-divider:after{content:"";width:24px;height:2px;background:var(--border);border-radius:1px}.popup-section-divider:hover:after{background:var(--primary)}.popup-expenses-area{flex:1;overflow-y:auto}.loc-note-section{display:flex;flex-direction:column;height:100%}.note-panel-input-top{display:flex;gap:6px;padding:6px 10px;border-bottom:1px solid var(--border);flex-shrink:0}.note-panel-input-top input{flex:1;padding:6px 10px;border:1.5px solid var(--border);border-radius:14px;font-size:12px;outline:none;background:var(--bg)}.note-panel-input-top input:focus{border-color:var(--primary);background:#fff}.note-panel-messages{flex:1;overflow-y:auto;padding:6px 10px;display:flex;flex-direction:column;gap:6px}.note-panel-msg{background:var(--bg);border-radius:8px;padding:7px 10px}.note-panel-msg-text{font-size:12px;color:var(--text);line-height:1.5}.note-panel-msg-text.editable{cursor:pointer;position:relative;padding-right:16px}.note-panel-msg-text.editable .note-edit-hint{position:absolute;right:2px;top:2px;opacity:0;transition:opacity .15s}.note-panel-msg-text.editable:hover .note-edit-hint{opacity:1}.note-panel-msg-footer{display:flex;align-items:center;justify-content:space-between;margin-top:3px}.note-panel-msg-meta{font-size:10px;color:var(--text-muted);display:flex;align-items:center;gap:3px}.note-edit-mode{display:flex;flex-direction:column;gap:5px}.note-edit-textarea{width:100%;border:1.5px solid var(--primary);border-radius:6px;padding:6px 8px;font-size:12px;resize:none;outline:none;font-family:inherit}.note-edit-actions{display:flex;gap:5px;justify-content:flex-end}.note-delete-confirm{display:flex;align-items:center;gap:5px;font-size:11px;color:#ef4444}.mobile-has-selected .mobile-stop-detail{display:flex;flex-direction:column;flex-shrink:0;border-top:2px solid var(--primary);background:var(--surface);max-height:280px;overflow:hidden}.mobile-stop-detail-header{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#667eea0f;border-bottom:1px solid var(--border);flex-shrink:0}.mobile-stop-detail-title-wrap{flex:1;min-width:0}.mobile-stop-detail-kicker{font-size:9px;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);display:block}.mobile-stop-detail-title{font-size:12px;font-weight:700;color:var(--primary);display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mobile-stop-tabs{display:flex;gap:4px;padding:8px 10px;border-bottom:1px solid var(--border);flex-shrink:0}.mobile-stop-tab{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border:1.5px solid var(--border);border-radius:16px;font-size:11px;font-weight:600;background:#fff;color:var(--text-muted);cursor:pointer;transition:all .15s}.mobile-stop-tab.active{border-color:var(--primary);color:var(--primary);background:#667eea14}.mobile-stop-detail-body{flex:1;overflow:hidden}.public-view{display:flex;flex-direction:column;height:100vh;overflow:hidden}.public-view-header{display:flex;align-items:center;gap:12px;padding:12px 20px;color:#fff;flex-shrink:0}.public-back-link{display:flex;align-items:center;gap:4px;color:#ffffffd9;background:none;border:none;cursor:pointer;font-size:13px;font-weight:600;flex-shrink:0;white-space:nowrap}.public-view-header-center{flex:1;min-width:0;text-align:center}.public-badge{display:inline-flex;align-items:center;gap:4px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#fff;background:#fff3;border-radius:10px;padding:2px 8px;margin-bottom:4px}.public-view-header-center h1{font-size:18px;font-weight:700;color:#fff;margin-bottom:4px}.public-view-meta{display:flex;align-items:center;justify-content:center;gap:10px;flex-wrap:wrap;font-size:12px;color:#ffffffd9}.public-view-meta span{display:flex;align-items:center;gap:3px}.btn-copy-trip{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;background:#fff3;border:1.5px solid rgba(255,255,255,.5);border-radius:20px;color:#fff;font-size:13px;font-weight:700;cursor:pointer;transition:all .15s;white-space:nowrap}.btn-copy-trip:hover{background:#ffffff59}.public-view-body{flex:1;display:flex;overflow:hidden}.public-map-pane{flex:1;overflow:hidden}.public-itinerary-pane{width:320px;flex-shrink:0;display:flex;flex-direction:column;background:var(--surface);border-left:1px solid var(--border);overflow:hidden}.public-day-tabs{display:flex;gap:5px;padding:8px;overflow-x:auto;border-bottom:1px solid var(--border);flex-shrink:0;scrollbar-width:none}.public-day-tabs::-webkit-scrollbar{display:none}.public-itinerary-cards{flex:1;overflow-y:auto;padding:8px 10px;display:flex;flex-direction:column;gap:6px}.public-itinerary-card{display:flex;align-items:center;gap:8px;background:var(--bg);border-radius:8px;padding:8px 10px;border:1px solid var(--border);border-left:3px solid var(--primary)}.public-card-num{width:20px;height:20px;border-radius:50%;background:var(--primary);color:#fff;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.public-card-name{font-size:13px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.public-card-meta{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--text-muted);margin-top:2px}.public-readonly-notice{padding:8px 12px;border-top:1px solid var(--border);flex-shrink:0;font-size:11px;color:var(--text-muted);display:flex;align-items:center;gap:5px}.public-copy-inline{background:none;border:none;color:var(--primary);font-size:11px;cursor:pointer;text-decoration:underline;padding:0}px; min-height: 260px; } .popup-notes-area,.popup-expenses-area{min-height:90px}.note-panel-input-top{border-top:none!important;border-bottom:1px solid var(--border);background:#fff;flex-shrink:0}.loc-expense-panel>.loc-expense-form,.loc-expense-panel>.loc-expense-add-btn{flex-shrink:0;margin-bottom:6px}.loc-expense-list,.note-panel-messages{min-height:0}.mobile-stop-detail{display:none}@media (max-width: 768px){body{overflow:hidden}.plan-detail-header{padding:8px 10px;gap:8px;min-height:54px;grid-template-columns:92px minmax(0,1fr) 44px}.back-btn{padding:7px 9px;font-size:12px}.plan-detail-title{width:100%;min-width:0}.plan-detail-title h2{font-size:15px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.plan-detail-meta{display:none}.plan-detail-actions{gap:4px}.plan-detail-actions .btn-outline-white{padding:7px 8px;font-size:0}.trip-settings-menu .btn-outline-white,.trip-settings-menu .export-btn,.trip-settings-menu button{padding:9px 10px;font-size:13px}.trip-settings-menu{right:0;width:200px}.plan-detail-body{flex-direction:column;min-height:0}.map-pane{flex:0 0 60%;min-height:0;order:1}.itinerary-pane{order:2;width:100%;flex:0 0 40%;min-height:40%;border-left:none;border-top:1px solid var(--border);box-shadow:0 -8px 24px #0000001f}.itinerary-top-tabs{height:34px;flex-shrink:0}.itinerary-top-tabs .tab{flex:1;justify-content:center;padding:7px 8px;font-size:12px}.itinerary-day-nav{height:38px}.day-tab{padding:6px 10px}.day-tab-num{font-size:11px}.day-tab-date{display:none}.itinerary-cards{padding:6px 8px 10px;gap:6px}.itinerary.mobile-has-selected .itinerary-day-nav,.itinerary.mobile-has-selected .itinerary-cards{display:none}.mobile-stop-detail{display:flex;flex-direction:column;flex:1;min-height:0;background:#fff}.mobile-stop-detail-header{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:8px 10px;border-bottom:1px solid var(--border);flex-shrink:0}.mobile-stop-detail-title-wrap{min-width:0;display:flex;flex-direction:column;gap:1px}.mobile-stop-detail-kicker{font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:0;line-height:1}.mobile-stop-detail-title{font-size:13px;font-weight:700;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mobile-stop-tabs{display:grid;grid-template-columns:1fr 1fr;gap:6px;padding:7px 8px;border-bottom:1px solid var(--border);flex-shrink:0}.mobile-stop-tab{border:1px solid var(--border);background:var(--bg-light);color:var(--text-secondary);border-radius:7px;padding:7px 8px;font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center;gap:5px}.mobile-stop-tab.active{background:var(--primary);border-color:var(--primary);color:#fff}.mobile-stop-detail-body{flex:1;min-height:0;overflow:hidden;display:flex;flex-direction:column}.mobile-stop-detail-body .note-panel,.mobile-stop-detail-body .loc-expense-panel{height:100%;min-height:0;border:none;border-radius:0}.itinerary-card{padding:7px 8px;gap:6px}.itinerary-card-name{font-size:12px}.itinerary-card-time .time-input{width:60px;font-size:12px}.travel-connector{display:none}.expenses-summary{padding:8px 10px}.expenses-total-amount{font-size:18px}.expenses-add-btn{margin:6px 8px;padding:7px 10px;font-size:12px}.expenses-list{padding:6px 8px}.expense-item{padding:7px 8px}.map-search-bar{top:8px;width:calc(100% - 20px);max-width:none;padding:0 10px}.map-search-input{font-size:13px;padding:10px 8px}.map-info-panel{left:10px!important;right:10px!important;top:54px!important;width:auto;max-height:calc(60vh - 68px);overflow-y:auto}.map-info-panel:after{display:none}.chat-popup{width:min(320px,calc(100% - 20px));top:auto;left:10px;right:auto;bottom:12px;max-height:min(280px,calc(60vh - 24px));z-index:45}.chat-popup-messages{height:160px}.chat-popup.minimized{width:52px;height:52px;border-radius:999px;left:14px;right:auto;bottom:14px;overflow:visible;box-shadow:0 10px 26px #00000038}.chat-popup.minimized .chat-popup-header{width:52px;height:52px;padding:0;border-radius:999px;justify-content:center;gap:0}.chat-popup.minimized .chat-popup-header>span,.chat-popup.minimized .chat-popup-controls{display:none}.chat-popup.minimized .chat-count{display:block;position:absolute;top:-3px;right:-3px;min-width:18px;height:18px;padding:2px 5px;background:#ef4444;border:2px solid white;line-height:12px;text-align:center}.loc-notes-popup{display:none!important}}.plan-detail-actions .trip-settings-menu button,.plan-detail-actions .trip-settings-menu .export-btn{display:flex!important;align-items:center!important;justify-content:flex-start!important;gap:8px!important;width:100%!important;padding:10px 12px!important;background:transparent!important;border:0!important;color:#1e1e2e!important;font-size:13px!important;font-weight:600!important;line-height:1.2!important;text-align:left!important}.plan-detail-actions .trip-settings-menu button svg,.plan-detail-actions .trip-settings-menu .export-btn svg{color:currentColor!important;flex-shrink:0!important}.plan-detail-actions .trip-settings-menu button:hover,.plan-detail-actions .trip-settings-menu .export-btn:hover{background:#f3f4f6!important}.plan-detail-actions .trip-settings-menu .danger{color:#dc2626!important}.public-view{display:flex;flex-direction:column;height:100vh;background:var(--bg)}.public-view-header{display:flex;align-items:center;gap:16px;padding:14px 24px;color:#fff;flex-shrink:0}.public-back-link{display:flex;align-items:center;gap:6px;color:#ffffffd9;font-size:13px;font-weight:600;text-decoration:none;flex-shrink:0;background:none;border:none;cursor:pointer}.public-back-link:hover{color:#fff}.public-view-header-center{flex:1;text-align:center}.public-badge{display:inline-flex;align-items:center;gap:4px;background:#fff3;border-radius:20px;padding:3px 10px;font-size:11px;font-weight:600;margin-bottom:4px}.public-view-header-center h1{font-size:20px;font-weight:800;margin:0}.public-view-meta{display:flex;justify-content:center;gap:12px;font-size:12px;opacity:.85;margin-top:4px;flex-wrap:wrap}.public-view-meta span{display:flex;align-items:center;gap:4px}.public-view-cta{flex-shrink:0}.btn-copy-trip{display:flex;align-items:center;gap:8px;padding:10px 18px;background:#fff;color:var(--primary);font-size:13px;font-weight:700;border:none;border-radius:8px;cursor:pointer;box-shadow:0 2px 8px #0000001f}.btn-copy-trip:hover{background:#f0f0ff}.btn-copy-trip:disabled{opacity:.6;cursor:default}.copy-done-msg{background:#fff3;color:#fff;padding:10px 18px;border-radius:8px;font-size:13px;font-weight:700}.public-view-body{display:flex;flex:1;min-height:0}.public-map-pane{flex:1;min-width:0}.public-itinerary-pane{width:360px;flex-shrink:0;display:flex;flex-direction:column;background:var(--surface);border-left:1px solid var(--border);overflow:hidden}.public-day-tabs{display:flex;gap:4px;padding:10px 12px;flex-wrap:wrap;border-bottom:1px solid var(--border);flex-shrink:0}.public-itinerary-cards{flex:1;overflow-y:auto;padding:10px 12px;display:flex;flex-direction:column;gap:8px}.public-itinerary-card{display:flex;align-items:flex-start;gap:10px;padding:10px 12px;background:var(--bg);border-radius:8px;border:1px solid var(--border)}.public-card-num{width:22px;height:22px;border-radius:50%;background:var(--primary);color:#fff;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.public-card-body{flex:1;min-width:0}.public-card-name{font-size:13px;font-weight:600;color:var(--text);margin:0 0 3px}.public-card-meta{display:flex;gap:10px;font-size:11px;color:var(--text-muted)}.public-readonly-notice{display:flex;align-items:center;gap:8px;flex-wrap:wrap;padding:10px 14px;border-top:1px solid var(--border);font-size:12px;color:var(--text-muted);flex-shrink:0}.public-copy-inline{background:none;border:none;color:var(--primary);font-size:12px;font-weight:600;cursor:pointer;padding:0;text-decoration:underline}.public-view-error,.public-view-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;gap:12px;color:var(--text-muted)}.public-view-loading .spinner{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width: 768px){.public-view-header{flex-wrap:wrap;padding:10px 14px;gap:8px}.public-view-header-center{order:3;width:100%;text-align:left}.public-view-header-center h1{font-size:16px}.public-view-body{flex-direction:column}.public-map-pane{height:55vw;flex:none}.public-itinerary-pane{width:100%;flex:1;border-left:none;border-top:1px solid var(--border)}}
