/* SmartRoute SRMIST — Clean & Beautiful UI */
:root {
  --bg-1:#0f1117;--bg-2:#161822;--bg-3:#1e2030;--bg-4:#252840;--bg-5:#2d3050;
  --text-1:#f0f2f8;--text-2:#b4b8cc;--text-3:#7a7f99;
  --primary:#667eea;--primary-glow:rgba(102,126,234,0.2);
  --accent:#8b5cf6;--accent-glow:rgba(139,92,246,0.2);
  --success:#10b981;--warning:#f59e0b;--danger:#ef4444;
  --radius:12px;--radius-sm:8px;--shadow:0 4px 24px rgba(0,0,0,0.3);
  --glass:rgba(30,32,48,0.85);--border:rgba(255,255,255,0.06);
  --gradient:linear-gradient(135deg,#667eea,#764ba2);
  --gradient-accent:linear-gradient(135deg,#8b5cf6,#ec4899);
}
[data-theme="light"] {
  --bg-1:#f8f9fc;--bg-2:#ffffff;--bg-3:#f1f3f7;--bg-4:#e5e7ec;--bg-5:#d1d5dc;
  --text-1:#111827;--text-2:#4b5563;--text-3:#9ca3af;
  --glass:rgba(255,255,255,0.92);--border:rgba(0,0,0,0.06);--shadow:0 4px 24px rgba(0,0,0,0.06);
}
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:'Inter',system-ui,sans-serif;background:var(--bg-1);color:var(--text-1);overflow-x:hidden;min-height:100vh}
a{color:var(--primary);text-decoration:none}
::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--bg-5);border-radius:3px}

