/* =============================================================
   WANDERPIN / TRIPPLAN — Sistema de diseño
   Soporta modo claro y oscuro. Usa data-theme="dark/light" en <html>.
============================================================= */

@import url('https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,400;9..144,500;9..144,600;9..144,700;9..144,900&family=Manrope:wght@400;500;600;700;800&family=JetBrains+Mono:wght@400;500&display=swap');

/* ============================================================
   RW COINS — Pill y moneda (global, todas las páginas)
============================================================ */

/* Moneda giratoria */
.rw-coin-wrap {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.rw-coin-img {
  display: block;
  image-rendering: pixelated;
  image-rendering: crisp-edges;
  animation: rwCoinFlip 1.4s linear infinite;
}
.rw-coin-img.sz-sm { width: 16px; height: 16px; }
.rw-coin-img.sz-md { width: 22px; height: 22px; }
.rw-coin-img.sz-lg { width: 30px; height: 30px; }
.rw-coin-img.sz-xl { width: 44px; height: 44px; }

@keyframes rwCoinFlip {
  0%         { transform: scaleX(1);    filter: brightness(1); }
  20%        { transform: scaleX(0.4);  filter: brightness(0.75); }
  25%        { transform: scaleX(0.05); filter: brightness(0.55); }
  30%        { transform: scaleX(0.4);  filter: brightness(0.75); }
  50%        { transform: scaleX(1);    filter: brightness(0.9); }
  70%        { transform: scaleX(0.4);  filter: brightness(0.75); }
  75%        { transform: scaleX(0.05); filter: brightness(0.55); }
  80%        { transform: scaleX(0.4);  filter: brightness(0.75); }
  100%       { transform: scaleX(1);    filter: brightness(1); }
}

/* Pill alargada */
.rw-coins-pill {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  background: rgba(212,168,67,.13);
  border: 1px solid rgba(212,168,67,.4);
  border-radius: 50px;
  padding: 4px 14px 4px 6px;
  font-size: .84rem;
  font-weight: 700;
  color: #d4a843 !important;
  text-decoration: none !important;
  transition: background .15s;
  white-space: nowrap;
  font-variant-numeric: tabular-nums;
  cursor: pointer;
  line-height: 1;
}
.rw-coins-pill:hover {
  background: rgba(212,168,67,.25);
  color: #f5d060 !important;
}
/* Versión hero más grande */
.rw-coins-pill--hero {
  padding: 8px 20px 8px 10px;
  font-size: 1.15rem;
  gap: 10px;
  box-shadow: 0 0 20px rgba(212,168,67,.18);
}

/* ============================================================
   TOKENS — Modo claro (por defecto)
============================================================ */
:root {
  /* Bootstrap variable overrides — se actualizan automáticamente en dark mode
     porque referencian nuestras variables, que cambian con [data-theme="dark"] */
  --bs-body-color:              var(--ink);
  --bs-body-bg:                 var(--paper);
  --bs-secondary-color:         var(--ink-3);
  --bs-emphasis-color:          var(--ink);
  --bs-border-color:            var(--paper-edge);
  --bs-border-color-translucent: rgba(28,26,30,.12);
  --bs-link-color:              var(--plum);
  --bs-link-hover-color:        var(--plum-2);
  --bs-heading-color:           var(--ink);
  /* Papel / fondos */
  --paper:          #efe9df;
  --paper-2:        #e6dfd1;
  --paper-edge:     #d8cfbd;
  --ink:            #1d1c1f;
  --ink-2:          #3a3840;
  --ink-3:          #6c6874;
  --ink-4:          #9a96a3;
  --ink-5:          #c8c3cf;

  /* Superficies (tarjetas, inputs, sidebars) */
  --surface:        #f7f2e8;
  --surface-2:      #f3ede2;
  --surface-white:  #ffffff;

  /* Acento plum */
  --plum:           #5b3b8c;
  --plum-2:         #7a55b8;
  --plum-3:         #9c7fd1;
  --plum-soft:      #ece4f7;
  --plum-ink:       #2c1a4a;

  /* Chinchetas */
  --pin-red:        #d34b3a;
  --pin-red-2:      #f0e1de;
  --pin-blue:       #3863a8;
  --pin-blue-2:     #dde4f0;

  /* Estados */
  --ok:             #4f7a4a;
  --ok-bg:          #e2ecdc;
  --warn:           #b9852a;
  --warn-bg:        #f3e8cf;
  --bad:            #a3433b;
  --bad-bg:         #f1dcda;

  /* Sombras */
  --shadow-sm: 0 1px 2px rgba(28,26,30,.06), 0 1px 1px rgba(28,26,30,.04);
  --shadow-md: 0 6px 18px -8px rgba(28,26,30,.18), 0 2px 4px rgba(28,26,30,.05);
  --shadow-lg: 0 24px 48px -20px rgba(28,26,30,.28), 0 4px 12px rgba(28,26,30,.08);

  /* Radios */
  --radius-sm: 6px;
  --radius:    12px;
  --radius-lg: 18px;

  /* Glassmorphism surfaces */
  --glass-bar:      rgba(239,233,223,.88);
  --glass-toolbar:  rgba(239,233,223,.72);
  --glass-summary:  rgba(239,233,223,.94);
}

/* ============================================================
   TOKENS — Modo oscuro
============================================================ */
[data-theme="dark"] {
  --paper:          #0f0d14;
  --paper-2:        #18152a;
  --paper-edge:     #2a2540;
  --ink:            #e8e4f4;
  --ink-2:          #b8b2d0;
  --ink-3:          #7a7390;
  --ink-4:          #4e4868;
  --ink-5:          #2e2850;

  --surface:        #18152a;
  --surface-2:      #110e1e;
  --surface-white:  #1e1a30;

  --plum:           #8562cc;
  --plum-2:         #a07de0;
  --plum-3:         #c4a8f0;
  --plum-soft:      #1e1640;
  --plum-ink:       #dfd4fa;

  --pin-red:        #e86050;
  --pin-red-2:      #2a1414;
  --pin-blue:       #4d7ac4;
  --pin-blue-2:     #101e38;

  --ok:             #5eaa58;
  --ok-bg:          #0c2016;
  --warn:           #d4a840;
  --warn-bg:        #221a06;
  --bad:            #e05848;
  --bad-bg:         #280e0e;

  --shadow-sm: 0 1px 3px rgba(0,0,0,.5), 0 1px 2px rgba(0,0,0,.3);
  --shadow-md: 0 6px 20px -8px rgba(0,0,0,.7), 0 2px 6px rgba(0,0,0,.4);
  --shadow-lg: 0 24px 50px -20px rgba(0,0,0,.9), 0 4px 14px rgba(0,0,0,.5);

  --glass-bar:      rgba(15,13,20,.88);
  --glass-toolbar:  rgba(15,13,20,.72);
  --glass-summary:  rgba(15,13,20,.94);
}

/* ============================================================
   BASE
============================================================ */
* { -webkit-font-smoothing: antialiased; box-sizing: border-box; }

html { color-scheme: light; }
[data-theme="dark"] { color-scheme: dark; }

html, body {
  background: var(--paper);
  color: var(--ink);
  /* Refuerzo: sobreescribe el body color de Bootstrap cualquiera que sea */
  background-color: var(--paper) !important;
}
body {
  color: var(--ink) !important;
  font-family: "Manrope", system-ui, sans-serif;
  font-size: 15px;
  line-height: 1.5;
  margin: 0;
  background-image:
    radial-gradient(circle at 20% 10%, rgba(91,59,140,.05), transparent 40%),
    radial-gradient(circle at 80% 90%, rgba(211,75,58,.03), transparent 45%),
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2'/><feColorMatrix values='0 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 0.04 0'/></filter><rect width='160' height='160' filter='url(%23n)'/></svg>");
  background-attachment: fixed;
  transition: background-color .25s ease, color .25s ease;
}
[data-theme="dark"] body {
  background-image:
    radial-gradient(circle at 20% 10%, rgba(133,98,204,.09), transparent 40%),
    radial-gradient(circle at 80% 90%, rgba(232,96,80,.05), transparent 45%),
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2'/><feColorMatrix values='0 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 0.055 0'/></filter><rect width='160' height='160' filter='url(%23n)'/></svg>");
}

.display, h1, h2, h3, h4 {
  font-family: "Fraunces", Georgia, serif;
  font-feature-settings: "ss01" on, "ss02" on;
  letter-spacing: -0.01em;
  color: var(--ink);
}
.display { font-weight: 600; line-height: 1.02; }
.mono { font-family: "JetBrains Mono", monospace; font-size: 12px; letter-spacing: .02em; }

a { color: var(--plum); text-decoration: none; }
a:hover { color: var(--plum-2); }

/* ============================================================
   NAVBAR
============================================================ */
.app-bar {
  position: sticky; top: 0; z-index: 60;
  background: var(--glass-bar);
  backdrop-filter: blur(12px) saturate(1.4);
  -webkit-backdrop-filter: blur(12px) saturate(1.4);
  border-bottom: 1px solid var(--paper-edge);
  transition: background .25s ease, border-color .25s ease;
}
.app-bar-inner {
  display: flex; align-items: center; gap: 28px;
  padding: 11px 28px;
}
.brand {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: "Fraunces", serif; font-weight: 700; font-size: 22px;
  letter-spacing: -0.02em; color: var(--ink);
}
.brand-logo {
  height: 100px; width: auto; display: block;
}
.brand-logo-icon {
  height: 36px; width: 36px; object-fit: contain; display: block;
  transition: filter 0.15s ease;
}
[data-theme="dark"] .brand-logo-icon {
  filter: invert(1) brightness(1.8);
}
.brand-mark {
  width: 28px; height: 28px; border-radius: 50%;
  background: var(--plum); position: relative;
  box-shadow: inset 0 -3px 0 rgba(0,0,0,.2), 0 2px 8px rgba(91,59,140,.45);
}
.brand-mark::after {
  content: ""; position: absolute; left: 50%; top: 100%;
  transform: translate(-50%, -2px);
  border-left: 5px solid transparent; border-right: 5px solid transparent;
  border-top: 9px solid var(--plum);
  filter: drop-shadow(0 2px 2px rgba(91,59,140,.4));
}
.app-bar-end {
  margin-left: auto; display: flex; align-items: center; gap: 10px;
  color: var(--ink-3); font-size: 13px;
}
.notif-badge {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 18px; height: 18px;
  background: var(--pin-red); color: #fff;
  border-radius: 999px; font-size: 11px; font-weight: 700;
  padding: 0 4px;
}

/* Sección central del navbar: ocupa espacio disponible, scroll horizontal suave */
.app-bar-nav-scroller {
  flex: 1;
  min-width: 0;
  overflow-x: auto;
  overflow-y: hidden;
  scrollbar-width: none;
  display: flex;
  align-items: center;
  gap: 4px;
}
.app-bar-nav-scroller::-webkit-scrollbar { display: none; }
.app-bar-nav-scroller .btn-wp { flex-shrink: 0; white-space: nowrap; }

/* ── Bottom nav (viaje, solo móvil) ───────────────────────── */
.bottom-nav {
  display: none; /* hidden on desktop; shown via media query */
}

/* Título de página en vistas de viaje (agenda, planes) */
.trip-page-title {
  font-size: 44px;
  margin: 0;
  letter-spacing: -0.025em;
  font-weight: 600;
}

/* Botón tema */
.theme-toggle {
  display: inline-flex; align-items: center; justify-content: center;
  width: 34px; height: 34px; border-radius: 999px;
  background: transparent; border: 1px solid var(--paper-edge);
  cursor: pointer; color: var(--ink-3);
  transition: background .15s, color .15s, border-color .15s;
}
.theme-toggle:hover { background: var(--surface); color: var(--ink); }
.theme-toggle .icon-sun  { display: none; }
.theme-toggle .icon-moon { display: block; }
[data-theme="dark"] .theme-toggle .icon-sun  { display: block; }
[data-theme="dark"] .theme-toggle .icon-moon { display: none; }

/* ============================================================
   AVATARES
============================================================ */
.avatar {
  width: 32px; height: 32px; border-radius: 50%;
  background: var(--plum-soft); color: var(--plum);
  display: inline-grid; place-items: center;
  font-weight: 700; font-size: 13px;
  border: 1.5px solid var(--paper); box-shadow: 0 0 0 1px var(--paper-edge);
  flex: none;
}
.avatar.lg { width: 44px; height: 44px; font-size: 16px; }
.avatar.sm { width: 24px; height: 24px; font-size: 11px; }
.avatar-stack { display: flex; }
.avatar-stack .avatar { margin-left: -8px; }
.avatar-stack .avatar:first-child { margin-left: 0; }

/* ============================================================
   BOTONES
============================================================ */
.btn-wp {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 10px 18px; border-radius: 999px;
  font-weight: 600; font-size: 14px;
  border: 1px solid transparent;
  cursor: pointer; transition: transform .12s ease, box-shadow .18s ease, background .18s, color .18s;
  line-height: 1; font-family: inherit;
  text-decoration: none;
}
.btn-wp:active { transform: translateY(1px); }
.btn-primary-wp {
  background: var(--plum); color: #fff;
  box-shadow: 0 2px 0 var(--plum-ink), 0 6px 16px -8px rgba(91,59,140,.5);
}
.btn-primary-wp:hover { background: var(--plum-2); color: #fff; box-shadow: 0 2px 0 var(--plum-ink), 0 8px 20px -8px rgba(91,59,140,.6); }
.btn-ghost-wp { background: transparent; color: var(--ink); border-color: var(--paper-edge); }
.btn-ghost-wp:hover { background: var(--surface); color: var(--ink); }
.btn-ghost-wp.active { background: var(--surface); color: var(--ink); }
.btn-ink-wp { background: var(--ink); color: var(--paper); }
.btn-ink-wp:hover { background: var(--ink-2); color: var(--paper); }
.btn-danger-wp { background: var(--bad-bg); color: var(--bad); border-color: var(--bad); }
.btn-danger-wp:hover { background: var(--bad); color: #fff; }
.btn-sm-wp { padding: 6px 12px; font-size: 12.5px; }

/* ============================================================
   BADGES
============================================================ */
.badge-wp {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 4px 10px; border-radius: 999px;
  font-size: 11.5px; font-weight: 700; letter-spacing: .03em;
  text-transform: uppercase; font-family: "Manrope", sans-serif;
}
.badge-ok      { background: var(--ok-bg);    color: var(--ok); }
.badge-warn    { background: var(--warn-bg);   color: var(--warn); }
.badge-bad     { background: var(--bad-bg);    color: var(--bad); }
.badge-neutral { background: var(--paper-2);   color: var(--ink-3); }
.badge-plum    { background: var(--plum-soft); color: var(--plum); }

/* ============================================================
   CHIPS / FILTROS
============================================================ */
.chip {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 7px 14px; border-radius: 999px; font-size: 13px;
  font-weight: 600; color: var(--ink-2); font-family: inherit;
  background: var(--surface); border: 1px solid var(--paper-edge);
  cursor: pointer; transition: all .15s ease; white-space: nowrap;
  text-decoration: none;
}
.chip:hover { background: var(--paper-2); color: var(--ink); }
.chip.active { background: var(--ink); color: var(--paper); border-color: var(--ink); }
.chip .mono { color: inherit; opacity: .6; }

/* ============================================================
   SEGMENTED CONTROL
============================================================ */
.seg {
  display: inline-flex; background: var(--surface);
  padding: 4px; border-radius: 999px; border: 1px solid var(--paper-edge);
}
.seg .btn-wp, .seg a, .seg button {
  border: 0; background: transparent; padding: 7px 14px;
  border-radius: 999px; font-size: 13px; font-weight: 600;
  color: var(--ink-3); cursor: pointer; transition: all .15s; font-family: inherit;
  text-decoration: none; display: inline-flex; align-items: center;
}
.seg .btn-wp:hover, .seg a:hover, .seg button:hover { color: var(--ink); background: transparent; }
.seg .btn-wp.active, .seg a.active, .seg button.active { background: var(--surface-white); color: var(--ink); box-shadow: var(--shadow-sm); }

/* ============================================================
   TARJETAS
============================================================ */
.card-paper {
  background: var(--surface); border: 1px solid var(--paper-edge);
  border-radius: var(--radius); box-shadow: var(--shadow-sm);
  transition: background .25s, border-color .25s;
}

/* ============================================================
   STAMP / SELLO
============================================================ */
.stamp {
  display: inline-block; padding: 4px 10px;
  border: 1.5px solid var(--plum); color: var(--plum);
  font-family: "JetBrains Mono", monospace; font-size: 10.5px;
  letter-spacing: .14em; text-transform: uppercase; border-radius: 3px;
  transform: rotate(-1.5deg); background: rgba(255,255,255,.35);
}
[data-theme="dark"] .stamp { background: rgba(255,255,255,.05); }
.stamp.sm { font-size: 9.5px; padding: 2px 7px; }

/* ============================================================
   PIN DOTS
============================================================ */
.pin-dot {
  width: 10px; height: 10px; border-radius: 50%;
  display: inline-block; flex: none;
  box-shadow: inset 0 -2px 0 rgba(0,0,0,.18);
}
.pin-dot.red  { background: var(--pin-red); }
.pin-dot.blue { background: var(--pin-blue); }

/* ============================================================
   FORMULARIOS
============================================================ */
.form-label-wp {
  font-family: "JetBrains Mono", monospace; font-size: 10.5px;
  letter-spacing: .18em; text-transform: uppercase;
  color: var(--ink-3); margin-bottom: 6px; display: block;
}
.input-wp, .textarea-wp, .select-wp {
  width: 100%; background: var(--surface-white);
  border: 1px solid var(--paper-edge); border-radius: 8px;
  padding: 10px 12px; font: inherit; color: var(--ink);
  transition: border-color .15s, box-shadow .15s, background .25s;
}
.input-wp:focus, .textarea-wp:focus, .select-wp:focus {
  outline: none; border-color: var(--plum);
  box-shadow: 0 0 0 3px rgba(91,59,140,.15);
}
[data-theme="dark"] .input-wp:focus,
[data-theme="dark"] .textarea-wp:focus,
[data-theme="dark"] .select-wp:focus {
  box-shadow: 0 0 0 3px rgba(133,98,204,.25);
}
.textarea-wp { min-height: 90px; resize: vertical; }

.drop {
  border: 1.5px dashed var(--ink-5); border-radius: 10px;
  padding: 24px; text-align: center;
  color: var(--ink-3); font-size: 13px;
  background: rgba(255,255,255,.4);
}
[data-theme="dark"] .drop { background: rgba(255,255,255,.03); }

.toggle-row {
  display: flex; align-items: center; gap: 12px;
  padding: 14px 16px; background: var(--surface-white);
  border: 1px solid var(--paper-edge); border-radius: 10px;
  transition: background .25s, border-color .25s;
}
.switch {
  position: relative; width: 44px; height: 24px;
  background: var(--paper-edge); border-radius: 999px;
  cursor: pointer; flex: none; transition: background .2s;
}
.switch::after {
  content: ""; position: absolute; left: 2px; top: 2px;
  width: 20px; height: 20px; background: var(--surface-white);
  border-radius: 50%; transition: transform .2s; box-shadow: var(--shadow-sm);
}
.switch.on { background: var(--plum); }
.switch.on::after { transform: translateX(20px); }

/* ============================================================
   TABS
============================================================ */
.tabs-wp {
  display: flex; gap: 4px;
  border-bottom: 1px solid var(--paper-edge); margin-bottom: 14px;
}
.tabs-wp button {
  background: transparent; border: 0; padding: 10px 14px;
  font-size: 13px; font-weight: 600; color: var(--ink-3);
  cursor: pointer; border-bottom: 2px solid transparent; margin-bottom: -1px;
  font-family: inherit;
}
.tabs-wp button.active { color: var(--ink); border-color: var(--plum); }

/* ============================================================
   VOTACIÓN
============================================================ */
.vote-block {
  background: var(--plum-soft); border: 1px solid var(--paper-edge);
  border-radius: var(--radius); padding: 18px;
}
.vote-row { display: flex; align-items: center; gap: 12px; margin-bottom: 14px; }
.vote-actions { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.vote-btn {
  padding: 10px; border-radius: 8px; font-weight: 700;
  font-size: 13.5px; border: 1.5px solid; cursor: pointer;
  background: var(--surface-white); transition: all .15s; font-family: inherit; color: inherit;
}
.vote-btn.approve { color: var(--ok); border-color: var(--ok); }
.vote-btn.approve:hover { background: var(--ok); color: #fff; }
.vote-btn.reject  { color: var(--bad); border-color: var(--bad); }
.vote-btn.reject:hover { background: var(--bad); color: #fff; }

/* ============================================================
   ARCHIVOS ADJUNTOS
============================================================ */
.file-row {
  display: flex; align-items: center; gap: 12px;
  padding: 10px 12px; border: 1px solid var(--paper-edge);
  border-radius: 8px; background: var(--surface-white); margin-bottom: 8px; font-size: 13px;
  transition: background .25s, border-color .25s;
}
.file-icon {
  width: 36px; height: 36px; border-radius: 6px;
  background: var(--plum-soft); color: var(--plum);
  display: grid; place-items: center;
  font-family: "JetBrains Mono", monospace; font-size: 10px; font-weight: 700;
}

/* ============================================================
   MAPA CSS (decorativo)
============================================================ */
.map-canvas {
  position: relative;
  background:
    radial-gradient(ellipse at 20% 30%, #f4ebd6 0%, transparent 40%),
    radial-gradient(ellipse at 70% 70%, #e8e0c9 0%, transparent 50%),
    linear-gradient(180deg, #ede2c5 0%, #e3d8b8 100%);
  overflow: hidden; border-radius: var(--radius);
}
[data-theme="dark"] .map-canvas {
  background:
    radial-gradient(ellipse at 20% 30%, #1e1640 0%, transparent 40%),
    radial-gradient(ellipse at 70% 70%, #18152a 0%, transparent 50%),
    linear-gradient(180deg, #13111a 0%, #0f0d14 100%);
}
.map-river { stroke: #b9c9d6; stroke-width: 14; fill: none; stroke-linecap: round; opacity: .85; }
.map-road  { stroke: #cdb98d; stroke-width: 3; fill: none; }
.map-city {
  position: absolute; font-family: "Fraunces", serif; font-style: italic;
  font-size: 14px; color: rgba(60,45,15,.55); letter-spacing: .03em;
  text-transform: uppercase; pointer-events: none; transform: translate(-50%, -50%);
  font-weight: 500;
}
.map-pin {
  position: absolute; transform: translate(-50%, -100%);
  cursor: pointer; transition: transform .15s ease; z-index: 2;
}
.map-pin:hover { transform: translate(-50%, -104%) scale(1.06); }
.map-pin .pin-shape { width: 26px; height: 32px; filter: drop-shadow(0 4px 6px rgba(0,0,0,.25)); }
.map-pin .pin-shape svg { width: 100%; height: 100%; display: block; }
.map-pin .pin-label {
  position: absolute; left: 50%; top: 100%; transform: translate(-50%, 4px);
  background: var(--ink); color: var(--paper); padding: 3px 8px; border-radius: 4px;
  font-size: 11px; font-weight: 600; white-space: nowrap;
  opacity: 0; transition: opacity .15s; pointer-events: none;
}
.map-pin:hover .pin-label { opacity: 1; }
.map-pin.active .pin-shape { transform: scale(1.15); }

/* ============================================================
   SHELL DEL VIAJE (layout 2 columnas)
============================================================ */
.trip-shell {
  display: grid; grid-template-columns: 380px 1fr;
  gap: 0; height: calc(100vh - 57px);
}
.trip-side {
  background: var(--surface-2); border-right: 1px solid var(--paper-edge);
  overflow-y: auto; padding: 24px 24px 32px;
  transition: background .25s, border-color .25s;
}
.trip-main { position: relative; overflow-y: auto; overflow-x: hidden; display: flex; flex-direction: column; }
.trip-toolbar {
  display: flex; align-items: center; gap: 12px;
  padding: 14px 20px; border-bottom: 1px solid var(--paper-edge);
  background: var(--glass-toolbar); backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px); flex-wrap: wrap;
  transition: background .25s, border-color .25s;
}
.trip-side h2 { font-size: 32px; margin: 0; line-height: 1; letter-spacing: -0.02em; }
.side-section { margin-top: 28px; }
.side-section h4 {
  font-family: "JetBrains Mono", monospace; font-size: 11px;
  text-transform: uppercase; letter-spacing: .18em; color: var(--ink-3);
  font-weight: 500; margin: 0 0 12px;
}

/* ============================================================
   PRESUPUESTO
============================================================ */
.budget-bar {
  height: 8px; background: var(--paper-edge); border-radius: 999px;
  overflow: hidden; position: relative; margin: 6px 0 8px;
}
.budget-bar-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--ok) 0%, var(--ok) 60%, var(--warn) 80%, var(--bad) 100%);
  transition: width .5s ease;
}
.budget-row { display: flex; justify-content: space-between; font-size: 13px; color: var(--ink-3); }
.budget-row strong { color: var(--ink); font-weight: 700; }

/* ============================================================
   LISTA DE PLANES (sidebar)
============================================================ */
.plan-list-item {
  display: flex; gap: 12px; padding: 12px; border-radius: 10px;
  cursor: pointer !important; transition: background .15s; align-items: flex-start;
  text-decoration: none; color: inherit;
}
.plan-list-item *, .plan-list-item *::before, .plan-list-item *::after { cursor: pointer !important; }
.plan-list-item:hover { background: rgba(255,255,255,.35); }
[data-theme="dark"] .plan-list-item:hover { background: rgba(255,255,255,.05); }
.plan-list-item.active { background: var(--surface-white); box-shadow: var(--shadow-sm); }
.plan-list-item .pin-icon {
  width: 32px; height: 32px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center; flex: none;
  font-size: 15px; line-height: 1;
}
.plan-list-item .pin-icon.red  { background: var(--pin-red-2); color: var(--pin-red); }
.plan-list-item .pin-icon.blue { background: var(--pin-blue-2); color: var(--pin-blue); }
.plan-list-item h5 { margin: 0; font-family: "Fraunces", serif; font-size: 17px; font-weight: 600; letter-spacing: -0.01em; }
.plan-list-item .meta { display: flex; gap: 10px; font-size: 12px; color: var(--ink-3); margin-top: 2px; align-items: center; }
.plan-list-item .meta .price { color: var(--ink); font-weight: 700; }

/* ============================================================
   PÁGINAS / DASHBOARD
============================================================ */
.page { max-width: 1280px; margin: 0 auto; padding: 32px 28px 64px; }
.page-head {
  display: flex; align-items: end; justify-content: space-between; gap: 24px;
  margin-bottom: 32px; padding-bottom: 24px; border-bottom: 1px dashed var(--paper-edge);
}
.page-eyebrow {
  font-family: "JetBrains Mono", monospace; font-size: 11px;
  text-transform: uppercase; letter-spacing: .2em; color: var(--ink-3);
}
.page-title { font-size: 52px; margin: 8px 0 0; font-weight: 600; letter-spacing: -0.025em; }
.page-title em { font-style: italic; font-weight: 400; color: var(--plum); }

/* ============================================================
   TRIP CARDS (dashboard)
============================================================ */
.trip-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); gap: 24px; }
.trip-card {
  position: relative; background: var(--surface); border: 1px solid var(--paper-edge);
  border-radius: var(--radius); padding: 20px;
  transition: transform .18s ease, box-shadow .18s ease, background .25s, border-color .25s;
  cursor: pointer; overflow: hidden; text-decoration: none; color: inherit; display: block;
}
.trip-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-md); }
.trip-card-art { aspect-ratio: 16/10; border-radius: var(--radius-sm); overflow: hidden; margin-bottom: 16px; position: relative; }
.trip-card-meta { display: flex; align-items: center; gap: 8px; font-family: "JetBrains Mono", monospace; font-size: 11px; text-transform: uppercase; letter-spacing: .14em; color: var(--ink-3); margin-bottom: 6px; }
.trip-card h3 { font-size: 26px; margin: 0 0 4px; line-height: 1.05; letter-spacing: -0.015em; }
.trip-card .dest { color: var(--ink-3); font-size: 14px; font-style: italic; font-family: "Fraunces", serif; }
.trip-card-foot { margin-top: 16px; display: flex; align-items: center; justify-content: space-between; }
.trip-new {
  border: 1.5px dashed var(--ink-5); background: transparent;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  text-align: center; min-height: 280px; color: var(--ink-3);
}
.trip-new:hover { border-color: var(--plum); color: var(--plum); }
.trip-new .plus { width: 48px; height: 48px; border-radius: 50%; border: 1.5px solid currentColor; display: grid; place-items: center; font-size: 22px; margin-bottom: 12px; }
.trip-role { position: absolute; top: 14px; left: 14px; z-index: 2; }

/* ============================================================
   PLAN CARDS (agenda)
============================================================ */
.agenda-shell { max-width: 1280px; margin: 0 auto; padding: 24px 28px 80px; }
.agenda-summary {
  position: sticky; top: 57px; z-index: 10;
  background: var(--glass-summary); backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border: 1px solid var(--paper-edge); border-radius: var(--radius);
  padding: 18px 22px; margin-bottom: 28px;
  display: grid; grid-template-columns: 1.4fr 1fr 1fr 1.2fr auto;
  gap: 28px; align-items: center; box-shadow: var(--shadow-sm);
  transition: background .25s, border-color .25s;
}
.agenda-summary .stat .lbl { font-family: "JetBrains Mono", monospace; font-size: 10.5px; text-transform: uppercase; letter-spacing: .18em; color: var(--ink-3); margin-bottom: 4px; }
.agenda-summary .stat .val { font-family: "Fraunces", serif; font-size: 26px; font-weight: 600; line-height: 1; letter-spacing: -0.02em; }
.agenda-summary .stat .val small { font-size: 14px; color: var(--ink-3); font-weight: 500; }

.day-block { border-bottom: 1px solid var(--paper-edge); padding: 8px 0 28px; margin-bottom: 4px; }
.day-head { display: flex; align-items: baseline; gap: 18px; padding: 18px 6px; cursor: pointer; user-select: none; transition: background .15s; border-radius: 10px; }
.day-head:hover { background: rgba(0,0,0,.03); }
[data-theme="dark"] .day-head:hover { background: rgba(255,255,255,.04); }
.day-head .dnum { font-family: "Fraunces", serif; font-size: 14px; font-style: italic; color: var(--plum); font-weight: 500; letter-spacing: .03em; min-width: 56px; }
.day-head h3 { font-size: 38px; font-weight: 600; margin: 0; line-height: 1.05; letter-spacing: -0.025em; }
.day-head h3 em { font-style: italic; font-weight: 400; color: var(--ink-3); }
.day-head .day-meta { margin-left: auto; display: flex; gap: 22px; align-items: baseline; }
.day-head .day-meta .v { font-family: "Fraunces", serif; font-weight: 600; font-size: 22px; letter-spacing: -0.01em; }
.day-head .day-meta .l { font-family: "JetBrains Mono", monospace; font-size: 10.5px; text-transform: uppercase; letter-spacing: .15em; color: var(--ink-3); margin-left: 6px; }
.day-head .caret { width: 28px; height: 28px; display: grid; place-items: center; color: var(--ink-3); transition: transform .25s ease; }
.day-head[aria-expanded="false"] .caret { transform: rotate(-90deg); }

.plan-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 20px; padding: 8px 6px 0; }
.plan-card {
  position: relative; background: var(--surface); border: 1px solid var(--paper-edge);
  border-radius: var(--radius); overflow: hidden;
  transition: transform .2s ease, box-shadow .2s ease, background .25s, border-color .25s;
  cursor: pointer !important; display: flex; flex-direction: column; text-decoration: none; color: inherit;
}
.plan-card *, .plan-card *::before, .plan-card *::after { cursor: pointer !important; }
.plan-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); }
.plan-card .img { aspect-ratio: 4/3; position: relative; overflow: hidden; }
.plan-card .img.placeholder { background: repeating-linear-gradient(45deg, rgba(91,59,140,.04) 0 8px, rgba(91,59,140,.08) 8px 16px), var(--plum-soft); display: grid; place-items: center; color: var(--plum); font-size: 28px; }
.plan-card .body { padding: 16px 18px 18px; }
.plan-card h4 { margin: 0 0 6px; font-size: 20px; line-height: 1.15; letter-spacing: -0.015em; font-weight: 600; }
.plan-card .row { display: flex; align-items: center; gap: 12px; color: var(--ink-3); font-size: 13px; }
.plan-card .row .price { color: var(--ink); font-weight: 700; }
.plan-card .pin-corner { position: absolute; top: 12px; left: 12px; width: 28px; height: 36px; z-index: 2; filter: drop-shadow(0 2px 4px rgba(0,0,0,.35)); }
.plan-card .badge-corner { position: absolute; top: 14px; right: 14px; z-index: 2; }
.plan-card .quick { position: absolute; inset: auto 0 -1px 0; padding: 12px; background: linear-gradient(to top, rgba(0,0,0,.65), transparent); display: flex; justify-content: flex-end; opacity: 0; transition: opacity .2s; }
.plan-card:hover .quick { opacity: 1; }
.plan-card .foot { display: flex; align-items: center; justify-content: space-between; padding: 0 18px 16px; margin-top: auto; }

/* ============================================================
   SHEET / MODAL
============================================================ */
.sheet-backdrop { position: fixed; inset: 0; background: rgba(15,13,20,.55); backdrop-filter: blur(3px); z-index: 100; display: none; }
.sheet-backdrop.show { display: block; }
.sheet {
  position: fixed; top: 0; right: 0; bottom: 0; width: 540px; max-width: 100vw;
  background: var(--paper); z-index: 101;
  box-shadow: -16px 0 48px -10px rgba(0,0,0,.3);
  transform: translateX(100%); transition: transform .3s cubic-bezier(.2,.8,.2,1), background .25s;
  overflow-y: auto; display: flex; flex-direction: column;
}
.sheet.show { transform: translateX(0); }
.sheet-head { padding: 22px 28px 16px; border-bottom: 1px solid var(--paper-edge); display: flex; align-items: flex-start; gap: 16px; }
.sheet-body { padding: 24px 28px 32px; flex: 1; }
.sheet-foot { padding: 16px 28px; border-top: 1px solid var(--paper-edge); background: var(--surface-2); display: flex; gap: 10px; justify-content: flex-end; transition: background .25s; }
.sheet-close { background: transparent; border: 0; color: var(--ink-3); cursor: pointer; padding: 4px; margin-left: auto; }

.modal-center { position: fixed; inset: 0; z-index: 101; display: none; align-items: center; justify-content: center; padding: 28px; }
.modal-center.show { display: flex; }
.modal-card { width: 720px; max-width: 100%; background: var(--paper); border: 1px solid var(--paper-edge); border-radius: var(--radius-lg); box-shadow: var(--shadow-lg); max-height: 90vh; overflow-y: auto; transition: background .25s, border-color .25s; }

/* ============================================================
   MIEMBROS
============================================================ */
.members-grid { display: grid; grid-template-columns: 1fr 380px; gap: 32px; }
.member-row { display: flex; align-items: center; gap: 14px; padding: 14px 16px; border: 1px solid var(--paper-edge); border-radius: var(--radius); background: var(--surface); margin-bottom: 8px; transition: background .25s, border-color .25s; }
.member-row .role { margin-left: auto; font-family: "JetBrains Mono", monospace; font-size: 10.5px; text-transform: uppercase; letter-spacing: .15em; color: var(--ink-3); }
.invite-card { background: var(--surface); border: 1px solid var(--paper-edge); border-radius: var(--radius); padding: 22px; transition: background .25s, border-color .25s; }
.invite-link { display: flex; gap: 6px; background: var(--surface-white); border: 1px solid var(--paper-edge); border-radius: 8px; padding: 6px 6px 6px 12px; font-family: "JetBrains Mono", monospace; font-size: 12px; align-items: center; transition: background .25s; }
.invite-link span { flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; color: var(--ink-3); }

/* ============================================================
   IMÁGENES PLACEHOLDER
============================================================ */
.photo-ph { position: absolute; inset: 0; background-size: cover; background-position: center; }
.photo-ph.p1 { background: linear-gradient(135deg, #6b5d8c 0%, #9c83b8 35%, #d8a87e 75%, #f0d2a2 100%); }
.photo-ph.p2 { background: linear-gradient(160deg, #2d3f5c 0%, #5d7493 50%, #d6c5a0 100%); }
.photo-ph.p3 { background: linear-gradient(200deg, #3a3a4a 0%, #7a5a6a 50%, #c2826b 100%); }
.photo-ph.p4 { background: linear-gradient(170deg, #44604a 0%, #7c9070 50%, #d4c389 100%); }
.photo-ph.p5 { background: linear-gradient(150deg, #5b3b8c 0%, #8e6cb0 50%, #d6a895 100%); }
.photo-ph.p6 { background: linear-gradient(135deg, #1f3340 0%, #4a6a7a 50%, #b8a578 100%); }
.photo-ph.p7 { background: linear-gradient(125deg, #6e3535 0%, #b86a55 50%, #e8c08a 100%); }

/* ============================================================
   TOASTS
============================================================ */
.toast-stack { position: fixed; bottom: 24px; right: 24px; z-index: 9999; display: flex; flex-direction: column; gap: 10px; }
.toast {
  min-width: 300px; max-width: 420px;
  padding: 14px 14px 14px 18px;
  border-radius: 12px; border: 1px solid transparent;
  box-shadow: var(--shadow-md); font-size: 14px; font-weight: 500;
  display: flex; align-items: center; gap: 10px;
  position: relative; overflow: hidden;
  animation: toastIn .28s cubic-bezier(.22,.68,0,1.2) both;
}
.toast.success { background: var(--ok-bg);     border-color: var(--ok);     color: var(--ok); }
.toast.error   { background: var(--bad-bg);    border-color: var(--bad);    color: var(--bad); }
.toast.warning { background: var(--warn-bg);   border-color: var(--warn);   color: var(--warn); }
.toast.info    { background: var(--plum-soft); border-color: var(--plum-3); color: var(--plum); }
.toast-icon { font-size: 16px; flex-shrink: 0; }
.toast-msg  { flex: 1; line-height: 1.4; }
.toast-close {
  flex-shrink: 0; background: none; border: none; cursor: pointer;
  color: inherit; opacity: .5; font-size: 18px; line-height: 1;
  padding: 0 2px; transition: opacity .15s;
}
.toast-close:hover { opacity: 1; }
.toast-bar {
  position: absolute; bottom: 0; left: 0; height: 3px; width: 100%;
  animation: toastBar linear forwards;
  transform-origin: left;
}
.toast.success .toast-bar { background: var(--ok); }
.toast.error   .toast-bar { background: var(--bad); }
.toast.warning .toast-bar { background: var(--warn); }
.toast.info    .toast-bar { background: var(--plum); }
@keyframes toastIn  { from { opacity: 0; transform: translateX(24px) scale(.97); } to { opacity: 1; transform: translateX(0) scale(1); } }
@keyframes toastOut { from { opacity: 1; transform: translateX(0); max-height: 80px; margin-bottom: 0; } to { opacity: 0; transform: translateX(24px); max-height: 0; margin-bottom: -10px; } }
@keyframes toastBar { from { transform: scaleX(1); } to { transform: scaleX(0); } }

/* ============================================================
   AUTH PAGES
============================================================ */
.auth-wrap { min-height: 100vh; display: grid; place-items: center; padding: 32px 16px; }
.auth-card { width: 100%; max-width: 420px; }
.auth-card h1 { font-size: 44px; margin: 0 0 8px; }
.auth-card .sub { color: var(--ink-3); margin-bottom: 32px; }
.alert-wp { padding: 12px 16px; border-radius: var(--radius-sm); font-size: 14px; border: 1px solid; }
.alert-error-wp { background: var(--bad-bg); border-color: var(--bad); color: var(--bad); }
.form-errors {
  background: var(--bad-bg); border: 1px solid var(--bad); border-radius: 10px;
  padding: 12px 16px; color: var(--bad); font-size: 14px; font-weight: 500;
}
.form-errors p { margin: 0; line-height: 1.6; }
.form-errors p + p { margin-top: 4px; }
.form-errors p::before { content: "✕  "; }

/* ============================================================
   ERRORS
============================================================ */
.error-page { min-height: 100vh; display: grid; place-items: center; text-align: center; padding: 32px; }
.error-page .code { font-family: "Fraunces", serif; font-size: 120px; font-weight: 600; letter-spacing: -0.04em; color: var(--plum); line-height: 1; }

/* ============================================================
   MISC
============================================================ */
.divider-dashed { border: 0; border-top: 1px dashed var(--paper-edge); margin: 20px 0; }
.text-muted-wp { color: var(--ink-3); }
.text-overlap { color: var(--pin-red); }

.compass { position: absolute; right: 20px; top: 20px; width: 64px; height: 64px; border-radius: 50%; background: var(--glass-bar); border: 1px solid var(--paper-edge); display: grid; place-items: center; box-shadow: var(--shadow-md); font-family: "Fraunces", serif; z-index: 4; transition: background .25s; }
.map-controls { position: absolute; right: 20px; bottom: 20px; display: flex; flex-direction: column; gap: 1px; background: var(--paper-edge); border-radius: 8px; overflow: hidden; box-shadow: var(--shadow-md); z-index: 4; }
.map-controls button { width: 36px; height: 36px; background: var(--surface-white); border: 0; font-weight: 700; color: var(--ink-2); cursor: pointer; font-family: inherit; transition: background .15s; }
.map-controls button:hover { background: var(--surface); }

/* ============================================================
   SCROLLBARS
============================================================ */
.trip-side::-webkit-scrollbar { width: 6px; }
.trip-side::-webkit-scrollbar-thumb { background: var(--paper-edge); border-radius: 999px; }
.trip-side::-webkit-scrollbar-track { background: transparent; }

/* ============================================================
   RESPONSIVE
============================================================ */

/* Tablet ancho: colapsar trip-shell y members-grid */
@media (max-width: 960px) {
  .trip-shell { grid-template-columns: 1fr; height: auto; }
  .trip-side { border-right: 0; border-bottom: 1px solid var(--paper-edge); }
  .members-grid { grid-template-columns: 1fr; }
  .page-title { font-size: 36px; }
  .agenda-summary { grid-template-columns: 1fr 1fr 1fr auto; gap: 20px; }
}

/* ============================================================
   MÓVIL — 767px
============================================================ */
@media (max-width: 767px) {

  /* --- Navbar ------------------------------------------- */
  .app-bar-inner { padding: 8px 12px; gap: 6px; }
  .app-bar-end { gap: 4px; }
  /* Ocultar "Proponer plan" en navbar en móvil: disponible desde el sidebar */
  .app-bar-propose { display: none !important; }
  /* Coins pill más compacto: solo icono + número sin padding extra */
  .rw-coins-pill { padding: 3px 8px 3px 4px; gap: 4px; font-size: .78rem; }
  /* Botones icono compactos */
  .app-bar-end > a.btn-wp[style*="padding: 6px 10px"],
  .app-bar-end > a.btn-wp { padding: 5px 8px !important; font-size: 15px; min-height: 32px; }

  /* --- Trip shell --------------------------------------- */
  .trip-shell { grid-template-columns: 1fr !important; height: auto !important; }
  .trip-side {
    border-right: 0;
    border-bottom: 1px solid var(--paper-edge);
    padding: 14px;
  }
  .trip-side h2 { font-size: 24px; }

  /* --- Títulos de página con inline font-size overrides --- */
  .trip-page-title { font-size: 28px; }
  /* Mapa: altura mínima garantizada (overrides el style inline de flex:1) */
  #map { flex: none !important; min-height: 60vh !important; }

  /* --- Toolbar / chips ---------------------------------- */
  .trip-toolbar {
    flex-direction: column;
    align-items: stretch;
    padding: 8px 12px;
    gap: 6px;
  }
  .trip-toolbar > .d-flex:first-child {
    flex-wrap: wrap !important;
    gap: 6px !important;
  }
  .trip-toolbar .ms-auto {
    margin-left: 0 !important;
    flex-shrink: 0;
    justify-content: flex-end;
    border-top: 1px solid var(--paper-edge);
    padding-top: 6px;
  }
  .chip { white-space: nowrap; flex-shrink: 0; }

  /* --- Pages -------------------------------------------- */
  .page { padding: 16px 14px 56px; }
  .page-head {
    flex-direction: column;
    align-items: flex-start;
    gap: 12px;
    margin-bottom: 18px;
    padding-bottom: 14px;
  }
  .page-title { font-size: 30px; }

  /* --- Agenda ------------------------------------------- */
  .agenda-shell { padding: 14px 14px 64px; }
  .agenda-summary {
    position: static;
    grid-template-columns: 1fr 1fr;
    gap: 14px;
    padding: 14px;
    margin-bottom: 14px;
  }
  .agenda-summary .stat .val { font-size: 20px; }
  .agenda-summary .stat .lbl { font-size: 9.5px; }
  .agenda-summary > a.btn-wp { grid-column: 1 / -1; justify-content: center; }

  /* --- Day blocks --------------------------------------- */
  .day-head { padding: 12px 4px; gap: 8px; }
  .day-head h3 { font-size: 26px; }
  .day-head .day-meta { gap: 10px; }
  .day-head .day-meta .v { font-size: 17px; }
  .day-head .dnum { min-width: 40px; font-size: 12px; }

  /* --- Grids -------------------------------------------- */
  .plan-grid { grid-template-columns: 1fr !important; gap: 14px; }
  .trip-grid { grid-template-columns: 1fr !important; gap: 16px; }
  .members-grid { grid-template-columns: 1fr; }

  /* --- Toasts ------------------------------------------- */
  .toast-stack { left: 10px; right: 10px; bottom: 12px; }
  .toast { min-width: unset; max-width: unset; width: 100%; }

  /* --- Sheet -------------------------------------------- */
  .sheet { width: 100%; }

  /* --- Modal -------------------------------------------- */
  .modal-center { padding: 12px; }
  .modal-card { max-height: 95vh; }

  /* --- Touch targets mínimas ---------------------------- */
  .btn-wp { min-height: 40px; }
  .btn-sm-wp { min-height: 34px; }

  /* --- Misc --------------------------------------------- */
  .trip-new { min-height: 160px; }
  .side-section { margin-top: 20px; }

  /* --- Inputs de archivo -------------------------------- */
  input[type="file"].input-wp { min-width: 0; }

  /* --- Seg en agenda header ----------------------------- */
  .agenda-shell > .d-flex > .seg { flex-shrink: 0; }

  /* --- Vote block en detalle de plan -------------------- */
  .vote-block { padding: 14px; }

  /* --- Tabs desbordables -------------------------------- */
  .tabs-wp { overflow-x: auto; scrollbar-width: none; flex-wrap: nowrap; }
  .tabs-wp::-webkit-scrollbar { display: none; }
  .tabs-wp button { white-space: nowrap; flex-shrink: 0; }

  /* --- File row en adjuntos ----------------------------- */
  .file-row { flex-wrap: wrap; }
  .file-row > div { min-width: 0; flex: 1; }

  /* --- Invite link en miembros -------------------------- */
  .invite-link { max-width: 100%; }
  .invite-link span { min-width: 0; }
}

/* ============================================================
   MÓVIL PEQUEÑO — 480px
============================================================ */
@media (max-width: 480px) {
  .page-title { font-size: 26px; }
  .trip-page-title { font-size: 24px; }
  .agenda-summary { grid-template-columns: 1fr; }
  .day-head h3 { font-size: 22px; }
  .trip-side h2 { font-size: 20px; }
  .plan-grid { gap: 12px; }
  .trip-grid { gap: 14px; }
  .day-head .day-meta { display: none; }

  /* File inputs: ocupa ancho completo para que el botón baje */
  input[type="file"].input-wp { width: 100%; }

  /* Seg en agenda header: quita el ms-auto para que quede a la izquierda */
  .agenda-shell > .d-flex > .ms-auto.seg,
  .agenda-shell > .d-flex > div.ms-auto { margin-left: 0 !important; }

  /* Vote block botones */
  .vote-btn { font-size: 13px; padding: 8px; }

  /* Reserva banner en detalle plan */
  .reserva-banner { gap: 10px; padding: 12px 14px; }
  .reserva-banner > form { width: 100%; }
  .reserva-banner > form .btn-wp { width: 100%; justify-content: center; }
}

/* ============================================================
   MÓVIL MÍNIMO — 320px
============================================================ */
@media (max-width: 320px) {
  /* Navbar */
  .app-bar-inner { padding: 6px 10px; }
  .app-bar-subnav { padding: 3px 10px 5px; }
  .brand { font-size: 17px; gap: 7px; }
  .brand-mark { width: 20px; height: 20px; }
  .brand-mark::after { border-top-width: 7px; border-left-width: 4px; border-right-width: 4px; }
  .app-bar-end { gap: 4px; }
  .theme-toggle { width: 30px; height: 30px; }

  /* Pages */
  .page { padding: 10px 10px 40px; }
  .page-title { font-size: 22px; }
  .page-head { margin-bottom: 12px; padding-bottom: 10px; }
  .page-eyebrow { font-size: 10px; letter-spacing: .14em; }

  /* Agenda */
  .agenda-shell { padding: 10px 10px 48px; }
  .agenda-summary { gap: 10px; padding: 12px 10px; }
  .agenda-summary .stat .val { font-size: 17px; }

  /* Trip side */
  .trip-side { padding: 10px; }
  .trip-side h2 { font-size: 18px; }
  .trip-page-title { font-size: 20px; }
  .side-section { margin-top: 16px; }
  .side-section h4 { font-size: 10px; margin-bottom: 8px; }

  /* Day blocks */
  .day-head { padding: 8px 2px; gap: 6px; }
  .day-head h3 { font-size: 19px; }
  .day-head .dnum { display: none; }

  /* Buttons */
  .btn-wp { font-size: 13px; padding: 8px 14px; }
  .btn-sm-wp { padding: 5px 9px; font-size: 12px; }
  .chip { padding: 5px 10px; font-size: 12px; }

  /* Toasts */
  .toast-stack { left: 6px; right: 6px; bottom: 8px; }
  .toast { font-size: 13px; padding: 12px 12px 12px 14px; }

  /* Error page */
  .error-page .code { font-size: 72px; }

  /* Members */
  .member-row { padding: 10px 12px; gap: 10px; }
  .invite-card { padding: 16px; }

  /* Seg buttons más compactos */
  .seg a, .seg button, .seg .btn-wp { padding: 6px 10px; font-size: 12px; }

  /* Vote actions */
  .vote-actions { gap: 8px; }
  .vote-block { padding: 12px; }

  /* Tabs */
  .tabs-wp button { padding: 8px 10px; font-size: 12px; }

  /* Plan card body */
  .plan-card .body { padding: 12px 14px 14px; }
  .plan-card h4 { font-size: 17px; }

  /* Trip card */
  .trip-card { padding: 14px; }
  .trip-card h3 { font-size: 20px; }

  /* Formularios */
  .input-wp, .textarea-wp, .select-wp { padding: 8px 10px; font-size: 14px; }
  .form-label-wp { font-size: 9.5px; letter-spacing: .14em; }

  /* File row adjuntos */
  .file-row { padding: 8px 10px; font-size: 12px; }
  .file-icon { width: 30px; height: 30px; font-size: 9px; }
}

/* ============================================================
   DEPTH & ELEVATION — Modo claro (layered look)
============================================================ */
.trip-card {
  box-shadow: 0 0 0 1px rgba(28,26,30,.04), var(--shadow-sm);
}
.trip-card:hover {
  box-shadow: 0 0 0 1px rgba(91,59,140,.08), var(--shadow-md);
  border-color: rgba(91,59,140,.2);
}
.plan-card {
  box-shadow: 0 0 0 1px rgba(28,26,30,.04), var(--shadow-sm);
}
.plan-card:hover {
  box-shadow: 0 0 0 1px rgba(91,59,140,.08), var(--shadow-md);
  border-color: rgba(91,59,140,.2);
}

/* Trip title más dramático */
.trip-side h2 { font-size: 34px; }

/* ============================================================
   DARK MODE — Overrides específicos de profundidad
============================================================ */

/* Chips: transparentes inactivos, plum activo con glow */
[data-theme="dark"] .chip {
  background: rgba(255,255,255,.04);
  border-color: rgba(255,255,255,.08);
  color: var(--ink-3);
}
[data-theme="dark"] .chip:hover {
  background: rgba(255,255,255,.08);
  color: var(--ink);
  border-color: rgba(255,255,255,.14);
}
[data-theme="dark"] .chip.active {
  background: var(--plum);
  color: #fff;
  border-color: var(--plum);
  box-shadow: 0 0 18px rgba(133,98,204,.4), 0 2px 8px rgba(133,98,204,.3);
}

/* Segmented control en dark */
[data-theme="dark"] .seg {
  background: rgba(255,255,255,.04);
  border-color: rgba(255,255,255,.08);
}
[data-theme="dark"] .seg .btn-wp.active,
[data-theme="dark"] .seg a.active {
  background: rgba(255,255,255,.12);
  color: var(--ink);
  box-shadow: 0 1px 0 rgba(255,255,255,.06) inset;
}

/* Toolbar en dark: más separación del mapa */
[data-theme="dark"] .trip-toolbar {
  background: rgba(20,17,36,.9);
  border-bottom-color: rgba(255,255,255,.06);
  box-shadow: 0 1px 0 rgba(255,255,255,.03);
}

/* Navbar en dark: más visible */
[data-theme="dark"] .app-bar {
  border-bottom-color: rgba(255,255,255,.06);
  box-shadow: 0 1px 0 rgba(255,255,255,.03);
}

/* Tarjetas en dark: inner highlight + hover glow */
[data-theme="dark"] .trip-card,
[data-theme="dark"] .plan-card {
  border-color: rgba(255,255,255,.06);
  box-shadow: 0 1px 0 rgba(255,255,255,.05) inset, var(--shadow-sm);
}
[data-theme="dark"] .trip-card:hover,
[data-theme="dark"] .plan-card:hover {
  border-color: rgba(133,98,204,.35);
  box-shadow: 0 0 0 1px rgba(133,98,204,.15), 0 0 30px rgba(133,98,204,.08), var(--shadow-md);
}

/* Botón primario con glow plum en dark */
[data-theme="dark"] .btn-primary-wp {
  box-shadow: 0 2px 0 rgba(0,0,0,.5), 0 0 24px rgba(133,98,204,.35);
}
[data-theme="dark"] .btn-primary-wp:hover {
  box-shadow: 0 2px 0 rgba(0,0,0,.5), 0 0 32px rgba(133,98,204,.5);
}

/* Plan list items en dark */
[data-theme="dark"] .plan-list-item:hover {
  background: rgba(133,98,204,.07);
}
[data-theme="dark"] .plan-list-item.active {
  background: rgba(133,98,204,.12);
}

/* Sidebar en dark — diferencia sutil del fondo */
[data-theme="dark"] .trip-side {
  background: #12101f;
  border-right-color: rgba(255,255,255,.05);
}

/* Budget bar en dark — más vibrante */
[data-theme="dark"] .budget-bar {
  background: rgba(255,255,255,.06);
}

/* Formularios en dark */
[data-theme="dark"] .input-wp,
[data-theme="dark"] .textarea-wp,
[data-theme="dark"] .select-wp {
  border-color: rgba(255,255,255,.08);
}
[data-theme="dark"] .input-wp:hover,
[data-theme="dark"] .textarea-wp:hover,
[data-theme="dark"] .select-wp:hover {
  border-color: rgba(255,255,255,.14);
}

/* Card-paper en dark */
[data-theme="dark"] .card-paper {
  border-color: rgba(255,255,255,.06);
  box-shadow: 0 1px 0 rgba(255,255,255,.04) inset;
}

/* Divider en dark */
[data-theme="dark"] .divider-dashed {
  border-top-color: rgba(255,255,255,.07);
}

/* Toasts en dark con glow sutil */
[data-theme="dark"] .toast {
  box-shadow: var(--shadow-md), 0 0 24px rgba(0,0,0,.4);
}

/* Page head separator en dark */
[data-theme="dark"] .page-head {
  border-bottom-color: rgba(255,255,255,.06);
}

/* Texto de ciudad en mapa decorativo — era oscuro sobre fondo oscuro */
[data-theme="dark"] .map-city {
  color: rgba(200,185,240,.4);
}

/* Ríos y caminos del mapa decorativo */
[data-theme="dark"] .map-river { stroke: #1e3050; }
[data-theme="dark"] .map-road  { stroke: #2a2540; }

/* Popups de Leaflet en dark mode */
[data-theme="dark"] .leaflet-popup-content-wrapper,
[data-theme="dark"] .leaflet-popup-tip {
  background: var(--surface-white);
  color: var(--ink);
  box-shadow: var(--shadow-lg);
}
[data-theme="dark"] .leaflet-popup-content-wrapper a {
  color: var(--plum-3);
}
[data-theme="dark"] .leaflet-popup-close-button {
  color: var(--ink-3) !important;
}
[data-theme="dark"] .leaflet-bar a,
[data-theme="dark"] .leaflet-bar a:hover {
  background: var(--surface-white);
  color: var(--ink);
  border-bottom-color: var(--paper-edge);
}
[data-theme="dark"] .leaflet-control-attribution {
  background: rgba(15,13,20,.75);
  color: var(--ink-3);
}
[data-theme="dark"] .leaflet-control-attribution a { color: var(--plum-3); }

/* Agenda summary en dark */
[data-theme="dark"] .agenda-summary {
  border-color: rgba(255,255,255,.06);
  box-shadow: 0 1px 0 rgba(255,255,255,.04) inset;
}

/* Ghost button en dark más visible */
[data-theme="dark"] .btn-ghost-wp {
  border-color: rgba(255,255,255,.1);
  color: var(--ink-2);
}
[data-theme="dark"] .btn-ghost-wp:hover {
  background: rgba(255,255,255,.07);
  border-color: rgba(255,255,255,.16);
  color: var(--ink);
}
[data-theme="dark"] .btn-ghost-wp.active {
  background: rgba(255,255,255,.08);
  border-color: rgba(255,255,255,.16);
  color: var(--ink);
}

/* ============================================================
   DETALLES VISUALES RESTAURADOS
============================================================ */

/* Línea de acento plum en tope del sidebar */
.trip-side { position: relative; }
.trip-side::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--plum) 0%, var(--plum-2) 50%, transparent 100%);
  opacity: .55;
  pointer-events: none;
}
[data-theme="dark"] .trip-side::before { opacity: .85; }

/* Gradient en el título del viaje (sidebar) */
.trip-side h2 {
  font-size: 34px;
  background: linear-gradient(130deg, var(--ink) 30%, var(--plum-2) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
[data-theme="dark"] .trip-side h2 {
  background: linear-gradient(130deg, var(--ink) 20%, var(--plum-3) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* Borde izquierdo en plan list items */
.plan-list-item {
  border-left: 2px solid transparent;
  padding-left: 10px;
  transition: background .15s, border-color .2s;
}
.plan-list-item:hover { border-left-color: var(--plum-3); }
.plan-list-item.active { border-left-color: var(--plum); }
[data-theme="dark"] .plan-list-item:hover { border-left-color: var(--plum-2); }
[data-theme="dark"] .plan-list-item.active { border-left-color: var(--plum); }

/* ============================================================
   ANIMACIONES
============================================================ */

@keyframes fadeSlideUp {
  from { opacity: 0; transform: translateY(20px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes fadeIn {
  from { opacity: 0; }
  to   { opacity: 1; }
}
@keyframes shimmer {
  0%   { background-position: -400px 0; }
  100% { background-position: 400px 0; }
}
@keyframes pulseGlow {
  0%, 100% { box-shadow: 0 0 10px rgba(133,98,204,.25), 0 2px 8px rgba(133,98,204,.2); }
  50%       { box-shadow: 0 0 24px rgba(133,98,204,.55), 0 4px 16px rgba(133,98,204,.35); }
}
@keyframes pinBounce {
  0%, 100% { transform: translate(-50%, -100%) scaleY(1); }
  40%       { transform: translate(-50%, -100%) scaleY(1.12); }
  60%       { transform: translate(-50%, -100%) scaleY(.94); }
}
@keyframes slideInRight {
  from { opacity: 0; transform: translateX(12px); }
  to   { opacity: 1; transform: translateX(0); }
}
@keyframes barFill {
  from { width: 0 !important; }
}

/* Cards — entrada escalonada */
.trip-grid .trip-card {
  animation: fadeSlideUp .45s cubic-bezier(.22,1,.36,1) both;
}
.trip-grid .trip-card:nth-child(1) { animation-delay: .04s; }
.trip-grid .trip-card:nth-child(2) { animation-delay: .09s; }
.trip-grid .trip-card:nth-child(3) { animation-delay: .14s; }
.trip-grid .trip-card:nth-child(4) { animation-delay: .19s; }
.trip-grid .trip-card:nth-child(5) { animation-delay: .24s; }
.trip-grid .trip-card:nth-child(6) { animation-delay: .29s; }

/* Plan cards en agenda */
.plan-grid .plan-card {
  animation: fadeSlideUp .4s cubic-bezier(.22,1,.36,1) both;
}
.plan-grid .plan-card:nth-child(1) { animation-delay: .05s; }
.plan-grid .plan-card:nth-child(2) { animation-delay: .10s; }
.plan-grid .plan-card:nth-child(3) { animation-delay: .15s; }
.plan-grid .plan-card:nth-child(4) { animation-delay: .20s; }

/* Plan list items en sidebar */
.plan-list-item {
  animation: slideInRight .35s cubic-bezier(.22,1,.36,1) both;
}
.plan-list-item:nth-child(1) { animation-delay: .06s; }
.plan-list-item:nth-child(2) { animation-delay: .11s; }
.plan-list-item:nth-child(3) { animation-delay: .16s; }
.plan-list-item:nth-child(4) { animation-delay: .21s; }
.plan-list-item:nth-child(5) { animation-delay: .26s; }

/* Budget bar animada */
.budget-bar-fill { animation: barFill .9s cubic-bezier(.22,1,.36,1) both; animation-delay: .3s; }

/* Chip activo pulsa suavemente en dark */
[data-theme="dark"] .chip.active {
  animation: pulseGlow 2.8s ease-in-out infinite;
}

/* Botón primario — hover más expresivo */
.btn-primary-wp {
  transition: background .18s, box-shadow .22s, transform .12s cubic-bezier(.22,1,.36,1);
}
.btn-primary-wp:hover { transform: translateY(-2px); }
.btn-primary-wp:active { transform: translateY(0px); }

/* SweetAlert2 — integración con design system */
.swal-wp {
  background: var(--surface) !important;
  color: var(--ink) !important;
  border: 1px solid var(--paper-edge) !important;
  border-radius: var(--radius) !important;
  font-family: "Manrope", system-ui, sans-serif !important;
  box-shadow: var(--shadow-lg) !important;
}
.swal2-title { color: var(--ink) !important; font-family: "Fraunces", serif !important; }
.swal2-html-container { color: var(--ink-2) !important; font-size: 14px !important; }
.swal2-icon.swal2-error { border-color: var(--bad) !important; color: var(--bad) !important; }
.swal2-icon.swal2-error [class^=swal2-x-mark-line] { background: var(--bad) !important; }

/* Cards — hover más suave con spring */
.trip-card, .plan-card {
  transition: transform .22s cubic-bezier(.22,1,.36,1), box-shadow .22s ease, background .25s, border-color .25s;
}
.trip-card:hover, .plan-card:hover { transform: translateY(-5px); }

/* Pin dots — pulso en sidebar activo */
.plan-list-item.active .pin-icon {
  animation: pulseGlow 3s ease-in-out infinite;
}

/* Shimmer en placeholders de imagen */
.plan-card .img.placeholder::after {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(90deg, transparent 0%, rgba(255,255,255,.08) 50%, transparent 100%);
  background-size: 400px 100%;
  animation: shimmer 2s linear infinite;
  pointer-events: none;
  cursor: pointer;
}

/* Nav scroller — dot indicator en enlace activo */
.app-bar-nav-scroller a.btn-wp {
  position: relative;
  transition: color .18s, background .18s;
}
.app-bar-nav-scroller a.btn-wp.active::after {
  content: "";
  position: absolute; bottom: -10px; left: 50%; transform: translateX(-50%);
  width: 4px; height: 4px; border-radius: 50%;
  background: var(--plum);
}

/* Formularios — focus más expresivo */
.input-wp, .textarea-wp, .select-wp {
  transition: border-color .18s, box-shadow .22s cubic-bezier(.22,1,.36,1), background .25s;
}
.input-wp:focus, .textarea-wp:focus, .select-wp:focus {
  transform: none;
  box-shadow: 0 0 0 3px rgba(91,59,140,.18), 0 2px 8px rgba(91,59,140,.08);
}

/* Toast — entrada más expresiva */
@keyframes toastIn {
  from { opacity: 0; transform: translateY(16px) scale(.95); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}

/* Botones ghost — micro feedback */
.btn-ghost-wp {
  transition: background .15s, color .15s, border-color .15s, transform .1s;
}
.btn-ghost-wp:active { transform: scale(.97); }

/* Avatar — hover reveal */
.avatar {
  transition: transform .18s cubic-bezier(.22,1,.36,1), box-shadow .18s;
}
.avatar:hover { transform: scale(1.12); box-shadow: 0 4px 12px rgba(91,59,140,.3); }

/* Agenda summary — entrada */
.agenda-summary {
  animation: fadeSlideUp .5s cubic-bezier(.22,1,.36,1) both;
}

/* Checklist items — entrada */
#checklist-cuerpo .toggle-row {
  animation: fadeSlideUp .3s cubic-bezier(.22,1,.36,1) both;
}

/* Respeta preferencias de movimiento reducido */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: .01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: .01ms !important;
  }
}

/* ============================================================
   BOTTOM NAV — Navegación viaje en móvil
============================================================ */
.bottom-nav {
  position: fixed;
  bottom: 0; left: 0; right: 0;
  width: 100%;
  height: 60px;
  background: var(--paper);
  border-top: 1px solid var(--paper-edge);
  display: none;
  align-items: stretch;
  z-index: 1100;
  overflow: hidden;
  /* safe area para notch/home indicator en iOS */
  padding-bottom: env(safe-area-inset-bottom, 0px);
}

.bottom-nav-item {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 3px;
  font-size: 10px;
  font-weight: 600;
  color: var(--ink-3);
  text-decoration: none;
  letter-spacing: .03em;
  transition: color .15s;
  padding: 6px 4px;
}
.bottom-nav-item svg { flex-shrink: 0; transition: stroke .15s; }
.bottom-nav-item.active { color: var(--plum); }
.bottom-nav-item.active svg { stroke: var(--plum); }
.bottom-nav-item:hover { color: var(--ink); }

/* Botón CTA central (+) */
.bottom-nav-cta {
  position: relative;
  justify-content: center;
}
.bottom-nav-cta::before {
  content: '';
  position: absolute;
  width: 48px; height: 48px;
  border-radius: 50%;
  background: var(--plum);
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  z-index: -1;
  box-shadow: 0 4px 14px rgba(133,98,204,.45);
}
.bottom-nav-cta svg { stroke: #fff; }

[data-theme="dark"] .bottom-nav {
  background: var(--paper);
  border-top-color: var(--paper-edge);
}

@media (max-width: 767px) {
  .bottom-nav { display: flex; }
  /* Espacio para que el contenido no quede bajo el bottom nav */
  body { padding-bottom: calc(60px + env(safe-area-inset-bottom, 0)); }
  /* Ocultar nav tabs del header en móvil — reemplazados por bottom nav */
  .app-bar-nav-scroller { display: none !important; }
  /* trip-main y trip-side fluyen normal para que el body-scroll funcione */
  .trip-main { overflow-y: visible !important; overflow-x: hidden !important; height: auto !important; }
  .trip-side  { overflow-y: visible !important; }
  /* Toasts encima del bottom nav */
  .toast-stack { bottom: 76px; }
}

/* ============================================================
   COSMÉTICOS — Animaciones globales (disponibles en todas las páginas)
============================================================ */
@keyframes pulseGlow {
  0%,100% { box-shadow: 0 0 14px #8562cc; }
  50%      { box-shadow: 0 0 28px #8562cc, 0 0 50px #8562cc44; }
}
@keyframes rainbowBorder {
  0%   { border-color: #ff0000; box-shadow: 0 0 10px #ff000088; }
  16%  { border-color: #ff8800; box-shadow: 0 0 10px #ff880088; }
  33%  { border-color: #ffff00; box-shadow: 0 0 10px #ffff0088; }
  50%  { border-color: #00ff00; box-shadow: 0 0 10px #00ff0088; }
  66%  { border-color: #0088ff; box-shadow: 0 0 10px #0088ff88; }
  83%  { border-color: #8800ff; box-shadow: 0 0 10px #8800ff88; }
  100% { border-color: #ff0000; box-shadow: 0 0 10px #ff000088; }
}
@keyframes flameBorder {
  0%,100% { border-color: #ff4400; box-shadow: 0 0 12px #ff440099, 0 0 24px #ff220044; }
  50%     { border-color: #ffaa00; box-shadow: 0 0 20px #ffaa0099, 0 0 40px #ff440044; }
}

/* Mascota flotante */
@keyframes mascotaFloat {
  0%,100% { transform: translateY(0) rotate(-3deg); }
  50%     { transform: translateY(-8px) rotate(3deg); }
}
@keyframes mascotaBounce {
  0%   { transform: scale(1) rotate(0deg); }
  20%  { transform: scale(1.3) rotate(-15deg); }
  40%  { transform: scale(.9) rotate(10deg); }
  60%  { transform: scale(1.15) rotate(-8deg); }
  80%  { transform: scale(.95) rotate(4deg); }
  100% { transform: scale(1) rotate(0deg); }
}
#mascota-widget {
  position: fixed;
  bottom: 24px; right: 20px;
  z-index: 1000;
  cursor: pointer;
  user-select: none;
  filter: drop-shadow(0 4px 8px rgba(0,0,0,.35));
  animation: mascotaFloat 3s ease-in-out infinite;
  display: none;
  flex-direction: column;
  align-items: center;
  gap: 6px;
}
#mascota-widget.visible { display: flex; }
#mascota-emoji { font-size: 2.2rem; line-height: 1; }
#mascota-burbuja {
  background: var(--paper);
  border: 1.5px solid var(--paper-edge);
  border-radius: 12px 12px 12px 0;
  padding: 5px 10px;
  font-size: 11px;
  font-weight: 600;
  color: var(--ink-2);
  white-space: nowrap;
  opacity: 0;
  transform: scale(.8);
  transition: opacity .2s, transform .2s;
  pointer-events: none;
}
#mascota-widget:hover #mascota-burbuja,
#mascota-widget.hablando #mascota-burbuja {
  opacity: 1; transform: scale(1);
}
@media (max-width: 768px) {
  #mascota-widget { bottom: 76px; }
}

