/* File: assets/css/pages/car-single.css */
/* Single car page (gallery + form + lightbox) */

.dag-car-single{
  padding-block:clamp(20px, 3vw, 52px);
}

/* Accessible “screen reader only” helper */
.dag-car-single .car-sr{
  position:absolute !important;
  width:1px;height:1px;
  padding:0;margin:-1px;
  overflow:hidden;clip:rect(0,0,0,0);
  white-space:nowrap;border:0;
}

.dag-car-single .car-head{
  margin-bottom:clamp(14px, 2vw, 18px);
}
.dag-car-single .car-title{
  margin:0;
  letter-spacing:-.02em;
}

/* Layout */
.dag-car-single .car-layout{
  display:grid;
  grid-template-columns:minmax(0, 1.55fr) minmax(0, 1fr);
  gap:clamp(16px, 2.2vw, 28px);
  align-items:start;
}
@media (max-width: 980px){
  .dag-car-single .car-layout{ grid-template-columns:1fr; }
}

/* -------------------------
   Gallery
------------------------- */
.dag-car-single .car-gallery__main{
  border:1px solid var(--dag-border);
  border-radius:var(--dag-radius-lg);
  overflow:hidden;
  background:rgba(255,255,255,.02);
  box-shadow:var(--dag-shadow-sm);
}

.dag-car-single .car-gallery__main-btn{
  appearance:none;
  border:0;
  padding:0;
  background:transparent;
  width:100%;
  display:block;
  cursor:zoom-in;
}

.dag-car-single .car-gallery__main-img{
  width:100%;
  height:auto;
  display:block;
  max-height:min(62vh, 560px);
  object-fit:cover;
}

.dag-car-single .car-gallery__thumbs{
  list-style:none;
  margin:12px 0 0;
  padding:0;
  display:grid;
  grid-template-columns:repeat(6, minmax(0, 1fr));
  gap:10px;
}
@media (max-width: 980px){
  .dag-car-single .car-gallery__thumbs{ grid-template-columns:repeat(5, minmax(0, 1fr)); }
}
@media (max-width: 720px){
  .dag-car-single .car-gallery__thumbs{ grid-template-columns:repeat(4, minmax(0, 1fr)); }
}

/* Mobile UX: horizontal scroll + snap instead of grid */
@media (max-width: 560px){
  .dag-car-single .car-gallery__thumbs{
    display:flex;
    overflow-x:auto;
    overscroll-behavior-x:contain;
    -webkit-overflow-scrolling:touch;
    scroll-snap-type:x mandatory;
    gap:10px;
    padding:6px var(--dag-gutter) 10px;
    margin:12px calc(-1 * var(--dag-gutter)) 0;
  }
  .dag-car-single .car-gallery__thumb{
    flex:0 0 auto;
    width:78px;
    scroll-snap-align:start;
  }
}

.dag-car-single .car-thumb{
  width:100%;
  aspect-ratio:1/1;
  border-radius:12px;
  overflow:hidden;
  border:1px solid var(--dag-border);
  background:var(--dag-surface-2);
  padding:0;
  display:block;
  cursor:pointer;
  transition:transform var(--dag-transition), border-color var(--dag-transition), box-shadow var(--dag-transition);
}
.dag-car-single .car-thumb img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

.dag-car-single .car-thumb:hover{
  transform:translateY(-1px);
  border-color:rgba(96,165,250,.35);
  box-shadow:0 10px 30px rgba(0,0,0,.18);
}
.dag-car-single .car-thumb.is-active{
  border-color:rgba(96,165,250,.55);
  box-shadow:0 0 0 3px rgba(96,165,250,.18);
}

.dag-car-single .car-gallery__hint{
  margin:10px 0 0;
  font-size:13px;
  color:var(--dag-muted);
}

/* -------------------------
   Cards: pricing/specs
------------------------- */
.dag-car-single .car-badge{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 10px;
  border-radius:999px;
  font-weight:900;
  letter-spacing:.08em;
  text-transform:uppercase;
  font-size:11px;
  border:1px solid var(--dag-border);
  background:rgba(255,255,255,.04);
}

.dag-car-single .car-badge--sold{
  border-color:rgba(248,113,113,.35);
  background:rgba(248,113,113,.10);
}
.dag-car-single .car-badge--discount{
  border-color:rgba(52,211,153,.28);
  background:rgba(52,211,153,.10);
}

.dag-car-single .car-pricing__top{
  display:flex;
  align-items:center;
  gap:10px;
  justify-content:space-between;
  flex-wrap:wrap;
  margin-bottom:10px;
}

