/* =========================================================
   ZNAKI-UDACHI — PORTFOLIO + LIGHTBOX + MOBILE FIX (FULL)
   - Old portfolio markup: .portfolio-grid / .portfolio-item / .portfolio-link
   - New portfolio markup: .portfolio-shell / .p-grid / .p-card / .pf-btn
   - Lightbox fixed (desktop + mobile)
   - PROCESS block fixed on mobile (overrides inline styles)
========================================================= */


/* =========================
   PORTFOLIO GRID (OLD MARKUP)
========================= */

.portfolio-grid{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 22px;
  margin-top: 30px;
}

@media (max-width: 980px){
  .portfolio-grid{ grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 560px){
  .portfolio-grid{ grid-template-columns: 1fr; }
}

.portfolio-item{
  border-radius: 22px;
  overflow: hidden;
  background: rgba(255,255,255,0.03);
  transition: transform 0.25s ease, background 0.25s ease;
  will-change: transform;
}

.portfolio-item:hover{
  transform: translateY(-6px);
  background: rgba(255,255,255,0.05);
}

/* чтобы ссылка не выглядела как ссылка */
.portfolio-link{
  display:block;
  color: inherit;
  text-decoration:none;
}

/* миниатюра */
.portfolio-thumb{
  aspect-ratio: 16 / 10;
  overflow: hidden;
  cursor: zoom-in;
  position: relative;
}

/* лёгкая "лупа" при наведении */
.portfolio-thumb::after{
  content: "🔍";
  position: absolute;
  right: 12px;
  top: 12px;
  width: 38px;
  height: 38px;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius: 999px;
  background: rgba(0,0,0,0.35);
  border: 1px solid rgba(255,255,255,0.14);
  opacity: 0;
  transform: translateY(-6px);
  transition: 0.25s ease;
  pointer-events: none;
}

.portfolio-item:hover .portfolio-thumb::after{
  opacity: 1;
  transform: translateY(0);
}

.portfolio-thumb img{
  width:100%;
  height:100%;
  object-fit: cover;
  display:block;
  transform: scale(1);
  transition: transform 0.35s ease;
}

.portfolio-item:hover .portfolio-thumb img{
  transform: scale(1.04);
}

.portfolio-title{
  padding:14px;
  font-weight:600;
  font-size:15px;
}


/* =========================
   PORTFOLIO (NEW MARKUP)
========================= */

.portfolio-shell{
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 18px;
  background: rgba(17,19,26,.45);
  overflow: hidden;
}

/* верхняя панель */
.port-top{
  padding:16px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  border-bottom:1px solid rgba(255,255,255,.08);
  flex-wrap:wrap;
}

/* фильтр */
.portfolio-filter{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  padding:14px 16px 0;
}

.pf-btn{
  border:1px solid rgba(255,255,255,.18);
  background: rgba(255,255,255,.06);
  color:#fff;
  padding:8px 12px;
  border-radius:999px;
  cursor:pointer;
  font-weight:800;
  font-size:13px;
  line-height: 1.2;
}

.pf-btn:hover{
  background: rgba(255,255,255,.09);
}

.pf-btn.is-active{
  background: rgba(255,138,0,0.92);
  border-color: rgba(255,138,0,0.92);
  color:#111;
}

/* сетка новых карточек */
.p-grid{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 22px;
  padding: 16px;
}

@media (max-width: 980px){
  .p-grid{ grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 560px){
  .p-grid{ grid-template-columns: 1fr; padding: 12px; gap: 14px; }
}

/* новые карточки */
.p-card{
  position:relative;
  border-radius: 22px;
  overflow:hidden;
  background: rgba(255,255,255,0.03);
  transition: transform 0.25s ease, background 0.25s ease;
  will-change: transform;
  cursor: zoom-in;
}

.p-card:hover{
  transform: translateY(-6px);
  background: rgba(255,255,255,0.05);
}

/* картинка в карточке */
.p-img{
  height: 190px;
  background-size: cover;
  background-position: center;
  transform: scale(1);
  transition: transform 0.35s ease;
}

.p-card:hover .p-img{
  transform: scale(1.04);
}

@media (max-width: 560px){
  .p-img{ height: 180px; }
}

/* бейдж типа работ */
.p-badge{
  position:absolute;
  left:12px;
  top:12px;
  padding:6px 10px;
  border-radius:999px;
  font-size:12px;
  font-weight:900;
  background: rgba(0,0,0,0.35);
  border: 1px solid rgba(255,255,255,0.14);
  backdrop-filter: blur(6px);
}

/* подписи */
.p-meta{
  padding: 14px;
}

.p-title{
  font-weight:800;
  font-size:15px;
  margin-bottom:6px;
}

.p-sub{
  font-size:13px;
  color: rgba(255,255,255,0.75);
  font-weight:700;
}


/* =========================
   LIGHTBOX (FINAL FIX)
========================= */

.no-scroll{
  overflow:hidden;
  height: 100%;
}

/* контейнер лайтбокса */
.lightbox{
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: none;
}

/* открытие */
.lightbox.is-open{
  display: block;
}

/* затемнение + блюр */
.lightbox__backdrop{
  position:absolute;
  inset:0;
  background: rgba(0,0,0,0.78);
  backdrop-filter: blur(6px);
}

/* центрирование содержимого */
.lightbox__content{
  position: absolute;
  inset: 0;
  display:flex;
  align-items:center;
  justify-content:center;
  padding: 24px;
  overflow: hidden;
}

/* ✅ contain + fit */
.lightbox__img{
  display:block !important;

  width:auto !important;
  height:auto !important;

  max-width: min(1100px, 92vw) !important;
  max-height: calc(100vh - 170px) !important;

  object-fit: contain !important;
  object-position: center center !important;

  border-radius: 18px;
  background: rgba(255,255,255,0.04);
  box-shadow: 0 20px 80px rgba(0,0,0,0.55);

  touch-action: manipulation;
}

/* подпись */
.lightbox__caption{
  position: fixed;
  bottom: 18px;
  left: 50%;
  transform: translateX(-50%);
  max-width: 92vw;
  text-align:center;
  font-size: 14px;
  color: rgba(255,255,255,0.88);
  padding: 8px 14px;
  border-radius: 999px;
  background: rgba(0,0,0,0.35);
  border: 1px solid rgba(255,255,255,0.10);
  z-index: 10000;
}

/* кнопка закрытия */
.lightbox__close{
  position:absolute;
  top: 18px;
  right: 18px;
  width: 44px;
  height: 44px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.16);
  background: rgba(0,0,0,0.35);
  color: #fff;
  font-size: 28px;
  line-height: 40px;
  cursor:pointer;
  z-index: 10001;
}

.lightbox__close:hover{
  background: rgba(0,0,0,0.55);
}

/* навигация */
.lightbox__nav{
  position:absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 54px;
  height: 54px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.16);
  background: rgba(0,0,0,0.35);
  color:#fff;
  font-size: 36px;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  user-select: none;
  z-index: 10001;
}

