.concierge-hero{
  background:
    linear-gradient(105deg,rgba(248,251,252,.94) 0%,rgba(248,251,252,.72) 48%,rgba(248,251,252,.28) 100%),
    url("destinations/rapallo-harbour.jpg") center/cover no-repeat;
  border-bottom:1px solid rgba(36,51,74,.10);
}
.concierge-hero-inner{
  min-height:430px;
  padding:70px 0 54px;
  display:grid;
  grid-template-columns:minmax(0,.78fr) minmax(300px,.32fr);
  gap:28px;
  align-items:end;
}
.concierge-hero h1{
  margin:0;
  max-width:820px;
  font-size:56px;
  line-height:1;
}
.concierge-hero p{
  max-width:760px;
  margin:18px 0 0;
  color:var(--muted);
  font-size:18px;
}
.concierge-card,
.concierge-form,
.concierge-result,
.chat-panel{
  border:1px solid var(--line);
  border-radius:var(--radius);
  background:rgba(255,255,255,.94);
  box-shadow:0 18px 42px rgba(36,51,74,.10);
}
.concierge-card{
  padding:20px;
}
.concierge-card strong{
  display:block;
  font-size:20px;
}
.concierge-card ul{
  margin:10px 0 0;
  padding-left:18px;
  color:var(--muted);
}
.concierge-page{
  padding-bottom:0;
  height:100vh;
  height:100dvh;
  overflow:hidden;
}
.concierge-page .concierge-hero{
  display:none;
}
.concierge-page .site-header{
  position:relative;
}
.concierge-page .nav{
  width:min(1220px,calc(100% - 32px));
  min-height:68px;
}
.concierge-page .brand img{
  width:150px;
  max-height:46px;
}
.concierge-page .nav-links{
  gap:12px;
}
.concierge-page .nav-links a{
  font-size:13px;
}
.concierge-page .nav-links .btn{
  min-height:40px;
  padding:9px 15px;
}
.concierge-main{
  height:calc(100vh - 69px);
  height:calc(100dvh - 69px);
  min-height:0;
  overflow:hidden;
  display:grid;
}
.concierge-page .section{
  min-height:0;
  padding:14px 0;
  overflow:hidden;
}
.concierge-page .section-inner{
  width:min(1220px,calc(100% - 32px));
  min-height:0;
  height:100%;
}
.concierge-layout{
  display:grid;
  grid-template-columns:minmax(0,.55fr) minmax(340px,.45fr);
  gap:20px;
  align-items:start;
}
.chat-layout{
  grid-template-columns:minmax(470px,.48fr) minmax(430px,.52fr);
  gap:14px;
  align-items:stretch;
}
.chat-panel{
  min-height:720px;
  display:grid;
  grid-template-rows:auto minmax(420px,1fr) auto auto;
  overflow:hidden;
}
.concierge-page .chat-panel{
  height:100%;
  min-height:0;
  grid-template-rows:auto minmax(0,1fr) auto auto;
}
.chat-heading{
  padding:22px 22px 14px;
  border-bottom:1px solid var(--line);
  display:flex;
  justify-content:space-between;
  gap:18px;
  align-items:flex-start;
}
.chat-heading h2{
  margin:0;
  font-size:32px;
  line-height:1.08;
}
.chat-heading p{
  color:var(--muted);
}
.concierge-page .chat-heading{
  padding:12px 16px 10px;
  gap:12px;
  align-items:center;
}
.concierge-page .chat-heading .kicker{
  display:none;
}
.concierge-page .chat-heading h2{
  font-size:24px;
}
.concierge-page .chat-heading p{
  margin:4px 0 0;
  font-size:13px;
  line-height:1.35;
}
.lia-heading-copy{
  min-width:0;
}
.lia-name-row{
  display:flex;
  align-items:center;
  gap:12px;
}
.lia-portrait{
  width:46px;
  height:46px;
  flex:0 0 auto;
  display:grid;
  place-items:center;
  border:1px solid rgba(61,155,167,.34);
  border-radius:50%;
  background:
    linear-gradient(145deg,rgba(61,155,167,.18),rgba(255,255,255,.96)),
    radial-gradient(circle at 35% 28%,rgba(255,255,255,.95),transparent 34%);
  color:var(--brand);
  font-size:12px;
  font-weight:900;
  letter-spacing:.08em;
  box-shadow:0 10px 22px rgba(36,51,74,.10);
}
.lia-portrait.large{
  width:78px;
  height:78px;
  margin:0 auto 4px;
  font-size:18px;
}
.chat-presence{
  display:inline-flex;
  align-items:center;
  gap:8px;
  flex:0 0 auto;
  border:1px solid rgba(61,155,167,.28);
  border-radius:999px;
  background:var(--soft);
  color:var(--brand);
  padding:7px 10px;
  font-size:13px;
  font-weight:900;
}
.chat-presence span{
  width:8px;
  height:8px;
  border-radius:50%;
  background:#24a16f;
  box-shadow:0 0 0 4px rgba(36,161,111,.13);
}
.chat-presence.busy span{
  background:var(--accent);
  animation:pulseDot 1.1s infinite ease-in-out;
}
@keyframes pulseDot{
  0%,100%{transform:scale(1);opacity:.65}
  50%{transform:scale(1.35);opacity:1}
}
.chat-messages{
  display:grid;
  align-content:start;
  gap:12px;
  min-height:420px;
  max-height:680px;
  overflow:auto;
  padding:22px;
  background:
    linear-gradient(180deg,rgba(247,251,252,.78),rgba(255,255,255,.94)),
    radial-gradient(circle at 12px 12px,rgba(61,155,167,.08) 1px,transparent 1.5px);
  background-size:auto,24px 24px;
}
.concierge-page .chat-messages{
  min-height:0;
  max-height:none;
  padding:16px;
  gap:10px;
}
.chat-message{
  display:grid;
  grid-template-columns:36px minmax(0,1fr);
  gap:10px;
  align-items:start;
}
.chat-message.user{
  grid-template-columns:minmax(0,1fr) 36px;
}
.chat-message.user .avatar{
  grid-column:2;
  grid-row:1;
}
.chat-message.user .bubble{
  grid-column:1;
  grid-row:1;
  justify-self:end;
  background:var(--brand);
  color:#fff;
  border-color:var(--brand);
}
.avatar{
  width:36px;
  height:36px;
  border:1px solid rgba(61,155,167,.30);
  border-radius:50%;
  display:grid;
  place-items:center;
  background:var(--soft);
  color:var(--brand);
  font-size:11px;
  font-weight:900;
}
.bubble{
  width:fit-content;
  max-width:min(78%,680px);
  border:1px solid rgba(36,51,74,.10);
  border-radius:18px 18px 18px 5px;
  background:#fff;
  padding:12px 14px 7px;
  color:var(--ink);
  box-shadow:0 8px 18px rgba(36,51,74,.07);
}
.concierge-page .bubble{
  max-width:min(84%,680px);
  padding:10px 12px 7px;
}
.chat-message.user .bubble{
  border-radius:18px 18px 5px 18px;
  max-width:min(78%,680px);
}
.bubble p{
  margin:0;
  line-height:1.52;
}
.bubble p + p{
  margin-top:8px;
}
.bubble time{
  display:block;
  margin-top:5px;
  color:rgba(36,51,74,.54);
  font-size:11px;
  line-height:1;
  text-align:right;
}
.chat-message.user .bubble time{
  color:rgba(255,255,255,.70);
}
.chat-action-button{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:100%;
  min-height:46px;
  margin:12px 0 4px;
  border:1px solid var(--brand);
  border-radius:999px;
  background:var(--brand);
  color:#fff;
  padding:0 16px;
  font-weight:900;
  cursor:pointer;
}
.chat-action-button:hover,
.chat-action-button:focus-visible{
  background:#1a2940;
}
.chat-action-button:disabled{
  cursor:progress;
  opacity:.72;
}
.chat-lead-form{
  display:grid;
  gap:10px;
  margin:12px 0 4px;
}
.chat-lead-form label{
  display:grid;
  gap:5px;
  color:var(--ink);
  font-weight:900;
  font-size:13px;
}
.chat-lead-form input[type="text"],
.chat-lead-form input[type="email"]{
  width:100%;
  min-height:42px;
  border:1px solid rgba(36,51,74,.16);
  border-radius:12px;
  background:#fff;
  color:var(--ink);
  padding:9px 11px;
  font:inherit;
}
.chat-lead-form .lead-consent{
  display:grid;
  grid-template-columns:auto minmax(0,1fr);
  align-items:start;
  gap:9px;
  color:var(--muted);
  font-weight:700;
  line-height:1.35;
}
.chat-lead-form .lead-consent input{
  width:18px;
  height:18px;
  margin-top:2px;
  accent-color:var(--accent);
}
.typing .bubble{
  min-width:260px;
}
.typing-dots{
  display:flex;
  gap:4px;
  margin-top:9px;
}
.typing-dots span{
  width:6px;
  height:6px;
  border-radius:50%;
  background:var(--accent);
  opacity:.35;
  animation:pulseTyping 1.2s infinite ease-in-out;
}
.typing-dots span:nth-child(2){
  animation-delay:.15s;
}
.typing-dots span:nth-child(3){
  animation-delay:.30s;
}
@keyframes pulseTyping{
  0%,100%{opacity:.25;transform:translateY(0)}
  50%{opacity:.95;transform:translateY(-3px)}
}
.chat-composer{
  padding:18px 22px 14px;
  border-top:1px solid var(--line);
  background:linear-gradient(180deg,#fff,rgba(247,251,252,.94));
}
.concierge-page .chat-composer{
  padding:10px 16px 10px;
}
.composer-box{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:12px;
  align-items:end;
  border:1px solid rgba(36,51,74,.16);
  border-radius:22px;
  background:#fff;
  padding:10px 10px 10px 16px;
  box-shadow:0 12px 28px rgba(36,51,74,.08);
}
.concierge-page .composer-box{
  border-radius:18px;
  padding:8px 8px 8px 12px;
}
.chat-composer textarea{
  width:100%;
  min-height:92px;
  max-height:220px;
  resize:vertical;
  border:0;
  border-radius:16px;
  padding:8px 4px;
  color:var(--ink);
  line-height:1.45;
  font-size:16px;
  outline:none;
}
.concierge-page .chat-composer textarea{
  min-height:58px;
  max-height:120px;
  font-size:15px;
  resize:none;
  overflow:hidden;
}
.chat-composer textarea::placeholder{
  color:rgba(36,51,74,.52);
}
.send-button{
  align-self:end;
  min-width:88px;
  min-height:52px;
  border:1px solid var(--brand);
  border-radius:999px;
  background:var(--brand);
  color:#fff;
  padding:0 18px;
  font-weight:900;
  cursor:pointer;
}
.concierge-page .send-button{
  min-width:78px;
  min-height:46px;
  padding:0 15px;
}
.send-button:disabled{
  cursor:progress;
  opacity:.72;
}
.send-button:disabled span::after{
  content:"...";
}
.chat-panel > .concierge-note{
  padding:0 22px 18px;
}
.concierge-page .chat-panel > .concierge-note{
  margin:0;
  padding:0 16px 12px;
  font-size:12px;
  line-height:1.35;
}
.concierge-page .footer{
  display:none;
}
.visually-hidden{
  position:absolute;
  width:1px;
  height:1px;
  padding:0;
  margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap;
  border:0;
}
.concierge-form{
  padding:22px;
}
.concierge-form h2{
  margin:0;
}
.concierge-form p{
  color:var(--muted);
}
.form-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px;
  margin:18px 0;
}
.concierge-form label,
.concierge-form legend{
  font-weight:900;
}
.concierge-form input,
.concierge-form select,
.concierge-form textarea{
  width:100%;
  min-height:44px;
  margin-top:6px;
  border:1px solid var(--line);
  border-radius:var(--radius);
  background:#fff;
  color:var(--ink);
  padding:10px 12px;
}
.concierge-form textarea{
  min-height:110px;
  resize:vertical;
  line-height:1.45;
}
.concierge-form fieldset{
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:14px;
  margin:14px 0;
}
.interest-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:8px;
  margin-top:10px;
}
.check{
  display:flex;
  align-items:center;
  gap:9px;
  min-height:34px;
  color:var(--ink);
}
.check input{
  width:18px;
  min-height:18px;
  margin:0;
  accent-color:var(--accent);
}
.surprise-check{
  border:1px solid rgba(61,155,167,.34);
  border-radius:var(--radius);
  background:var(--soft);
  padding:12px;
  margin:14px 0;
}
.concierge-note{
  margin:12px 0 0;
  font-size:13px;
}
.concierge-result{
  min-height:420px;
  padding:22px;
}
.concierge-page .concierge-result{
  height:100%;
  min-height:0;
  overflow:auto;
  padding:18px;
}
.result-loading,
.result-waiting{
  min-height:360px;
  display:grid;
  align-content:center;
  justify-items:center;
  text-align:center;
  gap:12px;
  color:var(--muted);
}
.result-loading strong,
.result-waiting strong{
  color:var(--ink);
  font-size:22px;
}
.loader-ring{
  width:46px;
  height:46px;
  border:4px solid rgba(61,155,167,.18);
  border-top-color:var(--accent);
  border-radius:50%;
  animation:spinLoader 1s linear infinite;
}
.result-waiting span{
  width:40px;
  height:40px;
  border-radius:50%;
  background:var(--soft);
  border:1px solid rgba(61,155,167,.34);
}
.profile-progress{
  width:min(520px,100%);
  margin-top:12px;
  border:1px solid rgba(36,51,74,.12);
  border-radius:14px;
  background:#fff;
  padding:14px;
  text-align:left;
  box-shadow:0 10px 24px rgba(36,51,74,.06);
}
.progress-top{
  display:flex;
  justify-content:space-between;
  gap:12px;
  align-items:center;
}
.progress-top strong{
  font-size:15px;
  color:var(--ink);
}
.progress-top small{
  color:var(--brand);
  font-weight:900;
}
.progress-bar{
  height:8px;
  margin:10px 0 12px;
  border-radius:999px;
  background:rgba(36,51,74,.08);
  overflow:hidden;
}
.progress-bar span{
  display:block;
  height:100%;
  border:0;
  border-radius:999px;
  background:linear-gradient(90deg,var(--accent),var(--brand));
}
.progress-chips{
  display:flex;
  flex-wrap:wrap;
  gap:7px;
}
.progress-chips span{
  width:auto;
  height:auto;
  display:inline-flex;
  border:1px solid rgba(61,155,167,.28);
  border-radius:999px;
  background:var(--soft);
  color:var(--brand);
  padding:5px 9px;
  font-size:12px;
  font-weight:900;
}
.progress-missing{
  margin-top:12px;
  color:var(--muted);
  font-size:13px;
}
.progress-missing ul{
  margin:6px 0 0;
  padding-left:18px;
}
@keyframes spinLoader{
  to{transform:rotate(360deg)}
}
.empty-state{
  color:var(--muted);
}
.lia-empty{
  min-height:100%;
  display:grid;
  align-content:center;
  justify-items:center;
  text-align:center;
  gap:10px;
  color:var(--muted);
}
.lia-empty .kicker{
  margin:0;
  color:var(--brand);
}
.lia-empty strong{
  max-width:520px;
  color:var(--ink);
  font-size:28px;
  line-height:1.08;
}
.lia-empty p{
  max-width:620px;
  margin:0;
}
.lia-traits{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:8px;
  margin-top:6px;
}
.lia-traits span{
  border:1px solid rgba(61,155,167,.30);
  border-radius:999px;
  background:var(--soft);
  color:var(--brand);
  padding:6px 10px;
  font-size:12px;
  font-weight:900;
}
.starter-prompts{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:9px;
  width:min(660px,100%);
  margin-top:10px;
}
.starter-chip{
  min-height:44px;
  border:1px solid rgba(36,51,74,.14);
  border-radius:14px;
  background:#fff;
  color:var(--ink);
  padding:9px 11px;
  font:inherit;
  font-size:13px;
  font-weight:900;
  cursor:pointer;
  box-shadow:0 8px 18px rgba(36,51,74,.06);
}
.starter-chip:hover,
.starter-chip:focus-visible{
  border-color:rgba(61,155,167,.55);
  background:var(--soft);
  color:var(--brand);
  outline:none;
}
.result-title{
  margin:0 0 8px;
  font-size:30px;
  line-height:1.1;
}
.concierge-page .result-title{
  font-size:25px;
}
.result-profile{
  margin:0 0 16px;
  color:var(--muted);
}
.local-debug{
  display:inline-flex;
  margin:0 0 10px;
  border:1px solid rgba(61,155,167,.34);
  border-radius:999px;
  background:var(--soft);
  color:var(--brand);
  padding:5px 9px;
  font-size:12px;
  font-weight:900;
}
.reading-card{
  border:1px solid rgba(61,155,167,.34);
  border-radius:var(--radius);
  background:var(--soft);
  padding:15px;
  margin:12px 0 16px;
}
.reading-card span{
  color:var(--brand);
  font-size:12px;
  font-weight:900;
  text-transform:uppercase;
}
.reading-card h3{
  margin:6px 0;
  font-size:22px;
}
.reading-card p,
.reading-card small{
  color:var(--muted);
}
.question-list{
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:12px 14px 12px 28px;
  background:#fff;
  list-style:disc;
}
.journey-map,
.contingency-section,
.refine-box{
  margin:16px 0;
}
.journey-map h3,
.contingency-section h3,
.refine-box h3{
  margin:0 0 10px;
}
.journey-track{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:10px;
}
.journey-step{
  position:relative;
  border:1px solid rgba(61,155,167,.28);
  border-radius:var(--radius);
  background:linear-gradient(180deg,#fff 0%,var(--soft) 100%);
  padding:13px;
}
.journey-step span,
.contingency-card span{
  display:inline-flex;
  color:var(--brand);
  font-size:12px;
  font-weight:900;
  text-transform:uppercase;
}
.journey-step strong,
.contingency-card strong{
  display:block;
  margin-top:6px;
}
.journey-step p,
.contingency-card p,
.refine-box p{
  margin:6px 0 0;
  color:var(--muted);
}
.contingency-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:10px;
}
.contingency-card,
.refine-box{
  border:1px solid var(--line);
  border-radius:var(--radius);
  background:#fff;
  padding:13px;
}
.refine-actions{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  margin-top:12px;
}
.refine-actions button{
  min-height:38px;
  border:1px solid rgba(36,51,74,.18);
  border-radius:999px;
  background:#fff;
  color:var(--ink);
  padding:8px 12px;
  font-weight:900;
  cursor:pointer;
}
.refine-actions button:hover,
.refine-actions button:focus-visible{
  border-color:var(--brand);
  color:var(--brand);
}
.mini-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px;
  margin:12px 0 16px;
}
.mini-card{
  border:1px solid var(--line);
  border-radius:var(--radius);
  background:#fff;
  padding:13px;
}
.mini-card span{
  display:inline-flex;
  border:1px solid rgba(61,155,167,.28);
  border-radius:999px;
  padding:4px 8px;
  color:var(--brand);
  font-size:12px;
  font-weight:900;
}
.mini-card h3{
  margin:8px 0 6px;
  font-size:18px;
}
.mini-card p{
  margin:6px 0;
  color:var(--muted);
}
.mini-card small{
  display:block;
  color:var(--muted);
}
.mini-card a{
  display:inline-flex;
  margin-top:8px;
  font-weight:900;
}
.day-card{
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:14px;
  margin:12px 0;
  background:#fff;
}
.day-card h3{
  margin:0 0 8px;
}
.day-card ul{
  margin:0;
  padding-left:18px;
  color:var(--muted);
}
.source-list{
  display:grid;
  gap:6px;
  margin:14px 0;
  padding:0;
  list-style:none;
}
.source-list a{
  font-weight:850;
}
.concierge-cta{
  border:1px solid rgba(61,155,167,.34);
  border-radius:var(--radius);
  background:var(--soft);
  padding:16px;
  margin-top:16px;
}
.concierge-cta p{
  margin:0 0 12px;
  color:var(--muted);
}
.concierge-error{
  border:1px solid #d7a1a1;
  background:#fff7f7;
  color:#7a1f1f;
  padding:14px;
  border-radius:var(--radius);
}
@media (max-width:900px){
  .concierge-page{
    height:auto;
    overflow:auto;
  }
  .concierge-main{
    height:auto;
    overflow:visible;
  }
  .concierge-page .section{
    overflow:visible;
    padding:16px 0 28px;
  }
  .concierge-page .section-inner{
    height:auto;
  }
  .concierge-page .footer{
    display:block;
  }
  .concierge-page .chat-panel{
    height:auto;
    min-height:640px;
  }
  .concierge-page .concierge-result{
    height:auto;
    min-height:320px;
    overflow:visible;
  }
  .concierge-hero-inner,
  .concierge-layout{
    grid-template-columns:1fr;
  }
  .concierge-hero h1{
    font-size:42px;
  }
}
@media (max-width:560px){
  .concierge-page{
    height:100dvh;
    overflow:hidden;
  }
  .concierge-main{
    height:calc(100dvh - 69px);
    overflow:hidden;
  }
  .concierge-page .section{
    height:100%;
    padding:8px 0;
    overflow:hidden;
  }
  .concierge-page .section-inner{
    height:100%;
    width:min(100% - 16px, 1220px);
  }
  .concierge-layout,
  .chat-layout{
    display:block;
    height:100%;
  }
  .concierge-page .concierge-result{
    display:none;
  }
  .concierge-page .chat-panel{
    height:100%;
    min-height:0;
    grid-template-rows:auto minmax(0,1fr) auto auto;
  }
  .chat-panel{
    min-height:0;
  }
  .chat-messages{
    padding:12px;
    max-height:none;
    gap:9px;
  }
  .chat-composer{
    padding:10px 12px;
  }
  .composer-box{
    grid-template-columns:minmax(0,1fr) auto;
    gap:8px;
    border-radius:16px;
    padding:8px;
  }
  .chat-composer textarea{
    min-height:76px;
    font-size:16px;
  }
  .send-button{
    width:74px;
    min-height:52px;
    align-self:end;
    padding:10px;
  }
  .chat-heading{
    padding:12px;
    display:grid;
    gap:8px;
  }
  .concierge-page .chat-heading h2{
    font-size:23px;
  }
  .concierge-page .chat-heading p{
    font-size:12px;
  }
  .starter-prompts{
    grid-template-columns:1fr;
  }
  .chat-message,
  .chat-message.user{
    grid-template-columns:34px minmax(0,1fr);
  }
  .chat-message.user .avatar{
    grid-column:1;
  }
  .chat-message.user .bubble{
    grid-column:2;
    justify-self:start;
  }
  .avatar{
    width:34px;
    height:34px;
  }
  .bubble,
  .chat-message.user .bubble{
    max-width:100%;
  }
  .concierge-note{
    padding:7px 12px 8px;
    font-size:11px;
    line-height:1.35;
  }
  .form-grid,
  .interest-grid,
  .mini-grid,
  .journey-track,
  .contingency-grid{
    grid-template-columns:1fr;
  }
}
