/* Reusable components: cards, callouts, banners, lists, tags, advisor surfaces. */

/* Cards */
.card{
  background:var(--white);
  border-radius:var(--radius-lg);
  padding:clamp(22px,3vw,32px);
  margin-bottom:22px;
  box-shadow:var(--shadow-md);
  border:1px solid var(--line);
  position:relative;
  transition:transform var(--t-med),box-shadow var(--t-med),border-color var(--t-med);
}
.card::before{
  content:'';
  position:absolute;top:0;left:28px;right:28px;
  height:3px;
  background:linear-gradient(90deg,var(--teal),var(--teal-light));
  border-radius:0 0 3px 3px;
  opacity:0.7;
  transition:opacity var(--t-med);
}
.card.port::before{background:linear-gradient(90deg,var(--warn),#d4824f)}
.card.embark::before{background:linear-gradient(90deg,var(--gold),var(--gold-bright))}
.card.disembark::before{background:linear-gradient(90deg,var(--muted),#9aa9bd)}
.card.menu::before{background:linear-gradient(90deg,#8a6a9b,#b08bc4)}
@media (hover:hover) and (pointer:fine){
  .card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:rgba(201,161,75,0.25)}
  .card:hover::before{opacity:1}
}

.banner{
  display:inline-flex;align-items:center;gap:10px;
  font-family:'JetBrains Mono',monospace;
  font-size:0.72rem;font-weight:500;
  text-transform:uppercase;letter-spacing:0.15em;
  color:var(--text-soft);
  margin-bottom:12px;
  padding:5px 12px 5px 5px;
  background:var(--cream-warm);
  border-radius:999px;
}
.banner::before{
  content:'';
  width:16px;height:16px;border-radius:50%;
  background:var(--teal);
  box-shadow:0 0 0 3px rgba(13,115,136,0.18);
}
.card.port .banner::before{background:var(--warn)}
.card.embark .banner::before{background:var(--gold)}
.card.menu .banner::before{background:#8a6a9b}

/* Callouts */
.callout{
  background:var(--cream-warm);
  border-radius:var(--radius-md);
  padding:16px 18px 16px 22px;
  margin:14px 0;
  font-size:0.95rem;
  color:var(--text);
  border-left:3px solid var(--gold);
}
.callout strong{color:var(--navy)}
.callout.warn{background:var(--warn-bg);border-left-color:var(--warn)}
.callout.alert{background:var(--alert-bg);border-left-color:var(--alert)}
.callout.good{background:var(--good-bg);border-left-color:var(--good)}
.callout ul{margin-bottom:0}

/* Pull quote */
.pull-quote{
  font-family:'Fraunces',serif;font-style:italic;
  font-size:clamp(1.05rem,1.8vw,1.25rem);
  line-height:1.45;color:var(--ocean);
  padding:22px 8px 22px 30px;
  border-left:3px solid var(--gold);
  margin:18px 0;position:relative;
}
.pull-quote::before{
  content:'\201C';
  position:absolute;left:8px;top:-4px;
  font-size:2.6rem;color:var(--gold);
  line-height:1;font-family:'Fraunces',serif;
}

/* Time list */
.time-list{list-style:none;margin:14px 0 6px;padding:0}
.time-list li{
  display:grid;grid-template-columns:96px 1fr;gap:16px;
  padding:12px 0;
  border-bottom:1px solid var(--line);
  align-items:start;
}
.time-list li:last-child{border-bottom:none}
.time-list .when{
  font-family:'JetBrains Mono',monospace;font-weight:500;
  color:var(--teal);font-size:0.86rem;padding-top:2px;
}
.time-list .what{font-size:0.95rem;color:var(--text);line-height:1.55}
.time-list .what em{font-style:normal;color:var(--muted);font-size:0.84rem;display:block;margin-top:4px}
.time-list .what strong{color:var(--navy)}
@media(max-width:600px){.time-list li{grid-template-columns:80px 1fr;gap:12px}}

/* Excursions */
.excursion-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:14px;margin-top:14px}
.excursion{
  background:var(--cream);
  border-radius:var(--radius-md);
  padding:18px;
  border:1px solid var(--line);
  border-top:3px solid var(--teal);
  transition:transform var(--t-fast),border-color var(--t-fast),box-shadow var(--t-fast);
}
.excursion.beach{border-top-color:var(--teal-light)}
.excursion.active{border-top-color:var(--warn)}
.excursion h4{
  color:var(--navy);text-transform:none;letter-spacing:-0.01em;
  font-family:'Fraunces',serif;font-size:1.06rem;font-weight:600;
  margin:0 0 6px;
}
.excursion .meta{font-family:'JetBrains Mono',monospace;font-size:0.74rem;color:var(--muted);margin-bottom:10px}
.excursion .meta strong{color:var(--text)}
.excursion p{font-size:0.9rem;margin-bottom:4px;line-height:1.5}
@media (hover:hover) and (pointer:fine){
  .excursion:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:rgba(201,161,75,0.3)}
}

/* Tags */
.tag{
  display:inline-flex;align-items:center;gap:4px;
  font-family:'JetBrains Mono',monospace;
  font-size:0.7rem;
  padding:3px 10px;border-radius:999px;
  background:rgba(13,115,136,0.1);color:var(--teal);
  font-weight:500;
  margin-right:4px;margin-bottom:6px;
  letter-spacing:0.04em;text-transform:uppercase;
}
.tag.gold{background:rgba(201,161,75,0.14);color:var(--gold-deep)}
.tag.warn{background:rgba(180,98,42,0.12);color:var(--warn)}
.tag.good{background:rgba(45,122,79,0.12);color:var(--good)}
.tag.alert{background:rgba(168,51,76,0.12);color:var(--alert)}

/* Tables */
table{
  width:100%;border-collapse:collapse;margin:14px 0;
  background:var(--white);
  border-radius:var(--radius-md);overflow:hidden;
  box-shadow:var(--shadow-sm);
  font-size:0.92rem;
  border:1px solid var(--line);
}
table th{
  background:linear-gradient(135deg,var(--navy),var(--ocean));
  color:var(--white);text-align:left;padding:12px 14px;
  font-family:'JetBrains Mono',monospace;
  font-size:0.74rem;text-transform:uppercase;letter-spacing:0.1em;
  font-weight:500;
}
table td{padding:12px 14px;border-top:1px solid var(--line);vertical-align:top;color:var(--text)}
table td strong{color:var(--navy)}
table tr:nth-child(even) td{background:rgba(243,235,217,0.3)}

/* Layout helpers */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin:14px 0}
@media(max-width:600px){.two-col{grid-template-columns:1fr}}
.pill-row{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}

/* MDR night cards */
.mdr-night{
  background:var(--cream);
  border-radius:var(--radius-md);
  padding:18px 20px;margin-bottom:12px;
  border-left:4px solid #8a6a9b;
}
.mdr-night.strong{border-left-color:var(--good);background:var(--good-bg)}
.mdr-night.weak{border-left-color:var(--alert);background:var(--alert-bg)}
.mdr-night.medium{border-left-color:#8a6a9b;background:#f3eef7}
.mdr-night-head{
  display:flex;justify-content:space-between;align-items:baseline;
  flex-wrap:wrap;gap:8px;margin-bottom:8px;
}
.mdr-night-head strong{font-family:'Fraunces',serif;font-size:1.05rem;font-weight:600;color:var(--navy)}
.mdr-night-head .badge{
  font-family:'JetBrains Mono',monospace;
  font-size:0.66rem;font-weight:500;
  padding:4px 10px;border-radius:999px;
  text-transform:uppercase;letter-spacing:0.1em;
}
.mdr-night.strong .badge{background:rgba(45,122,79,0.18);color:var(--good)}
.mdr-night.weak .badge{background:rgba(168,51,76,0.18);color:var(--alert)}
.mdr-night.medium .badge{background:rgba(138,106,155,0.22);color:#6f5285}
.mdr-night p{font-size:0.92rem;margin-bottom:6px}
.mdr-night .menu{color:var(--text-soft);font-size:0.85rem;font-style:italic;font-family:'Fraunces',serif}
.mdr-night .rec{font-weight:600;color:var(--navy);margin-top:8px;font-size:0.92rem}

/* Ordered steps */
.steps-ol{counter-reset:step;list-style:none;margin-left:0;padding-left:0}
.steps-ol li{
  counter-increment:step;
  position:relative;
  padding:14px 14px 14px 52px;margin-bottom:10px;
  background:var(--cream);border-radius:var(--radius-md);
  font-size:0.95rem;border:1px solid var(--line);
}
.steps-ol li::before{
  content:counter(step);
  position:absolute;left:14px;top:14px;
  width:28px;height:28px;
  background:linear-gradient(135deg,var(--navy),var(--ocean));
  color:var(--gold-bright);
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-family:'Fraunces',serif;font-size:0.92rem;font-weight:600;
}

/* Theme cards (Gala / White / Tropical nights) */
.theme-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;margin-top:14px}
.theme-card{
  background:var(--cream);
  border:1px solid var(--line);
  border-radius:var(--radius-md);
  padding:16px;
  border-top:3px solid var(--gold);
}
.theme-card.gala{border-top-color:var(--gold)}
.theme-card.white{border-top-color:var(--text-soft);background:linear-gradient(180deg,#fff,var(--cream))}
.theme-card.tropical{border-top-color:var(--teal-light)}
.theme-card h4{
  font-family:'Fraunces',serif;font-size:1.05rem;font-weight:600;
  color:var(--navy);text-transform:none;letter-spacing:-0.01em;
  margin:0 0 6px;
}
.theme-card .when{
  font-family:'JetBrains Mono',monospace;font-size:0.74rem;
  color:var(--gold-deep);text-transform:uppercase;letter-spacing:0.1em;
  margin-bottom:10px;
}
.theme-card p{font-size:0.9rem;margin-bottom:6px;line-height:1.5}

/* ===== Advisor surfaces — Phase 2 ===== */

/* Vibe banner — full-width gradient hero, time-of-day colour wash. */
.adv-vibe-banner{
  position:relative;
  border-radius:var(--radius-lg);
  padding:24px 22px 22px;
  margin:8px 0 18px;
  color:var(--white);
  overflow:hidden;
  isolation:isolate;
  background:linear-gradient(135deg,#0a1628 0%,#1a3a5c 60%,#2ba8bc 130%);
  box-shadow:0 14px 32px rgba(10,22,40,0.18);
  transition:background 1200ms ease;
}
.adv-vibe-banner::before{
  content:'';position:absolute;inset:0;z-index:-1;
  background:
    radial-gradient(600px 220px at 80% -10%,rgba(255,255,255,0.18),transparent 70%),
    radial-gradient(420px 220px at 10% 110%,rgba(201,161,75,0.18),transparent 70%);
  pointer-events:none;
}
.adv-vibe-banner[data-block="dawn"]{background:linear-gradient(135deg,#1a3a5c 0%,#b46c5e 55%,#e3c071 120%)}
.adv-vibe-banner[data-block="morning"]{background:linear-gradient(135deg,#1a3a5c 0%,#2ba8bc 50%,#e3c071 130%)}
.adv-vibe-banner[data-block="midday"]{background:linear-gradient(135deg,#0d7388 0%,#2ba8bc 60%,#faf6ee 140%);color:var(--navy)}
.adv-vibe-banner[data-block="afternoon"]{background:linear-gradient(135deg,#1a3a5c 0%,#0d7388 50%,#c9a14b 130%)}
.adv-vibe-banner[data-block="sunset"]{background:linear-gradient(135deg,#3a1d3f 0%,#a8334c 45%,#e3a55a 100%)}
.adv-vibe-banner[data-block="evening"]{background:linear-gradient(135deg,#050e1f 0%,#122a47 55%,#8a6f30 130%)}
.adv-vibe-banner[data-block="night"]{background:linear-gradient(135deg,#050e1f 0%,#0a1628 55%,#1a3a5c 120%)}
.adv-vibe-banner[data-block="midday"] .adv-vibe-eyebrow,
.adv-vibe-banner[data-block="midday"] .adv-vibe-stamp,
.adv-vibe-banner[data-block="midday"] .adv-chip-glass{color:var(--navy)}

.adv-vibe-eyebrow{
  display:flex;justify-content:space-between;align-items:center;gap:12px;
  font-family:'JetBrains Mono',monospace;
  font-size:0.7rem;
  color:rgba(255,255,255,0.78);
  letter-spacing:0.18em;text-transform:uppercase;
  font-weight:500;margin-bottom:14px;
}
.adv-vibe-stamp{font-weight:500;color:rgba(255,255,255,0.6)}
.adv-vibe{
  font-family:'Fraunces',serif;
  font-size:clamp(1.5rem,4vw,2.2rem);
  font-weight:500;
  line-height:1.18;letter-spacing:-0.015em;
  margin:0 0 18px;
  color:inherit;
  border:none;padding:0;
}

.adv-vibe-tools{
  display:flex;gap:6px;flex-wrap:wrap;
}

/* Glassy chips that sit on the gradient banner. */
.adv-chip-glass{
  font-family:'JetBrains Mono',monospace;
  font-size:0.72rem;
  padding:9px 13px;min-height:38px;
  border-radius:999px;
  background:rgba(255,255,255,0.14);
  border:1px solid rgba(255,255,255,0.22);
  color:rgba(255,255,255,0.95);
  cursor:pointer;
  letter-spacing:0.06em;text-transform:uppercase;font-weight:500;
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  transition:background var(--t-fast),border-color var(--t-fast),transform var(--t-fast);
  display:inline-flex;align-items:center;gap:6px;
}
.adv-chip-glass:active{transform:scale(0.96);background:rgba(255,255,255,0.22)}
@media (hover:hover) and (pointer:fine){
  .adv-chip-glass:hover{background:rgba(255,255,255,0.22);border-color:rgba(255,255,255,0.4)}
}

/* "You are here" pill — calls out current/picked location. */
#advHereBtn{padding-left:10px;text-transform:none;letter-spacing:0.02em;font-family:'Inter',sans-serif;font-weight:600}
.adv-here-pin{font-size:0.95rem;line-height:1}
.adv-here-text{white-space:nowrap;text-overflow:ellipsis;overflow:hidden;max-width:160px}
#advHereBtn.is-set{background:rgba(201,161,75,0.32);border-color:rgba(201,161,75,0.55);color:var(--white)}
.adv-vibe-banner[data-block="midday"] #advHereBtn{color:var(--navy)}
.adv-vibe-banner[data-block="midday"] #advHereBtn.is-set{background:rgba(201,161,75,0.45);border-color:rgba(201,161,75,0.7);color:var(--navy)}

/* Legacy surfaces (used by countdown card + lists) — kept for re-use elsewhere. */
.adv-greeting{padding:8px 4px 16px}
.adv-eyebrow{
  font-family:'JetBrains Mono',monospace;
  font-size:0.74rem;color:var(--gold-deep);
  letter-spacing:0.18em;text-transform:uppercase;
  font-weight:500;margin-bottom:10px;
}
.adv-status{
  display:flex;justify-content:space-between;align-items:center;
  gap:10px;flex-wrap:wrap;
  background:var(--white);
  border:1px solid var(--line);
  border-radius:var(--radius-md);
  padding:10px 14px;margin-bottom:18px;
  box-shadow:var(--shadow-sm);
}
.adv-stamp{font-family:'JetBrains Mono',monospace;font-size:0.82rem;color:var(--text);font-weight:500;letter-spacing:0.04em}
.adv-stamp .accent{color:var(--gold-deep)}
.adv-tools{display:flex;gap:6px;flex-wrap:wrap}
.adv-chip{
  font-family:'JetBrains Mono',monospace;
  font-size:0.72rem;
  padding:8px 12px;min-height:36px;
  border-radius:999px;
  background:var(--cream-warm);
  border:1px solid var(--line);
  color:var(--text-soft);cursor:pointer;
  letter-spacing:0.06em;text-transform:uppercase;font-weight:500;
  transition:all var(--t-fast);
}
.adv-chip:active{background:var(--gold);color:var(--white)}
@media (hover:hover) and (pointer:fine){
  .adv-chip:hover{border-color:var(--gold);color:var(--navy)}
}

.adv-banner{
  display:flex;justify-content:space-between;align-items:center;gap:8px;
  background:rgba(201,161,75,0.14);
  border:1px solid rgba(201,161,75,0.4);
  border-radius:var(--radius-md);
  padding:10px 14px;margin-bottom:16px;
  font-size:0.88rem;color:var(--gold-deep);font-weight:500;
}
.adv-banner button{
  background:transparent;
  border:1px solid var(--gold-deep);
  color:var(--gold-deep);
  padding:6px 12px;min-height:32px;
  border-radius:999px;
  font-size:0.74rem;cursor:pointer;
  font-family:inherit;
}

.adv-panel{
  background:var(--white);
  border:1px solid var(--line);
  border-radius:var(--radius-md);
  padding:16px;margin-bottom:18px;
  box-shadow:var(--shadow-sm);
}
.adv-panel h4{
  margin:0 0 10px;color:var(--navy);
  text-transform:none;letter-spacing:0;
  font-family:'Fraunces',serif;font-size:1rem;font-weight:600;
}
.adv-day-pills,.adv-time-pills{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:14px}
.adv-day-pill,.adv-time-pill{
  padding:10px 14px;min-height:40px;
  border:1px solid var(--line);
  background:var(--cream);
  border-radius:999px;
  font-family:'JetBrains Mono',monospace;
  font-size:0.78rem;color:var(--text-soft);cursor:pointer;font-weight:500;
}
.adv-time-pill{border-radius:8px}
.adv-day-pill.selected,.adv-time-pill.selected{
  background:linear-gradient(135deg,var(--navy),var(--ocean));
  color:var(--gold-bright);border-color:transparent;
}
.adv-panel-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:8px}
.adv-btn{
  padding:10px 18px;min-height:44px;
  border:none;border-radius:8px;cursor:pointer;
  font-family:inherit;font-size:0.9rem;font-weight:600;
}
.adv-btn-primary{background:linear-gradient(135deg,var(--navy),var(--ocean));color:var(--gold-bright)}
.adv-btn-ghost{background:transparent;color:var(--text-soft);border:1px solid var(--line)}

.adv-now{
  background:var(--white);
  border:1px solid var(--line);border-left:4px solid var(--gold);
  border-radius:var(--radius-lg);
  padding:20px 22px;margin-bottom:14px;
  box-shadow:var(--shadow-md);
}
.adv-now-label{
  font-family:'JetBrains Mono',monospace;
  font-size:0.7rem;color:var(--gold-deep);
  text-transform:uppercase;letter-spacing:0.18em;
  font-weight:500;margin-bottom:8px;
  display:flex;align-items:center;gap:8px;
}
.adv-now-label::before{
  content:'';width:8px;height:8px;border-radius:50%;
  background:var(--gold);
  box-shadow:0 0 0 4px rgba(201,161,75,0.2);
  animation:pulse 2s infinite;
}
.adv-now-title{
  font-family:'Fraunces',serif;font-size:1.3rem;font-weight:600;
  color:var(--navy);margin-bottom:6px;line-height:1.25;
}
.adv-now-meta{font-size:0.88rem;color:var(--text-soft);margin-bottom:6px}
.adv-now-tip{font-size:0.94rem;color:var(--text);line-height:1.5;margin-top:8px}

.adv-countdown-card{
  background:linear-gradient(135deg,var(--navy) 0%,var(--ocean) 100%);
  color:var(--white);
  border-radius:var(--radius-lg);
  padding:18px 22px;margin-bottom:14px;
  box-shadow:var(--shadow-md);
  position:relative;overflow:hidden;
}
.adv-countdown-card::after{
  content:'';position:absolute;right:-30px;top:-30px;
  width:140px;height:140px;
  background:radial-gradient(circle,rgba(201,161,75,0.18),transparent);
  pointer-events:none;
}
.adv-countdown-label{
  font-family:'JetBrains Mono',monospace;
  font-size:0.7rem;color:var(--gold-bright);
  text-transform:uppercase;letter-spacing:0.18em;
  margin-bottom:6px;position:relative;
}
.adv-countdown-time{
  font-family:'Fraunces',serif;font-size:1.5rem;font-weight:600;
  color:var(--white);line-height:1.2;margin-bottom:4px;position:relative;
}
.adv-countdown-sub{font-size:0.88rem;color:rgba(255,255,255,0.8);position:relative}

.adv-list-card{
  background:var(--white);
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  padding:18px 22px;margin-bottom:14px;
  box-shadow:var(--shadow-sm);
}
.adv-list-label{
  font-family:'JetBrains Mono',monospace;
  font-size:0.7rem;color:var(--text-soft);
  text-transform:uppercase;letter-spacing:0.18em;
  margin-bottom:12px;font-weight:500;
}

.adv-event-row{margin:0 -8px}
.adv-event{
  display:grid;grid-template-columns:64px 1fr auto;gap:12px;
  padding:12px 8px;min-height:48px;
  border-bottom:1px dashed var(--line);
  align-items:start;cursor:pointer;
  transition:background var(--t-fast);
  border-radius:8px;
}
.adv-event-row:last-child .adv-event{border-bottom:none}
.adv-event.open{background:var(--cream)}
.adv-event:active{background:var(--cream-warm)}
@media (hover:hover) and (pointer:fine){
  .adv-event:hover{background:var(--cream)}
}
.adv-event-time{font-family:'JetBrains Mono',monospace;font-size:0.82rem;color:var(--teal);font-weight:500;padding-top:2px}
.adv-event-body{font-size:0.94rem;line-height:1.4}
.adv-event-title{font-weight:600;color:var(--navy)}
.adv-event-loc{font-size:0.82rem;color:var(--muted);margin-top:2px}
.adv-event-cd{
  font-family:'JetBrains Mono',monospace;
  font-size:0.74rem;color:var(--gold-deep);
  background:rgba(201,161,75,0.12);
  padding:3px 8px;border-radius:999px;
  white-space:nowrap;align-self:center;
}
.adv-event-expand{
  background:var(--cream);
  border-radius:var(--radius-md);
  padding:14px 16px;margin:6px 8px 12px 8px;
  animation:expandIn 240ms cubic-bezier(.2,.7,.3,1);
  border-left:3px solid var(--gold);
}
.adv-event-expand .tip-text{font-size:0.94rem;color:var(--text);line-height:1.5;margin-bottom:10px}

/* Ask grid */
.adv-asks{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-top:18px}
.adv-ask{
  background:var(--white);
  border:1px solid var(--line);
  border-radius:var(--radius-md);
  padding:18px 14px;min-height:96px;
  text-align:left;cursor:pointer;
  font-family:inherit;
  transition:all var(--t-fast);
  display:flex;flex-direction:column;gap:4px;
  box-shadow:var(--shadow-sm);
}
.adv-ask:active{transform:scale(0.98);box-shadow:var(--shadow-md)}
@media (hover:hover) and (pointer:fine){
  .adv-ask:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:rgba(201,161,75,0.35)}
}
.adv-ask.open{background:linear-gradient(135deg,var(--navy),var(--ocean));border-color:transparent}
.adv-ask.open .adv-ask-label{color:var(--gold-bright)}
.adv-ask.open .adv-ask-sub{color:rgba(255,255,255,0.7)}
.adv-ask-icon{font-size:1.5rem;margin-bottom:4px}
.adv-ask-label{font-family:'Fraunces',serif;font-size:1.04rem;font-weight:600;color:var(--navy);line-height:1.2}
.adv-ask-sub{font-size:0.82rem;color:var(--text-soft);line-height:1.3}
@media(min-width:600px){.adv-asks{grid-template-columns:repeat(3,1fr)}}

/* Inline answer panel */
.adv-inline{
  background:var(--white);
  border:1px solid var(--line);border-left:4px solid var(--gold);
  border-radius:var(--radius-lg);
  padding:20px 22px;margin-top:12px;
  box-shadow:var(--shadow-md);
  animation:expandIn 320ms cubic-bezier(.2,.7,.3,1);
}
.adv-inline h3{font-family:'Fraunces',serif;font-size:1.2rem;color:var(--navy);margin:0 0 4px;font-weight:600}
.adv-inline-sub{color:var(--text-soft);font-size:0.9rem;margin-bottom:14px}
.adv-inline-context{
  font-family:'JetBrains Mono',monospace;
  font-size:0.74rem;color:var(--gold-deep);
  text-transform:uppercase;letter-spacing:0.1em;
  margin-bottom:12px;
}

.adv-result{
  background:var(--cream);
  border:1px solid var(--line);
  border-radius:var(--radius-md);
  padding:14px;margin-bottom:8px;
  cursor:pointer;
  transition:all var(--t-fast);
}
.adv-result:active{background:var(--cream-warm);border-color:var(--gold)}
@media (hover:hover) and (pointer:fine){
  .adv-result:hover{transform:translateX(2px);border-color:var(--gold);background:var(--cream-warm)}
}
.adv-result-title{font-family:'Fraunces',serif;font-size:1.04rem;font-weight:600;color:var(--navy);margin-bottom:2px}
.adv-result-meta{
  font-family:'JetBrains Mono',monospace;
  font-size:0.72rem;color:var(--gold-deep);
  text-transform:uppercase;letter-spacing:0.06em;
  margin-bottom:6px;
}
.adv-result-body{font-size:0.9rem;color:var(--text);line-height:1.5}

.adv-loc-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:8px;margin-bottom:12px}
.adv-loc-pill{
  padding:12px 14px;min-height:44px;
  border:1px solid var(--line);
  background:var(--cream);
  border-radius:8px;
  font-family:inherit;font-size:0.86rem;
  color:var(--text);cursor:pointer;font-weight:500;
  transition:all var(--t-fast);
  text-align:left;
}
.adv-loc-pill:active{border-color:var(--gold);background:var(--cream-warm)}
@media (hover:hover) and (pointer:fine){
  .adv-loc-pill:hover{border-color:var(--gold);background:var(--cream-warm)}
}

.adv-back-link{
  display:inline-flex;align-items:center;gap:6px;
  background:transparent;border:none;
  color:var(--gold-deep);
  font-family:'JetBrains Mono',monospace;
  font-size:0.74rem;
  text-transform:uppercase;letter-spacing:0.1em;
  cursor:pointer;
  padding:6px 0;min-height:32px;
  margin-bottom:10px;font-weight:500;
}

.adv-remind-label{
  font-family:'JetBrains Mono',monospace;
  font-size:0.7rem;color:var(--gold-deep);
  text-transform:uppercase;letter-spacing:0.14em;
  font-weight:500;margin-top:6px;margin-bottom:6px;
}
.adv-remind-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}
.adv-remind-btn{
  padding:10px 14px;min-height:40px;
  border:1px solid var(--gold);
  background:rgba(201,161,75,0.08);
  color:var(--gold-deep);
  border-radius:8px;
  font-family:inherit;font-size:0.82rem;
  cursor:pointer;font-weight:500;
}
.adv-remind-btn:active{background:var(--gold);color:var(--white)}
@media (hover:hover) and (pointer:fine){
  .adv-remind-btn:hover{background:var(--gold);color:var(--white)}
}
.adv-remind-btn.set{background:var(--good);color:var(--white);border-color:var(--good)}

/* Walk pill — appears next to events with deck/area calc. */
.adv-walk-pill{
  display:inline-flex;align-items:center;gap:5px;
  font-family:'JetBrains Mono',monospace;
  font-size:0.7rem;font-weight:500;
  padding:3px 9px;
  border-radius:999px;
  background:rgba(13,115,136,0.12);
  color:var(--teal);
  letter-spacing:0.04em;
  margin-right:6px;
  white-space:nowrap;
}
.adv-walk-pill::before{content:"🚶";font-size:0.78rem;line-height:1}

/* Right Now v2 — bigger, with walk pill + reminder slider. */
.adv-now-v2{
  position:relative;
  background:linear-gradient(135deg,#fff 0%,var(--cream) 100%);
  border:1px solid var(--line);border-left:4px solid var(--gold);
  border-radius:var(--radius-lg);
  padding:22px 22px 18px;margin-bottom:14px;
  box-shadow:0 10px 26px rgba(10,22,40,0.1);
}
.adv-now-v2.is-soft{border-left-color:var(--teal-light);background:var(--cream)}
.adv-now-v2 .adv-now-label{margin-bottom:10px}
.adv-now-v2 .adv-now-title{font-size:1.42rem}
.adv-now-v2 .adv-now-meta-row{display:flex;flex-wrap:wrap;gap:6px 10px;align-items:center;margin:8px 0 4px}
.adv-now-v2 .adv-now-meta-row .meta-text{font-size:0.88rem;color:var(--text-soft)}

.adv-reminder-row{
  display:flex;align-items:center;gap:10px;
  margin-top:14px;padding-top:14px;
  border-top:1px dashed var(--line);
}
.adv-reminder-label{
  font-family:'JetBrains Mono',monospace;
  font-size:0.7rem;color:var(--gold-deep);
  text-transform:uppercase;letter-spacing:0.14em;
  white-space:nowrap;
}
.adv-reminder-slider{
  flex:1;
  appearance:none;-webkit-appearance:none;
  height:6px;border-radius:3px;
  background:linear-gradient(90deg,var(--gold) 0,var(--gold) var(--fill,0%),var(--cream-warm) var(--fill,0%),var(--cream-warm) 100%);
  outline:none;
  margin:0;
}
.adv-reminder-slider::-webkit-slider-thumb{
  appearance:none;-webkit-appearance:none;
  width:22px;height:22px;border-radius:50%;
  background:linear-gradient(135deg,var(--navy),var(--ocean));
  border:2px solid var(--gold-bright);
  cursor:pointer;
  box-shadow:0 2px 6px rgba(10,22,40,0.3);
}
.adv-reminder-slider::-moz-range-thumb{
  width:22px;height:22px;border-radius:50%;
  background:linear-gradient(135deg,var(--navy),var(--ocean));
  border:2px solid var(--gold-bright);
  cursor:pointer;
  box-shadow:0 2px 6px rgba(10,22,40,0.3);
}
.adv-reminder-readout{
  font-family:'JetBrains Mono',monospace;
  font-size:0.78rem;color:var(--navy);font-weight:600;
  white-space:nowrap;min-width:64px;text-align:right;
}
.adv-reminder-readout.is-set{color:var(--good)}

/* Horizontal swipeable timeline — Apple Wallet style cards. */
.adv-timeline-wrap{margin:0 -16px 18px;padding:0 16px;position:relative}
.adv-timeline-label{
  display:flex;justify-content:space-between;align-items:center;
  font-family:'JetBrains Mono',monospace;
  font-size:0.7rem;color:var(--text-soft);
  text-transform:uppercase;letter-spacing:0.18em;
  font-weight:500;margin:0 0 10px;
}
.adv-timeline-label .progress{color:var(--gold-deep)}
.adv-timeline{
  display:flex;gap:10px;
  overflow-x:auto;
  scroll-snap-type:x mandatory;
  scrollbar-width:none;
  padding:6px 8px 16px 0;
  scroll-padding-left:0;
}
.adv-timeline::-webkit-scrollbar{display:none}
.adv-tcard{
  flex:0 0 78%;max-width:320px;min-width:240px;
  scroll-snap-align:start;
  background:var(--white);
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  padding:14px 16px 14px;
  box-shadow:var(--shadow-sm);
  position:relative;
  transition:transform var(--t-fast),box-shadow var(--t-fast);
  display:flex;flex-direction:column;gap:6px;
  cursor:pointer;
  user-select:none;
  -webkit-user-select:none;
}
.adv-tcard:active{transform:scale(0.98)}
.adv-tcard.past{opacity:0.55}
.adv-tcard.now{
  background:linear-gradient(135deg,var(--navy),var(--ocean));
  color:var(--white);
  border-color:transparent;
  box-shadow:0 14px 32px rgba(10,22,40,0.25);
  flex:0 0 84%;
}
.adv-tcard.now::before{
  content:'';position:absolute;top:10px;right:10px;
  width:10px;height:10px;border-radius:50%;
  background:var(--gold-bright);
  box-shadow:0 0 0 4px rgba(227,192,113,0.25);
  animation:pulse 2s infinite;
}
.adv-tcard.next{border-left:3px solid var(--gold)}
.adv-tcard.done{opacity:0.55;border-left:3px solid var(--good);background:var(--good-bg)}
.adv-tcard-time{
  font-family:'JetBrains Mono',monospace;
  font-size:0.78rem;font-weight:500;
  color:var(--teal);letter-spacing:0.04em;
}
.adv-tcard.now .adv-tcard-time{color:var(--gold-bright)}
.adv-tcard.past .adv-tcard-time,.adv-tcard.done .adv-tcard-time{color:var(--muted)}
.adv-tcard-title{
  font-family:'Fraunces',serif;
  font-size:1.08rem;font-weight:600;
  line-height:1.25;color:var(--navy);
}
.adv-tcard.now .adv-tcard-title{color:var(--white);font-size:1.18rem}
.adv-tcard-meta{
  font-size:0.82rem;color:var(--text-soft);
  display:flex;align-items:center;gap:6px;flex-wrap:wrap;
}
.adv-tcard.now .adv-tcard-meta{color:rgba(255,255,255,0.78)}
.adv-tcard-meta .pill{
  display:inline-flex;align-items:center;gap:3px;
  font-family:'JetBrains Mono',monospace;
  font-size:0.7rem;
  padding:2px 8px;border-radius:999px;
  background:rgba(13,115,136,0.12);color:var(--teal);
}
.adv-tcard.now .adv-tcard-meta .pill{background:rgba(227,192,113,0.22);color:var(--gold-bright)}
.adv-tcard-foot{
  display:flex;justify-content:space-between;align-items:center;gap:8px;
  margin-top:6px;padding-top:8px;
  border-top:1px dashed rgba(20,35,59,0.1);
}
.adv-tcard.now .adv-tcard-foot{border-top-color:rgba(255,255,255,0.18)}
.adv-tcard-cd{
  font-family:'JetBrains Mono',monospace;
  font-size:0.74rem;font-weight:500;
  color:var(--gold-deep);
}
.adv-tcard.now .adv-tcard-cd{color:var(--gold-bright)}
.adv-tcard.past .adv-tcard-cd{color:var(--muted)}

/* "Mark complete" toggle on timeline cards. */
.adv-tcard-check{
  appearance:none;background:transparent;border:none;
  display:inline-flex;align-items:center;justify-content:center;
  width:32px;height:32px;border-radius:50%;
  border:1.5px solid rgba(20,35,59,0.18);
  cursor:pointer;
  color:var(--muted);
  transition:all var(--t-fast);
}
.adv-tcard.now .adv-tcard-check{border-color:rgba(255,255,255,0.32);color:rgba(255,255,255,0.78)}
.adv-tcard-check:active{transform:scale(0.9)}
.adv-tcard.done .adv-tcard-check{
  background:var(--good);border-color:var(--good);color:var(--white);
}

/* Live widgets row — sunset, tomorrow's port, tonight's meal. */
.adv-widgets{
  display:grid;grid-template-columns:1fr;gap:10px;
  margin-bottom:16px;
}
@media(min-width:520px){.adv-widgets{grid-template-columns:1fr 1fr}}
.adv-widget{
  background:var(--white);
  border:1px solid var(--line);
  border-radius:var(--radius-md);
  padding:14px 16px;
  box-shadow:var(--shadow-sm);
  position:relative;
  display:flex;flex-direction:column;gap:4px;
  overflow:hidden;
}
.adv-widget.is-sun{background:linear-gradient(135deg,#fffaef 0%,#fff 100%)}
.adv-widget.is-port{background:linear-gradient(135deg,#eff8fb 0%,#fff 100%)}
.adv-widget.is-meal{background:linear-gradient(135deg,#fbf3e6 0%,#fff 100%)}
.adv-widget-icon{font-size:1.25rem;line-height:1;margin-bottom:4px}
.adv-widget-label{
  font-family:'JetBrains Mono',monospace;
  font-size:0.66rem;color:var(--text-soft);
  text-transform:uppercase;letter-spacing:0.14em;font-weight:500;
}
.adv-widget-title{
  font-family:'Fraunces',serif;
  font-size:1.08rem;font-weight:600;
  color:var(--navy);line-height:1.25;
}
.adv-widget-body{font-size:0.86rem;color:var(--text-soft);line-height:1.4;margin-top:2px}
.adv-widget-cta{
  margin-top:8px;
  font-family:'JetBrains Mono',monospace;
  font-size:0.7rem;color:var(--gold-deep);font-weight:600;
  letter-spacing:0.06em;text-transform:uppercase;
}

/* Search-anything bar — sits above the action grid. */
.adv-action-search{
  display:flex;align-items:center;gap:10px;
  background:var(--white);
  border:1px solid var(--line);
  border-radius:999px;
  padding:6px 8px 6px 16px;
  margin:18px 0 12px;
  box-shadow:var(--shadow-sm);
  transition:border-color var(--t-fast),box-shadow var(--t-fast);
}
.adv-action-search:focus-within{
  border-color:rgba(201,161,75,0.55);
  box-shadow:0 0 0 4px rgba(201,161,75,0.16);
}
.adv-action-search-icon{font-size:1rem;line-height:1;opacity:0.7}
.adv-action-search-input{
  flex:1;
  appearance:none;background:transparent;border:none;outline:none;
  font-family:inherit;font-size:0.96rem;
  color:var(--text);
  padding:8px 0;min-height:36px;
}
.adv-action-search-input::placeholder{color:var(--muted)}
.adv-action-search-clear{
  appearance:none;background:rgba(20,35,59,0.08);border:none;
  width:32px;height:32px;border-radius:50%;
  font-size:1.2rem;line-height:1;color:var(--text-soft);
  cursor:pointer;
  display:flex;align-items:center;justify-content:center;
}
.adv-action-search-clear:active{background:rgba(20,35,59,0.15)}

/* 8-chip action grid (replaces .adv-asks). */
.adv-actions{
  display:grid;grid-template-columns:repeat(2,1fr);gap:10px;
  margin-bottom:14px;
}
@media(min-width:520px){.adv-actions{grid-template-columns:repeat(4,1fr)}}
.adv-action{
  appearance:none;
  display:flex;flex-direction:column;align-items:flex-start;gap:2px;
  background:var(--white);
  border:1px solid var(--line);
  border-radius:var(--radius-md);
  padding:14px 14px 14px;
  min-height:84px;
  text-align:left;cursor:pointer;
  font-family:inherit;
  transition:all var(--t-fast);
  box-shadow:var(--shadow-sm);
  position:relative;
}
.adv-action:active{transform:scale(0.97);box-shadow:var(--shadow-md)}
@media (hover:hover) and (pointer:fine){
  .adv-action:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:rgba(201,161,75,0.35)}
}
.adv-action.open{background:linear-gradient(135deg,var(--navy),var(--ocean));border-color:transparent}
.adv-action.open .adv-action-label{color:var(--gold-bright)}
.adv-action.open .adv-action-sub{color:rgba(255,255,255,0.7)}
.adv-action-icon{font-size:1.5rem;margin-bottom:6px;line-height:1}
.adv-action-label{
  font-family:'Fraunces',serif;font-size:1rem;font-weight:600;
  color:var(--navy);line-height:1.2;
}
.adv-action-sub{
  font-size:0.78rem;color:var(--text-soft);line-height:1.3;
}

/* Search results panel. */
.adv-search-results{
  background:var(--white);
  border:1px solid var(--line);
  border-radius:var(--radius-md);
  padding:8px;margin-bottom:14px;
  box-shadow:var(--shadow-sm);
  max-height:60vh;overflow-y:auto;
}
.adv-search-row{
  display:flex;align-items:flex-start;gap:10px;
  padding:10px 12px;border-radius:8px;
  cursor:pointer;
}
.adv-search-row:active{background:var(--cream)}
@media (hover:hover) and (pointer:fine){
  .adv-search-row:hover{background:var(--cream)}
}
.adv-search-row+.adv-search-row{border-top:1px dashed var(--line)}
.adv-search-row .kind{
  font-family:'JetBrains Mono',monospace;
  font-size:0.62rem;
  padding:2px 7px;border-radius:999px;
  background:rgba(13,115,136,0.12);color:var(--teal);
  text-transform:uppercase;letter-spacing:0.08em;font-weight:500;
  flex-shrink:0;margin-top:2px;
}
.adv-search-row .body{flex:1;min-width:0}
.adv-search-row .title{font-weight:600;color:var(--navy);font-size:0.94rem}
.adv-search-row .meta{font-size:0.78rem;color:var(--text-soft);margin-top:1px}
.adv-search-empty{
  padding:24px 16px;text-align:center;
  color:var(--text-soft);font-size:0.9rem;
  font-style:italic;
}

/* Bottom sheet — for "Where are you?", quick actions, etc. */
.sheet-backdrop{
  position:fixed;inset:0;
  background:rgba(10,22,40,0.45);
  z-index:140;
  opacity:0;pointer-events:none;
  transition:opacity 240ms cubic-bezier(.2,.7,.3,1);
  backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);
}
.sheet-backdrop.show{opacity:1;pointer-events:auto}
.bottom-sheet{
  position:fixed;left:0;right:0;bottom:0;
  z-index:150;
  background:var(--cream);
  border-top-left-radius:var(--radius-lg);
  border-top-right-radius:var(--radius-lg);
  padding:8px 0 calc(var(--safe-bottom) + 16px);
  box-shadow:0 -16px 40px rgba(10,22,40,0.25);
  transform:translateY(100%);
  transition:transform 320ms cubic-bezier(.2,.7,.3,1);
  max-height:80vh;overflow-y:auto;
  scrollbar-width:none;
}
.bottom-sheet::-webkit-scrollbar{display:none}
.bottom-sheet.show{transform:translateY(0)}
.sheet-handle{
  display:block;
  width:48px;height:5px;
  background:rgba(20,35,59,0.18);
  border:none;border-radius:999px;
  margin:8px auto 12px;
  cursor:pointer;
  appearance:none;
}
.sheet-handle:active{background:rgba(20,35,59,0.32)}
.sheet-header{padding:0 22px 8px}
.sheet-title{
  font-family:'Fraunces',serif;
  font-size:1.32rem;font-weight:600;color:var(--navy);
  margin:0 0 2px;
}
.sheet-sub{font-size:0.88rem;color:var(--text-soft);margin:0}
.sheet-body{padding:8px 22px 20px}

/* Sheet location grid (used by "Where are you?"). */
.sheet-loc-grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:8px;
  margin-top:8px;
}
@media(min-width:520px){.sheet-loc-grid{grid-template-columns:repeat(3,1fr)}}
.sheet-loc-btn{
  appearance:none;background:var(--white);
  border:1px solid var(--line);border-radius:var(--radius-md);
  padding:14px 12px;min-height:64px;
  display:flex;flex-direction:column;align-items:flex-start;gap:2px;
  text-align:left;cursor:pointer;font-family:inherit;
  transition:all var(--t-fast);
}
.sheet-loc-btn:active{transform:scale(0.97);background:var(--cream-warm)}
@media (hover:hover) and (pointer:fine){
  .sheet-loc-btn:hover{border-color:var(--gold);background:var(--cream-warm)}
}
.sheet-loc-btn.is-current{
  background:linear-gradient(135deg,var(--gold) 0%,var(--gold-bright) 100%);
  border-color:transparent;color:var(--navy);
}
.sheet-loc-btn .nm{font-weight:600;font-size:0.92rem;color:var(--navy);line-height:1.2}
.sheet-loc-btn.is-current .nm{color:var(--navy)}
.sheet-loc-btn .deck{
  font-family:'JetBrains Mono',monospace;
  font-size:0.7rem;color:var(--text-soft);
}
.sheet-loc-btn.is-current .deck{color:var(--navy);opacity:0.7}

/* Sheet — generic action button (used by event quick-actions). */
.sheet-action{
  appearance:none;background:var(--white);
  border:1px solid var(--line);border-radius:var(--radius-md);
  padding:14px 16px;
  display:flex;align-items:center;gap:12px;
  width:100%;text-align:left;cursor:pointer;
  font-family:inherit;font-size:0.96rem;color:var(--text);
  margin-bottom:8px;min-height:52px;
}
.sheet-action:active{background:var(--cream-warm)}
.sheet-action .ico{font-size:1.3rem;line-height:1;flex-shrink:0}
.sheet-action .lab{font-weight:500}
.sheet-action.danger{color:var(--alert);border-color:rgba(168,51,76,0.25)}

/* Pull-to-refresh indicator — fixed at top, drives off CSS variables set by JS. */
.ptr-indicator{
  position:fixed;left:50%;top:6px;
  z-index:90;
  width:40px;height:40px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  background:rgba(10,22,40,0.92);
  color:var(--gold-bright);
  box-shadow:0 6px 18px rgba(10,22,40,0.25);
  transform:translate(-50%,calc(var(--ptr-y,-60px)));
  opacity:var(--ptr-opacity,0);
  transition:transform 90ms linear,opacity 120ms linear;
  pointer-events:none;
}
.ptr-indicator svg{
  width:18px;height:18px;
  transform:rotate(var(--ptr-rotate,0deg));
  transition:transform 90ms linear;
}
.ptr-indicator.refreshing{
  animation:ptr-spin 720ms linear infinite;
  transition:none;
}
@keyframes ptr-spin{from{transform:translate(-50%,calc(var(--ptr-y,12px))) rotate(0deg)}to{transform:translate(-50%,calc(var(--ptr-y,12px))) rotate(360deg)}}

/* PWA install hint card — bottom-anchored, glassy, dismissible. */
.pwa-hint{
  position:fixed;left:12px;right:12px;
  bottom:calc(var(--bottom-nav-h) + var(--safe-bottom) + 14px);
  z-index:130;
  display:flex;align-items:center;gap:12px;
  padding:14px 14px 14px 18px;
  background:linear-gradient(135deg,rgba(10,22,40,0.96),rgba(26,58,92,0.94));
  color:var(--white);
  border:1px solid rgba(201,161,75,0.4);
  border-left:4px solid var(--gold);
  border-radius:var(--radius-md);
  box-shadow:0 8px 28px rgba(10,22,40,0.35);
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  opacity:0;transform:translateY(20px);
  transition:opacity 280ms cubic-bezier(.2,.7,.3,1),transform 280ms cubic-bezier(.2,.7,.3,1);
  max-width:520px;margin:0 auto;
}
.pwa-hint.show{opacity:1;transform:none}
.pwa-hint-body{flex:1;min-width:0}
.pwa-hint-title{
  font-family:'Fraunces',serif;font-size:1rem;font-weight:600;
  color:var(--gold-bright);margin-bottom:2px;
}
.pwa-hint-msg{font-size:0.86rem;color:rgba(255,255,255,0.86);line-height:1.4}
.pwa-hint-actions{display:flex;align-items:center;gap:6px;flex-shrink:0}
.pwa-hint-install{
  background:linear-gradient(135deg,var(--gold),var(--gold-bright));
  color:var(--navy);
  border:none;
  padding:8px 14px;min-height:36px;
  border-radius:8px;
  font-family:inherit;font-size:0.84rem;font-weight:600;
  cursor:pointer;
}
.pwa-hint-install:active{transform:scale(0.96)}
.pwa-hint-dismiss{
  background:transparent;border:none;
  color:rgba(255,255,255,0.6);
  width:32px;height:32px;border-radius:50%;
  font-size:1.4rem;line-height:1;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
}
.pwa-hint-dismiss:active{background:rgba(255,255,255,0.08)}
