.jp-schengen {
  --jp-primary: #e28322;
  --jp-primary-hover: #d17416;
  --jp-primary-ink: #ffffff;
  --jp-brand-navy: #1f2f63;
  --jp-brand-red: #c12846;
  --jp-ink: #1f2f63;
  --jp-border: #c4ccd9;
  --jp-soft: #f4f5f7;
  --jp-soft-2: #eceff4;
  --jp-danger: #b91c1c;
  color: var(--jp-ink);
  font-family: inherit;
}

.jp-schengen__header {
  background: linear-gradient(105deg, var(--jp-brand-navy) 0%, #2e396f 45%, var(--jp-brand-red) 100%);
  border-radius: 16px;
  color: #fff;
  padding: 1rem 1.25rem;
}

.jp-schengen__header h2 { color: inherit; margin: 0 0 0.2rem; }
.jp-schengen__header p { color: rgba(255, 255, 255, 0.92); margin: 0; }

.jp-schengen__card {
  background: var(--jp-soft);
  border: 1px solid var(--jp-border);
  border-radius: 16px;
  padding: 1rem;
  margin-top: 1rem;
}

.jp-btn {
  background: var(--jp-primary);
  color: var(--jp-primary-ink);
  border: none;
  border-radius: 999px;
  padding: 0.62rem 1.2rem;
  cursor: pointer;
  font-weight: 600;
}
.jp-btn:hover { background: var(--jp-primary-hover); }

.jp-btn--ghost {
  background: transparent;
  color: var(--jp-ink);
  border: 1px solid var(--jp-border);
  border-radius: 10px;
}

.jp-help,
.jp-note { margin: .5rem 0; }
.jp-note--error { color: var(--jp-danger); }

.jp-schengen select,
.jp-schengen textarea,
.jp-schengen input {
  width: 100%;
  border: 1px solid #c9cdd4;
  border-radius: 10px;
  padding: 0.55rem 0.75rem;
  background: #fff;
}

.jp-schengen select[multiple] {
  min-height: 220px;
}

.jp-selected-box {
  margin-top: .6rem;
  border: 1px solid var(--jp-border);
  border-radius: 10px;
  padding: .55rem;
  background: #fff;
  min-height: 42px;
}

.jp-chip {
  display: inline-block;
  margin: 0.2rem;
  background: #e8edf7;
  border: 1px solid var(--jp-border);
  border-radius: 20px;
  padding: 0.2rem 0.55rem;
  font-size: 0.86rem;
}

.jp-calendar {
  border: 1px solid var(--jp-border);
  border-radius: 12px;
  background: #fff;
  padding: .75rem;
  overflow: hidden;
}

.jp-calendar__head {
  position: relative;
  min-width: 0;
  padding: 0 1.95rem;
}

.jp-arrow {
  position: absolute;
  top: 0.15rem;
  width: 28px;
  height: 28px;
  padding: 0;
  border: none;
  border-radius: 8px;
  background: transparent;
  color: #7786a0;
  font-size: 1.9rem;
  line-height: 1;
  cursor: pointer;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: background-color .18s ease, color .18s ease;
}

.jp-arrow:hover,
.jp-arrow:focus-visible {
  background: var(--jp-primary);
  color: #fff;
  outline: none;
}

.jp-arrow[data-action^="prev"] { left: .15rem; }
.jp-arrow[data-action^="next"] { right: .15rem; }

.jp-months {
  min-width: 0;
  display: grid;
  grid-template-columns: repeat(3, minmax(150px, 1fr));
  gap: .65rem;
}

.jp-month h4 {
  text-align: center;
  margin: 0 0 .45rem;
  font-size: clamp(1.1rem, 2.2vw, 2rem);
  font-weight: 600;
}

.jp-days {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 2px;
}

.jp-days__weekday {
  text-align: center;
  font-weight: 700;
  color: #8ea0b8;
  margin-bottom: .2rem;
  font-size: clamp(0.72rem, 1.5vw, 1rem);
}

.jp-day {
  min-height: clamp(26px, 3.2vw, 40px);
  border: 1px solid transparent;
  background: transparent;
  border-radius: 6px;
  color: #6f7f96;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  white-space: nowrap;
  line-height: 1;
  font-size: clamp(0.75rem, 1.5vw, 1.1rem);
  padding: 0;
}

.jp-day:hover { border-color: var(--jp-border); }
.jp-day--blank { visibility: hidden; }
.jp-day.is-selected { background: #ffe5ca; color: #4c2d12; }
.jp-day.is-edge { background: var(--jp-primary); color: #fff; font-weight: 700; }

.jp-clear {
  border: none;
  background: transparent;
  color: var(--jp-brand-red);
  text-transform: uppercase;
  font-size: .85rem;
  cursor: pointer;
  margin-top: .35rem;
}

.jp-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(280px, .9fr);
  gap: 1rem;
  margin-top: .75rem;
}

.jp-trip-cards { display: grid; gap: 1rem; }

.jp-trip-card {
  background: #fff;
  border: 1px solid var(--jp-border);
  border-radius: 14px;
  padding: .9rem;
}

.jp-trip-card__head {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr auto;
  gap: .75rem;
  align-items: center;
}

.jp-trip-card p { margin: .35rem 0; }
.jp-trip-card span { color: #415979; }

.jp-delete {
  border: none;
  background: transparent;
  color: #a4a4a4;
  cursor: pointer;
}

.jp-delete--inline { font-size: .9rem; margin-left: .35rem; }

.jp-summary {
  background: var(--jp-soft-2);
  border: 1px solid var(--jp-border);
  border-radius: 12px;
  padding: .9rem;
  align-self: start;
}

.jp-summary h4 { margin: 0 0 .5rem; font-size: clamp(1.1rem, 2.1vw, 1.7rem); }
.jp-summary ul { list-style: none; margin: 0 0 .5rem; padding: 0; }
.jp-summary li { margin-bottom: .35rem; }
.jp-empty {
  border: 1px dashed var(--jp-border);
  background: #fff;
  border-radius: 10px;
  padding: .8rem;
}

.jp-actions { display: flex; gap: .5rem; flex-wrap: wrap; margin-top: .65rem; }

.jp-result {
  background: #fff5e8;
  border: 1px solid #f5c790;
  border-radius: 10px;
  padding: 0.9rem;
  margin-top: 0.75rem;
  overflow-wrap: anywhere;
}

.jp-months--single { grid-template-columns: minmax(220px, 1fr); }

.jp-next-grid {
  display: grid;
  grid-template-columns: minmax(280px, 1fr) minmax(270px, .95fr);
  gap: 1rem;
  align-items: start;
}

.jp-next-status {
  background: var(--jp-soft-2);
  border: 1px solid var(--jp-border);
  border-radius: 12px;
  padding: .9rem;
  min-width: 0;
}

.jp-schengen__card--disclaimer {
  font-size: 0.82rem;
  line-height: 1.45;
}

.jp-schengen__card--disclaimer li + li { margin-top: .5rem; }

@media (max-width: 1100px) {
  .jp-months { grid-template-columns: repeat(2, minmax(150px, 1fr)); }
}

@media (max-width: 860px) {
  .jp-grid, .jp-next-grid { grid-template-columns: 1fr; }
  .jp-months { grid-template-columns: 1fr; }
  .jp-trip-card__head { grid-template-columns: 1fr 1fr; }
  .jp-schengen select[multiple] { min-height: 180px; }
}

@media (max-width: 480px) {
  .jp-calendar { padding: .55rem; }
  .jp-days { gap: 1px; }
  .jp-day { min-height: 24px; font-size: 0.78rem; }
  .jp-days__weekday { font-size: 0.72rem; }
  .jp-clear { font-size: .75rem; }
  .jp-arrow { width: 24px; height: 24px; font-size: 1.55rem; top: .1rem; border-radius: 7px; }
  .jp-calendar__head { padding: 0 1.5rem; }
  .jp-actions .jp-btn { width: 100%; justify-content: center; }
}
