/* App-wide styles for booking engine pages. Inherits tokens from theme.css */

/* NAV */
.app-nav { display: flex; align-items: center; gap: 32px; padding: 16px 48px; background: var(--cream); border-bottom: 1px solid var(--cream-dark); position: sticky; top: 0; z-index: 100; }
.app-nav-logo { font-family: 'Fraunces', serif; font-size: 22px; font-weight: 900; color: var(--teal); text-decoration: none; }
.app-nav-link { font-size: 14px; font-weight: 500; color: var(--ink-light); text-decoration: none; padding: 6px 12px; border-radius: 8px; transition: all 0.15s; }
.app-nav-link:hover, .app-nav-link.active { color: var(--teal); background: var(--cream-dark); }

/* HERO CTA */
.hero-cta { display: inline-block; margin-top: 28px; padding: 14px 32px; background: var(--mango); color: white; font-size: 15px; font-weight: 600; text-decoration: none; border-radius: 10px; transition: background 0.2s; }
.hero-cta:hover { background: var(--mango-light); }

/* EXPLORER */
.explorer-page { max-width: 1200px; margin: 0 auto; padding: 48px 48px 80px; }
.explorer-header { margin-bottom: 40px; }
.explorer-title { font-family: 'Fraunces', serif; font-size: 36px; font-weight: 900; color: var(--ink); margin-bottom: 8px; }
.explorer-sub { font-size: 16px; color: var(--ink-light); margin-bottom: 28px; }
.tab-bar { display: flex; gap: 4px; background: var(--cream-dark); border-radius: 12px; padding: 4px; width: fit-content; }
.tab { padding: 10px 24px; border: none; background: transparent; font-family: 'DM Sans', sans-serif; font-size: 14px; font-weight: 600; color: var(--ink-light); border-radius: 10px; cursor: pointer; transition: all 0.15s; }
.tab.active { background: white; color: var(--teal); box-shadow: 0 1px 3px rgba(0,0,0,0.08); }

