@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap');

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  /* Arena Friends design tokens */
  --bg:              hsl(220 20% 97%);
  --bg-secondary:    hsl(220 30% 94%);
  --foreground:      hsl(222 47% 11%);
  --card:            hsl(0 0% 100%);
  --muted:           hsl(220 14% 96%);
  --muted-fg:        hsl(220 9% 46%);
  --border:          hsl(220 13% 91%);

  /* Brand */
  --accent:          hsl(25 95% 53%);
  --accent-2:        hsl(35 100% 60%);
  --accent-fg:       hsl(0 0% 100%);

  /* Dark navy (sidebar / login) */
  --navy:            hsl(222 47% 11%);
  --navy-deep:       hsl(222 47% 6%);
  --navy-mid:        hsl(222 30% 14%);
  --navy-border:     hsl(222 30% 18%);
  --navy-fg:         hsl(220 20% 97%);
  --navy-muted:      hsl(220 9% 60%);

  /* Gradients */
  --grad-accent:     linear-gradient(135deg, hsl(25 95% 53%) 0%, hsl(35 100% 60%) 100%);
  --grad-navy:       linear-gradient(135deg, hsl(222 47% 6%) 0%, hsl(222 40% 12%) 100%);
  --grad-hero:       linear-gradient(135deg, hsl(222 47% 6%) 0%, hsl(222 40% 10%) 50%, hsl(222 47% 6%) 100%);
  --glow:            radial-gradient(ellipse at center, hsl(25 95% 53% / .12) 0%, transparent 70%);

  /* Shadows */
  --shadow-soft:     0 4px 20px -2px hsl(222 47% 11% / .08);
  --shadow-card:     0 8px 30px -10px hsl(222 47% 11% / .12);
  --shadow-glow:     0 0 40px hsl(25 95% 53% / .2);

  /* Radius */
  --radius:          .75rem;
  --radius-sm:       calc(var(--radius) - 2px);
  --radius-lg:       calc(var(--radius) + .25rem);
  --radius-full:     9999px;

  /* Layout */
  --sidebar-w:       280px;
}

html,body{
  height:100%;
  font-family:'Inter',ui-sans-serif,system-ui,sans-serif;
  font-size:1rem;
  background:var(--bg);
  color:var(--foreground);
  -webkit-font-smoothing:antialiased;
}

/* ── Utilities ──────────────────────────────────────────────────── */
.hidden{display:none!important}

/* ── App shell ──────────────────────────────────────────────────── */
#app{display:flex;height:100vh;overflow:hidden}

/* ── Sidebar ────────────────────────────────────────────────────── */
#sidebar{
  width:var(--sidebar-w);
  min-width:var(--sidebar-w);
  display:flex;
  flex-direction:column;
  background:var(--navy);
  color:var(--navy-fg);
  overflow:hidden;
}

.sidebar-header{
  display:flex;
  align-items:center;
  gap:10px;
  padding:18px 16px;
  border-bottom:1px solid var(--navy-border);
}

.user-info{display:flex;align-items:center;gap:10px;flex:1;min-width:0}

.user-name-text{
  font-size:.85rem;
  font-weight:600;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  color:var(--navy-fg);
}

.prompt-counter{
  font-size:.72rem;
  color:var(--navy-muted);
  margin-top:2px;
}

.btn-new{
  background:var(--grad-accent);
  color:#fff;
  border:none;
  border-radius:var(--radius-sm);
  width:32px;height:32px;
  font-size:1.1rem;
  cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
  box-shadow:var(--shadow-glow);
  transition:opacity .15s;
}
.btn-new:hover{opacity:.88}

.conv-list{flex:1;overflow-y:auto;padding:8px}