.dag-car-single .car-price__new{
  font-size:clamp(1.55rem, 1.2rem + 1vw, 2.05rem);
  font-weight:900;
  letter-spacing:-.02em;
}
.dag-car-single .car-price__old{
  color:var(--dag-muted);
  text-decoration:line-through;
  font-weight:800;
  margin-bottom:4px;
}
.dag-car-single .car-price__na{
  font-weight:900;
  letter-spacing:-.02em;
}

.dag-car-single .car-monthly{
  margin-top:12px;
  padding-top:12px;
  border-top:1px solid var(--dag-border);
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  align-items:baseline;
}
.dag-car-single .car-monthly__label{ color:var(--dag-muted); font-weight:800; }
.dag-car-single .car-monthly__value{ font-weight:900; }
.dag-car-single .car-monthly__note{ color:var(--dag-muted); font-size:12px; }

.dag-car-single .car-specs__title{
  margin:0 0 12px;
  font-size:1.1rem;
}
.dag-car-single .car-specs__grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:12px;
}
@media (max-width: 520px){
  .dag-car-single .car-specs__grid{ grid-template-columns:1fr; }
}

.dag-car-single .car-spec{
  padding:12px;
  border-radius:14px;
  border:1px solid var(--dag-border);
  background:rgba(255,255,255,.03);
}
.dag-car-single .car-spec__label{
  color:var(--dag-muted);
  font-weight:800;
  font-size:12px;
  letter-spacing:.06em;
  text-transform:uppercase;
}
.dag-car-single .car-spec__value{
  margin-top:6px;
  font-weight:900;
}

/* -------------------------
   Form (fix “white on white” + errors + loading)
------------------------- */
.dag-car-single .car-contact__form{
  background:transparent;
  border:0;
  padding:0;
  box-shadow:none;
}

.dag-car-single .car-form-alert{
  margin:0 0 12px;
  padding:12px 12px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.04);
}

.dag-car-single .dag-field__help{
  margin:8px 0 0;
  color:var(--dag-muted);
  font-size:12px;
}

.dag-car-single .dag-field__error{
  margin:8px 0 0;
  font-size:12px;
  font-weight:800;
  color:rgba(248,113,113,1);
}

.dag-car-single .dag-field.is-error :is(input, select, textarea){
  border-color:rgba(248,113,113,.55);
  box-shadow:0 0 0 3px rgba(248,113,113,.16);
}

.dag-car-single .car-submit-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  min-height:46px;
  white-space:nowrap;
}

.dag-car-single .car-submit-btn__spinner{
  width:16px;
  height:16px;
  border:2px solid rgba(255,255,255,.75);
  border-right-color:transparent;
  border-radius:50%;
  display:none;
}

.dag-car-single form.is-loading .car-submit-btn__spinner{
  display:inline-block;
  animation:dag-spin .8s linear infinite;
}

.dag-car-single .car-submit-status{
  margin:10px 0 0;
  min-height:1em;
  color:var(--dag-muted);
  font-size:12px;
}

@keyframes dag-spin{
  from{ transform:rotate(0deg); }
  to{ transform:rotate(360deg); }
}

/* -------------------------
   Lightbox (+ thumbs + zoom)
------------------------- */
.dag-car-single .car-lightbox{
  position:fixed;
  inset:0;
  z-index:99999;
  display:flex;
  align-items:center;
  justify-content:center;
  /* Safe-area friendly padding so controls/thumbnails never clip on iOS. */
  padding:
    calc(min(3vw, 18px) + env(safe-area-inset-top))
    calc(min(3vw, 18px) + env(safe-area-inset-right))
    calc(min(3vw, 18px) + env(safe-area-inset-bottom))
    calc(min(3vw, 18px) + env(safe-area-inset-left));
  opacity:0;
  pointer-events:none;
  transition:opacity 180ms ease;
}
.dag-car-single .car-lightbox.is-open{
  opacity:1;
  pointer-events:auto;
}
.dag-car-single .car-lightbox__backdrop{
  position:absolute;
  inset:0;
  background:rgba(3,7,18,.82);
  backdrop-filter:blur(8px) saturate(140%);
}

.dag-car-single .car-lightbox__dialog{
  position:relative;
  z-index:1;
  width:min(1100px, 100%);
  max-height:calc(100vh - 2 * min(3vw, 18px) - env(safe-area-inset-top) - env(safe-area-inset-bottom));
  border-radius:var(--dag-radius-lg);
  border:1px solid rgba(255,255,255,.14);
  background:linear-gradient(180deg, rgba(17,26,43,.94), rgba(17,26,43,.86));
  box-shadow:var(--dag-shadow-md);
  /* Reserve a header area for tools/close so they don't overlap the image. */
  --lb-top-pad:72px;
  --lb-side-pad:56px;
  padding:var(--lb-top-pad) var(--lb-side-pad) 14px;
  overflow:hidden;
  display:flex;
  flex-direction:column;
  gap:12px;
}

