/**
 * PhotoEZ Theme — assets/css/main.css
 * Supplementary styles loaded after style.css
 */

/* ============================================
   SKIP LINK
   ============================================ */
.pez-skip-link {
  position: absolute;
  top: -9999px;
  left: 1rem;
  z-index: 99999;
  background: var(--pez-primary);
  color: #fff;
  padding: 0.5rem 1rem;
  border-radius: 0 0 var(--pez-radius-md) var(--pez-radius-md);
  font-family: var(--pez-font-label);
  font-weight: 700;
  font-size: var(--pez-text-sm);
}
.pez-skip-link:focus { top: 0; }

/* ============================================
   WIDGET STYLES
   ============================================ */
.pez-widget { margin-bottom: var(--pez-space-lg); }
.pez-widget__title {
  font-family: var(--pez-font-label);
  font-size: var(--pez-text-sm);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  margin-bottom: var(--pez-space-sm);
  padding-bottom: 0.5rem;
  border-bottom: 2px solid var(--pez-primary);
  display: inline-block;
}

/* ============================================
   PAGINATION
   ============================================ */
.pez-pagination,
.nav-links {
  margin-top: var(--pez-space-xl);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  flex-wrap: wrap;
}

.nav-links .page-numbers,
.pez-pagination .page-numbers {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 42px;
  height: 42px;
  border-radius: var(--pez-radius-full);
  border: 1.5px solid var(--pez-border);
  font-family: var(--pez-font-label);
  font-size: var(--pez-text-sm);
  font-weight: 600;
  color: var(--pez-text);
  transition: all var(--pez-transition-fast);
  text-decoration: none;
}

.nav-links .page-numbers:hover,
.nav-links .page-numbers.current,
.pez-pagination .page-numbers:hover,
.pez-pagination .page-numbers.current {
  background: var(--pez-primary);
  border-color: var(--pez-primary);
  color: #fff;
}

/* ============================================
   SEARCH FORM
   ============================================ */
.search-form {
  display: flex;
  gap: 0.5rem;
  margin: var(--pez-space-md) 0;
}

.search-form label { flex: 1; }

.search-field {
  width: 100%;
  padding: 0.8em 1.1em;
  border: 1.5px solid var(--pez-border);
  border-radius: var(--pez-radius-full);
  font-family: var(--pez-font-body);
  font-size: var(--pez-text-base);
  transition: border-color var(--pez-transition-fast);
}

.search-field:focus {
  outline: none;
  border-color: var(--pez-primary);
  box-shadow: 0 0 0 3px rgba(232,49,91,0.12);
}

.search-submit {
  background: linear-gradient(135deg, var(--pez-primary), var(--pez-secondary));
  color: #fff;
  border: none;
  padding: 0.8em 1.5em;
  border-radius: var(--pez-radius-full);
  font-family: var(--pez-font-label);
  font-weight: 700;
  font-size: var(--pez-text-sm);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  cursor: pointer;
  white-space: nowrap;
  transition: all var(--pez-transition-base);
}

.search-submit:hover {
  transform: translateY(-1px);
  box-shadow: 0 4px 16px rgba(232,49,91,0.4);
}

/* ============================================
   COMMENT FORM
   ============================================ */
.pez-comment-form label {
  font-family: var(--pez-font-label);
  font-size: var(--pez-text-sm);
  font-weight: 600;
  display: block;
  margin-bottom: 0.35rem;
}

.pez-comment-form input[type="text"],
.pez-comment-form input[type="email"],
.pez-comment-form input[type="url"],
.pez-comment-form textarea {
  width: 100%;
  padding: 0.8em 1em;
  border: 1.5px solid var(--pez-border);
  border-radius: var(--pez-radius-md);
  font-family: var(--pez-font-body);
  margin-bottom: var(--pez-space-sm);
  transition: border-color var(--pez-transition-fast);
}

.pez-comment-form input:focus,
.pez-comment-form textarea:focus {
  outline: none;
  border-color: var(--pez-primary);
}

/* ============================================
   ELEMENTOR EXTRA FIXES
   ============================================ */

/* Remove Elementor default padding on canvas template */
.pez-canvas-page .elementor-section-wrap,
.pez-canvas-page .elementor-container {
  padding: 0 !important;
}

/* Make Elementor popups stack above our header */
.elementor-popup-modal { z-index: 99999 !important; }