/* Header */
.header{position:sticky;top:0;z-index:100;background:var(--glass);backdrop-filter:blur(20px);border-bottom:1px solid var(--border);padding:0 20px}
.header-inner{display:flex;align-items:center;justify-content:space-between;max-width:1800px;margin:0 auto;height:52px;gap:12px}
.logo{display:flex;align-items:center;gap:8px;font-weight:700;font-size:1.05rem;white-space:nowrap}
.logo-icon{font-size:1.4rem}
.badge{background:var(--gradient);color:#fff;font-size:0.6rem;padding:2px 7px;border-radius:10px;font-weight:600}
.header-nav{display:flex;gap:2px}
.nav-tab{background:none;border:none;color:var(--text-3);padding:7px 14px;border-radius:var(--radius-sm);cursor:pointer;font-size:0.82rem;font-weight:500;transition:all 0.2s;display:flex;align-items:center;gap:5px}
.nav-tab:hover{background:var(--bg-4);color:var(--text-1)}
.nav-tab.active{background:var(--primary-glow);color:var(--primary);font-weight:600}
.header-actions{display:flex;align-items:center;gap:4px}
.hide-mobile{display:inline}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:5px;padding:7px 12px;border-radius:var(--radius-sm);font-size:0.8rem;font-weight:500;cursor:pointer;border:none;transition:all 0.2s;background:var(--bg-4);color:var(--text-2)}
.btn:hover{transform:translateY(-1px);filter:brightness(1.1)}
.btn-primary{background:var(--gradient);color:#fff}
.btn-accent{background:var(--gradient-accent);color:#fff}
.btn-sm{padding:5px 9px;font-size:0.75rem}
.btn-outline{background:transparent;border:1px solid var(--border);color:var(--text-2);flex:1;justify-content:center}
.btn-outline:hover{border-color:var(--primary);color:var(--primary)}
.btn-icon{width:34px;height:34px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;background:var(--bg-4);color:var(--text-2);border:none;cursor:pointer;transition:all 0.2s;font-size:0.85rem;flex-shrink:0}
.btn-icon:hover{background:var(--bg-5);color:var(--text-1)}
.btn-icon-sm{width:30px;height:30px;font-size:0.8rem}
.btn-generate{width:100%;justify-content:center;margin-top:8px;padding:10px;font-size:0.88rem;font-weight:600}
.btn-train{background:rgba(6,182,212,0.15);color:#06b6d4}.btn-hotel{background:rgba(16,185,129,0.15);color:#10b981}
.btn-cab{background:rgba(245,158,11,0.15);color:#f59e0b}.btn-skip{background:rgba(139,92,246,0.15);color:#8b5cf6}
.btn-edit{background:rgba(245,158,11,0.15);color:#f59e0b}
.quick-actions{display:flex;gap:6px;margin-top:6px}
.backend-status{font-size:0.68rem;text-align:center;margin-top:4px;color:var(--text-3)}

/* Layout */
.app-layout{display:grid;grid-template-columns:290px 1fr 270px;gap:14px;padding:14px 20px;max-width:1800px;margin:0 auto}
.left-sidebar,.right-sidebar{display:flex;flex-direction:column;gap:10px;max-height:calc(100vh - 72px);overflow-y:auto;padding-right:2px}
.center-content{display:flex;flex-direction:column;gap:14px;min-width:0}

/* Panels */
.panel{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius);padding:12px;transition:all 0.2s}
.panel:hover{border-color:rgba(102,126,234,0.12)}
.panel-title{font-size:0.82rem;font-weight:700;margin-bottom:8px;display:flex;align-items:center;gap:6px;color:var(--text-1)}
.collapsible .panel-title{cursor:pointer;user-select:none}
.collapsible .panel-body{transition:all 0.3s ease;overflow:hidden;max-height:800px}
.collapsible.collapsed .panel-body{max-height:0;margin:0;padding:0;opacity:0}
.collapsible .collapse-icon{margin-left:auto;font-size:0.7rem;transition:transform 0.3s}
.collapsible.collapsed .collapse-icon{transform:rotate(-90deg)}
.collapsible.collapsed .panel-title{margin-bottom:0}

/* Forms */
.form-group{margin-bottom:7px}
.form-label{font-size:0.72rem;font-weight:600;color:var(--text-2);margin-bottom:3px;display:flex;align-items:center;gap:4px}
.form-input{width:100%;padding:7px 10px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-3);color:var(--text-1);font-size:0.82rem;outline:none;transition:border-color 0.2s}
.form-input:focus{border-color:var(--primary)}
.form-row{display:flex;gap:8px}
.form-row>.form-group{flex:1}
.checkbox-row{display:flex;flex-wrap:wrap;gap:6px;margin-top:4px}
.checkbox-label{font-size:0.75rem;color:var(--text-2);display:flex;align-items:center;gap:3px;cursor:pointer}

/* Persona */
.persona-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:5px}
.persona-card{text-align:center;padding:8px 4px;border-radius:var(--radius-sm);background:var(--bg-3);cursor:pointer;transition:all 0.2s;font-size:0.72rem;font-weight:500;border:1px solid transparent}
.persona-card:hover{background:var(--bg-4)}
.persona-card.active{background:var(--primary-glow);border-color:var(--primary);color:var(--primary)}
.persona-card .emoji{font-size:1.3rem;display:block;margin-bottom:2px}

/* Map */
.map-container{position:relative;height:380px;border-radius:var(--radius);overflow:hidden;border:1px solid var(--border);background:#f2f3f5}
[data-theme="dark"] .map-container{background:#1a1c2e}
#map{height:100%;width:100%;z-index:1}
.leaflet-container{background:#f2f3f5 !important;font-family:'Inter',system-ui,sans-serif}
[data-theme="dark"] #map,.leaflet-container{background:#f2f3f5 !important}
[data-theme="dark"] .leaflet-container{background:#1a1c2e !important}
.leaflet-tile-pane{opacity:1 !important}.leaflet-tile{visibility:visible !important}
.map-controls{position:absolute;top:10px;right:10px;z-index:10;display:flex;flex-direction:column;gap:4px}
.map-controls button{width:30px;height:30px;border-radius:6px;background:var(--glass);backdrop-filter:blur(10px);border:1px solid var(--border);color:var(--text-1);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:0.75rem}

/* === HERO EMPTY STATE === */
.hero-empty-state{text-align:center;padding:0}
.hero-image-grid{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:160px 120px;gap:8px;border-radius:var(--radius);overflow:hidden}
.hero-img-card{position:relative;overflow:hidden;border-radius:var(--radius-sm)}
.hero-img-card.hero-img-large{grid-row:1/3;grid-column:1/2}
.hero-img-card img{width:100%;height:100%;object-fit:cover;transition:transform 0.4s}
.hero-img-card:hover img{transform:scale(1.05)}
.hero-img-overlay{position:absolute;bottom:0;left:0;right:0;padding:8px 12px;background:linear-gradient(transparent,rgba(0,0,0,0.7))}
.hero-img-label{color:#fff;font-size:0.8rem;font-weight:600}
.hero-text{margin-top:16px}
.hero-text h2{font-size:1.6rem;font-weight:800;background:var(--gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.hero-text p{font-size:0.88rem;color:var(--text-3);margin-top:4px}

/* Budget */
.budget-display{display:flex;align-items:baseline;gap:4px;margin-bottom:4px}
.budget-amount{font-size:1.3rem;font-weight:800;background:var(--gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.budget-total{font-size:0.82rem;color:var(--text-3)}
.progress-bar{height:5px;background:var(--bg-4);border-radius:3px;overflow:hidden;margin-bottom:6px}
.progress-fill{height:100%;background:var(--gradient);border-radius:3px;transition:width 0.5s ease}
.budget-cats{display:flex;flex-direction:column;gap:3px}
.budget-cat{display:flex;justify-content:space-between;font-size:0.75rem;color:var(--text-2);padding:1px 0}

/* Weather */
.weather-grid{display:flex;gap:6px;overflow-x:auto;padding-bottom:2px}
.weather-card{min-width:60px;text-align:center;padding:6px;border-radius:var(--radius-sm);background:var(--bg-3)}
.weather-icon{font-size:1.3rem}.weather-temp{font-weight:700;font-size:0.85rem}

/* Crowd */
.crowd-bar{display:flex;gap:3px;height:7px}
.crowd-segment{flex:1;border-radius:4px;background:var(--bg-4);transition:background 0.3s}

/* Agent Cards — autonomous AI feel */
.agent-card{display:flex;align-items:center;gap:8px;padding:7px 8px;border-radius:var(--radius-sm);background:var(--bg-3);margin-bottom:4px;border-left:3px solid transparent;transition:all 0.3s;position:relative;overflow:hidden}
.agent-card::after{content:'';position:absolute;left:-100%;top:0;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(96,165,250,0.18),transparent);transition:left 0.6s}
.agent-card.working{border-left-color:var(--warning);animation:agentPulse 1.2s infinite}
.agent-card.thinking{border-left-color:#60a5fa;background:linear-gradient(90deg,var(--bg-3),rgba(59,130,246,0.07))}
.agent-card.thinking::after{animation:agentScan 1.4s infinite}
.agent-card.completed{border-left-color:var(--success);background:linear-gradient(90deg,var(--bg-3),rgba(34,197,94,0.05))}
.agent-icon{font-size:1.15rem;width:28px;text-align:center;filter:drop-shadow(0 0 4px rgba(96,165,250,0.25))}
.agent-card.working .agent-icon{animation:agentBob 0.8s infinite}
.agent-info{flex:1;min-width:0}
.agent-name{font-size:0.76rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.agent-role{font-size:0.68rem;color:var(--text-3)}
.agent-status{width:8px;height:8px;border-radius:50%;background:var(--text-3);box-shadow:0 0 0 0 rgba(0,0,0,0)}
.agent-status.working{background:var(--warning);animation:pulse 0.9s infinite;box-shadow:0 0 8px var(--warning)}
.agent-status.thinking{background:#60a5fa;animation:pulse 1.1s infinite;box-shadow:0 0 10px #60a5fa}
.agent-status.completed{background:var(--success);box-shadow:0 0 6px var(--success)}
@keyframes agentPulse{0%,100%{opacity:1}50%{opacity:0.78}}
@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.4)}}
@keyframes agentScan{0%{left:-100%}100%{left:100%}}
@keyframes agentBob{0%,100%{transform:translateY(0)}50%{transform:translateY(-2px)}}

/* Activity Log */
.activity-log{max-height:180px;overflow-y:auto}
.log-entry{font-size:0.72rem;padding:3px 4px;border-bottom:1px solid var(--border);color:var(--text-2)}
.log-time{color:var(--text-3);font-size:0.65rem}

/* Itinerary */
.itin-section{margin-bottom:14px}
.section-title{font-size:0.95rem;font-weight:700;margin-bottom:10px;display:flex;align-items:center;gap:6px}
.day-card{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:10px;overflow:hidden}
.day-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:var(--bg-3);cursor:pointer}
.day-title{font-weight:700;font-size:0.9rem;display:flex;align-items:center;gap:6px}
.day-meta{font-size:0.75rem;color:var(--text-3);display:flex;gap:10px}
.day-body{padding:10px 14px}

/* Activity Cards */
.activity-card{display:flex;gap:10px;padding:10px;border-radius:var(--radius-sm);background:var(--bg-3);margin-bottom:6px;border:1px solid var(--border);transition:all 0.2s;position:relative}
.activity-card:hover{border-color:rgba(102,126,234,0.2);transform:translateX(2px)}
.activity-photo{width:72px;height:72px;border-radius:var(--radius-sm);object-fit:cover;background:var(--bg-4);flex-shrink:0}
.activity-info{flex:1;min-width:0}
.activity-name{font-weight:600;font-size:0.85rem;margin-bottom:2px;cursor:pointer}
.activity-name:hover{color:var(--primary)}
.activity-desc{font-size:0.75rem;color:var(--text-2);margin-bottom:3px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.activity-tags{display:flex;flex-wrap:wrap;gap:3px;margin-top:3px}
.activity-rating{position:absolute;top:6px;right:6px}
.activity-rating select{background:var(--bg-4);border:1px solid var(--border);border-radius:4px;color:var(--text-1);font-size:0.72rem;padding:2px}

/* Tags */
.tag{display:inline-flex;align-items:center;gap:2px;padding:2px 7px;border-radius:10px;font-size:0.68rem;font-weight:500;white-space:nowrap}
.tag-time{background:rgba(102,126,234,0.15);color:var(--primary)}
.tag-cost{background:rgba(16,185,129,0.15);color:var(--success)}
.tag-type{background:rgba(139,92,246,0.15);color:var(--accent)}
.tag-crowd{background:rgba(245,158,11,0.15);color:var(--warning)}
.tag-weather{background:rgba(239,68,68,0.15);color:var(--danger)}
.tag-info{background:rgba(102,126,234,0.15);color:var(--primary)}
.tag-warning{background:rgba(245,158,11,0.15);color:var(--warning)}
.tag-danger{background:rgba(239,68,68,0.15);color:var(--danger)}
.tag-success{background:rgba(16,185,129,0.15);color:var(--success)}

/* Empty State */
.empty-state{text-align:center;padding:20px 16px;color:var(--text-3)}
.empty-state p{font-size:0.82rem}

/* Booking Wizard */
.agentic-wizard{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius);padding:14px;margin-bottom:14px}
.wizard-progress{display:flex;align-items:center;gap:0;margin-bottom:14px;overflow-x:auto}
.wizard-step{display:flex;flex-direction:column;align-items:center;gap:2px;min-width:45px;font-size:0.65rem;color:var(--text-3);transition:all 0.3s}
.wizard-step.completed{color:var(--success)}.wizard-step.active{color:var(--primary)}
.step-icon{font-size:1.1rem}.step-label{white-space:nowrap}
.wizard-connector{flex:1;height:2px;background:var(--bg-4);min-width:8px}
.agent-prompt-banner{display:flex;align-items:center;gap:10px;padding:10px;background:var(--bg-3);border-radius:var(--radius-sm);margin-bottom:10px}
.agent-prompt-avatar{font-size:1.8rem}
.agent-prompt-text{flex:1;font-size:0.82rem;color:var(--text-2)}
.agent-prompt-actions{display:flex;flex-wrap:wrap;gap:5px}
.booking-results-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:8px;margin-top:8px}
.booking-card{background:var(--bg-3);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px;cursor:pointer;transition:all 0.2s}
.booking-card:hover{border-color:var(--primary);transform:translateY(-2px)}
.booking-card.selected{border-color:var(--success);box-shadow:0 0 0 2px rgba(16,185,129,0.3)}
.booking-card-title{font-weight:600;font-size:0.85rem;margin-bottom:3px}
.booking-card-price{font-size:1rem;font-weight:700;color:var(--success)}
.booking-card-meta{font-size:0.72rem;color:var(--text-3);margin-top:3px}

/* Payment */
.payment-methods{display:flex;gap:6px;margin-bottom:10px}
.payment-method{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;padding:10px;border-radius:var(--radius-sm);background:var(--bg-3);border:1px solid var(--border);cursor:pointer;transition:all 0.2s;font-size:0.75rem;color:var(--text-2)}
.payment-method:hover{border-color:var(--primary)}.payment-method.active{border-color:var(--primary);background:var(--primary-glow);color:var(--primary)}
.payment-method i{font-size:1.2rem}
.cart-total{font-size:1.1rem;font-weight:700;text-align:center;padding:8px;background:var(--bg-3);border-radius:var(--radius-sm);margin-top:6px}
.cart-summary{display:flex;flex-direction:column;gap:5px}
.cart-item{display:flex;justify-content:space-between;padding:7px;background:var(--bg-3);border-radius:var(--radius-sm);font-size:0.82rem}
.confirmation-hero{text-align:center;padding:24px}
.confirmation-hero h2{font-size:1.3rem;margin:10px 0 4px}

/* Discovery */
.discovery-tabs{display:flex;gap:4px;margin-bottom:10px}
.disc-tab{padding:6px 14px;border-radius:var(--radius-sm);border:none;background:var(--bg-3);color:var(--text-3);cursor:pointer;font-size:0.8rem;font-weight:500;transition:all 0.2s}
.disc-tab.active{background:var(--primary-glow);color:var(--primary)}
.disc-content{display:none}.disc-content.active{display:block}
.discovery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:8px}
.discovery-card{background:var(--bg-3);border-radius:var(--radius-sm);overflow:hidden;border:1px solid var(--border);transition:all 0.2s}
.discovery-card:hover{transform:translateY(-2px);border-color:var(--primary)}
.discovery-card img{width:100%;height:110px;object-fit:cover}
.discovery-card-body{padding:7px}
.discovery-card-title{font-weight:600;font-size:0.82rem}
.discovery-card-meta{font-size:0.7rem;color:var(--text-3);margin-top:2px}

/* Language */
.lang-section{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius);padding:14px}
.lang-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:6px}
.lang-card{background:var(--bg-3);border-radius:var(--radius-sm);padding:8px;text-align:center;border:1px solid var(--border)}
.lang-phrase{font-size:0.95rem;font-weight:700;color:var(--primary)}
.lang-meaning{font-size:0.75rem;color:var(--text-2);margin-top:2px}
.lang-pronunciation{font-size:0.7rem;color:var(--text-3);font-style:italic}

/* Bottom Panels */
.bottom-panels{display:grid;grid-template-columns:1fr 1fr;gap:14px;padding:0 20px 20px;max-width:1800px;margin:0 auto}
.bottom-panel{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius);padding:14px}
#agentGraphCanvas{width:100%;height:180px}
.mdp-flow,.pomdp-flow{display:flex;align-items:center;gap:4px;flex-wrap:wrap;margin-bottom:6px}
.mdp-node{padding:5px 8px;border-radius:var(--radius-sm);font-size:0.72rem;font-weight:600;border:1px solid;text-align:center}
.pomdp-step{padding:5px 8px;border-radius:var(--radius-sm);font-size:0.72rem;font-weight:600;text-align:center}
.mdp-arrow{color:var(--text-3);font-weight:700;font-size:0.75rem}
.divider{height:1px;background:var(--border);margin:8px 0}

/* Modals */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.6);backdrop-filter:blur(4px);z-index:200;display:none;align-items:center;justify-content:center;padding:20px}
.modal-overlay.active{display:flex}
.modal-content{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius);width:100%;max-height:90vh;overflow-y:auto}
.modal-header{display:flex;align-items:center;justify-content:space-between;padding:14px;border-bottom:1px solid var(--border)}
.modal-header h3{font-size:1rem;display:flex;align-items:center;gap:6px}
.modal-body{padding:14px}
.media-modal{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius);max-width:650px;width:100%;max-height:90vh;overflow-y:auto}
.media-modal-header{display:flex;align-items:center;justify-content:space-between;padding:14px;border-bottom:1px solid var(--border)}
.media-modal-body{padding:14px}
.media-section{margin-bottom:12px}
.photo-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:6px}
.photo-gallery img{width:100%;height:100px;object-fit:cover;border-radius:var(--radius-sm)}
.media-links a{display:block;padding:5px 0;font-size:0.82rem;color:var(--primary);border-bottom:1px solid var(--border)}
.modal-quick-info{font-size:0.82rem;color:var(--text-2);line-height:1.5}