.dag-car-single .car-lightbox__tools{
  position:absolute;
  top:10px;
  left:10px;
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  max-width:calc(100% - 72px); /* keep space for close button */
  z-index:2;
}
.dag-car-single .car-lightbox__tool{
  appearance:none;
  border:1px solid rgba(255,255,255,.16);
  background:rgba(255,255,255,.05);
  color:var(--dag-text);
  border-radius:999px;
  padding:8px 10px;
  font-weight:900;
  font-size:12px;
  cursor:pointer;
}

.dag-car-single .car-lightbox__close{
  position:absolute;
  top:10px;
  right:10px;
  width:40px;
  height:40px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.16);
  background:rgba(255,255,255,.05);
  color:var(--dag-text);
  font-size:22px;
  line-height:1;
  cursor:pointer;
  z-index:2;
}

.dag-car-single .car-lightbox__nav{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  width:44px;
  height:44px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.16);
  background:rgba(255,255,255,.05);
  color:var(--dag-text);
  font-size:28px;
  line-height:1;
  cursor:pointer;
  z-index:2;
}
.dag-car-single .car-lightbox__prev{ left:8px; }
.dag-car-single .car-lightbox__next{ right:8px; }

.dag-car-single .car-lightbox__mid{
  display:flex;
  flex-direction:column;
  gap:10px;
  flex:1 1 auto;
  min-height:0; /* allow image to shrink to fit dialog */
}

.dag-car-single .car-lightbox__figure{
  margin:0;
  border-radius:16px;
  overflow:hidden;
  background:rgba(0,0,0,.22);
  border:1px solid rgba(255,255,255,.10);
  display:flex;
  flex-direction:column;
  flex:1 1 auto;
  min-height:0;
}
.dag-car-single .car-lightbox__figure img{
  width:100%;
  /* Let the layout define height, preventing collisions with thumbs/caption. */
  max-height:none;
  flex:1 1 auto;
  min-height:0;
  object-fit:contain;
  display:block;
  transition:transform 180ms ease;
  transform-origin:center center;
  cursor:zoom-in;
}

.dag-car-single .car-lightbox__figure.is-zoomed{
  overflow:auto;
}
.dag-car-single .car-lightbox__figure.is-zoomed img{
  transform:scale(1.8);
  cursor:zoom-out;
}

.dag-car-single .car-lightbox__cap{
  padding:10px 12px;
  color:var(--dag-muted);
  font-weight:800;
  font-size:12px;
  letter-spacing:.08em;
  text-transform:uppercase;
}

.dag-car-single .car-lightbox__thumbs{
  list-style:none;
  margin:0;
  padding:2px 2px calc(6px + env(safe-area-inset-bottom));
  display:flex;
  gap:10px;
  overflow-x:auto;
  overscroll-behavior-x:contain;
  -webkit-overflow-scrolling:touch;
  scroll-snap-type:x mandatory;
}

@media (max-width: 720px){
  .dag-car-single .car-lightbox__dialog{
    --lb-side-pad:18px;
    --lb-top-pad:80px;
  }
  .dag-car-single .car-lightbox__nav{
    width:42px;
    height:42px;
  }
  .dag-car-single .car-lightbox__prev{ left:10px; }
  .dag-car-single .car-lightbox__next{ right:10px; }
}

@media (max-width: 460px){
  .dag-car-single .car-lightbox__dialog{
    --lb-side-pad:12px;
    --lb-top-pad:92px; /* allow tool buttons to wrap */
  }
  .dag-car-single .car-lightbox__tool{ padding:7px 9px; }
}
.dag-car-single .car-lightbox__thumb{
  flex:0 0 auto;
  width:76px;
  scroll-snap-align:start;
}
.dag-car-single .car-lightbox__thumb-btn{
  width:100%;
  aspect-ratio:1/1;
  border-radius:12px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.04);
  padding:0;
  cursor:pointer;
}
.dag-car-single .car-lightbox__thumb-btn img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.dag-car-single .car-lightbox__thumb-btn.is-active{
  border-color:rgba(96,165,250,.55);
  box-shadow:0 0 0 3px rgba(96,165,250,.18);
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  .dag-car-single .car-lightbox,
  .dag-car-single .car-lightbox__figure img{
    transition:none;
  }
}