.conv-item{
  padding:10px 12px;
  border-radius:var(--radius-sm);
  cursor:pointer;
  margin-bottom:2px;
  transition:.15s;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  font-size:.85rem;
  color:var(--navy-muted);
}
.conv-item:hover{background:var(--navy-mid);color:var(--navy-fg)}
.conv-item.active{background:var(--navy-mid);color:var(--navy-fg)}
.conv-item.active .conv-title{font-weight:600}
.conv-title{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.conv-loc{font-size:.7rem;color:hsl(25 95% 60%);margin-top:2px}
.conv-badge{font-size:.65rem;background:hsl(25 95% 53%);color:#fff;border-radius:4px;padding:1px 4px;margin-left:5px;vertical-align:middle}
.conv-badge-mcp{background:hsl(262 80% 55%)}
.conv-row{display:flex;align-items:center;gap:6px}
.conv-del{margin-left:auto;flex-shrink:0;background:transparent;border:none;color:var(--navy-muted);font-size:1rem;line-height:1;cursor:pointer;padding:0 2px;opacity:0;transition:opacity .15s}
.conv-item:hover .conv-del{opacity:1}
.conv-del:hover{color:#f87171}

.btn-logout{
  margin:12px;
  padding:9px;
  background:transparent;
  border:1px solid var(--navy-border);
  color:var(--navy-muted);
  border-radius:var(--radius-sm);
  cursor:pointer;
  font-size:.8rem;
  font-family:inherit;
  transition:.15s;
}
.btn-logout:hover{background:var(--navy-mid);color:var(--navy-fg)}

/* ── Chat area ──────────────────────────────────────────────────── */
#chat-area{
  flex:1;
  display:flex;
  flex-direction:column;
  overflow:hidden;
  background:var(--card);
}

.empty-state{
  flex:1;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:16px;
  color:var(--muted-fg);
  padding:40px;
  text-align:center;
  background:var(--bg);
}
.empty-state h2{color:var(--foreground);font-size:1.4rem;font-weight:700}
.empty-state p{max-width:340px;font-size:.9rem;line-height:1.6}

.messages{
  flex:1;
  overflow-y:auto;
  padding:28px 24px;
  display:flex;
  flex-direction:column;
  gap:20px;
  background:var(--bg);
}

.message{max-width:74%;display:flex;flex-direction:column;gap:4px}
.message.user{align-self:flex-end;align-items:flex-end}
.message.assistant{align-self:flex-start;align-items:flex-start}
@media(max-width:640px){
  .message{max-width:96%}
  .messages{padding:16px 12px;gap:14px}
}

.bubble{
  padding:13px 17px;
  border-radius:var(--radius-lg);
  line-height:1.6;
  font-size:.9rem;
  white-space:pre-wrap;
  word-break:break-word;
  box-shadow:var(--shadow-soft);
}

.message.user .bubble{
  background:var(--grad-accent);
  color:#fff;
  border-bottom-right-radius:4px;
}

.message.assistant .bubble{
  background:var(--card);
  color:var(--foreground);
  border-bottom-left-radius:4px;
  border:1px solid var(--border);
}
.message.assistant .bubble strong{font-weight:700;color:var(--foreground)}

.msg-time{
  font-size:.68rem;
  color:var(--muted-fg);
  padding:0 4px;
}

/* Typing indicator */
.typing .bubble{
  display:flex;
  align-items:center;
  gap:5px;
  padding:15px 18px;
}
.dot{
  width:7px;height:7px;
  background:var(--muted-fg);
  border-radius:50%;
  animation:bounce .9s infinite;
}
.dot:nth-child(2){animation-delay:.2s}
.dot:nth-child(3){animation-delay:.4s}
@keyframes bounce{
  0%,80%,100%{transform:translateY(0)}
  40%{transform:translateY(-7px)}
}

/* ── Input area ─────────────────────────────────────────────────── */
.input-area{
  display:flex;
  align-items:flex-end;
  gap:10px;
  padding:14px 20px;
  border-top:1px solid var(--border);
  background:var(--card);
}

#input{
  flex:1;
  padding:11px 15px;
  border:1.5px solid var(--border);
  border-radius:var(--radius);
  font:inherit;
  font-size:.9rem;
  resize:none;
  max-height:160px;
  outline:none;
  line-height:1.5;
  background:var(--bg);
  color:var(--foreground);
  transition:border-color .15s;
}
#input:focus{border-color:var(--accent)}
#input::placeholder{color:var(--muted-fg)}
#input:disabled{opacity:.5;cursor:not-allowed}

.btn-send{
  width:40px;height:40px;
  background:var(--grad-accent);
  color:#fff;
  border:none;
  border-radius:50%;
  font-size:1.05rem;
  cursor:pointer;
  flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  box-shadow:var(--shadow-glow);
  transition:opacity .15s;
}
.btn-send:hover{opacity:.88}
.btn-send:disabled{background:var(--muted);box-shadow:none;cursor:not-allowed;opacity:1}

.limit-banner{
  background:hsl(25 95% 95%);
  color:hsl(25 95% 30%);
  padding:12px 20px;
  text-align:center;
  font-size:.85rem;
  font-weight:500;
  border-top:1px solid hsl(25 95% 85%);
  display:flex;align-items:center;justify-content:center;gap:12px;flex-wrap:wrap;
}
.btn-upgrade{
  background:var(--grad-accent);color:#fff;border:none;border-radius:var(--radius-full);
  padding:7px 16px;font-size:.85rem;font-weight:700;cursor:pointer;font-family:inherit;
  box-shadow:var(--shadow-glow);transition:opacity .15s;white-space:nowrap;
}
.btn-upgrade:hover{opacity:.88}
.btn-manage{
  background:transparent;color:hsl(25 95% 30%);border:1px solid hsl(25 95% 60%);
  border-radius:var(--radius-full);padding:6px 14px;font-size:.82rem;cursor:pointer;
  font-family:inherit;transition:.15s;
}
.btn-manage:hover{background:hsl(25 95% 88%)}
.sub-badge{
  display:inline-block;font-size:.65rem;background:var(--grad-accent);color:#fff;
  border-radius:4px;padding:1px 5px;margin-left:6px;vertical-align:middle;
}

/* ── Login ──────────────────────────────────────────────────────── */
#login-screen{
  min-height:100vh;
  display:flex;
  align-items:center;
  justify-content:center;
  background:var(--grad-hero);
  position:relative;
  overflow:hidden;
}
#login-screen::before{
  content:'';
  position:absolute;inset:0;
  background:var(--glow);
  pointer-events:none;
}