/* Pref Chips */
.pref-chips{display:flex;flex-wrap:wrap;gap:6px;margin-top:4px}
.pref-chip{display:flex;align-items:center;gap:3px;padding:5px 10px;border-radius:16px;background:var(--bg-3);border:1px solid var(--border);cursor:pointer;font-size:0.78rem;transition:all 0.2s}
.pref-chip:has(input:checked){background:var(--primary-glow);border-color:var(--primary);color:var(--primary)}
.pref-chip input{width:0;height:0;opacity:0;position:absolute}

/* Rec Cards */
.rec-card{background:var(--bg-3);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px;margin-bottom:6px;cursor:pointer;transition:all 0.2s}
.rec-card:hover{border-color:var(--primary);transform:translateX(2px)}
.rec-name{font-weight:700;font-size:0.95rem}.rec-state{font-size:0.75rem;color:var(--text-3)}
.rec-tags{display:flex;flex-wrap:wrap;gap:3px;margin-top:3px}
.rec-highlights{font-size:0.75rem;color:var(--text-2);margin-top:3px}
.rec-match{font-size:0.72rem;font-weight:600;color:var(--success);float:right}
.rec-cost{font-size:0.82rem;font-weight:600;color:var(--primary)}

/* === AUTONOMOUS AGENT LOADING SCREEN === */
.loading-overlay{position:fixed;inset:0;background:radial-gradient(ellipse at center,rgba(13,17,40,0.95) 0%,rgba(0,0,0,0.96) 70%);backdrop-filter:blur(14px);z-index:300;display:none;align-items:center;justify-content:center;flex-direction:column}
.loading-overlay.active{display:flex}
.loading-content{text-align:center;max-width:560px;width:92%}

