:root{
  --bg:#0b0b0f; --panel:#151521; --line:#25253a; --muted:#9ca3af; --text:#e5e7eb;
}
*{box-sizing:border-box}
html,body{height:100%}
body{margin:0;font-family:system-ui,Segoe UI,Arial,sans-serif;background:var(--bg);color:var(--text)}
a{color:#93c5fd}
.wrap{max-width:1260px;margin:0 auto;padding:16px}
h1,h2,h3{margin:10px 0 12px}

/* Top Nav */
.topnav{background:#111827;border-bottom:1px solid #1f2937;position:sticky;top:0;z-index:10}
.topnav .wrap{display:flex;align-items:center;gap:14px;padding:10px 16px}
.topnav a{color:#e5e7eb;text-decoration:none;padding:8px 10px;border-radius:8px}
.topnav a:hover{background:#1f2937}
.topnav a.active{background:#374151}
.topnav .spacer{flex:1}
.topnav .hello{color:#9ca3af;white-space:nowrap}

/* Forms */
.input, .select, .textarea{
  width:100%;background:#0f0f18;border:1px solid var(--line);color:var(--text);
  padding:10px;border-radius:10px
}
.row{display:flex;gap:10px;align-items:center}
.chk{display:flex;align-items:center;gap:8px;color:var(--muted);padding:8px 10px;border:1px solid var(--line);border-radius:10px;background:#0f0f18}
.btn{display:inline-block;border:1px solid var(--line);background:#1f2937;color:#fff;
  padding:10px 14px;border-radius:10px;cursor:pointer;text-decoration:none}
.btn:hover{background:#374151}
.btn-danger{background:#7f1d1d;border-color:#7f1d1d}
.btn-success{background:#14532d;border-color:#14532d}
.note-ok{color:#22c55e}.note-err{color:#f87171}

/* Cards + grid */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:14px;margin-top:12px}
.card{background:var(--panel);border:1px solid var(--line);border-radius:14px;overflow:hidden}
.card img{width:100%;height:220px;object-fit:cover;display:block;background:#0f0f18}
.card .b{padding:10px 12px}
.pill{display:inline-block;padding:2px 8px;border:1px solid var(--line);border-radius:999px;font-size:12px;margin-right:6px;color:var(--muted)}
.muted{color:var(--muted)}

/* Tables */
.table{width:100%;border-collapse:collapse;border:1px solid var(--line);background:var(--panel)}
.table th,.table td{border:1px solid var(--line);padding:10px}
.table th{background:#111827;text-align:left}

/* Pagination */
.pagination{display:flex;gap:6px;justify-content:center;margin:18px 0}
.pagination a{padding:6px 10px;border:1px solid var(--line);border-radius:10px;color:#fff;text-decoration:none;background:#1f2937}
.pagination .active{background:#374151}

@media (max-width:640px){
  .topnav .hello{display:none}
  .card img{height:180px}
}
/* Rating stars */
.rating{display:inline-flex;flex-direction:row-reverse;gap:4px}
.rating input{display:none}
.rating label{font-size:24px;cursor:pointer;color:#4b5563;user-select:none}
.rating label::before{content:'★'}
.rating input:checked ~ label,
.rating label:hover,
.rating label:hover ~ label{color:#fbbf24}

.stars{display:inline-flex;gap:2px}
.stars .star{font-size:18px;line-height:1;color:#4b5563}
.stars .star.filled{color:#fbbf24}
/* Hover-эффект только для каталога на главной */
@media (hover: hover) and (pointer: fine){
  .grid-catalog .card{
    transition: transform .22s ease, box-shadow .22s ease;
    will-change: transform;
  }
  .grid-catalog .card:hover{
    transform: translateY(-4px) scale(1.03);
    box-shadow: 0 14px 32px rgba(0,0,0,.35);
  }
  .grid-catalog .card img{
    transition: transform .28s ease;
  }
  .grid-catalog .card:hover img{
    transform: scale(1.02);
  }
}
/* ---- Enhanced price box ---- */
/* ---- Enhanced price box (золотой текст) ---- */
.price-box{
  border:2px solid #d4af37;
  background:linear-gradient(180deg, rgba(212,175,55,.07), rgba(212,175,55,.02));
  border-radius:14px;
  padding:14px;
  color:#d4af37;                 /* весь текст в блоке золотистый */
}
.price-box .price-row{
  display:flex; justify-content:space-between; align-items:center;
  font-size:16px; margin:6px 0;
}
.price-box .price-amount{
  font-weight:700; font-size:22px; letter-spacing:.2px;
  color:#ffd76a;                 /* акцентная, чуть светлее золота */
}


/* ---- Alert box ---- */
.alert-box{
  border:2px solid #b45309; /* янтарный */
  background:rgba(180,83,9,.08);
  border-radius:14px; padding:12px 14px; color:#fde68a;
}

/* ---- Bigger facts (pills) ---- */
.facts{ margin-top:10px; display:flex; flex-wrap:wrap; gap:8px }
.facts .pill{
  font-size:13.5px; padding:4px 10px; border-width:1.5px;
}

/* VIP корона на карточках */
.vip-badge{
  position:absolute; top:8px; left:8px; z-index:2;
  background:linear-gradient(180deg,#f7d774,#d4af37);
  color:#1f2937; font-weight:700; font-size:12px;
  border-radius:10px; padding:4px 8px; display:flex; align-items:center; gap:8px;
  box-shadow:0 3px 10px rgba(0,0,0,.25);
}
.vip-badge .crown{font-size:19px}
.card.posrel{position:relative}

/* === Галерея фото (listing) === */
.photo-scroller{ position:relative; }
.photo-track{
  display:grid;
  grid-auto-flow:column;
  grid-auto-columns:minmax(56%, 1120px); /* ширина «слайда» */
  gap:-49px;
  overflow-x:auto;
  scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;
  padding:2px 4px 8px;
}
.photo-track::-webkit-scrollbar{ height:8px; }
.photo-track::-webkit-scrollbar-thumb{ background:#2a2f3a; border-radius:8px; }
.photo-slide{
  scroll-snap-align:start;
  border:1px solid var(--line);
  border-radius:12px;
  height:480px;              /* фиксируем высоту */
  width:80%;
  object-fit:cover;
  user-select:none;
}

/* затемнение по краям (подсказывает, что можно скроллить) */
.photo-scroller::before,
.photo-scroller::after{
  content:"";
  position:absolute; top:0; bottom:0; width:40px; pointer-events:none;
  z-index:2;
}
.photo-scroller::before{
  left:0; background:linear-gradient(90deg, rgba(17,24,39,.9), rgba(17,24,39,0));
}
.photo-scroller::after{
  right:0; background:linear-gradient(-90deg, rgba(17,24,39,.9), rgba(17,24,39,0));
}

/* Стрелки */
.g-arrow{
  position:absolute; top:50%; transform:translateY(-50%);
  z-index:3; border:1px solid var(--line);
  background:rgba(0,0,0,.45); backdrop-filter:blur(2px);
  width:38px; height:38px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-size:20px; line-height:1; cursor:pointer;
}
.g-arrow:hover{ background:rgba(0,0,0,.6); }
.g-arrow.left{  left:6px; }
.g-arrow.right{ right:6px; }

/* На мобилках стрелки убираем — там свайп */
@media (pointer:coarse){
  .g-arrow{ display:none; }
  .photo-track{ grid-auto-columns:85vw; height:auto; }
  .photo-slide{ height:64vw; }
}

/* Тонкая золотистая рамка для VIP на главной */
.vip-outline{
  border:5.0px solid #d4af37 !important;
  box-shadow:0 0 0 1px rgba(212,175,55,.15) inset;
}

/* === Фиксированная ширина карточек каталога === */
.grid-catalog{
  display:grid;
  grid-template-columns: repeat(auto-fill, 235px); /* фикс. ширина карточки */
  justify-content: start;                           /* выравнивание сетки */
  gap: 18px;                                        /* как было */
}

/* На очень узких экранах — не ломаемся */
@media (max-width: 640px){
  .grid-catalog{
    grid-template-columns: 1fr;    /* одна карточка на ряд */
  }
}