/* CATALOG CARDS */
.catalog-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); gap: 20px; }
.catalog-card { background: white; border-radius: 16px; overflow: hidden; border: 1px solid var(--cream-dark); transition: box-shadow 0.2s, transform 0.2s; cursor: pointer; text-decoration: none; color: inherit; display: flex; flex-direction: column; }
.catalog-card:hover { box-shadow: 0 8px 24px rgba(10,77,79,0.1); transform: translateY(-2px); }
.card-visual { height: 180px; display: flex; align-items: center; justify-content: center; position: relative; overflow: hidden; }
.card-visual.mer { background: linear-gradient(135deg, #0D6B6E, #3DC5C8); }
.card-visual.nature { background: linear-gradient(135deg, #2d7d3a, #6ec47e); }
.card-visual.culture { background: linear-gradient(135deg, #8B5E3C, #C4956A); }
.card-visual.gite { background: linear-gradient(135deg, #0A4D4F, #1a8a8e); }
.card-visual.villa { background: linear-gradient(135deg, #3a3a6e, #6e6eaf); }
.card-visual.chambre { background: linear-gradient(135deg, #6e4a3a, #af8a6e); }
.card-icon { font-size: 48px; opacity: 0.4; }
.card-category { position: absolute; top: 12px; left: 12px; background: rgba(255,255,255,0.2); backdrop-filter: blur(8px); padding: 4px 12px; border-radius: 20px; font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.1em; color: white; }
.card-body { padding: 20px; flex: 1; display: flex; flex-direction: column; }
.card-body h3 { font-family: 'Fraunces', serif; font-size: 20px; font-weight: 700; color: var(--ink); margin-bottom: 6px; }
.card-operator { font-size: 13px; color: var(--mist); margin-bottom: 8px; }
.card-desc { font-size: 14px; color: var(--ink-light); line-height: 1.5; flex: 1; margin-bottom: 16px; }
.card-footer { display: flex; align-items: center; justify-content: space-between; }
.card-price { font-family: 'Fraunces', serif; font-size: 22px; font-weight: 700; color: var(--teal); }
.card-price span { font-family: 'DM Sans', sans-serif; font-size: 13px; font-weight: 400; color: var(--mist); }
.card-cta { font-size: 13px; font-weight: 600; color: var(--mango); text-decoration: none; }

/* BOOKING PAGE */
.booking-page { max-width: 1100px; margin: 0 auto; padding: 48px 48px 80px; }
.booking-layout { display: grid; grid-template-columns: 1fr 380px; gap: 40px; align-items: start; }
.booking-detail h1 { font-family: 'Fraunces', serif; font-size: 32px; font-weight: 900; color: var(--ink); margin-bottom: 8px; }
.detail-operator { font-size: 14px; color: var(--mist); margin-bottom: 16px; }
.detail-desc { font-size: 16px; color: var(--ink-light); line-height: 1.7; margin-bottom: 24px; }
.detail-meta { display: flex; gap: 24px; margin-bottom: 32px; }
.meta-item { display: flex; flex-direction: column; gap: 2px; }
.meta-label { font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.1em; color: var(--mist); }
.meta-value { font-family: 'Fraunces', serif; font-size: 20px; font-weight: 700; color: var(--teal); }

/* CALENDAR */
.calendar-section h2 { font-family: 'Fraunces', serif; font-size: 20px; font-weight: 700; color: var(--ink); margin-bottom: 16px; }
.calendar-nav { display: flex; align-items: center; justify-content: space-between; margin-bottom: 12px; }
.calendar-nav button { background: var(--cream-dark); border: none; border-radius: 8px; padding: 8px 16px; font-weight: 600; color: var(--teal); cursor: pointer; }
.calendar-nav button:hover { background: var(--teal); color: white; }
.calendar-month { font-size: 16px; font-weight: 600; color: var(--ink); }
.calendar-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 4px; }
.calendar-day-header { text-align: center; font-size: 11px; font-weight: 600; text-transform: uppercase; color: var(--mist); padding: 8px 0; }
.calendar-day { text-align: center; padding: 10px 4px; border-radius: 8px; font-size: 14px; font-weight: 500; cursor: default; color: var(--ink-light); transition: all 0.15s; }
.calendar-day.available { cursor: pointer; color: var(--ink); background: rgba(10,77,79,0.06); }
.calendar-day.available:hover { background: var(--teal); color: white; }
.calendar-day.selected { background: var(--mango); color: white; font-weight: 700; }
.calendar-day.unavailable { color: var(--cream-dark); text-decoration: line-through; }
.calendar-day.past { color: var(--cream-dark); }
.calendar-day.empty { visibility: hidden; }

/* FORM */
.booking-form-panel { background: white; border-radius: 16px; border: 1px solid var(--cream-dark); padding: 28px; position: sticky; top: 80px; }
.form-title { font-family: 'Fraunces', serif; font-size: 20px; font-weight: 700; color: var(--ink); margin-bottom: 20px; }
.form-group { margin-bottom: 16px; }
.form-group label { display: block; font-size: 13px; font-weight: 600; color: var(--ink-light); margin-bottom: 6px; }
.form-group input, .form-group textarea, .form-group select { width: 100%; padding: 10px 14px; border: 1px solid var(--cream-dark); border-radius: 10px; font-family: 'DM Sans', sans-serif; font-size: 14px; color: var(--ink); background: var(--cream); transition: border-color 0.15s; }
.form-group input:focus, .form-group textarea:focus { outline: none; border-color: var(--teal); }
.booking-summary { margin: 20px 0; padding: 16px; background: var(--cream); border-radius: 12px; }
.summary-line { display: flex; justify-content: space-between; font-size: 14px; color: var(--ink-light); padding: 4px 0; }
.summary-line.total { border-top: 1px solid var(--cream-dark); margin-top: 8px; padding-top: 10px; font-size: 16px; }
.summary-line.total strong { color: var(--teal); font-family: 'Fraunces', serif; font-size: 20px; }
.btn-book { width: 100%; padding: 14px; background: var(--mango); color: white; border: none; border-radius: 10px; font-family: 'DM Sans', sans-serif; font-size: 15px; font-weight: 600; cursor: pointer; transition: background 0.2s; }
.btn-book:hover:not(:disabled) { background: var(--mango-light); }
.btn-book:disabled { opacity: 0.5; cursor: not-allowed; }
.form-error { margin-top: 12px; padding: 10px 14px; background: #fef2f2; border: 1px solid #fca5a5; border-radius: 8px; font-size: 14px; color: #b91c1c; }

/* CONFIRMATION */
.confirmation-page { max-width: 640px; margin: 0 auto; padding: 64px 48px 80px; }
.confirmation-card { background: white; border-radius: 16px; border: 1px solid var(--cream-dark); padding: 40px; text-align: center; }
.confirmation-check { width: 64px; height: 64px; background: var(--teal); border-radius: 50%; display: flex; align-items: center; justify-content: center; margin: 0 auto 20px; font-size: 28px; color: white; }
.confirmation-card h1 { font-family: 'Fraunces', serif; font-size: 28px; font-weight: 900; color: var(--ink); margin-bottom: 8px; }
.confirmation-card .conf-sub { font-size: 15px; color: var(--ink-light); margin-bottom: 32px; }
.conf-details { text-align: left; background: var(--cream); border-radius: 12px; padding: 24px; margin-bottom: 24px; }
.conf-row { display: flex; justify-content: space-between; padding: 8px 0; font-size: 14px; border-bottom: 1px solid var(--cream-dark); }
.conf-row:last-child { border-bottom: none; }
.conf-row .label { color: var(--ink-light); }
.conf-row .value { font-weight: 600; color: var(--ink); }
.conf-row.total .value { color: var(--teal); font-family: 'Fraunces', serif; font-size: 20px; }
.conf-ref { display: inline-block; margin-top: 8px; padding: 8px 20px; background: var(--cream-dark); border-radius: 8px; font-size: 13px; font-weight: 600; color: var(--ink-light); letter-spacing: 0.05em; }
.conf-actions { margin-top: 24px; display: flex; gap: 12px; justify-content: center; }
.conf-actions a { padding: 12px 24px; border-radius: 10px; font-size: 14px; font-weight: 600; text-decoration: none; transition: all 0.15s; }
.conf-actions .btn-primary { background: var(--mango); color: white; }
.conf-actions .btn-primary:hover { background: var(--mango-light); }
.conf-actions .btn-secondary { background: var(--cream-dark); color: var(--ink-light); }

/* LOADING */
.loading-spinner { text-align: center; padding: 48px; font-size: 16px; color: var(--mist); }

/* RESPONSIVE */
@media (max-width: 768px) {
  .app-nav { padding: 12px 24px; gap: 20px; }
  .explorer-page { padding: 24px 20px 60px; }
  .catalog-grid { grid-template-columns: 1fr; }
  .booking-page { padding: 24px 20px 60px; }
  .booking-layout { grid-template-columns: 1fr; }
  .booking-form-panel { position: static; }
  .confirmation-page { padding: 32px 20px; }
  .confirmation-card { padding: 24px; }
}