.login-card{
  position:relative;z-index:1;
  background:hsl(222 47% 8%);
  border:1px solid var(--navy-border);
  border-radius:var(--radius-lg);
  padding:44px 40px;
  width:100%;max-width:400px;
  display:flex;flex-direction:column;
  align-items:center;gap:32px;
  box-shadow:0 20px 60px hsl(0 0% 0% / .4);
}

.login-logo{
  text-align:center;
  display:flex;flex-direction:column;
  align-items:center;gap:14px;
}
.login-logo h1{
  font-size:1.5rem;font-weight:700;
  color:var(--navy-fg);
}
.login-logo p{color:var(--navy-muted);font-size:.875rem}

.login-buttons{width:100%;display:flex;flex-direction:column;gap:10px}

.btn-oauth{
  display:flex;align-items:center;justify-content:center;gap:12px;
  padding:12px 20px;
  border-radius:var(--radius-sm);
  text-decoration:none;
  font-size:.9rem;font-weight:600;font-family:inherit;
  transition:opacity .15s,transform .1s;
  border:none;cursor:pointer;
}
.btn-oauth:hover{opacity:.9;transform:translateY(-1px)}
.btn-oauth:active{transform:translateY(0)}

.btn-email{background:var(--grad-accent);color:#fff;border:none}
.btn-other-email{
  background:transparent;color:var(--navy-muted);
  border:1px solid var(--navy-border);
}
.btn-other-email:hover{color:var(--navy-fg);border-color:hsl(220 9% 46%)}
.btn-back{
  background:transparent;border:none;color:var(--navy-muted);
  font-size:.82rem;cursor:pointer;font-family:inherit;
  align-self:flex-start;padding:0 0 4px;margin-bottom:4px;
}
.btn-back:hover{color:var(--navy-fg)}
.btn-google{
  background:hsl(222 30% 14%);
  color:var(--navy-fg);
  border:1px solid var(--navy-border);
}
.btn-apple{background:#fff;color:#111}

.email-field{width:100%;margin-bottom:8px}
.email-field input{
  width:100%;padding:12px 15px;
  background:hsl(222 30% 14%);border:1.5px solid var(--navy-border);
  border-radius:var(--radius-sm);color:var(--navy-fg);
  font:inherit;font-size:.9rem;outline:none;transition:.15s;
}
.email-field input:focus{border-color:var(--accent)}
.email-field input::placeholder{color:var(--navy-muted)}

.login-divider{
  display:flex;align-items:center;gap:10px;
  color:var(--navy-muted);font-size:.75rem;margin:4px 0;
}
.login-divider::before,.login-divider::after{
  content:'';flex:1;height:1px;background:var(--navy-border);
}

.otp-hint{color:var(--navy-muted);font-size:.82rem;text-align:center;margin-bottom:12px}
.otp-fields{width:100%;margin-bottom:10px}
.otp-fields input{
  width:100%;padding:14px;text-align:center;letter-spacing:.4em;
  font-size:1.5rem;font-weight:700;
  background:hsl(222 30% 14%);border:1.5px solid var(--navy-border);
  border-radius:var(--radius-sm);color:var(--navy-fg);
  font-family:monospace;outline:none;transition:.15s;
}
.otp-fields input:focus{border-color:var(--accent)}

.btn-resend{
  background:transparent;border:none;color:var(--accent);
  font-size:.8rem;cursor:pointer;font-family:inherit;text-decoration:underline;
  margin-top:4px;
}
.login-error{color:#f87171;font-size:.8rem;text-align:center;margin-top:4px}

.login-note{
  color:var(--navy-muted);
  font-size:.78rem;
  text-align:center;
}
.login-contacts{
  display:flex;flex-direction:column;gap:8px;width:100%;
}
.contact-link{
  display:flex;align-items:center;gap:8px;
  color:var(--navy-muted);font-size:.78rem;text-decoration:none;
  padding:6px 10px;border-radius:var(--radius-sm);
  border:1px solid var(--navy-border);
  transition:.15s;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.contact-link:hover{color:var(--accent);border-color:var(--accent)}

.sidebar-contacts{
  display:flex;flex-direction:column;gap:4px;
  padding:0 12px 8px;
}
.sidebar-link{
  display:flex;align-items:center;gap:7px;
  color:var(--navy-muted);font-size:.72rem;text-decoration:none;
  padding:5px 8px;border-radius:var(--radius-sm);
  transition:.15s;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.sidebar-link:hover{color:var(--accent);background:var(--navy-mid)}

/* ── Avatars ────────────────────────────────────────────────────── */
.avatar-big{
  width:80px;height:80px;
  border-radius:50%;
  background:var(--grad-accent);
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-size:2rem;font-weight:700;
  box-shadow:var(--shadow-glow);
  overflow:hidden;flex-shrink:0;
}
.avatar-photo{object-fit:cover;width:100%;height:100%}

.avatar-sm{
  width:36px;height:36px;
  border-radius:50%;
  background:var(--grad-accent);
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-size:.9rem;font-weight:700;
  flex-shrink:0;overflow:hidden;
}
.avatar-sm img{width:100%;height:100%;object-fit:cover}

/* Valérie photo next to assistant messages */
.message.assistant{flex-direction:row;align-items:flex-end;gap:8px}
.msg-avatar{width:28px;height:28px;border-radius:50%;overflow:hidden;flex-shrink:0;margin-bottom:18px}
.msg-avatar img{width:100%;height:100%;object-fit:cover}

/* ── Scrollbar ──────────────────────────────────────────────────── */
::-webkit-scrollbar{width:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--navy-border);border-radius:var(--radius-full)}
.messages::-webkit-scrollbar-thumb{background:var(--border)}

/* ── DVF Table ───────────────────────────────────────────────────── */
.dvf-table-wrap{margin:4px 0 4px 36px;max-width:100%;min-width:0}
.dvf-header{font-size:.82rem;color:var(--muted-fg);margin-bottom:8px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.dvf-header strong{color:var(--foreground)}
.dvf-meta{font-size:.75rem;color:var(--muted-fg)}

/* Analysis summary */
.dvf-analysis{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px}
.dvf-analysis-stat{
  background:var(--muted);border:1px solid var(--border);
  border-radius:var(--radius-sm);padding:6px 11px;
  display:flex;flex-direction:column;gap:2px;flex:1;min-width:80px;
}
.dvf-analysis-label{font-size:.65rem;color:var(--muted-fg);text-transform:uppercase;letter-spacing:.04em;font-weight:500}
.dvf-analysis-value{font-size:.85rem;font-weight:700;color:var(--foreground);white-space:nowrap}
.dvf-trend-up{color:#16a34a}
.dvf-trend-down{color:#dc2626}
.dvf-trend-stable{color:var(--muted-fg)}

/* DVF Map */
.dvf-map{height:260px;border-radius:var(--radius-sm);border:1px solid var(--border);margin-bottom:10px;z-index:0;background:var(--muted)}
.dvf-row-active{background:hsl(25 95% 94%)!important}
.dvf-row-active td{color:hsl(25 80% 25%)!important}
tbody tr{cursor:pointer}
@media(max-width:640px){.dvf-map{height:190px}}

.dvf-scroll{overflow-x:auto;border-radius:var(--radius-sm);border:1px solid var(--border);-webkit-overflow-scrolling:touch}
.dvf-table{width:100%;border-collapse:collapse;font-size:.8rem;white-space:nowrap}
.dvf-th{
  padding:8px 10px;text-align:left;background:var(--muted);
  color:var(--foreground);font-weight:600;cursor:pointer;
  border-bottom:2px solid var(--border);user-select:none;
  transition:.1s;
}
.dvf-th:hover{background:hsl(220 14% 91%)}
.dvf-th.active{color:var(--accent)}
.dvf-table tbody tr{border-bottom:1px solid var(--border)}
.dvf-table tbody tr:last-child{border-bottom:none}
.dvf-table tbody tr:hover{background:hsl(220 20% 98%)}
.dvf-table td{padding:7px 10px;color:var(--foreground)}
.dvf-num{text-align:right;font-variant-numeric:tabular-nums}
.dvf-addr{max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

@media(max-width:640px){
  .dvf-table-wrap{margin-left:0}
  .dvf-col-desktop{display:none}
  .dvf-table{font-size:.75rem}
  .dvf-table td,.dvf-th{padding:6px 7px}
  .dvf-analysis-stat{min-width:70px;padding:5px 8px}
  .dvf-analysis-value{font-size:.8rem}
}

/* ── Search cards ────────────────────────────────────────────────── */
.search-cards{padding:4px 0 4px 36px}
.search-cards-label{font-size:.75rem;font-weight:600;color:var(--muted-fg);text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px}
.search-cards-grid{display:flex;flex-wrap:wrap;gap:8px}
.search-card{
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  padding:10px 14px;border-radius:var(--radius-sm);text-decoration:none;
  background:var(--card);border:1.5px solid var(--site-color);
  color:var(--site-color);font-size:.85rem;font-weight:700;
  transition:.15s;min-width:120px;
}
.search-card:hover{background:var(--site-color);color:#fff}
.search-card-arrow{font-size:1rem}

/* ── Listing photos ──────────────────────────────────────────────── */
.listing-photos{margin:6px 0 14px}
.listing-photos-grid{
  display:grid;gap:10px;
  grid-template-columns:repeat(3, 1fr);
}
.listing-photo{
  position:relative;display:block;aspect-ratio:1/1;border-radius:var(--radius);
  overflow:hidden;background:var(--bg-secondary);
  border:1.5px solid var(--border, hsl(220 15% 88%));
  transition:transform .12s, border-color .12s;
}
.listing-photo:hover{transform:translateY(-1px);border-color:var(--accent)}
.listing-photo img{
  width:100%;height:100%;object-fit:cover;display:block;
}
.listing-photo-label{
  position:absolute;left:8px;bottom:8px;
  padding:3px 8px;border-radius:999px;
  background:rgba(0,0,0,.55);color:#fff;
  font-size:.72rem;font-weight:600;letter-spacing:.02em;
  backdrop-filter:blur(4px);
}
.listing-photos-caption{
  margin-top:8px;font-size:.78rem;color:var(--muted-fg);
}
@media(max-width:640px){
  .listing-photos-grid{grid-template-columns:repeat(3, 1fr);gap:6px}
  .listing-photo-label{font-size:.65rem;padding:2px 6px;left:4px;bottom:4px}
}

/* ── Listing cards ───────────────────────────────────────────────── */
.listing-cards{margin:8px 0 8px 36px;max-width:100%}
.listing-cards-header{
  font-size:.78rem;font-weight:600;color:var(--muted-fg);
  text-transform:uppercase;letter-spacing:.05em;margin-bottom:10px;
}
.listing-cards-grid{
  display:grid;gap:12px;
  grid-template-columns:repeat(auto-fill,minmax(260px,1fr));
}
.listing-card{
  display:flex;flex-direction:column;gap:10px;
  padding:14px 16px;border-radius:var(--radius);
  background:var(--card);border:1.5px solid var(--border, hsl(220 15% 88%));
  text-align:left;cursor:pointer;font-family:inherit;color:inherit;
  transition:transform .12s, border-color .12s, box-shadow .12s;
  width:100%;
}
.listing-card:hover{
  border-color:var(--accent);
  box-shadow:0 4px 14px hsl(25 95% 53% / .12);
  transform:translateY(-1px);
}
.listing-card.selected{
  border-color:var(--accent);
  background:hsl(25 95% 53% / .06);
  box-shadow:0 0 0 1px var(--accent);
}
.listing-card-head{
  display:flex;align-items:center;justify-content:space-between;
  font-size:.78rem;font-weight:700;color:var(--muted-fg);
  text-transform:uppercase;letter-spacing:.04em;
}
.listing-card-tone{color:var(--accent)}
.listing-card-lang{font-size:1rem}
.listing-card-body{
  font-size:.88rem;line-height:1.5;color:var(--fg, inherit);
  white-space:pre-wrap;
}
.listing-card-foot{
  display:flex;justify-content:flex-end;
  font-size:.75rem;color:var(--muted-fg);font-weight:600;
}
.listing-card-action{
  padding:4px 10px;border-radius:999px;background:var(--bg-secondary);
}
.listing-card.selected .listing-card-action{
  background:var(--accent);color:var(--accent-fg);
}
@media(max-width:640px){
  .listing-cards{margin-left:0}
  .listing-cards-grid{grid-template-columns:1fr}
}

/* ── AirBnB import — sidebar button, modal, listing block ───────── */
.btn-airbnb-import{
  display:flex;align-items:center;gap:8px;justify-content:center;
  margin:0 12px 8px;padding:9px 12px;
  border-radius:var(--radius-sm);border:none;
  background:var(--grad-accent);color:#fff;font-family:inherit;
  font-size:.8rem;font-weight:600;cursor:pointer;width:calc(100% - 24px);
  box-shadow:var(--shadow-glow);
  transition:opacity .15s;
}
.btn-airbnb-import:hover{opacity:.88}

.airbnb-modal{
  position:fixed;inset:0;z-index:1100;background:rgba(15,23,42,.72);
  backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;
  padding:20px;
}
.airbnb-modal-inner{
  display:flex;flex-direction:column;width:min(520px,100%);
  background:var(--card,white);border-radius:var(--radius);overflow:hidden;
  box-shadow:0 20px 60px rgba(0,0,0,.35);
}
.airbnb-modal-head{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 18px;border-bottom:1px solid var(--border,hsl(220 15% 88%));
  font-weight:600;
}
.airbnb-modal-close{
  border:none;background:transparent;font-size:1.6rem;line-height:1;
  cursor:pointer;color:var(--muted-fg);padding:0 6px;
}
.airbnb-modal-close:hover{color:var(--accent)}
.airbnb-modal-body{padding:18px;display:flex;flex-direction:column;gap:12px}
.airbnb-modal-body p{margin:0;font-size:.85rem;color:var(--muted-fg);line-height:1.5}
.airbnb-url-input{
  padding:10px 14px;border-radius:var(--radius-sm);font-size:.9rem;font-family:ui-monospace,monospace;
  border:1.5px solid var(--border,hsl(220 15% 88%));
}
.airbnb-url-input:focus{outline:none;border-color:var(--accent)}
.airbnb-import-submit{
  padding:10px 18px;border-radius:var(--radius-sm);
  background:var(--accent);color:var(--accent-fg,white);border:none;
  font-weight:700;cursor:pointer;font-family:inherit;
}
.airbnb-import-submit:disabled{opacity:.6;cursor:wait}
.airbnb-import-error{
  font-size:.8rem;color:#dc2626;background:hsl(0 80% 96%);
  padding:8px 12px;border-radius:var(--radius-sm);
}

/* AirBnB listing block (above picker) */
.abnb-block{
  margin:6px 0 14px;padding:14px 16px;border-radius:var(--radius);
  background:linear-gradient(180deg,hsl(348 80% 97%) 0%,var(--card) 100%);
  border:1.5px solid hsl(348 60% 90%);
  display:flex;flex-direction:column;gap:12px;
}
.abnb-head{display:flex;align-items:flex-start;gap:10px}
.abnb-icon{
  width:32px;height:32px;display:flex;align-items:center;justify-content:center;
  background:hsl(348 75% 53%);color:#fff;font-weight:900;font-size:1rem;
  border-radius:50%;flex-shrink:0;
}
.abnb-head-text{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}
.abnb-title{font-weight:700;font-size:.95rem;color:var(--fg,inherit)}
.abnb-source{font-size:.72rem;color:hsl(348 75% 53%);text-decoration:none}
.abnb-source:hover{text-decoration:underline}

.abnb-gallery{
  display:flex;gap:6px;overflow-x:auto;padding-bottom:4px;
  scrollbar-width:thin;
}
.abnb-photo{
  flex:0 0 200px;height:140px;position:relative;border-radius:var(--radius-sm);
  overflow:hidden;background:#eee;display:block;
}
.abnb-photo img{width:100%;height:100%;object-fit:cover;display:block;transition:.15s}
.abnb-photo:hover img{transform:scale(1.03)}
.abnb-photo-label{
  position:absolute;left:6px;bottom:6px;
  padding:2px 7px;border-radius:999px;
  background:rgba(0,0,0,.6);color:#fff;
  font-size:.65rem;font-weight:600;
  backdrop-filter:blur(3px);
}
.abnb-description{
  border-top:1px solid hsl(348 40% 92%);padding-top:8px;
  font-size:.82rem;
}
.abnb-description summary{
  cursor:pointer;font-weight:600;color:hsl(348 75% 40%);
  padding:4px 0;list-style:none;
}
.abnb-description summary::-webkit-details-marker{display:none}
.abnb-description summary::before{content:'▸ ';transition:.15s}
.abnb-description[open] summary::before{content:'▾ '}
.abnb-description-body{
  margin-top:8px;color:var(--fg,inherit);line-height:1.55;
  max-height:280px;overflow-y:auto;
}

/* ── Location picker — always-on map-confirm for listings ─────────── */
.loc-picker{
  display:flex;flex-direction:column;gap:10px;width:100%;
  margin:6px 0 14px;padding:14px 16px;border-radius:var(--radius);
  background:hsl(220 30% 97%);
  border:1.5px dashed hsl(220 15% 75%);
}
.loc-picker-head{display:flex;align-items:flex-start;gap:12px}
.loc-picker-icon{font-size:1.4rem;line-height:1.2}
.loc-picker-title{font-weight:600;font-size:.95rem;color:var(--fg,inherit)}
.loc-picker-sub{font-size:.78rem;color:var(--muted-fg);margin-top:2px}
.loc-picker-sub em{font-style:normal;color:var(--accent);font-weight:600}
.loc-picker-search{display:flex;gap:6px}
.loc-picker-input{
  flex:1;padding:8px 12px;border-radius:var(--radius-sm);font-size:.85rem;
  border:1.5px solid var(--border,hsl(220 15% 88%));font-family:inherit;
}
.loc-picker-input:focus{outline:none;border-color:var(--accent)}
.loc-picker-search-btn{
  padding:8px 14px;border-radius:var(--radius-sm);font-size:.8rem;
  background:var(--card,white);border:1.5px solid var(--border,hsl(220 15% 88%));
  color:var(--fg,inherit);font-family:inherit;font-weight:600;cursor:pointer;
}
.loc-picker-search-btn:hover{border-color:var(--accent);color:var(--accent)}
.loc-picker-search-btn:disabled{opacity:.6;cursor:wait}
.loc-picker-map{
  width:100%;height:280px;border-radius:var(--radius-sm);
  background:#e5e7eb;overflow:hidden;
  border:1.5px solid var(--border,hsl(220 15% 88%));
}
.loc-picker-coords{
  font-family:ui-monospace,monospace;font-size:.72rem;color:var(--muted-fg);
  text-align:center;
}
.loc-picker-actions{display:flex;gap:8px;justify-content:space-between;align-items:center;flex-wrap:wrap}
.loc-picker-here{
  padding:8px 14px;border-radius:var(--radius-sm);font-size:.8rem;
  background:var(--card,white);border:1.5px solid var(--border,hsl(220 15% 88%));
  color:var(--fg,inherit);font-family:inherit;font-weight:600;cursor:pointer;
}
.loc-picker-here:hover{border-color:var(--accent);color:var(--accent)}
.loc-picker-here:disabled{opacity:.6;cursor:wait}
.loc-picker-confirm{
  padding:9px 18px;border-radius:var(--radius-sm);font-size:.85rem;
  background:var(--accent);color:var(--accent-fg,white);border:none;
  font-family:inherit;font-weight:700;cursor:pointer;
}
.loc-picker-confirm:hover{filter:brightness(1.05)}
.loc-picker-confirm:disabled{opacity:.5;cursor:not-allowed;filter:none}
.loc-picker-error{
  font-size:.8rem;color:#dc2626;background:hsl(0 80% 96%);
  padding:8px 12px;border-radius:var(--radius-sm);
}
@media(max-width:640px){
  .loc-picker-map{height:220px}
}

/* ── Connectivity strip & map modal ───────────────────────────────── */
.stars{
  display:inline-block;position:relative;font-size:.95rem;line-height:1;
  color:hsl(220 15% 80%);letter-spacing:1px;white-space:nowrap;
}
.stars::before{content:"★★★★★"}
.stars-fill{
  position:absolute;top:0;left:0;overflow:hidden;color:hsl(40 95% 55%);
}
.stars-fill::before{content:"★★★★★"}

.conn-strip{
  display:flex;flex-direction:column;gap:8px;width:100%;
  margin:6px 0 14px;padding:12px 14px;border-radius:var(--radius);
  background:linear-gradient(180deg,hsl(25 95% 53% / .06) 0%,var(--card) 100%);
  border:1.5px solid var(--border, hsl(220 15% 88%));
  text-align:left;cursor:pointer;font-family:inherit;color:inherit;
  transition:transform .12s, border-color .12s, box-shadow .12s;
}
.conn-strip:hover{
  border-color:var(--accent);
  box-shadow:0 4px 14px hsl(25 95% 53% / .12);
  transform:translateY(-1px);
}
.conn-strip-head{
  display:flex;align-items:center;gap:10px;
  font-size:.85rem;font-weight:600;
}
.conn-strip-icon{font-size:1.1rem}
.conn-strip-title{flex:1;color:var(--fg, inherit)}
.conn-strip-overall{display:flex;align-items:center;gap:6px;font-size:.85rem}
.conn-strip-overall strong{font-size:.95rem;color:var(--accent)}
.conn-strip-rows{display:flex;flex-direction:column;gap:4px}
.conn-strip-row{
  display:grid;grid-template-columns:48px auto 1fr;
  align-items:center;gap:10px;font-size:.8rem;
}
.conn-strip-label{font-weight:700;color:var(--muted-fg);font-size:.75rem;letter-spacing:.04em}
.conn-strip-meta{color:var(--muted-fg);font-size:.75rem;text-align:right}
.conn-strip-foot{
  font-size:.72rem;color:var(--accent);font-weight:600;
  text-align:right;margin-top:2px;
}
.conn-modal{
  position:fixed;inset:0;z-index:1000;background:rgba(15,23,42,.72);
  backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;
  padding:20px;animation:conn-fade .15s ease-out;
}
@keyframes conn-fade{from{opacity:0}to{opacity:1}}
.conn-modal-inner{
  display:flex;flex-direction:column;width:min(960px,100%);height:min(85vh,720px);
  background:var(--card,white);border-radius:var(--radius);overflow:hidden;
  box-shadow:0 20px 60px rgba(0,0,0,.35);
}
.conn-modal-head{
  display:flex;align-items:center;justify-content:space-between;
  padding:12px 16px;border-bottom:1px solid var(--border, hsl(220 15% 88%));
  font-weight:600;font-size:.95rem;
}
.conn-modal-close{
  border:none;background:transparent;font-size:1.6rem;line-height:1;
  cursor:pointer;color:var(--muted-fg);padding:0 6px;
}
.conn-modal-close:hover{color:var(--accent)}
.conn-modal-frame{flex:1;width:100%;border:none}
@media(max-width:640px){
  .conn-modal{padding:0}
  .conn-modal-inner{width:100%;height:100%;border-radius:0}
  .conn-strip-row{grid-template-columns:42px auto 1fr;gap:6px}
}

/* ── Responsive ─────────────────────────────────────────────────── */
@media(max-width:640px){
  :root{--sidebar-w:100%}
  #app{flex-direction:column}
  #sidebar{width:100%;min-width:unset;max-height:190px}
  .conv-list{flex-direction:row;display:flex;overflow-x:auto;overflow-y:hidden;padding:4px 8px;gap:6px}
  .conv-item{min-width:130px;flex-shrink:0}
  .login-card{margin:16px;padding:32px 24px}
}
