/* Минималистичная тёмная карточка в духе примера. Можно править под ваш стиль. */
:root{
  --bg:#0b0b10;
  --card:#111119cc;
  --stroke:rgba(255,255,255,.10);
  --text:#ffffff;
  --muted:rgba(255,255,255,.70);
  --accent:#d9e7ff;
  --primary:#ffffff;
  --primaryText:#0b0b10;
  --shadow:0 20px 50px rgba(0,0,0,.50);
  --radius:22px;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  background:radial-gradient(1200px 900px at 30% 20%, #1a1a2a 0%, rgba(11,11,16,1) 45%, rgba(11,11,16,1) 100%);
  color:var(--text);
  font-family:Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  line-height:1.5;
}

.container{width:min(520px, 92vw); margin:0 auto; padding:16px}

.bg-pattern{
  position:fixed; inset:0;
  pointer-events:none;
  opacity:.20;
  background-image:url("assets/pattern.svg");
  background-size:520px 520px;
  background-repeat:repeat;
  mix-blend-mode:screen;
}

.topbar{
  position:sticky; top:0; z-index:20;
  backdrop-filter: blur(10px);
  background: linear-gradient(to bottom, rgba(11,11,16,.75), rgba(11,11,16,.15));
  border-bottom:1px solid rgba(255,255,255,.06);
}
.topbar__inner{display:flex; align-items:center; justify-content:space-between; gap:12px}
.brand{font-weight:600; letter-spacing:.08em; text-transform:uppercase; font-size:12px; color:var(--muted)}

.card{
  background:var(--card);
  border:1px solid var(--stroke);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  padding:20px;
  margin:16px 0;
  overflow:hidden;
}

.hero{position:relative}
.title{
  font-family:"Playfair Display", serif;
  font-weight:600;
  font-size:40px;
  line-height:1.05;
  text-align:center;
  margin:18px 0 12px;
}
.lead{
  margin:0 auto 18px;
  text-align:center;
  color:var(--muted);
  font-size:14px;
  max-width:44ch;
}
.accent{color:var(--accent)}

.countdown{
  display:flex; gap:10px; justify-content:center;
  padding-top:6px;
}
.cd-item{
  min-width:64px;
  text-align:center;
  padding:10px 10px;
  border:1px solid rgba(255,255,255,.10);
  border-radius:16px;
  background:rgba(255,255,255,.04);
}
.cd-val{
  font-family:"Playfair Display", serif;
  font-size:22px;
  font-weight:600;
}
.cd-lbl{font-size:11px; color:var(--muted); letter-spacing:.03em}

.photo-wrap{margin-top:14px; display:flex; flex-direction:column; align-items:center; gap:12px}
.photo-frame{
  width:min(360px, 82vw);
  aspect-ratio: 1 / 1;
  border-radius:18px;
  padding:10px;
  border:1px solid rgba(255,255,255,.12);
  background:linear-gradient(180deg, rgba(255,255,255,.12), rgba(255,255,255,.04));
}
.photo-frame img{
  width:100%; height:100%;
  object-fit:cover;
  border-radius:12px;
  display:block;
  filter:saturate(.95) contrast(1.02);
}

.subtitle{
  font-family:"Marck Script", cursive;
  font-size:18px;
  color:rgba(217,231,255,.90);
  text-align:center;
}

.hero-actions{
  display:flex; gap:10px; justify-content:center; flex-wrap:wrap;
  margin-top:16px;
}

.h2{
  font-family:"Playfair Display", serif;
  font-weight:600;
  margin:0 0 14px;
  font-size:22px;
}
.grid{
  display:grid;
  grid-template-columns:1fr;
  gap:12px;
}
.info{
  padding:14px;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.03);
}
.info__k{font-size:12px; color:var(--muted); margin-bottom:6px}
.info__v{font-size:14px}

.note{
  margin-top:14px;
  padding:14px;
  border-radius:18px;
  border:1px dashed rgba(255,255,255,.16);
  color:var(--muted);
}

.map{
  border-radius:18px;
  border:1px solid rgba(255,255,255,.10);
  padding:14px;
  background:rgba(255,255,255,.03);
}

