:root{
  --bg:#F7F4EC; --bg2:#EFEBE1; --surface:#FFFFFF; --surface2:#F2EEE4; --surface3:#E8E3D6;
  --line:rgba(20,22,28,0.08); --line2:rgba(20,22,28,0.14);
  --ink:#14161C; --muted:#6B6F78; --faint:rgba(107,111,120,0.55);
  --accent:#14161C; --accent-soft:rgba(20,22,28,0.06); --accent-line:rgba(20,22,28,0.22);
  --green:#2f8f5a; --red:#c44536; --blue:#3a6ea5; --orange:#c97a2b; --purple:#7a5fa3;
  --sans:'Inter',-apple-system,system-ui,sans-serif;
  --serif:'Newsreader',Georgia,serif;
  --mono:'JetBrains Mono',ui-monospace,monospace;
  --r:14px; --r-sm:10px; --r-lg:22px;
}
*,*::before,*::after{box-sizing:border-box;}
html,body{margin:0;padding:0;background:var(--bg);color:var(--ink);font-family:var(--sans);font-size:14px;-webkit-font-smoothing:antialiased;min-height:100vh;}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit;}
input,textarea{font-family:inherit;color:inherit;}
::-webkit-scrollbar{width:10px;height:10px;}
::-webkit-scrollbar-track{background:transparent;}
::-webkit-scrollbar-thumb{background:var(--surface2);border-radius:99px;border:2px solid var(--bg);}