.lightbox__nav:hover{
  background: rgba(0,0,0,0.55);
}

.lightbox__prev{ left: 16px; }
.lightbox__next{ right: 16px; }

/* мобильная адаптация */
@media (max-width: 560px){
  .lightbox__nav{ width: 46px; height: 46px; font-size: 30px; }
  .lightbox__close{ width: 40px; height: 40px; font-size: 24px; line-height: 36px; }
  .lightbox__content{ padding: 16px; }
  .lightbox__img{
    max-width: 92vw !important;
    max-height: 78vh !important;
  }
}

/* Safety: if something sets img height 100% */
.lightbox img,
#lightboxImg{
  height: auto !important;
}


/* =========================
   PROCESS BLOCK — MOBILE FIX (OVERRIDE INLINE)
   This fixes narrow cards in "Как работаем" on mobile.
========================= */

/* desktop default */
#process .card{
  grid-column: span 3 !important; /* IMPORTANT: overrides inline style */
}

/* tablet: 2 per row */
@media (max-width: 980px){
  #process .card{
    grid-column: span 6 !important;
  }
}

/* mobile: 1 per row */
@media (max-width: 560px){
  #process .card{
    grid-column: span 12 !important;
  }

  /* чуть больше воздуха для читаемости */
  #process .grid{ gap: 12px; }
  #process .card{ padding: 16px; }
}
/* =========================
   PORTFOLIO: HORIZONTAL SCROLL (LIKE TOSSHIN)
========================= */

