/* ==========================================================================
   Video Gallery Pro v3 – Frontend Styles (Redesign)
   ========================================================================== */

@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:wght@700;900&family=Inter:wght@400;500;600&display=swap');

:root {
  --vgp-sand:        #f4f1eb;
  --vgp-sand-dark:   #e8e3d8;
  --vgp-ink:         #1a1714;
  --vgp-ink-mid:     #3d3830;
  --vgp-muted:       #9a9080;
  --vgp-accent:      #e8ff45;
  --vgp-white:       #ffffff;
  --vgp-radius-card: 16px;
  --vgp-radius-sm:   8px;
  --vgp-gap:         18px;
  --vgp-ease:        cubic-bezier(0.4, 0, 0.2, 1);
  --vgp-font-serif:  'Playfair Display', Georgia, serif;
  --vgp-font-sans:   'Inter', -apple-system, sans-serif;
}

.vgp-wrapper {
  width: 100%;
  box-sizing: border-box;
  font-family: var(--vgp-font-sans);
  color: var(--vgp-ink);
}

.vgp-screen { display: none; width: 100%; }
.vgp-screen.is-active { display: block; animation: vgpIn 0.35s var(--vgp-ease) both; }
.vgp-screen.is-leaving { display: block; animation: vgpOut 0.25s var(--vgp-ease) both; pointer-events: none; }
.vgp-screen.is-active.dir-back  { animation: vgpInBack  0.35s var(--vgp-ease) both; }
.vgp-screen.is-leaving.dir-back { animation: vgpOutBack 0.25s var(--vgp-ease) both; }

@keyframes vgpIn      { from { opacity:0; transform:translateX(24px); } to { opacity:1; transform:none; } }
@keyframes vgpOut     { from { opacity:1; transform:none; } to { opacity:0; transform:translateX(-24px); } }
@keyframes vgpInBack  { from { opacity:0; transform:translateX(-24px); } to { opacity:1; transform:none; } }
@keyframes vgpOutBack { from { opacity:1; transform:none; } to { opacity:0; transform:translateX(24px); } }