/* Fix Elementor forms to use our style */
.elementor-field-type-text .elementor-field,
.elementor-field-type-email .elementor-field,
.elementor-field-type-textarea .elementor-field,
.elementor-field-type-select .elementor-field {
  border-radius: var(--pez-radius-md) !important;
  border: 1.5px solid var(--pez-border) !important;
  font-family: var(--pez-font-body) !important;
  transition: border-color var(--pez-transition-fast), box-shadow var(--pez-transition-fast) !important;
}

.elementor-field-type-text .elementor-field:focus,
.elementor-field-type-email .elementor-field:focus,
.elementor-field-type-textarea .elementor-field:focus {
  border-color: var(--pez-primary) !important;
  box-shadow: 0 0 0 3px rgba(232,49,91,0.12) !important;
  outline: none !important;
}

.elementor-button {
  border-radius: var(--pez-radius-full) !important;
  font-family: var(--pez-font-label) !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.08em !important;
}

/* ============================================
   PHOTOEZ PLUGIN UI OVERRIDES
   ============================================ */

/* PhotoEZ Core — gallery proof page */
.photoez-gallery-page .photoez-proof-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
  gap: 1rem;
}

.photoez-gallery-page .photoez-proof-item {
  border-radius: var(--pez-radius-lg);
  overflow: hidden;
  box-shadow: var(--pez-shadow-md);
  transition: transform var(--pez-transition-base);
}

.photoez-gallery-page .photoez-proof-item:hover {
  transform: scale(1.02);
}

/* PhotoEZ Booking — calendar overrides */
.photoez-booking-calendar {
  font-family: var(--pez-font-body) !important;
}

.photoez-booking-calendar .selected-date,
.photoez-booking-calendar .available:hover {
  background: var(--pez-primary) !important;
  color: #fff !important;
  border-radius: var(--pez-radius-sm) !important;
}

.photoez-booking-calendar .today {
  border: 2px solid var(--pez-secondary) !important;
  border-radius: var(--pez-radius-sm) !important;
}

/* PhotoEZ Contracts — confirmation state */
.photoez-contract-confirmed {
  background: linear-gradient(135deg, rgba(16,185,129,0.08), rgba(16,185,129,0.04));
  border: 2px solid #10b981;
  border-radius: var(--pez-radius-xl);
  padding: var(--pez-space-xl);
  text-align: center;
}

.photoez-contract-confirmed h2 {
  color: #059669;
}

/* ============================================
   ACCESSIBILITY UTILITIES
   ============================================ */
.screen-reader-text {
  clip: rect(1px, 1px, 1px, 1px);
  clip-path: inset(50%);
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute;
  width: 1px;
  word-wrap: normal !important;
}

.screen-reader-text:focus {
  background-color: var(--pez-white);
  clip: auto !important;
  clip-path: none;
  color: var(--pez-text);
  display: block;
  font-family: var(--pez-font-body);
  font-size: 0.875rem;
  font-weight: 700;
  height: auto;
  left: 5px;
  line-height: normal;
  padding: 15px 23px 14px;
  text-decoration: none;
  top: 5px;
  width: auto;
  z-index: 100000;
  border-radius: var(--pez-radius-md);
  box-shadow: var(--pez-shadow-lg);
}

/* ============================================
   UTILITY CLASSES (for use in Elementor HTML widget)
   ============================================ */
.pez-text-center { text-align: center; }
.pez-text-left   { text-align: left; }
.pez-text-right  { text-align: right; }
.pez-mt-0  { margin-top: 0 !important; }
.pez-mb-0  { margin-bottom: 0 !important; }
.pez-pt-xl { padding-top: var(--pez-space-xl); }
.pez-pb-xl { padding-bottom: var(--pez-space-xl); }
.pez-hidden { display: none !important; }
.pez-sr-only { position: absolute; width: 1px; height: 1px; overflow: hidden; clip: rect(0,0,0,0); }

/* ============================================
   DARK SECTION TEXT HELPERS
   ============================================ */
.pez-on-dark          { color: rgba(255,255,255,0.85); }
.pez-on-dark h1,
.pez-on-dark h2,
.pez-on-dark h3,
.pez-on-dark h4       { color: #fff; }
.pez-on-dark .pez-eyebrow { color: var(--pez-primary-light); }