/* Agentic loader (replaces image carousel) */
.agentic-loader{padding:24px}
.agentic-header{display:flex;align-items:center;gap:18px;margin-bottom:22px;text-align:left}
.agentic-brain{position:relative;width:72px;height:72px;flex-shrink:0}
.brain-core{position:absolute;inset:24px;border-radius:50%;background:radial-gradient(circle,#60a5fa 0%,#3b82f6 60%,#1e40af 100%);box-shadow:0 0 30px rgba(96,165,250,0.6),inset 0 0 12px rgba(255,255,255,0.4);animation:brainPulse 1.4s ease-in-out infinite}
.brain-ring{position:absolute;inset:0;border:2px solid transparent;border-top-color:#60a5fa;border-right-color:rgba(96,165,250,0.4);border-radius:50%;animation:brainSpin 2.4s linear infinite}
.brain-ring.r1{inset:0;animation-duration:2.4s}
.brain-ring.r2{inset:8px;border-top-color:#a78bfa;border-right-color:rgba(167,139,250,0.4);animation-duration:1.8s;animation-direction:reverse}
.brain-ring.r3{inset:16px;border-top-color:#22d3ee;border-right-color:rgba(34,211,238,0.4);animation-duration:1.4s}
@keyframes brainPulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.12);opacity:0.85}}
@keyframes brainSpin{from{transform:rotate(0)}to{transform:rotate(360deg)}}

.agentic-title h2{margin:0 0 4px;font-size:1.2rem;font-weight:700;color:#fff;background:linear-gradient(90deg,#60a5fa,#a78bfa,#22d3ee);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.agentic-subtitle{font-size:0.78rem;color:rgba(255,255,255,0.65);display:flex;align-items:center;gap:6px}
.status-dot{width:8px;height:8px;border-radius:50%;background:#22c55e;display:inline-block}
.status-dot.live{box-shadow:0 0 8px #22c55e;animation:pulse 0.9s infinite}

.agentic-pipeline{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:18px;justify-content:center}
.agent-pill{display:inline-flex;align-items:center;gap:5px;padding:6px 11px;border-radius:999px;background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.12);font-size:0.78rem;color:rgba(255,255,255,0.85);transition:all 0.35s;backdrop-filter:blur(6px);position:relative;overflow:hidden}
.agent-pill::before{content:'';position:absolute;left:-60%;top:0;width:60%;height:100%;background:linear-gradient(90deg,transparent,rgba(96,165,250,0.25),transparent);transition:none}
.agent-pill .pill-icon{font-size:0.95rem}
.agent-pill .pill-state{font-size:0.7rem;opacity:0.6}
.agent-pill.working{background:rgba(245,158,11,0.18);border-color:rgba(245,158,11,0.5);color:#fde68a}
.agent-pill.working::before{animation:pillScan 1.2s infinite}
.agent-pill.thinking{background:rgba(59,130,246,0.2);border-color:rgba(96,165,250,0.55);color:#bfdbfe}
.agent-pill.thinking::before{animation:pillScan 0.9s infinite}
.agent-pill.completed{background:rgba(34,197,94,0.18);border-color:rgba(34,197,94,0.55);color:#bbf7d0}
.agent-pill.completed .pill-state::after{content:'✓';font-weight:bold;color:#22c55e}
@keyframes pillScan{0%{left:-60%}100%{left:120%}}

.loading-progress-bar{height:6px;background:rgba(255,255,255,0.08);border-radius:3px;overflow:hidden;margin-bottom:14px;position:relative}
.loading-progress-fill{height:100%;background:linear-gradient(90deg,#60a5fa,#a78bfa,#22d3ee);border-radius:3px;width:0%;transition:width 0.5s ease;box-shadow:0 0 12px rgba(96,165,250,0.5)}
.loading-text{font-size:1.05rem;font-weight:600;color:#fff;margin-bottom:6px}
.loading-step{font-size:0.78rem;color:rgba(255,255,255,0.55);min-height:20px;font-family:'Courier New',monospace;letter-spacing:0.3px}

.agentic-stats{display:flex;justify-content:space-around;margin-top:20px;padding-top:18px;border-top:1px solid rgba(255,255,255,0.08)}
.agentic-stats > div{display:flex;flex-direction:column;align-items:center;gap:2px}
.stat-num{font-size:1.4rem;font-weight:700;color:#60a5fa;font-variant-numeric:tabular-nums;text-shadow:0 0 8px rgba(96,165,250,0.4)}
.stat-lbl{font-size:0.68rem;color:rgba(255,255,255,0.55);text-transform:uppercase;letter-spacing:0.5px}

/* Destination photo carousel inside agentic loader (mixed in from previous version) */
.loading-image-carousel{position:relative;width:100%;height:170px;border-radius:14px;overflow:hidden;margin-bottom:20px;box-shadow:0 8px 40px rgba(0,0,0,0.45),0 0 0 1px rgba(255,255,255,0.06)}
.loading-image-carousel .loading-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity 0.9s ease-in-out;transform:scale(1.04);animation:imgKenBurns 8s ease-in-out infinite alternate}
.loading-image-carousel .loading-img.active{opacity:1}
.loading-image-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(13,17,40,0) 50%,rgba(13,17,40,0.55) 100%);pointer-events:none}
@keyframes imgKenBurns{from{transform:scale(1.04)}to{transform:scale(1.12)}}

/* Chatbot */
.chatbot-toggle{position:fixed;bottom:20px;right:20px;width:50px;height:50px;border-radius:50%;background:var(--gradient);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.2rem;cursor:pointer;z-index:150;box-shadow:0 4px 16px rgba(102,126,234,0.4);transition:all 0.3s}
.chatbot-toggle:hover{transform:scale(1.1)}
.chatbot-window{position:fixed;bottom:80px;right:20px;width:360px;max-height:480px;background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius);z-index:150;display:none;flex-direction:column;box-shadow:var(--shadow)}
.chatbot-window.open{display:flex}
.chatbot-header{display:flex;align-items:center;justify-content:space-between;padding:10px;border-bottom:1px solid var(--border)}
.chatbot-header-info{display:flex;align-items:center;gap:8px}
.chatbot-avatar{font-size:1.3rem}
.chatbot-name{font-weight:600;font-size:0.85rem}.chatbot-status{font-size:0.7rem;color:var(--success)}
.chatbot-messages{flex:1;overflow-y:auto;padding:10px;max-height:280px}
.chat-msg{display:flex;gap:6px;margin-bottom:8px}
.chat-msg.bot .chat-msg-avatar{font-size:1rem}
.chat-msg.user{flex-direction:row-reverse}
.chat-msg-bubble{max-width:80%;padding:7px 10px;border-radius:10px;font-size:0.8rem;line-height:1.4;background:var(--bg-3)}
.chat-msg.user .chat-msg-bubble{background:var(--primary);color:#fff}
.chatbot-suggestions{display:flex;flex-wrap:wrap;gap:3px;padding:6px 10px;border-top:1px solid var(--border)}
.chatbot-suggestions button{padding:3px 8px;border-radius:10px;border:1px solid var(--border);background:var(--bg-3);color:var(--text-2);font-size:0.7rem;cursor:pointer;transition:all 0.2s}
.chatbot-suggestions button:hover{background:var(--primary-glow);color:var(--primary)}
.chatbot-input{display:flex;gap:5px;padding:8px 10px;border-top:1px solid var(--border)}
.chatbot-input input{flex:1;padding:7px 10px;border-radius:16px;border:1px solid var(--border);background:var(--bg-3);color:var(--text-1);font-size:0.82rem;outline:none}
.chatbot-input button{width:34px;height:34px;border-radius:50%;background:var(--gradient);color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center}
.chat-welcome{text-align:center;padding:16px 10px;color:var(--text-3)}
.chat-welcome-icon{font-size:1.8rem;margin-bottom:6px}
.chat-welcome-title{font-weight:600;font-size:0.85rem;color:var(--text-1);margin-bottom:3px}
.chat-welcome-text{font-size:0.75rem;line-height:1.4}

/* History */
.history-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.5);z-index:180;display:none}
.history-overlay.open{display:block}
.history-sidebar{position:fixed;top:0;right:-380px;width:360px;height:100vh;background:var(--bg-2);border-left:1px solid var(--border);z-index:190;transition:right 0.3s;display:flex;flex-direction:column}
.history-sidebar.open{right:0}
.history-header{display:flex;align-items:center;justify-content:space-between;padding:14px;border-bottom:1px solid var(--border)}
.history-stats{display:flex;gap:14px;padding:10px 14px;background:var(--bg-3)}
.history-stat{text-align:center;flex:1}
.stat-value{font-size:1.1rem;font-weight:700;display:block;background:var(--gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.stat-label{font-size:0.7rem;color:var(--text-3)}
.history-list{flex:1;overflow-y:auto;padding:10px}
.history-item{padding:8px;background:var(--bg-3);border-radius:var(--radius-sm);margin-bottom:6px;font-size:0.8rem}

/* Toast */
.toast-container{position:fixed;bottom:20px;left:50%;transform:translateX(-50%);z-index:300;display:flex;flex-direction:column;gap:6px}
.toast{padding:10px 16px;border-radius:var(--radius-sm);font-size:0.82rem;font-weight:500;color:#fff;animation:toastIn 0.3s ease;min-width:220px;text-align:center}
.toast-success{background:#10b981}.toast-error{background:#ef4444}.toast-info{background:#667eea}.toast-warning{background:#f59e0b}
@keyframes toastIn{from{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}

/* Atlas */
.atlas-view{padding:20px;max-width:1200px;margin:0 auto}
.atlas-container{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius);padding:20px}
.atlas-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;flex-wrap:wrap;gap:10px}
.atlas-header h2{font-size:1.2rem;display:flex;align-items:center;gap:6px}
.atlas-stats{display:flex;gap:12px}
.atlas-stat{text-align:center;padding:6px 14px;background:var(--bg-3);border-radius:var(--radius-sm)}
[data-theme="dark"] #atlasMap{background:#1a1c2e !important}

/* Dashboard Hero */
.dashboard-hero{position:relative;border-radius:var(--radius);overflow:hidden;margin-bottom:16px;height:160px}
.dashboard-hero-img{width:100%;height:100%;object-fit:cover}
.dashboard-hero-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(102,126,234,0.8),rgba(139,92,246,0.7));display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff}
.dashboard-hero-overlay h2{font-size:1.4rem;font-weight:800}
.dashboard-hero-overlay p{font-size:0.85rem;opacity:0.9}

/* Dashboard */
.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px}
.dash-card{background:var(--bg-3);border:1px solid var(--border);border-radius:var(--radius);padding:14px;text-align:center;transition:all 0.2s}
.dash-card:hover{border-color:var(--primary);transform:translateY(-2px)}
.dash-icon{font-size:1.5rem;margin-bottom:4px}
.dash-value{font-size:1.3rem;font-weight:800;background:var(--gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.dash-label{font-size:0.72rem;color:var(--text-3);margin-top:2px}

/* Packing */
.packing-view{padding:20px;max-width:1000px;margin:0 auto}
.packing-container{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius);padding:20px}
.packing-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;flex-wrap:wrap;gap:10px}
.packing-header h2{font-size:1.2rem;display:flex;align-items:center;gap:6px}
.packing-progress{display:flex;align-items:center;gap:6px}
.packing-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:10px}
.packing-category{background:var(--bg-3);border-radius:var(--radius-sm);padding:12px;border:1px solid var(--border)}
.packing-category-title{font-weight:700;font-size:0.85rem;margin-bottom:6px;display:flex;align-items:center;gap:5px}
.packing-item{display:flex;align-items:center;gap:6px;padding:3px 0;font-size:0.8rem;color:var(--text-2)}
.packing-item input[type="checkbox"]{accent-color:var(--primary)}
.packing-item.checked{text-decoration:line-through;opacity:0.5}

/* Timezone & Currency */
.timezone-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px}
.tz-card{text-align:center;padding:6px;background:var(--bg-3);border-radius:var(--radius-sm)}
.tz-city{font-size:0.7rem;color:var(--text-3)}.tz-time{font-size:1rem;font-weight:700;color:var(--primary)}

/* Chart */
.chart-container{position:relative;height:140px}

/* Agent Convo */
.agent-convo-panel{max-height:250px;overflow-y:auto}
.agent-convo{display:flex;flex-direction:column;gap:4px}
.convo-msg{display:flex;align-items:flex-start;gap:6px;padding:5px 7px;border-radius:var(--radius-sm);background:var(--bg-3);font-size:0.75rem;animation:fadeIn 0.3s}
.convo-icon{font-size:1rem;min-width:20px;text-align:center}
.convo-text{flex:1;color:var(--text-2)}.convo-text strong{color:var(--text-1)}
@keyframes fadeIn{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}

/* Emergency */
.emg-row{display:flex;justify-content:space-between;align-items:center;padding:4px 0;border-bottom:1px solid var(--border);font-size:0.78rem}
.emg-num{color:var(--primary);font-weight:700;font-size:0.82rem}

/* Journal */
.journal-entries{display:flex;flex-direction:column;gap:4px}
.journal-entry-card{position:relative;padding:6px;background:var(--bg-3);border-radius:var(--radius-sm);border:1px solid var(--border);font-size:0.8rem}

/* Multi-City */
.mc-city-row{display:flex;gap:6px;align-items:center;margin-bottom:6px}

/* Utility */
.text-xs{font-size:0.72rem}.text-sm{font-size:0.82rem}.text-muted{color:var(--text-3)}.text-center{text-align:center}
.fw-600{font-weight:600}.fw-700{font-weight:700}
.mt-1{margin-top:4px}.mb-1{margin-bottom:4px}
.flex-between{display:flex;justify-content:space-between;align-items:center}

/* Smart Automations */
.auto-actions{display:grid;grid-template-columns:1fr 1fr;gap:4px}
.auto-btn{justify-content:flex-start;font-size:0.72rem;padding:7px 8px;background:var(--bg-3);border:1px solid var(--border)}
.auto-btn:hover{background:var(--primary-glow);border-color:var(--primary);color:var(--primary)}
.auto-result{margin-top:8px;padding:8px;background:var(--bg-3);border-radius:var(--radius-sm);font-size:0.8rem;color:var(--text-2);border-left:3px solid var(--success);max-height:180px;overflow-y:auto}

/* Readiness */
.readiness-score{display:flex;align-items:center;gap:12px}
.readiness-ring{width:65px;height:65px;flex-shrink:0}
.readiness-svg{width:100%;height:100%}
.readiness-bg{fill:none;stroke:var(--bg-4);stroke-width:3}
.readiness-fill{fill:none;stroke:var(--primary);stroke-width:3;stroke-linecap:round;transition:stroke-dasharray 0.5s ease}
.readiness-text{fill:var(--text-1);font-size:8px;font-weight:800;text-anchor:middle}
.readiness-items{flex:1;display:flex;flex-direction:column;gap:3px}
.readiness-item{font-size:0.72rem;color:var(--text-3);display:flex;align-items:center;gap:5px}
.readiness-item[data-ready="true"]{color:var(--success);text-decoration:line-through}
.readiness-item[data-ready="true"] i{color:var(--success)}

/* Smart Suggestions */
.smart-suggestions-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:6px}

/* Trip Countdown */
.trip-countdown-panel{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius);padding:14px}
.countdown-box{text-align:center;padding:8px 18px;background:var(--gradient);border-radius:var(--radius-sm);color:#fff}
.countdown-value{font-size:1.6rem;font-weight:900;line-height:1}
.countdown-label{font-size:0.68rem;opacity:0.8}
.trip-quick-stats{display:flex;gap:10px;flex-wrap:wrap}
.trip-stat-mini{font-size:0.75rem;color:var(--text-2);display:flex;align-items:center;gap:3px}
.trip-stat-mini strong{color:var(--text-1)}
.trip-actions-mini{display:flex;gap:5px;flex-wrap:wrap}

@keyframes wizardPulse{0%{box-shadow:0 0 0 0 rgba(102,126,234,0.4)}50%{box-shadow:0 0 0 10px rgba(102,126,234,0)}100%{box-shadow:0 0 0 0 rgba(102,126,234,0)}}

/* Responsive */
@media(max-width:1200px){.app-layout{grid-template-columns:260px 1fr 240px}}
@media(max-width:992px){
  .app-layout{grid-template-columns:1fr;max-width:800px}
  .left-sidebar,.right-sidebar{max-height:none;flex-direction:row;flex-wrap:wrap;overflow:visible}
  .left-sidebar .panel,.right-sidebar .panel{flex:1;min-width:240px}
  .bottom-panels{grid-template-columns:1fr}
  .hide-mobile{display:none}
  .header-nav{display:none}
  .hero-image-grid{grid-template-rows:140px 100px}
}
@media(max-width:600px){
  .header-inner{height:44px}
  .logo span:not(.badge){display:none}
  .chatbot-window{width:calc(100vw - 28px);right:14px;bottom:76px}
  .persona-grid{grid-template-columns:repeat(2,1fr)}
  .map-container{height:260px}
  .hero-image-grid{grid-template-columns:1fr;grid-template-rows:140px 80px 80px}
  .hero-img-card.hero-img-large{grid-row:1/2;grid-column:1/2}
  .dashboard-grid{grid-template-columns:repeat(2,1fr)}
}

/* ====== TRIP SUMMARY DASHBOARD (tablet-style, matches reference image 3) ====== */
.trip-summary-dashboard{background:linear-gradient(180deg,#ffffff 0%,#f8fafc 100%);border-radius:18px;padding:18px 20px 22px;margin-bottom:18px;box-shadow:0 8px 32px rgba(15,23,42,0.08),0 0 0 1px rgba(15,23,42,0.04)}
[data-theme="dark"] .trip-summary-dashboard{background:linear-gradient(180deg,#1e293b 0%,#0f172a 100%);box-shadow:0 8px 32px rgba(0,0,0,0.4),0 0 0 1px rgba(255,255,255,0.06)}
.tsd-header{display:flex;align-items:baseline;gap:12px;margin-bottom:14px;padding-bottom:10px;border-bottom:1px solid rgba(15,23,42,0.08)}
[data-theme="dark"] .tsd-header{border-bottom-color:rgba(255,255,255,0.08)}
.tsd-brand{font-size:1.25rem;font-weight:800;letter-spacing:-0.5px}
.tsd-brand-bold{color:#0ea5e9}
.tsd-brand-light{color:#64748b;font-weight:500}
.tsd-tagline{font-size:0.7rem;color:#64748b;letter-spacing:1px;text-transform:uppercase}
.tsd-row{display:grid;gap:14px;margin-bottom:14px}
.tsd-row-main{grid-template-columns:0.8fr 1.6fr}
.tsd-itin-card{background:#fff;border-radius:14px;padding:14px 16px;box-shadow:0 2px 8px rgba(15,23,42,0.04),0 0 0 1px rgba(15,23,42,0.04)}
[data-theme="dark"] .tsd-itin-card{background:#0f172a;box-shadow:0 2px 8px rgba(0,0,0,0.3),0 0 0 1px rgba(255,255,255,0.06)}
.tsd-card-title{font-size:0.78rem;font-weight:700;color:#0ea5e9;margin-bottom:10px;letter-spacing:0.3px}
.tsd-itin-timeline{list-style:none;padding:0;margin:0;position:relative}
.tsd-itin-timeline::before{content:'';position:absolute;left:5px;top:6px;bottom:6px;width:2px;background:linear-gradient(180deg,#3b82f6,#10b981)}
.tsd-itin-timeline li{position:relative;padding:6px 0 6px 22px;font-size:0.86rem;color:#334155;display:flex;align-items:center;justify-content:space-between;gap:8px}
[data-theme="dark"] .tsd-itin-timeline li{color:#cbd5e1}
.tsd-itin-timeline li::before{content:'';position:absolute;left:0;top:11px;width:12px;height:12px;border-radius:50%;background:#fff;border:2px solid #3b82f6;box-shadow:0 0 0 2px #fff}
[data-theme="dark"] .tsd-itin-timeline li::before{background:#0f172a;box-shadow:0 0 0 2px #0f172a}
.tsd-itin-timeline li .tsd-itin-time{font-size:0.7rem;color:#94a3b8}
.tsd-map-card{background:#fff;border-radius:14px;overflow:hidden;box-shadow:0 2px 8px rgba(15,23,42,0.04),0 0 0 1px rgba(15,23,42,0.04);min-height:260px;position:relative}
[data-theme="dark"] .tsd-map-card{background:#0f172a;box-shadow:0 2px 8px rgba(0,0,0,0.3),0 0 0 1px rgba(255,255,255,0.06)}
.tsd-map-card .map-container{height:100%;min-height:260px;border-radius:0;margin:0}
.tsd-map-card #map{height:100%;min-height:260px}
.tsd-section-label{font-size:0.72rem;font-weight:700;color:#64748b;letter-spacing:1.2px;margin:14px 0 8px;text-transform:uppercase}
.tsd-booking-row{grid-template-columns:repeat(4,1fr)}
.tsd-booking-tile{background:#fff;border-radius:12px;padding:12px 14px;display:flex;gap:10px;align-items:flex-start;box-shadow:0 2px 8px rgba(15,23,42,0.04),0 0 0 1px rgba(15,23,42,0.04);min-height:74px}
[data-theme="dark"] .tsd-booking-tile{background:#0f172a;box-shadow:0 2px 8px rgba(0,0,0,0.3),0 0 0 1px rgba(255,255,255,0.06)}
.tsd-tile-icon{font-size:1.4rem;flex-shrink:0;width:34px;height:34px;border-radius:9px;background:rgba(59,130,246,0.1);display:flex;align-items:center;justify-content:center}
.tsd-tile-content{flex:1;min-width:0}
.tsd-tile-label{font-size:0.68rem;font-weight:700;color:#64748b;letter-spacing:0.4px;margin-bottom:2px}
.tsd-tile-value{font-size:0.8rem;font-weight:600;color:#0f172a;line-height:1.35;word-break:break-word}
[data-theme="dark"] .tsd-tile-value{color:#e2e8f0}
.tsd-tile-cta{display:inline-block;margin-top:4px;font-size:0.7rem;color:#3b82f6;font-weight:600;text-decoration:none}
.tsd-tile-cta:hover{text-decoration:underline}
.tsd-risk-row{grid-template-columns:1fr 1fr 1fr 1.4fr}
.tsd-weather-card,.tsd-crowd-card,.tsd-replan-card,.tsd-cost-card{background:#fff;border-radius:12px;padding:14px;box-shadow:0 2px 8px rgba(15,23,42,0.04),0 0 0 1px rgba(15,23,42,0.04)}
[data-theme="dark"] .tsd-weather-card,[data-theme="dark"] .tsd-crowd-card,[data-theme="dark"] .tsd-replan-card,[data-theme="dark"] .tsd-cost-card{background:#0f172a;box-shadow:0 2px 8px rgba(0,0,0,0.3),0 0 0 1px rgba(255,255,255,0.06)}
.tsd-mini-title{font-size:0.7rem;font-weight:700;color:#64748b;letter-spacing:0.4px;margin-bottom:10px;text-transform:uppercase}
.tsd-weather-cells{display:flex;gap:10px;flex-wrap:wrap}
.tsd-weather-cell{display:flex;flex-direction:column;align-items:center;gap:4px;flex:1;min-width:50px}
.tsd-weather-icon{width:38px;height:38px;border-radius:50%;border:2px solid #e2e8f0;display:flex;align-items:center;justify-content:center;font-size:1.1rem}
.tsd-weather-label{font-size:0.66rem;color:#64748b;text-align:center}
.tsd-crowd-bars{display:flex;align-items:flex-end;gap:6px;height:54px;margin-bottom:6px}
.tsd-bar{flex:1;background:#e2e8f0;border-radius:4px 4px 0 0;transition:all 0.6s ease;min-height:14px}
[data-theme="dark"] .tsd-bar{background:#334155}
.tsd-bar.active{background:linear-gradient(180deg,#3b82f6,#1d4ed8)}
.tsd-crowd-labels{display:flex;justify-content:space-between;font-size:0.64rem;color:#94a3b8}
.tsd-replan-status{display:flex;align-items:center;gap:10px}
.tsd-replan-icon{width:42px;height:42px;border-radius:50%;background:#10b981;color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.3rem}
.tsd-replan-icon.warn{background:#f59e0b}
.tsd-replan-icon.danger{background:#ef4444}
.tsd-replan-text{font-size:1rem;font-weight:700;color:#10b981}
.tsd-replan-text.warn{color:#f59e0b}
.tsd-replan-text.danger{color:#ef4444}
.tsd-cost-rows{display:flex;flex-direction:column;gap:4px;margin-bottom:8px}
.tsd-cost-row{display:flex;justify-content:space-between;font-size:0.82rem;color:#334155}
[data-theme="dark"] .tsd-cost-row{color:#cbd5e1}
.tsd-cost-val{font-weight:700;color:#0f172a;font-variant-numeric:tabular-nums}
[data-theme="dark"] .tsd-cost-val{color:#e2e8f0}
.tsd-cost-est{color:#3b82f6}
.tsd-cost-savings{color:#10b981;font-weight:600}
.tsd-cost-savings .tsd-cost-val{color:#10b981}
.tsd-cost-bar{height:6px;background:#e2e8f0;border-radius:3px;overflow:hidden;margin-top:6px}
[data-theme="dark"] .tsd-cost-bar{background:#1e293b}
.tsd-cost-bar-fill{height:100%;background:linear-gradient(90deg,#3b82f6,#10b981);border-radius:3px;width:0%;transition:width 0.8s ease}

@media (max-width:1100px){
  .tsd-row-main{grid-template-columns:1fr}
  .tsd-booking-row{grid-template-columns:repeat(2,1fr)}
  .tsd-risk-row{grid-template-columns:1fr 1fr}
}
@media (max-width:600px){
  .tsd-booking-row{grid-template-columns:1fr}
  .tsd-risk-row{grid-template-columns:1fr}
}