.p-scroll{
  overflow-x: auto;
  overflow-y: hidden;
  padding: 16px;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
}

.p-track{
  display: flex;
  gap: 16px;
  min-width: 100%;
}

/* карточки в ленте */
.p-track .p-card{
  flex: 0 0 360px;
  scroll-snap-align: start;
}

/* планшет */
@media (max-width: 980px){
  .p-track .p-card{ flex-basis: 320px; }
}

/* мобильный */
@media (max-width: 560px){
  .p-scroll{ padding: 12px; }
  .p-track{ gap: 12px; }
  .p-track .p-card{ flex-basis: 78vw; }
}

/* скроллбар красиво */
.p-scroll::-webkit-scrollbar{ height: 10px; }
.p-scroll::-webkit-scrollbar-track{ background: rgba(255,255,255,.04); border-radius: 999px; }
.p-scroll::-webkit-scrollbar-thumb{ background: rgba(255,255,255,.14); border-radius: 999px; }
.p-scroll{ scrollbar-color: rgba(255,255,255,.14) rgba(255,255,255,.04); }

/* dots */
.p-dots{
  display:flex;
  justify-content:center;
  align-items:center;
  gap: 8px;
  padding: 10px 16px 18px;
  flex-wrap: wrap;
}

.p-dot{
  width: 8px;
  height: 8px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.20);
  background: rgba(255,255,255,.10);
  cursor: pointer;
  padding: 0;
}

.p-dot.is-active{
  background: rgba(255,138,0,.95);
  border-color: rgba(255,138,0,.95);
}

/* =========================================================
   ✅ CONTACT LEAD FORM (ADDED)
   Markup: <form class="leadform"> ... </form>
========================================================= */

.leadform{
  margin-top: 12px;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 16px;
  padding: 14px;
  background: rgba(255,255,255,.03);
}

.leadform .row{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:10px;
}

@media (max-width: 560px){
  .leadform .row{ grid-template-columns: 1fr; }
}

.leadform .field{
  display:grid;
  gap:6px;
}

.leadform .field label{
  font-size:12px;
  font-weight:850;
  color: rgba(255,255,255,.78);
}

.leadform input,
.leadform textarea{
  width:100%;
  padding: 12px 12px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.25);
  color: rgba(255,255,255,.92);
  outline: none;
  font-weight: 750;
}

.leadform input::placeholder,
.leadform textarea::placeholder{
  color: rgba(255,255,255,.45);
  font-weight: 750;
}

.leadform input:focus,
.leadform textarea:focus{
  border-color: rgba(255,61,0,.55);
  box-shadow: 0 0 0 6px rgba(255,61,0,.10);
}

.leadform textarea{
  min-height: 110px;
  resize: vertical;
}

.leadform .actions-row{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-top:10px;
}

.leadform .actions-row .btn{
  white-space: nowrap;
}

@media (max-width: 560px){
  .leadform .actions-row .btn{ width:100%; }
}

.leadform .hint{
  margin-top:10px;
  color: rgba(166,175,191,.95);
  font-size: 12px;
  font-weight: 750;
  line-height:1.35;
}