/* ====================== APP SHELL ====================== */
.app{display:grid;grid-template-columns:240px 1fr;min-height:100vh;}
.sidebar{background:var(--bg2);border-right:1px solid var(--line);padding:22px 16px;position:sticky;top:0;height:100vh;display:flex;flex-direction:column;gap:18px;}
.brand{display:flex;align-items:center;gap:10px;padding:0 6px 14px;border-bottom:1px solid var(--line);}
.brand-mark{width:30px;height:30px;border-radius:9px;background:linear-gradient(135deg,#14161C,#3a3d47);display:flex;align-items:center;justify-content:center;color:#F7F4EC;}
.brand-name{font-family:var(--serif);font-size:22px;letter-spacing:-0.3px;}
.brand-dot{width:6px;height:6px;border-radius:99px;background:var(--green);box-shadow:0 0 6px rgba(46,204,113,.6);margin-left:auto;}

.nav-section{display:flex;flex-direction:column;gap:2px;}
.nav-title{font-family:var(--mono);font-size:9px;letter-spacing:0.18em;text-transform:uppercase;color:var(--faint);padding:0 10px 6px;}
.nav-item{display:flex;align-items:center;gap:11px;padding:9px 10px;border-radius:9px;color:var(--muted);font-weight:500;font-size:13px;cursor:pointer;transition:background .15s,color .15s;}
.nav-item:hover{background:var(--surface);color:var(--ink);}
.nav-item.active{background:var(--accent-soft);color:var(--accent);}
.nav-item svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0;}
.nav-badge{margin-left:auto;font-family:var(--mono);font-size:9px;color:var(--accent);}

.side-profile{margin-top:auto;padding:10px;border-radius:12px;background:var(--surface);display:flex;align-items:center;gap:10px;cursor:pointer;}
.avatar{width:32px;height:32px;border-radius:99px;background:linear-gradient(135deg,#14161C,#3a3d47);display:flex;align-items:center;justify-content:center;color:#F7F4EC;font-weight:700;font-size:13px;flex-shrink:0;}
.sp-info{flex:1;min-width:0;}
.sp-name{font-size:12.5px;font-weight:600;}
.sp-sub{font-family:var(--mono);font-size:9px;color:var(--muted);letter-spacing:0.05em;}

/* ====================== TOPBAR ====================== */
.main{min-width:0;display:flex;flex-direction:column;}
.topbar{display:flex;align-items:center;gap:14px;padding:14px 28px;border-bottom:1px solid var(--line);background:var(--bg);position:sticky;top:0;z-index:30;}
.crumb{font-family:var(--mono);font-size:10px;letter-spacing:0.15em;color:var(--faint);text-transform:uppercase;white-space:nowrap;}
.crumb span{color:var(--ink);margin:0 4px;}
.search{flex:1;max-width:420px;min-width:0;margin:0 12px;position:relative;}
.search input{width:100%;background:var(--surface);border:1px solid var(--line);border-radius:99px;padding:8px 14px 8px 36px;color:var(--ink);font-size:13px;outline:none;transition:border-color .15s;}
.search input:focus{border-color:var(--accent-line);}
.search svg{position:absolute;left:12px;top:50%;transform:translateY(-50%);width:14px;height:14px;color:var(--muted);}
.top-actions{display:flex;align-items:center;gap:8px;margin-left:auto;}
.top-btn{padding:7px 10px;border-radius:9px;color:var(--muted);border:1px solid var(--line);display:flex;align-items:center;gap:6px;font-size:12px;}
.top-btn:hover{color:var(--ink);border-color:var(--line2);}
.top-btn svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:1.8;}
.top-btn .notif-dot{width:6px;height:6px;border-radius:99px;background:var(--red);margin-left:2px;}
.top-install{background:var(--accent);color:#F7F4EC;border:none;font-weight:600;padding:7px 12px;border-radius:9px;font-size:12px;display:flex;align-items:center;gap:6px;white-space:nowrap;}

/* ====================== PAGES ====================== */
.page{flex:1;padding:28px;display:none;}
.page.active{display:block;}
.page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:20px;margin-bottom:22px;}
.page-header>div:first-child{min-width:0;flex:1;}
.page-kicker{font-family:var(--mono);font-size:10px;letter-spacing:0.18em;color:var(--accent);text-transform:uppercase;margin-bottom:8px;}
.page-title{font-family:var(--serif);font-size:30px;letter-spacing:-0.4px;margin:0;line-height:1.15;}
.page-title-sub{color:var(--muted);font-size:13.5px;margin-top:14px;line-height:1.45;}
.date-chip{font-family:var(--mono);font-size:11px;color:var(--muted);letter-spacing:0.1em;padding:6px 10px;border:1px solid var(--line);border-radius:99px;}

/* ====================== DASHBOARD ====================== */
.dash-grid{display:grid;grid-template-columns:1.55fr 1fr;gap:18px;}
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;}
.card-head{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:14px 16px;border-bottom:1px solid var(--line);}
.card-head h3{margin:0;font-size:13px;font-weight:600;white-space:nowrap;}
.card-head .meta{font-family:var(--mono);font-size:10px;color:var(--muted);letter-spacing:0.1em;white-space:nowrap;flex-shrink:0;}
.card-body{padding:16px;}

/* Map hero */
.map-card{grid-column:span 1;position:relative;min-height:340px;display:flex;flex-direction:column;}
.map-stage{flex:1;position:relative;overflow:hidden;background:#EFEBE1;}
.map-overlay-top{position:absolute;top:14px;left:14px;right:14px;display:flex;justify-content:space-between;align-items:flex-start;z-index:5;pointer-events:none;}
.map-now{background:rgba(255,255,255,0.82);backdrop-filter:blur(10px);border:1px solid var(--accent-line);border-radius:10px;padding:10px 12px;pointer-events:auto;}
.map-now-label{font-family:var(--mono);font-size:9px;letter-spacing:0.2em;color:var(--accent);text-transform:uppercase;}
.map-now-city{font-family:var(--serif);font-size:22px;margin-top:2px;}
.map-now-meta{font-family:var(--mono);font-size:10px;color:var(--muted);margin-top:2px;}
.map-ctl{display:flex;flex-direction:column;gap:4px;pointer-events:auto;}
.map-ctl button{width:30px;height:30px;border-radius:8px;background:rgba(255,255,255,0.82);backdrop-filter:blur(10px);border:1px solid var(--line2);color:var(--ink);font-family:var(--mono);font-size:14px;display:flex;align-items:center;justify-content:center;}
.map-stat-row{display:flex;gap:0;border-top:1px solid var(--line);}
.map-stat{flex:1;padding:12px 14px;border-right:1px solid var(--line);}
.map-stat:last-child{border-right:none;}
.map-stat-label{font-family:var(--mono);font-size:9px;letter-spacing:0.15em;color:var(--muted);text-transform:uppercase;}
.map-stat-val{font-family:var(--serif);font-size:22px;margin-top:3px;letter-spacing:-0.2px;}
.map-stat-val .unit{font-family:var(--sans);font-style:normal;font-size:11px;color:var(--muted);font-weight:400;margin-left:3px;}

/* Right column */
.right-col{display:flex;flex-direction:column;gap:18px;}

/* Next up */
.next-up{padding:18px;background:linear-gradient(135deg,#EFEBE1,#E8E3D6);border:1px solid var(--accent-line);border-radius:var(--r);position:relative;overflow:hidden;}
.next-up::before{content:'';position:absolute;top:-40px;right:-40px;width:160px;height:160px;border-radius:99px;background:radial-gradient(circle,var(--accent-soft),transparent 70%);}
.nu-label{font-family:var(--mono);font-size:10px;color:var(--accent);letter-spacing:0.15em;text-transform:uppercase;position:relative;}
.nu-route{font-family:var(--serif);font-size:32px;margin-top:6px;letter-spacing:-0.5px;line-height:1;position:relative;}
.nu-iata{display:flex;align-items:center;gap:12px;margin-top:14px;font-family:var(--mono);font-size:12px;color:var(--muted);letter-spacing:0.08em;position:relative;}
.nu-iata .big{color:var(--ink);font-size:14px;font-weight:500;}
.nu-iata .plane{color:var(--accent);}
.nu-countdown{display:flex;gap:14px;margin-top:16px;position:relative;}
.nu-count{padding:8px 0;flex:1;border-top:1px solid var(--line);}
.nu-count-val{font-family:var(--serif);font-size:24px;letter-spacing:-0.3px;}
.nu-count-lbl{font-family:var(--mono);font-size:9px;color:var(--muted);letter-spacing:0.15em;text-transform:uppercase;margin-top:2px;}

/* Nudges / alerts */
.nudge{display:flex;gap:12px;padding:12px 14px;align-items:flex-start;cursor:pointer;transition:background .12s;border-bottom:1px solid var(--line);}
.nudge:last-child{border-bottom:none;}
.nudge:hover{background:var(--surface2);}
.nudge-ic{width:32px;height:32px;border-radius:9px;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.nudge-ic svg{width:15px;height:15px;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;}
.ic-gold{background:var(--accent-soft);color:var(--accent);}
.ic-red{background:rgba(231,76,60,0.12);color:var(--red);}
.ic-blue{background:rgba(52,152,219,0.12);color:var(--blue);}
.ic-green{background:rgba(46,204,113,0.12);color:var(--green);}
.ic-purple{background:rgba(155,89,182,0.12);color:var(--purple);}
.nudge-body{flex:1;min-width:0;}
.nudge-title{font-size:13px;font-weight:600;line-height:1.3;}
.nudge-desc{font-size:11.5px;color:var(--muted);line-height:1.5;margin-top:2px;}
.nudge-time{font-family:var(--mono);font-size:9px;color:var(--faint);letter-spacing:0.1em;margin-top:4px;}
.nudge-cta{display:flex;gap:6px;margin-top:8px;flex-wrap:wrap;}
.nudge-cta button{font-size:11px;font-weight:600;padding:5px 10px;border-radius:99px;white-space:nowrap;}
.nudge-cta .primary{background:var(--accent);color:#F7F4EC;}
.nudge-cta .ghost{background:transparent;border:1px solid var(--line2);color:var(--muted);}

/* Timeline strip */
.timeline-strip{padding:6px 0;}
.tl-row{display:grid;grid-template-columns:56px 16px 1fr auto;gap:12px;padding:11px 16px;align-items:center;border-bottom:1px solid var(--line);cursor:pointer;}
.tl-row:last-child{border-bottom:none;}
.tl-row:hover{background:var(--surface2);}
.tl-date{font-family:var(--mono);font-size:10px;color:var(--muted);letter-spacing:0.08em;}
.tl-dot{width:10px;height:10px;border-radius:99px;border:1.5px solid var(--muted);background:transparent;justify-self:center;}
.tl-dot.done{background:var(--green);border-color:var(--green);}
.tl-dot.active{background:var(--accent);border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft);}
.tl-dot.gap{border-color:var(--red);}
.tl-body-title{font-size:13px;font-weight:500;}
.tl-body-sub{font-size:11px;color:var(--muted);margin-top:1px;}
.tl-tag{font-family:var(--mono);font-size:9px;letter-spacing:0.12em;padding:3px 8px;border-radius:99px;text-transform:uppercase;}
.tag-ok{background:rgba(46,204,113,0.12);color:var(--green);}
.tag-warn{background:rgba(231,76,60,0.12);color:var(--red);}
.tag-info{background:var(--surface2);color:var(--muted);}

/* Stat row */
.stat-row{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;}
.stat{padding:14px 14px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r);}
.stat-label{font-family:var(--mono);font-size:9px;color:var(--muted);letter-spacing:0.15em;text-transform:uppercase;}
.stat-val{font-family:var(--serif);font-size:28px;margin-top:6px;letter-spacing:-0.3px;line-height:1;}
.stat-val .s{font-family:var(--sans);font-size:12px;color:var(--muted);font-style:normal;margin-left:3px;font-weight:400;}
.stat-delta{font-family:var(--mono);font-size:10px;margin-top:6px;}
.stat-delta.up{color:var(--green);}
.stat-delta.down{color:var(--red);}

/* PWA push notification mock */
.push-mock{margin-top:0;padding:12px 14px;border:1px dashed var(--accent-line);border-radius:var(--r);background:rgba(20,22,28,0.03);display:flex;gap:11px;align-items:flex-start;}
.push-mock .app-ico{width:28px;height:28px;border-radius:7px;background:linear-gradient(135deg,#14161C,#3a3d47);display:flex;align-items:center;justify-content:center;color:#F7F4EC;font-weight:800;font-size:12px;flex-shrink:0;}
.push-mock .pb{flex:1;min-width:0;}
.push-mock .pb-row{display:flex;justify-content:space-between;align-items:baseline;}
.push-mock .pb-app{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:0.08em;font-weight:600;}
.push-mock .pb-time{font-family:var(--mono);font-size:10px;color:var(--faint);}
.push-mock .pb-title{font-size:13px;font-weight:600;margin-top:3px;}
.push-mock .pb-body{font-size:12px;color:var(--muted);margin-top:2px;line-height:1.45;}

/* ====================== CHAT ====================== */
/* Chat page locks to the viewport — no vertical page scroll, only the message list scrolls. */
body:has(#page-chat.active){overflow:hidden;}
#page-chat.active{height:calc(100vh - 60px);display:flex;flex-direction:column;overflow:hidden;padding-bottom:18px;}
#page-chat .page-header{flex-shrink:0;margin-bottom:14px;}
.chat-layout{display:grid;grid-template-columns:1fr 320px;gap:18px;flex:1;min-height:0;}
.chat-main{display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;min-height:0;}
.chat-head{display:flex;align-items:center;gap:10px;padding:14px 16px;border-bottom:1px solid var(--line);}
.ch-av{width:30px;height:30px;border-radius:99px;background:linear-gradient(135deg,#14161C,#3a3d47);display:flex;align-items:center;justify-content:center;color:#F7F4EC;}
.ch-name{font-weight:600;font-size:13px;}
.ch-status{font-family:var(--mono);font-size:10px;color:var(--accent);letter-spacing:0.1em;}
.ch-msgs{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:14px;min-height:0;}
.msg{display:flex;gap:10px;max-width:82%;}
.msg.you{align-self:flex-end;flex-direction:row-reverse;}
.msg-av{width:26px;height:26px;border-radius:99px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:11px;align-self:flex-end;}
.msg.ai .msg-av{background:linear-gradient(135deg,#14161C,#3a3d47);color:#F7F4EC;}
.msg.you .msg-av{background:var(--surface3);color:var(--ink);}
.msg-bubble{padding:10px 14px;border-radius:14px;font-size:13.5px;line-height:1.55;white-space:pre-wrap;}
.msg.ai .msg-bubble{background:var(--surface2);border:1px solid var(--line);border-bottom-left-radius:4px;}
.msg.you .msg-bubble{background:var(--accent);color:#F7F4EC;border-bottom-right-radius:4px;font-weight:500;}
.msg-col{display:flex;flex-direction:column;gap:6px;min-width:0;}
.tool-card{background:var(--bg2);border:1px solid var(--line2);border-radius:10px;padding:12px 13px;}
.tool-head{display:flex;justify-content:space-between;gap:8px;font-family:var(--mono);font-size:10px;letter-spacing:0.08em;color:var(--muted);margin-bottom:6px;white-space:nowrap;}
.tool-head .src{color:var(--accent);}
.tool-route{display:flex;align-items:center;gap:8px;}
.tool-iata{font-family:var(--serif);font-size:22px;letter-spacing:-0.2px;white-space:nowrap;}
.tool-arr{flex:1;height:1px;background:var(--line2);position:relative;}
.tool-arr::after{content:'';position:absolute;right:0;top:-3px;width:6px;height:6px;border-right:1px solid var(--accent);border-top:1px solid var(--accent);transform:rotate(45deg);}
.tool-times{display:flex;justify-content:space-between;font-family:var(--mono);font-size:10px;color:var(--muted);margin-top:4px;}
.tool-meta{display:flex;justify-content:space-between;align-items:baseline;gap:10px;margin-top:10px;font-size:11.5px;color:var(--muted);}
.tool-meta>span:first-child{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.tool-meta .price{color:var(--accent);font-weight:600;font-size:14px;font-family:var(--serif);white-space:nowrap;flex-shrink:0;}
.tool-disclaimer{font-size:10.5px;color:var(--muted);margin-top:8px;padding:6px 8px;background:var(--surface2);border-radius:6px;line-height:1.4;}
.tool-actions{display:flex;gap:6px;margin-top:10px;padding-top:10px;border-top:1px solid var(--line);flex-wrap:wrap;}
.tool-actions button,.tool-actions a{font-size:11px;padding:5px 10px;border-radius:99px;font-weight:600;white-space:nowrap;text-decoration:none;display:inline-flex;align-items:center;}
.tool-actions .save{background:var(--accent);color:#F7F4EC;border:none;cursor:pointer;}
.tool-actions .save.saved{background:var(--green);}
.tool-actions .view{border:1px solid var(--line2);color:var(--muted);background:transparent;cursor:pointer;}
.tool-compare{margin-top:8px;display:flex;gap:8px;align-items:center;flex-wrap:wrap;font-size:10.5px;color:var(--muted);}
.tool-compare a{color:var(--accent);text-decoration:none;font-weight:500;}
.tool-error{background:rgba(196,69,54,0.06);border:1px solid rgba(196,69,54,0.25);border-radius:10px;padding:10px 12px;}
.tool-error-title{font-size:12px;font-weight:600;color:var(--red);margin-bottom:4px;}
.tool-error-msg{font-size:11.5px;color:var(--muted);line-height:1.5;}
.tool-insight{margin-top:8px;font-family:var(--mono);font-size:10.5px;color:var(--muted);padding:6px 9px;background:var(--surface2);border-radius:8px;}
.prefs-banner{font-family:var(--mono);font-size:10.5px;color:var(--muted);padding:7px 10px;background:var(--surface2);border:1px solid var(--line);border-radius:8px;margin:6px 0 10px;line-height:1.45;}
.badge{display:inline-block;font-family:var(--mono);font-size:9px;font-weight:600;letter-spacing:0.08em;text-transform:uppercase;padding:2px 7px;border-radius:99px;margin-bottom:7px;margin-right:5px;}
.badge-best{background:var(--accent);color:var(--bg);}
.badge-cheap{background:var(--green);color:#fff;}
.chat-bar{display:flex;gap:8px;padding:12px;border-top:1px solid var(--line);background:var(--bg2);}
.chat-inp{flex:1;background:var(--surface2);border:1px solid var(--line);border-radius:14px;padding:10px 14px;outline:none;font-size:13px;resize:none;max-height:120px;color:var(--ink);}
.chat-inp:focus{border-color:var(--accent-line);}
.chat-send{width:38px;height:38px;border-radius:99px;background:var(--accent);color:#F7F4EC;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.chat-send:disabled{opacity:0.5;cursor:not-allowed;}
.chat-send svg{width:16px;height:16px;fill:currentColor;}
.chat-sug{display:flex;gap:6px;padding:0 12px 10px;flex-wrap:wrap;}
.sug-chip{font-size:11px;padding:5px 10px;border-radius:99px;background:var(--surface2);border:1px solid var(--line);color:var(--muted);cursor:pointer;white-space:nowrap;}
.sug-chip:hover{border-color:var(--accent-line);color:var(--accent);}

.typing{display:flex;gap:4px;padding:10px 14px;background:var(--surface2);border:1px solid var(--line);border-radius:14px;border-bottom-left-radius:4px;align-items:center;}
.typing .dot{width:6px;height:6px;border-radius:99px;background:var(--muted);opacity:0.5;animation:typingPulse 1.2s infinite ease-in-out;}
.typing .dot:nth-child(2){animation-delay:0.15s;}
.typing .dot:nth-child(3){animation-delay:0.3s;}
@keyframes typingPulse{0%,60%,100%{opacity:0.3;transform:translateY(0);}30%{opacity:1;transform:translateY(-2px);}}

.chat-aside{display:flex;flex-direction:column;gap:14px;min-height:0;overflow-y:auto;}
.aside-sec{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:14px;}
.aside-sec h4{margin:0 0 10px;font-size:12px;font-weight:600;display:flex;align-items:center;justify-content:space-between;}
.aside-sec h4 span{font-family:var(--mono);font-size:9px;color:var(--muted);letter-spacing:0.1em;font-weight:400;}
.ctx-item{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:6px 0;border-top:1px solid var(--line);font-size:12px;}
.ctx-item:first-of-type{border-top:none;}
.ctx-item .k{color:var(--muted);white-space:nowrap;}
.ctx-item .v{font-family:var(--mono);font-size:11px;color:var(--ink);white-space:nowrap;}

/* ====================== PROFILE ====================== */
.prof-layout{display:grid;grid-template-columns:260px 1fr;gap:20px;}
.prof-nav{display:flex;flex-direction:column;gap:2px;position:sticky;top:100px;align-self:flex-start;}
.prof-nav-item{padding:9px 12px;border-radius:9px;font-size:12.5px;color:var(--muted);cursor:pointer;display:flex;justify-content:space-between;align-items:center;}
.prof-nav-item:hover{background:var(--surface);color:var(--ink);}
.prof-nav-item.active{background:var(--accent-soft);color:var(--accent);}
.prof-nav-item .count{font-family:var(--mono);font-size:10px;color:var(--muted);}
.prof-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);margin-bottom:16px;}
.prof-card h3{margin:0;padding:14px 18px;border-bottom:1px solid var(--line);font-size:13px;font-weight:600;display:flex;align-items:center;gap:8px;}
.prof-card h3 .tag{font-family:var(--mono);font-size:9px;color:var(--accent);letter-spacing:0.1em;font-weight:400;white-space:nowrap;}
.p-row{display:flex;justify-content:space-between;align-items:center;padding:12px 18px;border-bottom:1px solid var(--line);gap:14px;}
.p-row:last-child{border-bottom:none;}
.p-row.col{flex-direction:column;align-items:flex-start;gap:8px;}
.p-label{font-size:13px;color:var(--ink);}
.p-sub{font-size:11px;color:var(--muted);margin-top:2px;}
.p-val{font-family:var(--mono);font-size:11px;color:var(--muted);}
.tog{width:38px;height:22px;background:var(--surface3);border-radius:99px;position:relative;cursor:pointer;transition:background .2s;flex-shrink:0;}
.tog.on{background:var(--accent);}
.tog::after{content:'';position:absolute;top:2px;left:2px;width:18px;height:18px;border-radius:99px;background:white;transition:transform .2s;}
.tog.on::after{transform:translateX(16px);}
.p-inp{background:var(--bg2);border:1px solid var(--line);border-radius:8px;padding:8px 10px;font-size:12.5px;outline:none;width:100%;}
.p-inp:focus{border-color:var(--accent-line);}
.chips{display:flex;gap:5px;flex-wrap:wrap;}
.chip{padding:5px 11px;border-radius:99px;border:1px solid var(--line);background:var(--bg2);color:var(--muted);font-size:11px;cursor:pointer;user-select:none;white-space:nowrap;}
.chip.sel{background:var(--accent-soft);border-color:var(--accent-line);color:var(--accent);}

/* ====================== CALENDAR ====================== */
.cal-layout{display:grid;grid-template-columns:1fr 360px;gap:18px;align-items:flex-start;}
.cal-main{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:14px 16px 16px;}
.cal-toolbar{display:flex;align-items:center;gap:10px;padding:0 4px 12px;border-bottom:1px solid var(--line);margin-bottom:10px;}
.cal-month{font-family:var(--serif);font-size:20px;letter-spacing:-0.2px;flex:1;}
.cal-nav{width:30px;height:30px;border-radius:8px;border:1px solid var(--line);color:var(--muted);display:flex;align-items:center;justify-content:center;background:transparent;}
.cal-nav:hover{border-color:var(--line2);color:var(--ink);}
.cal-today-btn{padding:6px 12px;border-radius:99px;border:1px solid var(--line2);font-size:11px;font-weight:600;color:var(--muted);background:transparent;letter-spacing:0.04em;}
.cal-today-btn:hover{color:var(--ink);border-color:var(--accent-line);}
.cal-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;font-family:var(--mono);font-size:9px;letter-spacing:0.15em;color:var(--faint);text-transform:uppercase;padding:6px 4px;}
.cal-weekdays>div{text-align:center;}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;}
.cal-cell{position:relative;min-height:84px;background:var(--bg2);border:1px solid var(--line);border-radius:8px;padding:6px 7px;cursor:pointer;display:flex;flex-direction:column;gap:4px;transition:border-color .12s,background .12s;overflow:hidden;}
.cal-cell:hover{border-color:var(--line2);background:var(--surface2);}
.cal-cell.dim{opacity:0.45;}
.cal-cell.today{border-color:var(--accent);background:var(--surface2);}
.cal-cell.today .cal-cell-num{color:var(--accent);font-weight:700;}
.cal-cell.selected{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-soft);background:var(--surface);}
.cal-cell-num{font-family:var(--mono);font-size:11px;color:var(--ink);font-weight:500;align-self:flex-start;}
.cal-cell-events{display:flex;flex-direction:column;gap:2px;flex:1;min-height:0;overflow:hidden;}
.cal-evt{font-size:10px;line-height:1.3;padding:2px 6px;border-radius:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:500;background:var(--surface2);color:var(--ink);border-left:2px solid var(--muted);}
.cal-evt.type-flight{background:rgba(58,110,165,0.12);border-left-color:var(--blue);color:var(--blue);}
.cal-evt.type-stay{background:rgba(46,143,90,0.12);border-left-color:var(--green);color:var(--green);}
.cal-evt.type-transfer{background:rgba(201,122,43,0.12);border-left-color:var(--orange);color:var(--orange);}
.cal-evt.type-activity{background:rgba(122,95,163,0.12);border-left-color:var(--purple);color:var(--purple);}
.cal-evt.type-note{background:var(--surface2);border-left-color:var(--muted);color:var(--muted);}
.cal-evt.type-personal{background:rgba(107,111,120,0.08);border-left-color:var(--faint);color:var(--muted);font-style:italic;}
.cal-evt.source-google{border-left-style:dashed;}
.cal-evt-more{font-family:var(--mono);font-size:9px;color:var(--muted);letter-spacing:0.05em;padding-left:4px;}

.cal-legend{display:flex;flex-wrap:wrap;gap:14px;margin-top:14px;padding-top:12px;border-top:1px solid var(--line);font-size:11px;color:var(--muted);}
.cal-legend-item{display:inline-flex;align-items:center;gap:6px;}
.cal-dot{width:8px;height:8px;border-radius:99px;display:inline-block;}
.cal-dot.type-flight{background:var(--blue);}
.cal-dot.type-stay{background:var(--green);}
.cal-dot.type-transfer{background:var(--orange);}
.cal-dot.type-activity{background:var(--purple);}
.cal-dot.type-note{background:var(--muted);}
.cal-dot.type-personal{background:var(--faint);}

.cal-aside{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:18px;display:flex;flex-direction:column;gap:14px;position:sticky;top:80px;max-height:calc(100vh - 110px);overflow-y:auto;}
.cal-aside-head{display:flex;justify-content:space-between;align-items:flex-start;}

.cal-gcal-card{background:var(--bg2);border:1px solid var(--line);border-radius:10px;padding:12px 14px;display:flex;flex-direction:column;gap:8px;}
.cal-gcal-row{display:flex;align-items:center;gap:10px;}
.cal-gcal-ic{width:30px;height:30px;border-radius:8px;background:var(--surface);display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.cal-gcal-ic svg{width:18px;height:18px;}
.cal-gcal-meta{flex:1;min-width:0;}
.cal-gcal-title{font-size:12.5px;font-weight:600;}
.cal-gcal-sub{font-size:11px;color:var(--muted);margin-top:1px;line-height:1.4;}
.cal-gcal-btn{padding:7px 12px;border-radius:99px;font-size:11.5px;font-weight:600;letter-spacing:0.02em;cursor:pointer;border:none;}
.cal-gcal-btn.connect{background:var(--accent);color:#F7F4EC;}
.cal-gcal-btn.connect:hover{background:#23262e;}
.cal-gcal-btn.disconnect{background:transparent;color:var(--muted);border:1px solid var(--line2);}
.cal-gcal-btn.disconnect:hover{color:var(--red);border-color:var(--red);}
.cal-gcal-status{font-family:var(--mono);font-size:10px;letter-spacing:0.08em;color:var(--green);text-transform:uppercase;display:inline-flex;align-items:center;gap:5px;}
.cal-gcal-status::before{content:'';width:6px;height:6px;border-radius:99px;background:var(--green);box-shadow:0 0 6px rgba(46,143,90,.6);}
.cal-gcal-status.error{color:var(--red);}
.cal-gcal-status.error::before{background:var(--red);box-shadow:0 0 6px rgba(196,69,54,.6);}
.cal-gcal-filter{margin-top:4px;padding-top:10px;border-top:1px solid var(--line);}
.cal-gcal-filter-row{display:flex;justify-content:space-between;align-items:center;gap:10px;}
.cal-gcal-filter-label{flex:1;min-width:0;}
.cal-gcal-filter-title{font-size:12.5px;font-weight:600;}
.cal-gcal-filter-sub{font-family:var(--mono);font-size:10px;color:var(--muted);letter-spacing:0.05em;margin-top:2px;}

.cal-day-events{display:flex;flex-direction:column;gap:8px;}
.cal-day-empty{font-size:12.5px;color:var(--muted);line-height:1.55;padding:6px 0;}
.cal-day-row{display:flex;gap:10px;padding:10px 12px;border:1px solid var(--line);border-radius:10px;background:var(--bg2);align-items:flex-start;}
.cal-day-row .bar{width:3px;border-radius:99px;align-self:stretch;background:var(--muted);flex-shrink:0;}
.cal-day-row.type-flight .bar{background:var(--blue);}
.cal-day-row.type-stay .bar{background:var(--green);}
.cal-day-row.type-transfer .bar{background:var(--orange);}
.cal-day-row.type-activity .bar{background:var(--purple);}
.cal-day-row.type-note .bar{background:var(--muted);}
.cal-day-row.type-personal .bar{background:var(--faint);}
.cal-day-row .body{flex:1;min-width:0;}
.cal-day-row .title{font-size:13px;font-weight:600;line-height:1.3;}
.cal-day-row .meta{font-family:var(--mono);font-size:10px;color:var(--muted);letter-spacing:0.05em;margin-top:3px;}
.cal-day-row .notes{font-size:11.5px;color:var(--muted);margin-top:4px;line-height:1.45;white-space:pre-wrap;}
.cal-day-row .src{font-family:var(--mono);font-size:9px;color:var(--faint);letter-spacing:0.1em;text-transform:uppercase;margin-top:4px;}
.cal-day-row .acts{display:flex;flex-direction:column;gap:4px;flex-shrink:0;}
.cal-day-row .acts button{padding:3px 8px;font-size:10.5px;color:var(--muted);border:1px solid var(--line);border-radius:6px;background:transparent;}
.cal-day-row .acts button:hover{color:var(--ink);border-color:var(--line2);}
.cal-day-row .acts button.del:hover{color:var(--red);border-color:var(--red);}

.cal-form{display:flex;flex-direction:column;gap:10px;padding:14px;background:var(--bg2);border:1px solid var(--line);border-radius:10px;}
.cal-form-head{display:flex;justify-content:space-between;align-items:center;font-size:12px;font-weight:600;color:var(--accent);text-transform:uppercase;letter-spacing:0.1em;font-family:var(--mono);}
.cal-form-close{padding:4px;border-radius:6px;color:var(--muted);}
.cal-form-close:hover{color:var(--ink);background:var(--surface2);}
.cal-field{display:flex;flex-direction:column;gap:5px;}
.cal-field label{font-family:var(--mono);font-size:9.5px;letter-spacing:0.12em;color:var(--muted);text-transform:uppercase;}
.cal-field-row{display:grid;grid-template-columns:1fr 1fr;gap:8px;}
.cal-form-actions{display:flex;gap:6px;justify-content:flex-end;margin-top:4px;}
.cal-form-actions button{padding:7px 14px;border-radius:99px;font-size:12px;font-weight:600;cursor:pointer;}
.cal-cancel{background:transparent;color:var(--muted);border:1px solid var(--line2);}
.cal-cancel:hover{color:var(--ink);}
.cal-save{background:var(--accent);color:#F7F4EC;border:none;}
.cal-save:hover{background:#23262e;}

/* ====================== RESPONSIVE ====================== */
@media (max-width:900px){
  .app{grid-template-columns:1fr;}
  .sidebar{display:none;}
  .topbar{padding:12px 16px;}
  .search{display:none;}
  .page{padding:16px 14px 90px;}
  .page-title{font-size:30px;}
  .dash-grid{grid-template-columns:1fr;}
  .map-card{min-height:260px;}
  .stat-row{grid-template-columns:repeat(2,1fr);}
  .chat-layout{grid-template-columns:1fr;height:auto;}
  .chat-main{height:65vh;}
  .chat-aside{order:-1;flex-direction:row;overflow-x:auto;}
  .aside-sec{min-width:220px;flex-shrink:0;}
  .prof-layout{grid-template-columns:1fr;}
  .prof-nav{flex-direction:row;overflow-x:auto;position:static;}
  .prof-nav-item{flex-shrink:0;}
  .cal-layout{grid-template-columns:1fr;}
  .cal-aside{position:static;max-height:none;}
  .cal-cell{min-height:60px;padding:4px 5px;}
  .cal-evt{font-size:9px;padding:1px 4px;}
  .mob-tabs{display:flex !important;}
}
.mob-tabs{display:none;position:fixed;bottom:0;left:0;right:0;background:var(--bg2);border-top:1px solid var(--line);z-index:50;padding:8px 0 calc(8px + env(safe-area-inset-bottom));}
.mob-tab{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;padding:6px 0;color:var(--muted);}
.mob-tab.active{color:var(--accent);}
.mob-tab svg{width:19px;height:19px;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;}
.mob-tab span{font-size:10px;font-weight:600;}

/* ====================== NOTIF TOAST ====================== */
.toast-stack{position:fixed;top:78px;right:22px;z-index:100;display:flex;flex-direction:column;gap:8px;max-width:320px;}
.toast{background:rgba(255,255,255,0.92);backdrop-filter:blur(14px);border:1px solid var(--accent-line);border-radius:12px;padding:11px 13px;display:flex;gap:10px;animation:slideIn .4s cubic-bezier(.2,.9,.3,1);}
@keyframes slideIn{from{transform:translateX(20px);opacity:0;}to{transform:translateX(0);opacity:1;}}
.toast-ic{width:28px;height:28px;border-radius:7px;background:linear-gradient(135deg,#14161C,#3a3d47);color:#F7F4EC;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:12px;flex-shrink:0;}
.toast-body{flex:1;min-width:0;}
.toast-row{display:flex;justify-content:space-between;}
.toast-app{font-size:10.5px;color:var(--muted);text-transform:uppercase;letter-spacing:0.08em;font-weight:600;}
.toast-time{font-family:var(--mono);font-size:10px;color:var(--faint);}
.toast-title{font-size:12.5px;font-weight:600;margin-top:2px;}
.toast-desc{font-size:11.5px;color:var(--muted);margin-top:2px;line-height:1.4;}