.footer{padding:22px 0 40px; text-align:center}

.muted{color:var(--muted)}

.btn{
  appearance:none;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.06);
  color:var(--text);
  padding:10px 14px;
  border-radius:999px;
  font-weight:600;
  font-size:13px;
  text-decoration:none;
  cursor:pointer;
  transition:transform .08s ease, background .2s ease, border-color .2s ease;
}
.btn:hover{background:rgba(255,255,255,.10)}
.btn:active{transform:translateY(1px)}
.btn--primary{
  background:var(--primary);
  color:var(--primaryText);
  border-color:rgba(255,255,255,.20);
}
.btn--primary:hover{background:rgba(255,255,255,.92)}
.btn--ghost{background:transparent}

.icon-btn{
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.06);
  color:var(--text);
  width:34px; height:34px;
  border-radius:12px;
  cursor:pointer;
}

.modal{
  position:fixed; inset:0; z-index:50;
  display:none;
}
.modal.is-open{display:block}
.modal__backdrop{
  position:absolute; inset:0;
  background:rgba(0,0,0,.55);
  backdrop-filter: blur(6px);
}
.modal__panel{
  position:relative;
  width:min(560px, 92vw);
  margin: 10vh auto;
  border-radius:24px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(17,17,25,.96);
  box-shadow:var(--shadow);
  overflow:hidden;
}
.modal__head{
  display:flex; justify-content:space-between; align-items:flex-start; gap:12px;
  padding:18px 18px 10px;
  border-bottom:1px solid rgba(255,255,255,.06);
}
.modal__title{font-weight:700}
.modal__sub{font-size:12px; margin-top:4px}

.form{padding:14px 18px 18px}
.field{display:flex; flex-direction:column; gap:8px; margin:10px 0}
.field span{font-size:12px; color:var(--muted)}
input, select, textarea{
  width:100%;
  padding:10px 12px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.06);
  color:var(--text);
  outline:none;
}
textarea{resize:vertical; min-height:80px}

.row{display:grid; grid-template-columns:1fr 1fr; gap:10px}
@media (max-width:420px){ .row{grid-template-columns:1fr} .cd-item{min-width:56px} .title{font-size:36px}}

.form__actions{display:flex; justify-content:flex-end; gap:10px; margin-top:12px}
.form__status{margin-top:10px; font-size:12px; color:var(--muted)}

/* ===== Улучшение читаемости select ===== */

/* Само поле select (выбранное значение) */
select,
select option {
  color: #EAEAF0;
}

/* Когда select не в фокусе */
select {
  background-color: rgba(255, 255, 255, 0.06);
}

/* Выпадающий список */
select option {
  background-color: #1c1f2a;
  color: #EAEAF0;
}

/* Hover и выбранный пункт */
select option:hover,
select option:checked {
  background-color: #2a2f45;
  color: #ffffff;
}

/* Плейсхолдер / disabled */
select:has(option:disabled:checked) {
  color: rgba(234, 234, 240, 0.6);
}
/* Убираем жирность только внутри деталей (карточки) */
#details strong,
#details b {
  font-weight: 400;
}
/* Маршрут дня — обычный вес текста */
#details .detail,
#details .detail p,
#details .detail span {
  font-weight: 400;
}
#details h3 {
  font-weight: 500;
  margin: 12px 0 6px;
}
/* Маршрут дня — убрать жирность и сделать аккуратнее */
.route { margin-top: 10px; }

.route__title{
  font-family: "Playfair Display", serif;
  font-size: 18px;
  font-weight: 600; /* только заголовок можно оставить чуть плотнее */
  margin: 6px 0 10px;
}

.route__item{ margin: 10px 0 12px; }

.route__label{
  font-size: 13px;
  font-weight: 400 !important;
  color: var(--text);
  opacity: .95;
}

.route__place{
  font-size: 14px;
  font-weight: 400 !important;
  color: var(--text);
}

.route__addr{
  font-size: 13px;
  font-weight: 400 !important;
  color: var(--muted);
}