/* Back button */
.vgp-back-btn {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  font-family: var(--vgp-font-sans);
  font-size: 13px;
  font-weight: 500;
  color: var(--vgp-ink-mid);
  background: var(--vgp-white);
  border: 1px solid var(--vgp-sand-dark);
  border-radius: 100px;
  padding: 7px 16px 7px 12px;
  cursor: pointer;
  margin-bottom: 24px;
  transition: background 0.2s, border-color 0.2s;
  box-shadow: 0 1px 4px rgba(0,0,0,.07);
}
.vgp-back-btn svg { width:15px; height:15px; stroke:currentColor; stroke-width:2.2; fill:none; flex-shrink:0; }
.vgp-back-btn:hover { background: var(--vgp-sand); border-color: #c8c0b0; }

/* Screen header */
.vgp-screen-header { margin-bottom: 28px; }
.vgp-screen-title {
  font-family: var(--vgp-font-serif);
  font-size: 2rem;
  font-weight: 900;
  color: var(--vgp-ink);
  margin: 0 0 5px;
  line-height: 1.1;
  letter-spacing: -0.02em;
}
.vgp-screen-sub { font-size: 13px; color: var(--vgp-muted); margin: 0; }

/* Grid */
.vgp-grid { display: grid; gap: var(--vgp-gap); width: 100%; box-sizing: border-box; }
.vgp-grid.vgp-cols-1 { grid-template-columns: 1fr; max-width: 480px; }
.vgp-grid.vgp-cols-2 { grid-template-columns: repeat(2, 1fr); }
.vgp-grid.vgp-cols-3 { grid-template-columns: repeat(3, 1fr); }
.vgp-grid.vgp-cols-4 { grid-template-columns: repeat(4, 1fr); }

.vgp-empty { font-size: 14px; color: var(--vgp-muted); padding: 32px 0; grid-column: 1 / -1; }

/* ==== DESTINATION CARDS ==== */
.vgp-dest-card {
  position: relative;
  border-radius: var(--vgp-radius-card);
  overflow: hidden;
  cursor: pointer;
  outline: none;
  aspect-ratio: 4 / 5;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  background: #1a1714;
  transition: transform 0.3s var(--vgp-ease), box-shadow 0.3s var(--vgp-ease);
}
.vgp-dest-card:hover,
.vgp-dest-card:focus-visible {
  transform: translateY(-5px) scale(1.012);
  box-shadow: 0 20px 48px rgba(0,0,0,0.22);
}

.vgp-dest-card__img,
.vgp-dest-card__img.wp-post-image,
.vgp-dest-card__img.attachment-large,
.vgp-dest-card__img.size-large,
.vgp-dest-card__img.size-full {
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  width: 100% !important;
  height: 100% !important;
  max-width: none !important;
  object-fit: cover !important;
  object-position: center !important;
  display: block !important;
  margin: 0 !important;
  border: none !important;
  border-radius: 0 !important;
  transition: transform 0.5s var(--vgp-ease);
}
.vgp-dest-card:hover .vgp-dest-card__img { transform: scale(1.06); }

.vgp-dest-card__placeholder {
  position: absolute;
  inset: 0;
  background: linear-gradient(160deg, #2a4a3a 0%, #1a2d24 100%);
  display: flex;
  align-items: center;
  justify-content: center;
}
.vgp-dest-card__placeholder svg { width: 64px; height: 64px; opacity: 0.18; }

.vgp-dest-card__grad {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(0,0,0,0.88) 0%, rgba(0,0,0,0.3) 45%, rgba(0,0,0,0.05) 100%);
}

.vgp-dest-card__badge {
  position: absolute;
  top: 13px;
  right: 13px;
  background: rgba(255,255,255,0.13);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border: 1px solid rgba(255,255,255,0.2);
  color: rgba(255,255,255,0.9);
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.05em;
  padding: 4px 10px;
  border-radius: 100px;
  z-index: 2;
}

.vgp-dest-card__body {
  position: relative;
  z-index: 2;
  padding: 18px 16px 16px;
  display: flex;
  flex-direction: column;
}

.vgp-dest-card__name {
  font-family: var(--vgp-font-serif);
  font-size: 22px;
  font-weight: 700;
  color: #fff;
  line-height: 1.1;
  margin: 0 0 4px;
  letter-spacing: -0.01em;
}

.vgp-dest-card__meta {
  font-size: 11px;
  color: rgba(255,255,255,0.5);
  letter-spacing: 0.03em;
  margin: 0 0 12px;
}

.vgp-dest-card__arrow {
  width: 34px;
  height: 34px;
  border-radius: 50%;
  background: var(--vgp-accent);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  align-self: flex-start;
  transition: transform 0.25s var(--vgp-ease), box-shadow 0.25s var(--vgp-ease);
  box-shadow: 0 4px 14px rgba(232,255,69,0.35);
}
.vgp-dest-card:hover .vgp-dest-card__arrow {
  transform: translateX(4px);
  box-shadow: 0 6px 20px rgba(232,255,69,0.5);
}
.vgp-dest-card__arrow svg { width:15px; height:15px; stroke:#1a1714; stroke-width:2.5; fill:none; }

.vgp-sub-card { aspect-ratio: 3 / 4; }
.vgp-sub-card .vgp-dest-card__name { font-size: 18px; }

/* ==== VIDEO CARDS ==== */
.vgp-card {
  background: var(--vgp-white);
  border-radius: var(--vgp-radius-card);
  overflow: hidden;
  cursor: pointer;
  outline: none;
  display: flex;
  flex-direction: column;
  box-shadow: 0 2px 10px rgba(0,0,0,0.07), 0 0 0 1px rgba(0,0,0,0.04);
  transition: transform 0.28s var(--vgp-ease), box-shadow 0.28s var(--vgp-ease);
}
.vgp-card:hover,
.vgp-card:focus-visible {
  transform: translateY(-5px);
  box-shadow: 0 14px 36px rgba(0,0,0,0.14), 0 0 0 1px rgba(0,0,0,0.04);
}

.vgp-card__thumb {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  background: #1a2d24;
  flex-shrink: 0;
  line-height: 0;
}
.vgp-card__thumb img,
.vgp-card__thumb img.wp-post-image,
.vgp-card__thumb img.attachment-large,
.vgp-card__thumb img.size-large,
.vgp-card__thumb img.size-full {
  width: 100% !important;
  height: 100% !important;
  max-width: none !important;
  object-fit: cover !important;
  object-position: center !important;
  display: block !important;
  vertical-align: top !important;
  margin: 0 !important;
  border: none !important;
  border-radius: 0 !important;
  transition: transform 0.4s var(--vgp-ease);
}
.vgp-card:hover .vgp-card__thumb img { transform: scale(1.05); }

.vgp-card__thumb-placeholder {
  width: 100%;
  height: 100%;
  background: linear-gradient(135deg, #2a4a3a, #1a2d24);
}

.vgp-card__overlay {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(0,0,0,0);
  transition: background 0.25s;
}
.vgp-card:hover .vgp-card__overlay { background: rgba(0,0,0,0.28); }

.vgp-play-btn {
  width: 52px;
  height: 52px;
  opacity: 0;
  transform: scale(0.75);
  transition: opacity 0.25s, transform 0.25s var(--vgp-ease);
}
.vgp-card:hover .vgp-play-btn { opacity: 1; transform: scale(1); }
.vgp-play-btn svg { width: 100%; height: 100%; }

@media (hover: none) {
  .vgp-play-btn { opacity: 0.8; transform: scale(0.9); }
  .vgp-dest-card__arrow { transform: none !important; }
}

.vgp-card__info {
  padding: 13px 15px 15px;
  border-top: 1px solid rgba(0,0,0,0.05);
}
.vgp-card__title {
  font-family: var(--vgp-font-serif);
  font-size: 14px;
  font-weight: 700;
  color: var(--vgp-ink);
  margin: 0 0 4px;
  line-height: 1.3;
  letter-spacing: -0.01em;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.vgp-card__desc {
  font-size: 11px;
  color: var(--vgp-muted);
  margin: 0;
  line-height: 1.5;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* ==== MODAL ==== */
.vgp-modal {
  position: fixed;
  inset: 0;
  z-index: 999999;
  display: flex;
  align-items: center;
  justify-content: center;
  visibility: hidden;
  pointer-events: none;
  padding: 20px;
  box-sizing: border-box;
}
.vgp-modal.is-open { visibility: visible; pointer-events: all; }

.vgp-modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(26,23,20,0);
  backdrop-filter: blur(0px);
  -webkit-backdrop-filter: blur(0px);
  transition: background 0.3s ease, backdrop-filter 0.3s ease;
}
.vgp-modal.is-open .vgp-modal__backdrop {
  background: rgba(26,23,20,0.9);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}

.vgp-modal__container {
  position: relative;
  width: 100%;
  max-width: 880px;
  background: var(--vgp-white);
  border-radius: 20px;
  overflow: hidden;
  transform: scale(0.9) translateY(20px);
  opacity: 0;
  transition: transform 0.4s cubic-bezier(0.34,1.56,0.64,1), opacity 0.28s ease;
  box-shadow: 0 40px 100px rgba(0,0,0,0.5);
}
.vgp-modal.is-open .vgp-modal__container { transform: scale(1) translateY(0); opacity: 1; }

.vgp-modal__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 20px;
  border-bottom: 1px solid rgba(0,0,0,0.07);
  gap: 12px;
  background: var(--vgp-white);
}
.vgp-modal__title {
  font-family: var(--vgp-font-serif);
  font-size: 1rem;
  font-weight: 700;
  color: var(--vgp-ink);
  margin: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  flex: 1;
  letter-spacing: -0.01em;
}
.vgp-modal__close {
  width: 34px;
  height: 34px;
  border-radius: 50%;
  border: 1px solid var(--vgp-sand-dark);
  background: var(--vgp-sand);
  color: var(--vgp-ink-mid);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  transition: background 0.2s, transform 0.25s;
}
.vgp-modal__close:hover { background: var(--vgp-sand-dark); transform: rotate(90deg); }
.vgp-modal__close svg { width:15px; height:15px; stroke:currentColor; stroke-width:2.2; fill:none; }

.vgp-modal__player { width: 100%; aspect-ratio: 16/9; background: #000; }
.vgp-modal__player video { width: 100%; height: 100%; display: block; outline: none; }

/* ==== RESPONSIVE ==== */
@media (max-width: 1024px) {
  .vgp-grid.vgp-cols-4 { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 768px) {
  .vgp-grid.vgp-cols-3,
  .vgp-grid.vgp-cols-4 { grid-template-columns: repeat(2, 1fr); }
  .vgp-grid { gap: 14px; }
  .vgp-screen-title { font-size: 1.6rem; }
}
@media (max-width: 480px) {
  .vgp-grid.vgp-cols-2,
  .vgp-grid.vgp-cols-3,
  .vgp-grid.vgp-cols-4 { grid-template-columns: 1fr; }
  .vgp-grid { gap: 12px; }
  .vgp-screen-title { font-size: 1.4rem; }
  .vgp-dest-card { aspect-ratio: 3/2; }
  .vgp-sub-card  { aspect-ratio: 3/2; }
  .vgp-modal { padding: 0; align-items: flex-end; }
  .vgp-modal__container { border-radius: 20px 20px 0 0; max-width: 100%; transform: translateY(40px); }
  .vgp-modal.is-open .vgp-modal__container { transform: translateY(0); }
}
